lamassu-server/packages/admin-ui/src/pages/Triggers/components/AdvancedTriggers.jsx
2025-05-23 16:53:04 +01:00

133 lines
3.6 KiB
JavaScript

import { useMutation, useQuery, gql } from '@apollo/client'
import * as R from 'ramda'
import React, { memo, useState } from 'react'
import Section from '../../../components/layout/Section'
import { Table as EditableTable } from '../../../components/editableTable'
import { fromNamespace, toNamespace, namespaces } from '../../../utils/config'
import {
defaultSchema,
getOverridesSchema,
defaults,
overridesDefaults,
getDefaultSettings,
getOverrides,
} from './helper'
const SAVE_CONFIG = gql`
mutation Save($config: JSONObject) {
saveConfig(config: $config)
}
`
const GET_INFO = gql`
query getData {
config
}
`
const GET_CUSTOM_REQUESTS = gql`
query customInfoRequests {
customInfoRequests {
id
customRequest
enabled
}
}
`
const AdvancedTriggersSettings = memo(() => {
const SCREEN_KEY = namespaces.TRIGGERS
const [error, setError] = useState(null)
const [isEditingDefault, setEditingDefault] = useState(false)
const [isEditingOverrides, setEditingOverrides] = useState(false)
const { data, loading: configLoading } = useQuery(GET_INFO)
const { data: customInfoReqData, loading: customInfoLoading } =
useQuery(GET_CUSTOM_REQUESTS)
const customInfoRequests =
R.path(['customInfoRequests'])(customInfoReqData) ?? []
const enabledCustomInfoRequests = R.filter(R.propEq(true, 'enabled'))(
customInfoRequests,
)
const loading = configLoading || customInfoLoading
const [saveConfig] = useMutation(SAVE_CONFIG, {
refetchQueries: () => ['getData'],
onError: error => setError(error),
})
const saveDefaults = it => {
const newConfig = toNamespace(SCREEN_KEY)(it.triggersConfig[0])
setError(null)
return saveConfig({
variables: { config: newConfig },
})
}
const saveOverrides = it => {
const config = toNamespace(SCREEN_KEY)(it)
setError(null)
return saveConfig({ variables: { config } })
}
const requirementsData =
data?.config && fromNamespace(SCREEN_KEY)(data?.config)
const requirementsDefaults =
requirementsData && !R.isEmpty(requirementsData)
? requirementsData
: defaults
const requirementsOverrides = requirementsData?.overrides ?? []
const onEditingDefault = (it, editing) => setEditingDefault(editing)
const onEditingOverrides = (it, editing) => setEditingOverrides(editing)
return (
!loading && (
<>
<Section>
<EditableTable
title="Default requirement settings"
error={error?.message}
titleLg
name="triggersConfig"
enableEdit
initialValues={requirementsDefaults}
save={saveDefaults}
validationSchema={defaultSchema}
data={R.of(Array, requirementsDefaults)}
elements={getDefaultSettings()}
setEditing={onEditingDefault}
forceDisable={isEditingOverrides}
/>
</Section>
<Section>
<EditableTable
error={error?.message}
title="Overrides"
titleLg
name="overrides"
enableDelete
enableEdit
enableCreate
initialValues={overridesDefaults}
save={saveOverrides}
validationSchema={getOverridesSchema(
requirementsOverrides,
enabledCustomInfoRequests,
)}
data={requirementsOverrides}
elements={getOverrides(enabledCustomInfoRequests)}
setEditing={onEditingOverrides}
forceDisable={isEditingDefault}
/>
</Section>
</>
)
)
})
export default AdvancedTriggersSettings