@servicetitan/dte-pdf-editor 1.21.0 → 1.22.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/display-conditions/condition-group.d.ts +11 -0
- package/dist/components/display-conditions/condition-group.d.ts.map +1 -0
- package/dist/components/display-conditions/condition-group.js +52 -0
- package/dist/components/display-conditions/condition-group.js.map +1 -0
- package/dist/components/display-conditions/condition-groups-section.d.ts +10 -0
- package/dist/components/display-conditions/condition-groups-section.d.ts.map +1 -0
- package/dist/components/display-conditions/condition-groups-section.js +14 -0
- package/dist/components/display-conditions/condition-groups-section.js.map +1 -0
- package/dist/components/display-conditions/condition-row.d.ts +10 -0
- package/dist/components/display-conditions/condition-row.d.ts.map +1 -0
- package/dist/components/display-conditions/condition-row.js +60 -0
- package/dist/components/display-conditions/condition-row.js.map +1 -0
- package/dist/components/display-conditions/display-condition-modal.d.ts +12 -0
- package/dist/components/display-conditions/display-condition-modal.d.ts.map +1 -0
- package/dist/components/display-conditions/display-condition-modal.js +89 -0
- package/dist/components/display-conditions/display-condition-modal.js.map +1 -0
- package/dist/components/display-conditions/display-condition.d.ts +9 -0
- package/dist/components/display-conditions/display-condition.d.ts.map +1 -0
- package/dist/components/display-conditions/display-condition.js +10 -0
- package/dist/components/display-conditions/display-condition.js.map +1 -0
- package/dist/components/field-config-panel/advanced-settings.d.ts.map +1 -1
- package/dist/components/field-config-panel/advanced-settings.js +10 -8
- package/dist/components/field-config-panel/advanced-settings.js.map +1 -1
- package/dist/components/field-config-panel/field-config-panel.d.ts +1 -1
- package/dist/components/field-config-panel/field-config-panel.d.ts.map +1 -1
- package/dist/components/field-config-panel/field-config-panel.js +4 -2
- package/dist/components/field-config-panel/field-config-panel.js.map +1 -1
- package/dist/components/field-config-panel/formula-generator.d.ts.map +1 -1
- package/dist/components/field-config-panel/formula-generator.js +3 -20
- package/dist/components/field-config-panel/formula-generator.js.map +1 -1
- package/dist/components/field-config-panel/formula-modal.d.ts.map +1 -1
- package/dist/components/field-config-panel/formula-modal.js +9 -3
- package/dist/components/field-config-panel/formula-modal.js.map +1 -1
- package/dist/components/field-config-panel/formula-workspace.d.ts.map +1 -1
- package/dist/components/field-config-panel/formula-workspace.js +4 -3
- package/dist/components/field-config-panel/formula-workspace.js.map +1 -1
- package/dist/components/field-config-panel/result-type-selector.d.ts.map +1 -1
- package/dist/components/field-config-panel/result-type-selector.js +2 -2
- package/dist/components/field-config-panel/result-type-selector.js.map +1 -1
- package/dist/components/pdf-view/pdf-view-field-container.d.ts +2 -1
- package/dist/components/pdf-view/pdf-view-field-container.d.ts.map +1 -1
- package/dist/components/pdf-view/pdf-view-field-container.js +6 -2
- package/dist/components/pdf-view/pdf-view-field-container.js.map +1 -1
- package/dist/components/pdf-view/pdf-view.d.ts.map +1 -1
- package/dist/components/pdf-view/pdf-view.js +1 -1
- package/dist/components/pdf-view/pdf-view.js.map +1 -1
- package/dist/constants/calculated.constants.d.ts +2 -0
- package/dist/constants/calculated.constants.d.ts.map +1 -0
- package/dist/constants/calculated.constants.js +2 -0
- package/dist/constants/calculated.constants.js.map +1 -0
- package/dist/constants/conditions.constants.d.ts +6 -0
- package/dist/constants/conditions.constants.d.ts.map +1 -0
- package/dist/constants/conditions.constants.js +17 -0
- package/dist/constants/conditions.constants.js.map +1 -0
- package/dist/constants/index.d.ts +3 -0
- package/dist/constants/index.d.ts.map +1 -1
- package/dist/constants/index.js +3 -0
- package/dist/constants/index.js.map +1 -1
- package/dist/interface/types.d.ts +74 -0
- package/dist/interface/types.d.ts.map +1 -1
- package/dist/interface/types.js +25 -0
- package/dist/interface/types.js.map +1 -1
- package/dist/utils/conditions/evaluate.utils.d.ts +6 -0
- package/dist/utils/conditions/evaluate.utils.d.ts.map +1 -0
- package/dist/utils/conditions/evaluate.utils.js +95 -0
- package/dist/utils/conditions/evaluate.utils.js.map +1 -0
- package/dist/utils/conditions/index.d.ts +3 -0
- package/dist/utils/conditions/index.d.ts.map +1 -0
- package/dist/utils/conditions/index.js +3 -0
- package/dist/utils/conditions/index.js.map +1 -0
- package/dist/utils/conditions/schema-data-points.utils.d.ts +12 -0
- package/dist/utils/conditions/schema-data-points.utils.d.ts.map +1 -0
- package/dist/utils/conditions/schema-data-points.utils.js +67 -0
- package/dist/utils/conditions/schema-data-points.utils.js.map +1 -0
- package/dist/utils/data-model/extract-fields.utils.d.ts +1 -0
- package/dist/utils/data-model/extract-fields.utils.d.ts.map +1 -1
- package/dist/utils/data-model/extract-fields.utils.js.map +1 -1
- package/dist/utils/formula/render-formula.utils.d.ts +0 -6
- package/dist/utils/formula/render-formula.utils.d.ts.map +1 -1
- package/dist/utils/formula/render-formula.utils.js +0 -17
- package/dist/utils/formula/render-formula.utils.js.map +1 -1
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +2 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/shared/index.d.ts +2 -0
- package/dist/utils/shared/index.d.ts.map +1 -0
- package/dist/utils/shared/index.js +2 -0
- package/dist/utils/shared/index.js.map +1 -0
- package/dist/utils/shared/number.utils.d.ts +2 -0
- package/dist/utils/shared/number.utils.d.ts.map +1 -0
- package/dist/utils/shared/number.utils.js +12 -0
- package/dist/utils/shared/number.utils.js.map +1 -0
- package/package.json +1 -1
- package/src/components/display-conditions/condition-group.tsx +141 -0
- package/src/components/display-conditions/condition-groups-section.tsx +63 -0
- package/src/components/display-conditions/condition-row.tsx +182 -0
- package/src/components/display-conditions/display-condition-modal.tsx +180 -0
- package/src/components/display-conditions/display-condition.tsx +41 -0
- package/src/components/field-config-panel/advanced-settings.tsx +42 -46
- package/src/components/field-config-panel/field-config-panel.tsx +12 -2
- package/src/components/field-config-panel/formula-generator.tsx +9 -44
- package/src/components/field-config-panel/formula-modal.tsx +72 -82
- package/src/components/field-config-panel/formula-workspace.tsx +6 -5
- package/src/components/field-config-panel/result-type-selector.tsx +8 -11
- package/src/components/pdf-view/pdf-view-field-container.tsx +11 -2
- package/src/components/pdf-view/pdf-view.tsx +1 -0
- package/src/constants/calculated.constants.ts +1 -0
- package/src/constants/conditions.constants.ts +26 -0
- package/src/constants/index.ts +3 -0
- package/src/interface/types.ts +59 -0
- package/src/styles/formula-modal.css +1 -155
- package/src/utils/conditions/evaluate.utils.ts +134 -0
- package/src/utils/conditions/index.ts +2 -0
- package/src/utils/conditions/schema-data-points.utils.ts +93 -0
- package/src/utils/data-model/extract-fields.utils.ts +1 -0
- package/src/utils/formula/render-formula.utils.ts +0 -19
- package/src/utils/index.ts +2 -0
- package/src/utils/shared/index.ts +1 -0
- package/src/utils/shared/number.utils.ts +13 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { DataPointOption, DisplayConditionGroup } from '../../interface/types';
|
|
2
|
+
export interface ConditionGroupProps {
|
|
3
|
+
canDelete: boolean;
|
|
4
|
+
dataPointOptions: DataPointOption[];
|
|
5
|
+
group: DisplayConditionGroup;
|
|
6
|
+
onDelete: () => void;
|
|
7
|
+
onUpdate: (g: DisplayConditionGroup) => void;
|
|
8
|
+
ruleIndex: number;
|
|
9
|
+
}
|
|
10
|
+
export declare function ConditionGroup({ canDelete, dataPointOptions, group, onDelete, onUpdate, ruleIndex, }: Readonly<ConditionGroupProps>): import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
//# sourceMappingURL=condition-group.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"condition-group.d.ts","sourceRoot":"","sources":["../../../src/components/display-conditions/condition-group.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACR,eAAe,EACf,qBAAqB,EAExB,MAAM,uBAAuB,CAAC;AAG/B,MAAM,WAAW,mBAAmB;IAChC,SAAS,EAAE,OAAO,CAAC;IACnB,gBAAgB,EAAE,eAAe,EAAE,CAAC;IACpC,KAAK,EAAE,qBAAqB,CAAC;IAC7B,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,CAAC,CAAC,EAAE,qBAAqB,KAAK,IAAI,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;CACrB;AAED,wBAAgB,cAAc,CAAC,EAC3B,SAAS,EACT,gBAAgB,EAChB,KAAK,EACL,QAAQ,EACR,QAAQ,EACR,SAAS,GACZ,EAAE,QAAQ,CAAC,mBAAmB,CAAC,2CAgH/B"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Button, Flex, SegmentedControl, Text } from '@servicetitan/anvil2';
|
|
3
|
+
import PlusIcon from '@servicetitan/anvil2/assets/icons/material/round/add.svg';
|
|
4
|
+
import TrashIcon from '@servicetitan/anvil2/assets/icons/material/round/delete.svg';
|
|
5
|
+
import { useCallback } from 'react';
|
|
6
|
+
import { defaultCondition } from '../../constants';
|
|
7
|
+
import { ConditionRow } from './condition-row';
|
|
8
|
+
export function ConditionGroup({ canDelete, dataPointOptions, group, onDelete, onUpdate, ruleIndex, }) {
|
|
9
|
+
const addCondition = useCallback(() => {
|
|
10
|
+
const newCondition = {
|
|
11
|
+
...defaultCondition(),
|
|
12
|
+
logicalOperator: 'and',
|
|
13
|
+
};
|
|
14
|
+
onUpdate({
|
|
15
|
+
...group,
|
|
16
|
+
conditions: [...group.conditions, newCondition],
|
|
17
|
+
});
|
|
18
|
+
}, [group, onUpdate]);
|
|
19
|
+
const updateCondition = useCallback((index, c) => {
|
|
20
|
+
const next = [...group.conditions];
|
|
21
|
+
next[index] = c;
|
|
22
|
+
onUpdate({ ...group, conditions: next });
|
|
23
|
+
}, [group, onUpdate]);
|
|
24
|
+
const removeCondition = useCallback((index) => {
|
|
25
|
+
let next = group.conditions.filter((_, i) => i !== index);
|
|
26
|
+
if (index === 0 && next.length > 0) {
|
|
27
|
+
const { logicalOperator: omit, ...rest } = next[0];
|
|
28
|
+
next = [rest, ...next.slice(1)];
|
|
29
|
+
}
|
|
30
|
+
onUpdate({
|
|
31
|
+
...group,
|
|
32
|
+
conditions: next.length ? next : [defaultCondition()],
|
|
33
|
+
});
|
|
34
|
+
}, [group, onUpdate]);
|
|
35
|
+
const handleLogicalOperatorChange = useCallback((conditionIndex, value) => {
|
|
36
|
+
const next = [...group.conditions];
|
|
37
|
+
next[conditionIndex] = {
|
|
38
|
+
...next[conditionIndex],
|
|
39
|
+
logicalOperator: value,
|
|
40
|
+
};
|
|
41
|
+
onUpdate({ ...group, conditions: next });
|
|
42
|
+
}, [group, onUpdate]);
|
|
43
|
+
return (_jsxs(Flex, { direction: "column", gap: "2", flex: 1, children: [_jsxs(Flex, { direction: "row", alignItems: "center", justifyContent: "space-between", flex: 1, children: [_jsxs(Text, { size: "medium", variant: "body", style: { fontWeight: 'bold' }, children: ["Rule ", ruleIndex + 1] }), canDelete && (_jsx(Button, { appearance: "ghost", "aria-label": "Delete rule", icon: { before: TrashIcon }, size: "large", onClick: onDelete }))] }), _jsxs(Flex, { direction: "column", gap: "3", flex: 1, style: {
|
|
44
|
+
border: '1px solid #e0e0e0',
|
|
45
|
+
borderRadius: 8,
|
|
46
|
+
padding: 12,
|
|
47
|
+
}, children: [group.conditions.map((c, i) => {
|
|
48
|
+
var _a;
|
|
49
|
+
return (_jsxs(Flex, { direction: "column", gap: "3", style: { padding: '8px 0' }, children: [i > 0 && (_jsx(Flex, { justifyContent: "center", alignItems: "center", gap: "2", children: _jsxs(SegmentedControl, { selected: (_a = c.logicalOperator) !== null && _a !== void 0 ? _a : 'and', onChange: (v) => handleLogicalOperatorChange(i, v), children: [_jsx(SegmentedControl.Segment, { value: "and", children: "And" }), _jsx(SegmentedControl.Segment, { value: "or", children: "Or" })] }) })), _jsx(ConditionRow, { canRemove: true, condition: c, dataPointOptions: dataPointOptions, onRemove: () => removeCondition(i), onChange: next => updateCondition(i, next) })] }, c.id));
|
|
50
|
+
}), _jsx(Flex, { justifyContent: "center", flex: 1, style: { paddingTop: 8 }, children: _jsx(Button, { appearance: "secondary", icon: { before: PlusIcon }, onClick: addCondition, children: "Add Condition" }) })] })] }));
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=condition-group.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"condition-group.js","sourceRoot":"","sources":["../../../src/components/display-conditions/condition-group.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { DataPointOption, DisplayConditionGroup } from '../../interface/types';
|
|
2
|
+
export interface ConditionGroupsSectionProps {
|
|
3
|
+
dataPointOptions: DataPointOption[];
|
|
4
|
+
groups: DisplayConditionGroup[];
|
|
5
|
+
onAddGroup: () => void;
|
|
6
|
+
onRemoveGroup: (index: number) => void;
|
|
7
|
+
onUpdateGroup: (index: number, group: DisplayConditionGroup) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function ConditionGroupsSection({ dataPointOptions, groups, onAddGroup, onRemoveGroup, onUpdateGroup, }: Readonly<ConditionGroupsSectionProps>): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=condition-groups-section.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"condition-groups-section.d.ts","sourceRoot":"","sources":["../../../src/components/display-conditions/condition-groups-section.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAGpF,MAAM,WAAW,2BAA2B;IACxC,gBAAgB,EAAE,eAAe,EAAE,CAAC;IACpC,MAAM,EAAE,qBAAqB,EAAE,CAAC;IAChC,UAAU,EAAE,MAAM,IAAI,CAAC;IACvB,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,qBAAqB,KAAK,IAAI,CAAC;CACxE;AAED,wBAAgB,sBAAsB,CAAC,EACnC,gBAAgB,EAChB,MAAM,EACN,UAAU,EACV,aAAa,EACb,aAAa,GAChB,EAAE,QAAQ,CAAC,2BAA2B,CAAC,2CA2CvC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Button, Flex, SegmentedControl } from '@servicetitan/anvil2';
|
|
3
|
+
import PlusIcon from '@servicetitan/anvil2/assets/icons/material/round/add.svg';
|
|
4
|
+
import { ConditionGroup } from './condition-group';
|
|
5
|
+
export function ConditionGroupsSection({ dataPointOptions, groups, onAddGroup, onRemoveGroup, onUpdateGroup, }) {
|
|
6
|
+
return (_jsxs(Flex, { direction: "column", gap: "4", children: [groups.map((group, index) => {
|
|
7
|
+
var _a;
|
|
8
|
+
return (_jsxs(Flex, { direction: "column", gap: "3", children: [index > 0 && (_jsx(Flex, { justifyContent: "center", alignItems: "center", gap: "2", style: { padding: '12px' }, children: _jsxs(SegmentedControl, { selected: (_a = group.logicalOperator) !== null && _a !== void 0 ? _a : 'and', onChange: (value) => onUpdateGroup(index, {
|
|
9
|
+
...group,
|
|
10
|
+
logicalOperator: value,
|
|
11
|
+
}), children: [_jsx(SegmentedControl.Segment, { value: "and", children: "And" }), _jsx(SegmentedControl.Segment, { value: "or", children: "Or" })] }) })), _jsx(ConditionGroup, { canDelete: groups.length > 1, dataPointOptions: dataPointOptions, group: group, onDelete: () => onRemoveGroup(index), onUpdate: g => onUpdateGroup(index, g), ruleIndex: index })] }, group.id));
|
|
12
|
+
}), _jsx(Flex, { justifyContent: "center", flex: 1, style: { paddingTop: 8 }, children: _jsx(Button, { appearance: "secondary", icon: { before: PlusIcon }, onClick: onAddGroup, children: "Add Rule" }) })] }));
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=condition-groups-section.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"condition-groups-section.js","sourceRoot":"","sources":["../../../src/components/display-conditions/condition-groups-section.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACtE,OAAO,QAAQ,MAAM,0DAA0D,CAAC;AAEhF,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAUnD,MAAM,UAAU,sBAAsB,CAAC,EACnC,gBAAgB,EAChB,MAAM,EACN,UAAU,EACV,aAAa,EACb,aAAa,GACuB;IACpC,OAAO,CACH,MAAC,IAAI,IAAC,SAAS,EAAC,QAAQ,EAAC,GAAG,EAAC,GAAG,aAC3B,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;;gBAAC,OAAA,CAC1B,MAAC,IAAI,IAAgB,SAAS,EAAC,QAAQ,EAAC,GAAG,EAAC,GAAG,aAC1C,KAAK,GAAG,CAAC,IAAI,CACV,KAAC,IAAI,IACD,cAAc,EAAC,QAAQ,EACvB,UAAU,EAAC,QAAQ,EACnB,GAAG,EAAC,GAAG,EACP,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,YAE1B,MAAC,gBAAgB,IACb,QAAQ,EAAE,MAAA,KAAK,CAAC,eAAe,mCAAI,KAAK,EACxC,QAAQ,EAAE,CAAC,KAAa,EAAE,EAAE,CACxB,aAAa,CAAC,KAAK,EAAE;oCACjB,GAAG,KAAK;oCACR,eAAe,EAAE,KAAqB;iCACzC,CAAC,aAGN,KAAC,gBAAgB,CAAC,OAAO,IAAC,KAAK,EAAC,KAAK,oBAA+B,EACpE,KAAC,gBAAgB,CAAC,OAAO,IAAC,KAAK,EAAC,IAAI,mBAA8B,IACnD,GAChB,CACV,EACD,KAAC,cAAc,IACX,SAAS,EAAE,MAAM,CAAC,MAAM,GAAG,CAAC,EAC5B,gBAAgB,EAAE,gBAAgB,EAClC,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,EACpC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,CAAC,EACtC,SAAS,EAAE,KAAK,GAClB,KA7BK,KAAK,CAAC,EAAE,CA8BZ,CACV,CAAA;aAAA,CAAC,EACF,KAAC,IAAI,IAAC,cAAc,EAAC,QAAQ,EAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,YAC3D,KAAC,MAAM,IAAC,UAAU,EAAC,WAAW,EAAC,IAAI,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,OAAO,EAAE,UAAU,yBAErE,GACN,IACJ,CACV,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { DataPointOption, DisplayConditionSingle } from '../../interface/types';
|
|
2
|
+
export interface ConditionRowProps {
|
|
3
|
+
canRemove: boolean;
|
|
4
|
+
condition: DisplayConditionSingle;
|
|
5
|
+
dataPointOptions: DataPointOption[];
|
|
6
|
+
onChange: (c: DisplayConditionSingle) => void;
|
|
7
|
+
onRemove: () => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function ConditionRow({ canRemove, condition, dataPointOptions, onChange, onRemove, }: Readonly<ConditionRowProps>): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=condition-row.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"condition-row.d.ts","sourceRoot":"","sources":["../../../src/components/display-conditions/condition-row.tsx"],"names":[],"mappings":"AAGA,OAAO,EAEH,eAAe,EACf,sBAAsB,EAIzB,MAAM,uBAAuB,CAAC;AAE/B,MAAM,WAAW,iBAAiB;IAC9B,SAAS,EAAE,OAAO,CAAC;IACnB,SAAS,EAAE,sBAAsB,CAAC;IAClC,gBAAgB,EAAE,eAAe,EAAE,CAAC;IACpC,QAAQ,EAAE,CAAC,CAAC,EAAE,sBAAsB,KAAK,IAAI,CAAC;IAC9C,QAAQ,EAAE,MAAM,IAAI,CAAC;CACxB;AAqBD,wBAAgB,YAAY,CAAC,EACzB,SAAS,EACT,SAAS,EACT,gBAAgB,EAChB,QAAQ,EACR,QAAQ,GACX,EAAE,QAAQ,CAAC,iBAAiB,CAAC,2CAwI7B"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Button, Chip, Combobox, Flex, TextField } from '@servicetitan/anvil2';
|
|
3
|
+
import TrashIcon from '@servicetitan/anvil2/assets/icons/material/round/delete.svg';
|
|
4
|
+
import { useMemo } from 'react';
|
|
5
|
+
import { NUMBER_OPERATORS, STRING_OPERATORS, VALUE_LESS_OPERATORS, } from '../../interface/types';
|
|
6
|
+
function sanitizeNumericInput(raw) {
|
|
7
|
+
let value = raw.replaceAll(/[^0-9.-]/g, '');
|
|
8
|
+
const isNegative = value.startsWith('-');
|
|
9
|
+
value = value.replaceAll('-', '');
|
|
10
|
+
if (isNegative) {
|
|
11
|
+
value = `-${value}`;
|
|
12
|
+
}
|
|
13
|
+
const firstDot = value.indexOf('.');
|
|
14
|
+
if (firstDot >= 0) {
|
|
15
|
+
value = `${value.slice(0, firstDot + 1)}${value.slice(firstDot + 1).replaceAll('.', '')}`;
|
|
16
|
+
}
|
|
17
|
+
return value;
|
|
18
|
+
}
|
|
19
|
+
export function ConditionRow({ canRemove, condition, dataPointOptions, onChange, onRemove, }) {
|
|
20
|
+
var _a;
|
|
21
|
+
const selectedDataPoint = useMemo(() => { var _a; return (_a = dataPointOptions.find(opt => opt.fullKey === condition.dataPointKey)) !== null && _a !== void 0 ? _a : null; }, [dataPointOptions, condition.dataPointKey]);
|
|
22
|
+
const fieldType = (_a = selectedDataPoint === null || selectedDataPoint === void 0 ? void 0 : selectedDataPoint.fieldType) !== null && _a !== void 0 ? _a : 'string';
|
|
23
|
+
const operatorItems = useMemo(() => fieldType === 'number'
|
|
24
|
+
? [...NUMBER_OPERATORS]
|
|
25
|
+
: [...STRING_OPERATORS], [fieldType]);
|
|
26
|
+
const selectedOperator = useMemo(() => { var _a; return (_a = operatorItems.find(op => op.value === condition.operator)) !== null && _a !== void 0 ? _a : null; }, [operatorItems, condition.operator]);
|
|
27
|
+
const isValueLess = VALUE_LESS_OPERATORS.includes(condition.operator);
|
|
28
|
+
const handleValueChange = (raw) => {
|
|
29
|
+
const value = fieldType === 'number' ? sanitizeNumericInput(raw) : raw;
|
|
30
|
+
onChange({ ...condition, value });
|
|
31
|
+
};
|
|
32
|
+
const handleDataPointChange = (item) => {
|
|
33
|
+
var _a, _b;
|
|
34
|
+
const nextFieldType = (_a = item === null || item === void 0 ? void 0 : item.fieldType) !== null && _a !== void 0 ? _a : 'string';
|
|
35
|
+
const nextIsNumber = nextFieldType === 'number';
|
|
36
|
+
const nextOperatorItems = nextIsNumber ? NUMBER_OPERATORS : STRING_OPERATORS;
|
|
37
|
+
const operatorReset = !nextOperatorItems.some(op => op.value === condition.operator);
|
|
38
|
+
onChange({
|
|
39
|
+
...condition,
|
|
40
|
+
dataPointKey: (_b = item === null || item === void 0 ? void 0 : item.fullKey) !== null && _b !== void 0 ? _b : '',
|
|
41
|
+
operator: operatorReset
|
|
42
|
+
? nextIsNumber
|
|
43
|
+
? 'num_eq'
|
|
44
|
+
: 'is_equal_to'
|
|
45
|
+
: condition.operator,
|
|
46
|
+
});
|
|
47
|
+
};
|
|
48
|
+
return (_jsxs(Flex, { direction: "row", alignItems: "flex-end", gap: "2", flex: 1, children: [_jsx(Flex, { alignItems: "flex-end", style: {
|
|
49
|
+
padding: '8px 12px',
|
|
50
|
+
}, children: _jsx(Chip, { label: "IF", size: "medium" }) }), _jsx(Flex, { flex: 1, children: _jsxs(Combobox, { flex: 1, itemToKey: (item) => { var _a; return (_a = item === null || item === void 0 ? void 0 : item.fullKey) !== null && _a !== void 0 ? _a : ''; }, itemToString: (item) => { var _a; return (_a = item === null || item === void 0 ? void 0 : item.title) !== null && _a !== void 0 ? _a : ''; }, items: dataPointOptions, selectedItem: selectedDataPoint, onChange: handleDataPointChange, children: [_jsx(Combobox.SelectTrigger, { label: "Data point", placeholder: "Select data point..." }), _jsx(Combobox.Content, { children: ({ items }) => (_jsx(Combobox.List, { children: items.map((item, i) => (_jsx(Combobox.Item, { index: i, item: item, children: item.title }, item.fullKey))) })) })] }) }), _jsx(Flex, { flex: 1, children: _jsxs(Combobox, { flex: 1, itemToKey: (item) => { var _a; return (_a = item === null || item === void 0 ? void 0 : item.value) !== null && _a !== void 0 ? _a : ''; }, itemToString: (item) => { var _a; return (_a = item === null || item === void 0 ? void 0 : item.label) !== null && _a !== void 0 ? _a : ''; }, items: operatorItems, selectedItem: selectedOperator, onChange: (item) => {
|
|
51
|
+
var _a;
|
|
52
|
+
return onChange({
|
|
53
|
+
...condition,
|
|
54
|
+
operator: ((_a = item === null || item === void 0 ? void 0 : item.value) !== null && _a !== void 0 ? _a : 'is_equal_to'),
|
|
55
|
+
});
|
|
56
|
+
}, children: [_jsx(Combobox.SelectTrigger, { label: "Condition", placeholder: "Select..." }), _jsx(Combobox.Content, { children: ({ items }) => (_jsx(Combobox.List, { children: items.map((item, i) => (_jsx(Combobox.Item, { index: i, item: item, children: item.label }, item.value))) })) })] }) }), !isValueLess && (_jsx(Flex, { flex: 1, children: _jsx(TextField, { label: "Value", flex: 1, value: condition.value, onChange: e => handleValueChange(e.target.value), placeholder: fieldType === 'number' ? 'e.g. 1.5' : 'Enter value...', "aria-label": "Value", ...(fieldType === 'number' && { inputMode: 'decimal' }) }) })), canRemove && (_jsx(Flex, { alignItems: "flex-end", style: {
|
|
57
|
+
padding: '6px 12px',
|
|
58
|
+
}, children: _jsx(Button, { appearance: "secondary", "aria-label": "Remove condition", icon: { before: TrashIcon }, onClick: onRemove }) }))] }));
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=condition-row.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"condition-row.js","sourceRoot":"","sources":["../../../src/components/display-conditions/condition-row.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC/E,OAAO,SAAS,MAAM,6DAA6D,CAAC;AACpF,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAIH,gBAAgB,EAChB,gBAAgB,EAChB,oBAAoB,GACvB,MAAM,uBAAuB,CAAC;AAe/B,SAAS,oBAAoB,CAAC,GAAW;IACrC,IAAI,KAAK,GAAG,GAAG,CAAC,UAAU,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;IAC5C,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IACzC,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IAClC,IAAI,UAAU,EAAE,CAAC;QACb,KAAK,GAAG,IAAI,KAAK,EAAE,CAAC;IACxB,CAAC;IACD,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACpC,IAAI,QAAQ,IAAI,CAAC,EAAE,CAAC;QAChB,KAAK,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC;IAC9F,CAAC;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,EACzB,SAAS,EACT,SAAS,EACT,gBAAgB,EAChB,QAAQ,EACR,QAAQ,GACkB;;IAC1B,MAAM,iBAAiB,GAAG,OAAO,CAC7B,GAAG,EAAE,WAAC,OAAA,MAAA,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,KAAK,SAAS,CAAC,YAAY,CAAC,mCAAI,IAAI,CAAA,EAAA,EAClF,CAAC,gBAAgB,EAAE,SAAS,CAAC,YAAY,CAAC,CAC7C,CAAC;IAEF,MAAM,SAAS,GAAG,MAAA,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,SAAS,mCAAI,QAAQ,CAAC;IAE3D,MAAM,aAAa,GAAqB,OAAO,CAC3C,GAAG,EAAE,CACD,SAAS,KAAK,QAAQ;QAClB,CAAC,CAAE,CAAC,GAAG,gBAAgB,CAAsB;QAC7C,CAAC,CAAE,CAAC,GAAG,gBAAgB,CAAsB,EACrD,CAAC,SAAS,CAAC,CACd,CAAC;IAEF,MAAM,gBAAgB,GAAG,OAAO,CAC5B,GAAG,EAAE,WAAC,OAAA,MAAA,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,KAAK,SAAS,CAAC,QAAQ,CAAC,mCAAI,IAAI,CAAA,EAAA,EACvE,CAAC,aAAa,EAAE,SAAS,CAAC,QAAQ,CAAC,CACtC,CAAC;IAEF,MAAM,WAAW,GAAG,oBAAoB,CAAC,QAAQ,CAAC,SAAS,CAAC,QAA6B,CAAC,CAAC;IAE3F,MAAM,iBAAiB,GAAG,CAAC,GAAW,EAAE,EAAE;QACtC,MAAM,KAAK,GAAG,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QACvE,QAAQ,CAAC,EAAE,GAAG,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IACtC,CAAC,CAAC;IAEF,MAAM,qBAAqB,GAAG,CAAC,IAA4B,EAAE,EAAE;;QAC3D,MAAM,aAAa,GAAG,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,SAAS,mCAAI,QAAQ,CAAC;QAClD,MAAM,YAAY,GAAG,aAAa,KAAK,QAAQ,CAAC;QAChD,MAAM,iBAAiB,GAAG,YAAY,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,gBAAgB,CAAC;QAC7E,MAAM,aAAa,GAAG,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,KAAK,SAAS,CAAC,QAAQ,CAAC,CAAC;QACrF,QAAQ,CAAC;YACL,GAAG,SAAS;YACZ,YAAY,EAAE,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,mCAAI,EAAE;YACjC,QAAQ,EAAE,aAAa;gBACnB,CAAC,CAAC,YAAY;oBACV,CAAC,CAAC,QAAQ;oBACV,CAAC,CAAC,aAAa;gBACnB,CAAC,CAAC,SAAS,CAAC,QAAQ;SAC3B,CAAC,CAAC;IACP,CAAC,CAAC;IAEF,OAAO,CACH,MAAC,IAAI,IAAC,SAAS,EAAC,KAAK,EAAC,UAAU,EAAC,UAAU,EAAC,GAAG,EAAC,GAAG,EAAC,IAAI,EAAE,CAAC,aACvD,KAAC,IAAI,IACD,UAAU,EAAC,UAAU,EACrB,KAAK,EAAE;oBACH,OAAO,EAAE,UAAU;iBACtB,YAED,KAAC,IAAI,IAAC,KAAK,EAAC,IAAI,EAAC,IAAI,EAAC,QAAQ,GAAG,GAC9B,EACP,KAAC,IAAI,IAAC,IAAI,EAAE,CAAC,YACT,MAAC,QAAQ,IACL,IAAI,EAAE,CAAC,EACP,SAAS,EAAE,CAAC,IAA4B,EAAE,EAAE,WAAC,OAAA,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,mCAAI,EAAE,CAAA,EAAA,EAChE,YAAY,EAAE,CAAC,IAA4B,EAAE,EAAE,WAAC,OAAA,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,mCAAI,EAAE,CAAA,EAAA,EACjE,KAAK,EAAE,gBAAgB,EACvB,YAAY,EAAE,iBAAiB,EAC/B,QAAQ,EAAE,qBAAqB,aAE/B,KAAC,QAAQ,CAAC,aAAa,IAAC,KAAK,EAAC,YAAY,EAAC,WAAW,EAAC,sBAAsB,GAAG,EAChF,KAAC,QAAQ,CAAC,OAAO,cACZ,CAAC,EAAE,KAAK,EAAgC,EAAE,EAAE,CAAC,CAC1C,KAAC,QAAQ,CAAC,IAAI,cACT,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CACpB,KAAC,QAAQ,CAAC,IAAI,IAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,YAC9B,IAAI,CAAC,KAAK,IAD2B,IAAI,CAAC,OAAO,CAEtC,CACnB,CAAC,GACU,CACnB,GACc,IACZ,GACR,EACP,KAAC,IAAI,IAAC,IAAI,EAAE,CAAC,YACT,MAAC,QAAQ,IACL,IAAI,EAAE,CAAC,EACP,SAAS,EAAE,CAAC,IAA2B,EAAE,EAAE,WAAC,OAAA,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,mCAAI,EAAE,CAAA,EAAA,EAC7D,YAAY,EAAE,CAAC,IAA2B,EAAE,EAAE,WAAC,OAAA,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,mCAAI,EAAE,CAAA,EAAA,EAChE,KAAK,EAAE,aAAa,EACpB,YAAY,EAAE,gBAAgB,EAC9B,QAAQ,EAAE,CAAC,IAA2B,EAAE,EAAE;;wBACtC,OAAA,QAAQ,CAAC;4BACL,GAAG,SAAS;4BACZ,QAAQ,EAAE,CAAC,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,mCAClB,aAAa,CAAuC;yBAC3D,CAAC,CAAA;qBAAA,aAGN,KAAC,QAAQ,CAAC,aAAa,IAAC,KAAK,EAAC,WAAW,EAAC,WAAW,EAAC,WAAW,GAAG,EACpE,KAAC,QAAQ,CAAC,OAAO,cACZ,CAAC,EAAE,KAAK,EAA+B,EAAE,EAAE,CAAC,CACzC,KAAC,QAAQ,CAAC,IAAI,cACT,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CACpB,KAAC,QAAQ,CAAC,IAAI,IAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,YAC9B,IAAI,CAAC,KAAK,IAD2B,IAAI,CAAC,KAAK,CAEpC,CACnB,CAAC,GACU,CACnB,GACc,IACZ,GACR,EACN,CAAC,WAAW,IAAI,CACb,KAAC,IAAI,IAAC,IAAI,EAAE,CAAC,YACT,KAAC,SAAS,IACN,KAAK,EAAC,OAAO,EACb,IAAI,EAAE,CAAC,EACP,KAAK,EAAE,SAAS,CAAC,KAAK,EACtB,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAChD,WAAW,EAAE,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,gBAAgB,gBACxD,OAAO,KACd,CAAC,SAAS,KAAK,QAAQ,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,GAC1D,GACC,CACV,EACA,SAAS,IAAI,CACV,KAAC,IAAI,IACD,UAAU,EAAC,UAAU,EACrB,KAAK,EAAE;oBACH,OAAO,EAAE,UAAU;iBACtB,YAED,KAAC,MAAM,IACH,UAAU,EAAC,WAAW,gBACX,kBAAkB,EAC7B,IAAI,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,EAC3B,OAAO,EAAE,QAAQ,GACnB,GACC,CACV,IACE,CACV,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { DisplayConditionState, PdfField, SchemaObject } from '../../interface/types';
|
|
2
|
+
export interface DisplayConditionModalProps {
|
|
3
|
+
onClose: () => void;
|
|
4
|
+
onSave: (state: DisplayConditionState | null) => void;
|
|
5
|
+
initialState: DisplayConditionState | null | undefined;
|
|
6
|
+
/** Data model schema (for schema-backed data points). */
|
|
7
|
+
schema?: SchemaObject;
|
|
8
|
+
/** All document fields: fillable fields are included as data points. */
|
|
9
|
+
documentFields?: PdfField[];
|
|
10
|
+
}
|
|
11
|
+
export declare function DisplayConditionModal({ documentFields, initialState, onClose, onSave, schema, }: DisplayConditionModalProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=display-condition-modal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"display-condition-modal.d.ts","sourceRoot":"","sources":["../../../src/components/display-conditions/display-condition-modal.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,qBAAqB,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAS3F,MAAM,WAAW,0BAA0B;IACvC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,MAAM,EAAE,CAAC,KAAK,EAAE,qBAAqB,GAAG,IAAI,KAAK,IAAI,CAAC;IACtD,YAAY,EAAE,qBAAqB,GAAG,IAAI,GAAG,SAAS,CAAC;IACvD,yDAAyD;IACzD,MAAM,CAAC,EAAE,YAAY,CAAC;IACtB,wEAAwE;IACxE,cAAc,CAAC,EAAE,QAAQ,EAAE,CAAC;CAC/B;AAED,wBAAgB,qBAAqB,CAAC,EAClC,cAAc,EACd,YAAY,EACZ,OAAO,EACP,MAAM,EACN,MAAM,GACT,EAAE,0BAA0B,2CAuJ5B"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Button, Dialog, Divider, Flex, SegmentedControl, Text } from '@servicetitan/anvil2';
|
|
3
|
+
import { useCallback, useMemo, useState } from 'react';
|
|
4
|
+
import { defaultGroup, defaultState, MODAL_CONTENT_MAX_HEIGHT } from '../../constants';
|
|
5
|
+
import { getDataPointOptions, isValidNumber } from '../../utils';
|
|
6
|
+
import { ConditionGroupsSection } from './condition-groups-section';
|
|
7
|
+
const BEHAVIOR_OPTIONS = [
|
|
8
|
+
{ label: 'Show', value: 'show' },
|
|
9
|
+
{ label: 'Hide', value: 'hide' },
|
|
10
|
+
];
|
|
11
|
+
export function DisplayConditionModal({ documentFields, initialState, onClose, onSave, schema, }) {
|
|
12
|
+
const [state, setState] = useState(() => { var _a; return ((_a = initialState === null || initialState === void 0 ? void 0 : initialState.groups) === null || _a === void 0 ? void 0 : _a.length) ? initialState : defaultState(); });
|
|
13
|
+
const dataPointOptions = useMemo(() => getDataPointOptions(schema, documentFields), [schema, documentFields]);
|
|
14
|
+
const handleClose = useCallback(() => {
|
|
15
|
+
onClose();
|
|
16
|
+
}, [onClose]);
|
|
17
|
+
const handleSave = useCallback(() => {
|
|
18
|
+
const hasValidGroup = state.groups.some(group => group.conditions.some(c => c.dataPointKey &&
|
|
19
|
+
(c.operator === 'is_empty' ||
|
|
20
|
+
c.operator === 'is_not_empty' ||
|
|
21
|
+
c.value.trim() !== '')));
|
|
22
|
+
if (hasValidGroup) {
|
|
23
|
+
onSave(state);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
onSave(null);
|
|
27
|
+
}
|
|
28
|
+
onClose();
|
|
29
|
+
}, [onSave, state, onClose]);
|
|
30
|
+
const updateGroup = useCallback((index, group) => {
|
|
31
|
+
setState(prev => {
|
|
32
|
+
const next = [...prev.groups];
|
|
33
|
+
next[index] = group;
|
|
34
|
+
return { ...prev, groups: next };
|
|
35
|
+
});
|
|
36
|
+
}, []);
|
|
37
|
+
const removeGroup = useCallback((index) => {
|
|
38
|
+
setState(prev => ({
|
|
39
|
+
...prev,
|
|
40
|
+
groups: (() => {
|
|
41
|
+
const nextGroups = prev.groups.filter((_, i) => i !== index);
|
|
42
|
+
if (nextGroups.length === 0) {
|
|
43
|
+
return [defaultGroup()];
|
|
44
|
+
}
|
|
45
|
+
if (index === 0 && nextGroups[0]) {
|
|
46
|
+
const { logicalOperator: omit, ...firstGroup } = nextGroups[0];
|
|
47
|
+
return [firstGroup, ...nextGroups.slice(1)];
|
|
48
|
+
}
|
|
49
|
+
return nextGroups;
|
|
50
|
+
})(),
|
|
51
|
+
}));
|
|
52
|
+
}, []);
|
|
53
|
+
const addGroup = useCallback(() => {
|
|
54
|
+
setState(prev => ({
|
|
55
|
+
...prev,
|
|
56
|
+
groups: [...prev.groups, { ...defaultGroup(), logicalOperator: 'and' }],
|
|
57
|
+
}));
|
|
58
|
+
}, []);
|
|
59
|
+
const handleBehaviorChange = useCallback((behavior) => {
|
|
60
|
+
setState(prev => ({ ...prev, behavior }));
|
|
61
|
+
}, []);
|
|
62
|
+
const canSave = useMemo(() => {
|
|
63
|
+
var _a, _b;
|
|
64
|
+
for (const group of state.groups) {
|
|
65
|
+
for (const condition of group.conditions) {
|
|
66
|
+
if (!condition.dataPointKey) {
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
if (condition.operator === 'is_empty' || condition.operator === 'is_not_empty') {
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
const trimmedValue = condition.value.trim();
|
|
73
|
+
if (!trimmedValue) {
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
const fieldType = (_b = (_a = dataPointOptions.find(opt => opt.fullKey === condition.dataPointKey)) === null || _a === void 0 ? void 0 : _a.fieldType) !== null && _b !== void 0 ? _b : 'string';
|
|
77
|
+
if (fieldType === 'number' && !isValidNumber(trimmedValue)) {
|
|
78
|
+
return false;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return state.groups.length > 0;
|
|
83
|
+
}, [dataPointOptions, state.groups]);
|
|
84
|
+
return (_jsxs(Dialog, { open: true, onClose: handleClose, size: "xlarge", children: [_jsx(Dialog.Header, { children: "Rules and Conditions" }), _jsx(Dialog.Content, { children: _jsxs(Flex, { direction: "column", gap: "6", flex: 1, style: {
|
|
85
|
+
maxHeight: MODAL_CONTENT_MAX_HEIGHT,
|
|
86
|
+
overflowY: 'auto',
|
|
87
|
+
}, children: [_jsxs(Flex, { direction: "column", gap: "3", children: [_jsx(Text, { size: "medium", variant: "body", style: { fontWeight: 'bold' }, children: "When conditions are met:" }), _jsxs(Flex, { direction: "row", alignItems: "center", gap: "3", children: [_jsx(Text, { size: "small", subdued: true, variant: "body", children: "Select to show or hide this field." }), _jsx(SegmentedControl, { size: "small", selected: state.behavior, onChange: handleBehaviorChange, children: BEHAVIOR_OPTIONS.map(opt => (_jsx(SegmentedControl.Segment, { value: opt.value, children: opt.label }, opt.value))) })] })] }), _jsx(Divider, {}), _jsx(ConditionGroupsSection, { dataPointOptions: dataPointOptions, groups: state.groups, onAddGroup: addGroup, onRemoveGroup: removeGroup, onUpdateGroup: updateGroup }), !canSave && (_jsx(Text, { size: "small", subdued: true, variant: "body", children: "Complete each condition before saving. Data point and value are required, and numeric fields must contain a valid number." }))] }) }), _jsxs(Dialog.Footer, { sticky: true, children: [_jsx(Dialog.CancelButton, { onClick: handleClose, children: "Cancel" }), _jsx(Button, { appearance: "primary", disabled: !canSave, onClick: handleSave, children: "Save Changes" })] })] }));
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=display-condition-modal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"display-condition-modal.js","sourceRoot":"","sources":["../../../src/components/display-conditions/display-condition-modal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { FC } from 'react';
|
|
2
|
+
import { PdfField } from '../../interface/types';
|
|
3
|
+
import { DisplayConditionModalProps } from './display-condition-modal';
|
|
4
|
+
interface DisplayConditionProps extends Pick<DisplayConditionModalProps, 'initialState' | 'schema' | 'documentFields'> {
|
|
5
|
+
onSave: (state: Partial<PdfField>) => void;
|
|
6
|
+
}
|
|
7
|
+
export declare const DisplayCondition: FC<DisplayConditionProps>;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=display-condition.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"display-condition.d.ts","sourceRoot":"","sources":["../../../src/components/display-conditions/display-condition.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAsB,MAAM,OAAO,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAyB,0BAA0B,EAAE,MAAM,2BAA2B,CAAC;AAE9F,UAAU,qBACN,SAAQ,IAAI,CAAC,0BAA0B,EAAE,cAAc,GAAG,QAAQ,GAAG,gBAAgB,CAAC;IACtF,MAAM,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC;CAC9C;AAED,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,qBAAqB,CA6BtD,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Button } from '@servicetitan/anvil2';
|
|
3
|
+
import PlusIcon from '@servicetitan/anvil2/assets/icons/material/round/add.svg';
|
|
4
|
+
import { Fragment, useState } from 'react';
|
|
5
|
+
import { DisplayConditionModal } from './display-condition-modal';
|
|
6
|
+
export const DisplayCondition = ({ documentFields, initialState, onSave, schema, }) => {
|
|
7
|
+
const [open, setOpen] = useState(false);
|
|
8
|
+
return (_jsxs(Fragment, { children: [_jsx(Button, { appearance: "secondary", className: "full-width", icon: PlusIcon, onClick: () => setOpen(true), children: "Add Display Condition" }), open && (_jsx(DisplayConditionModal, { onClose: () => setOpen(false), onSave: state => onSave({ displayCondition: state !== null && state !== void 0 ? state : undefined }), initialState: initialState, schema: schema, documentFields: documentFields }))] }));
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=display-condition.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"display-condition.js","sourceRoot":"","sources":["../../../src/components/display-conditions/display-condition.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,QAAQ,MAAM,0DAA0D,CAAC;AAChF,OAAO,EAAM,QAAQ,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAE/C,OAAO,EAAE,qBAAqB,EAA8B,MAAM,2BAA2B,CAAC;AAO9F,MAAM,CAAC,MAAM,gBAAgB,GAA8B,CAAC,EACxD,cAAc,EACd,YAAY,EACZ,MAAM,EACN,MAAM,GACT,EAAE,EAAE;IACD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAExC,OAAO,CACH,MAAC,QAAQ,eACL,KAAC,MAAM,IACH,UAAU,EAAC,WAAW,EACtB,SAAS,EAAC,YAAY,EACtB,IAAI,EAAE,QAAQ,EACd,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,sCAGvB,EACR,IAAI,IAAI,CACL,KAAC,qBAAqB,IAClB,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAC7B,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,gBAAgB,EAAE,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,SAAS,EAAE,CAAC,EACjE,YAAY,EAAE,YAAY,EAC1B,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,cAAc,GAChC,CACL,IACM,CACd,CAAC;AACN,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"advanced-settings.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/advanced-settings.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAE9D,UAAU,qBAAqB;IAC3B,MAAM,EAAE,qBAAqB,CAAC;IAC9B,SAAS,EAAE,QAAQ,CAAC,cAAc,CAAC,qBAAqB,CAAC,CAAC,CAAC;CAC9D;AAQD,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,qBAAqB,
|
|
1
|
+
{"version":3,"file":"advanced-settings.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/advanced-settings.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAE9D,UAAU,qBAAqB;IAC3B,MAAM,EAAE,qBAAqB,CAAC;IAC9B,SAAS,EAAE,QAAQ,CAAC,cAAc,CAAC,qBAAqB,CAAC,CAAC,CAAC;CAC9D;AAQD,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,qBAAqB,CA6FtD,CAAC"}
|
|
@@ -1,17 +1,19 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import {
|
|
2
|
+
import { Flex, SegmentedControl, Switch, Text } from '@servicetitan/anvil2';
|
|
3
3
|
const ROUNDING_OPTIONS = [
|
|
4
4
|
{ label: 'Round', value: 'round' },
|
|
5
5
|
{ label: 'Floor', value: 'floor' },
|
|
6
6
|
{ label: 'Ceil', value: 'ceil' },
|
|
7
7
|
];
|
|
8
|
-
export const AdvancedSettings = ({ format, setFormat }) => (_jsxs("div", { className: "dte-formula-advanced", children: [_jsx(Text, { variant: "body", size: "small", children: "Rounding mode" }), _jsx(
|
|
8
|
+
export const AdvancedSettings = ({ format, setFormat }) => (_jsxs("div", { className: "dte-formula-advanced", children: [_jsx(Text, { variant: "body", size: "small", children: "Rounding mode" }), _jsx(SegmentedControl, { size: "medium", selected: format.roundingMode, onChange: (roundingMode) => setFormat(prev => ({ ...prev, roundingMode })), fill: true, children: ROUNDING_OPTIONS.map(opt => (_jsx(SegmentedControl.Segment, { value: opt.value, children: opt.label }, opt.value))) }), _jsxs(Flex, { alignItems: "center", justifyContent: "space-between", children: [_jsx(Text, { variant: "body", size: "small", children: "Decimal places" }), _jsx(Text, { variant: "body", size: "small", className: "dte-formula-advanced-value", children: format.decimals })] }), _jsx("input", { type: "range", min: 0, max: 10, value: format.decimals, onChange: e => setFormat(prev => ({
|
|
9
9
|
...prev,
|
|
10
10
|
decimals: Number(e.target.value),
|
|
11
|
-
})) }),
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
11
|
+
})) }), _jsx(Switch, { checked: format.thousandsSeparator, onChange: (_e, { checked }) => {
|
|
12
|
+
setFormat(prev => ({
|
|
13
|
+
...prev,
|
|
14
|
+
thousandsSeparator: checked,
|
|
15
|
+
decimalSeparatorEnabled: checked,
|
|
16
|
+
decimalSeparator: checked ? prev.decimalSeparator : '.',
|
|
17
|
+
}));
|
|
18
|
+
}, label: "Thousands separator", value: "switch-example" }), format.thousandsSeparator && (_jsx(SegmentedControl, { size: "medium", fill: true, selected: format.decimalSeparator, onChange: (decimalSeparator) => setFormat(prev => ({ ...prev, decimalSeparator })), children: ['.', ','].map(decimalSeparator => (_jsx(SegmentedControl.Segment, { value: decimalSeparator, children: decimalSeparator }, decimalSeparator))) })), _jsx(Text, { variant: "body", size: "small", children: "Result affixes" }), _jsxs(Flex, { gap: "2", alignItems: "center", children: [_jsx(Text, { variant: "body", size: "small", children: "Prefix" }), _jsx("input", { type: "text", className: "dte-formula-advanced-input", value: format.prefixText, onChange: e => setFormat(prev => ({ ...prev, prefixText: e.target.value })) }), _jsx(Text, { variant: "body", size: "small", children: "Postfix" }), _jsx("input", { type: "text", className: "dte-formula-advanced-input", value: format.postfixText, onChange: e => setFormat(prev => ({ ...prev, postfixText: e.target.value })) })] })] }));
|
|
17
19
|
//# sourceMappingURL=advanced-settings.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"advanced-settings.js","sourceRoot":"","sources":["../../../src/components/field-config-panel/advanced-settings.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"advanced-settings.js","sourceRoot":"","sources":["../../../src/components/field-config-panel/advanced-settings.tsx"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ import { PdfField, RecipientInfo, SchemaObject } from '../../interface/types';
|
|
|
3
3
|
interface FieldConfigPanelProps {
|
|
4
4
|
field: PdfField;
|
|
5
5
|
dataModel?: SchemaObject;
|
|
6
|
-
/** All fields on the document (e.g
|
|
6
|
+
/** All fields on the document (e.g., for a formula builder fillable section). */
|
|
7
7
|
documentFields?: PdfField[];
|
|
8
8
|
recipients?: RecipientInfo[];
|
|
9
9
|
onDeleteField(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"field-config-panel.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/field-config-panel.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAW,MAAM,OAAO,CAAC;AAEpC,OAAO,EAGH,QAAQ,EACR,aAAa,EACb,YAAY,EACf,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"field-config-panel.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/field-config-panel.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAW,MAAM,OAAO,CAAC;AAEpC,OAAO,EAGH,QAAQ,EACR,aAAa,EACb,YAAY,EACf,MAAM,uBAAuB,CAAC;AAK/B,UAAU,qBAAqB;IAC3B,KAAK,EAAE,QAAQ,CAAC;IAChB,SAAS,CAAC,EAAE,YAAY,CAAC;IACzB,iFAAiF;IACjF,cAAc,CAAC,EAAE,QAAQ,EAAE,CAAC;IAC5B,UAAU,CAAC,EAAE,aAAa,EAAE,CAAC;IAC7B,aAAa,IAAI,IAAI,CAAC;IACtB,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC;CACzD;AAED,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,qBAAqB,CAgKtD,CAAC"}
|
|
@@ -4,8 +4,10 @@ import { useMemo } from 'react';
|
|
|
4
4
|
import { E_SIGN_FIELD_TYPE_OPTIONS } from '../../constants';
|
|
5
5
|
import { FieldTypeEnum, } from '../../interface/types';
|
|
6
6
|
import { generateESignPath, generateFillablePath } from '../../utils';
|
|
7
|
+
import { DisplayCondition } from '../display-conditions/display-condition';
|
|
7
8
|
import { FormulaGenerator } from './formula-generator';
|
|
8
9
|
export const FieldConfigPanel = ({ dataModel, documentFields = [], field, onDeleteField, onFieldConfigChange, recipients = [], }) => {
|
|
10
|
+
var _a;
|
|
9
11
|
const recipientOptions = useMemo(() => recipients.map(recipient => ({
|
|
10
12
|
id: recipient.name,
|
|
11
13
|
name: recipient.displayName,
|
|
@@ -42,11 +44,11 @@ export const FieldConfigPanel = ({ dataModel, documentFields = [], field, onDele
|
|
|
42
44
|
}) })), field.type === FieldTypeEnum.calculated && (_jsx(FormulaGenerator, { dataModel: dataModel, documentFields: documentFields, formula: field.formula, formulaFormat: field.formulaFormat, onFormulaChange: (formula, formulaFormat) => onFieldConfigChange({
|
|
43
45
|
formula,
|
|
44
46
|
formulaFormat,
|
|
45
|
-
}) })), _jsx(Textarea, { label: "Description", value: field.description, onChange: e => {
|
|
47
|
+
}) })), _jsx(DisplayCondition, { onSave: onFieldConfigChange, documentFields: documentFields, schema: dataModel, initialState: (_a = field.displayCondition) !== null && _a !== void 0 ? _a : undefined }), _jsx(Textarea, { label: "Description", value: field.description, onChange: e => {
|
|
46
48
|
var _a;
|
|
47
49
|
return onFieldConfigChange({
|
|
48
50
|
description: (_a = e === null || e === void 0 ? void 0 : e.target.value) !== null && _a !== void 0 ? _a : '',
|
|
49
51
|
});
|
|
50
|
-
} }), _jsx(Button, { className: "full-width", onClick: onDeleteField, children: "Delete Field" })] }));
|
|
52
|
+
} }), _jsx(Button, { className: "full-width", onClick: onDeleteField, appearance: "danger", children: "Delete Field" })] }));
|
|
51
53
|
};
|
|
52
54
|
//# sourceMappingURL=field-config-panel.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"field-config-panel.js","sourceRoot":"","sources":["../../../src/components/field-config-panel/field-config-panel.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC7F,OAAO,EAAM,OAAO,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,yBAAyB,EAAE,MAAM,iBAAiB,CAAC;AAC5D,OAAO,EAEH,aAAa,GAIhB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAYvD,MAAM,CAAC,MAAM,gBAAgB,GAA8B,CAAC,EACxD,SAAS,EACT,cAAc,GAAG,EAAE,EACnB,KAAK,EACL,aAAa,EACb,mBAAmB,EACnB,UAAU,GAAG,EAAE,GAClB,EAAE,EAAE
|
|
1
|
+
{"version":3,"file":"field-config-panel.js","sourceRoot":"","sources":["../../../src/components/field-config-panel/field-config-panel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"formula-generator.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/formula-generator.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"formula-generator.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/formula-generator.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAA+B,MAAM,OAAO,CAAC;AACxD,OAAO,EACH,qBAAqB,EAGrB,QAAQ,EAER,YAAY,EACZ,iBAAiB,EACpB,MAAM,uBAAuB,CAAC;AAI/B,MAAM,WAAW,qBAAqB;IAClC,SAAS,CAAC,EAAE,YAAY,CAAC;IACzB,cAAc,CAAC,EAAE,QAAQ,EAAE,CAAC;IAC5B,OAAO,CAAC,EAAE,iBAAiB,CAAC;IAC5B,aAAa,CAAC,EAAE,qBAAqB,CAAC;IACtC,eAAe,CAAC,CAAC,OAAO,EAAE,iBAAiB,EAAE,MAAM,EAAE,qBAAqB,GAAG,IAAI,CAAC;CACrF;AAgBD,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,qBAAqB,CAiDtD,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import {
|
|
2
|
+
import { Button } from '@servicetitan/anvil2';
|
|
3
|
+
import EditIcon from '@servicetitan/anvil2/assets/icons/material/round/edit.svg';
|
|
3
4
|
import { Fragment, useMemo, useState } from 'react';
|
|
4
5
|
import { FieldTypeEnum, } from '../../interface/types';
|
|
5
6
|
import { extractGroupedFieldsFromDataModel } from '../../utils';
|
|
@@ -25,27 +26,9 @@ export const FormulaGenerator = ({ dataModel, documentFields = [], formula, form
|
|
|
25
26
|
})
|
|
26
27
|
: [], [dataModel]);
|
|
27
28
|
const fillableFieldsFromDocument = useMemo(() => getFillableFilteredBuySubTypeFields(documentFields, ['number']), [documentFields]);
|
|
28
|
-
const hasFormula = (formula === null || formula === void 0 ? void 0 : formula.tokens) && formula.tokens.length > 0;
|
|
29
29
|
const handleSave = (newFormula, format) => {
|
|
30
30
|
onFormulaChange === null || onFormulaChange === void 0 ? void 0 : onFormulaChange(newFormula, format);
|
|
31
31
|
};
|
|
32
|
-
return (_jsxs(Fragment, { children: [_jsx(
|
|
33
|
-
if (e.key === 'Enter' || e.key === ' ') {
|
|
34
|
-
e.preventDefault();
|
|
35
|
-
setModalOpen(true);
|
|
36
|
-
}
|
|
37
|
-
}, "aria-label": "Configure formula", children: hasFormula ? ((() => {
|
|
38
|
-
let offset = 0;
|
|
39
|
-
return formula.tokens.map((token) => {
|
|
40
|
-
const value = token.type === 'field'
|
|
41
|
-
? token.path
|
|
42
|
-
: token.value;
|
|
43
|
-
const key = `formula-${offset}-${token.type}-${value}`;
|
|
44
|
-
offset += value.length + 1;
|
|
45
|
-
return (_jsx("span", { className: `dte-formula-token dte-formula-token-${token.type}`, children: token.type === 'field'
|
|
46
|
-
? token.label
|
|
47
|
-
: token.value }, key));
|
|
48
|
-
});
|
|
49
|
-
})()) : (_jsx("span", { children: "Configure formula" })) }), modalOpen && (_jsx(FormulaModal, { initialFormula: formula, initialFormat: formulaFormat, dataModelGroups: dataModelGroups, fillableFieldsFromDocument: fillableFieldsFromDocument, onClose: () => setModalOpen(false), onSave: handleSave }))] }));
|
|
32
|
+
return (_jsxs(Fragment, { children: [_jsx(Button, { appearance: "secondary", className: "full-width", icon: EditIcon, onClick: () => setModalOpen(true), children: "Configure formula" }), modalOpen && (_jsx(FormulaModal, { initialFormula: formula, initialFormat: formulaFormat, dataModelGroups: dataModelGroups, fillableFieldsFromDocument: fillableFieldsFromDocument, onClose: () => setModalOpen(false), onSave: handleSave }))] }));
|
|
50
33
|
};
|
|
51
34
|
//# sourceMappingURL=formula-generator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"formula-generator.js","sourceRoot":"","sources":["../../../src/components/field-config-panel/formula-generator.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"formula-generator.js","sourceRoot":"","sources":["../../../src/components/field-config-panel/formula-generator.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,QAAQ,MAAM,2DAA2D,CAAC;AACjF,OAAO,EAAM,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxD,OAAO,EAEH,aAAa,GAMhB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,iCAAiC,EAAE,MAAM,aAAa,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAU/C,SAAS,mCAAmC,CACxC,MAAkB,EAClB,QAA2B;IAE3B,OAAO,MAAM;SACR,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,aAAa,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAQ,CAAC,CAAC;SAC/E,GAAG,CAAC,CAAC,CAAC,EAAE;;QAAC,OAAA,CAAC;YACP,KAAK,EAAE,MAAA,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,mCAAI,EAAE;YAChC,IAAI,EAAE,aAAa,CAAC,QAAQ;YAC5B,OAAO,EAAE,CAAC,CAAC,OAAO;YAClB,IAAI,EAAE,CAAC,CAAC,IAAI;SACf,CAAC,CAAA;KAAA,CAAC,CAAC;AACZ,CAAC;AAED,MAAM,CAAC,MAAM,gBAAgB,GAA8B,CAAC,EACxD,SAAS,EACT,cAAc,GAAG,EAAE,EACnB,OAAO,EACP,aAAa,EACb,eAAe,GAClB,EAAE,EAAE;IACD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,eAAe,GAAG,OAAO,CAC3B,GAAG,EAAE,CACD,SAAS;QACL,CAAC,CAAC,iCAAiC,CAAC,SAAS,EAAE;YACzC,yBAAyB,EAAE,IAAI;SAClC,CAAC;QACJ,CAAC,CAAC,EAAE,EACZ,CAAC,SAAS,CAAC,CACd,CAAC;IACF,MAAM,0BAA0B,GAAG,OAAO,CACtC,GAAG,EAAE,CAAC,mCAAmC,CAAC,cAAc,EAAE,CAAC,QAAQ,CAAC,CAAC,EACrE,CAAC,cAAc,CAAC,CACnB,CAAC;IAEF,MAAM,UAAU,GAAG,CAAC,UAA6B,EAAE,MAA6B,EAAE,EAAE;QAChF,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAG,UAAU,EAAE,MAAM,CAAC,CAAC;IAC1C,CAAC,CAAC;IAEF,OAAO,CACH,MAAC,QAAQ,eACL,KAAC,MAAM,IACH,UAAU,EAAC,WAAW,EACtB,SAAS,EAAC,YAAY,EACtB,IAAI,EAAE,QAAQ,EACd,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,kCAG5B,EAER,SAAS,IAAI,CACV,KAAC,YAAY,IACT,cAAc,EAAE,OAAO,EACvB,aAAa,EAAE,aAAa,EAC5B,eAAe,EAAE,eAAe,EAChC,0BAA0B,EAAE,0BAA0B,EACtD,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,EAClC,MAAM,EAAE,UAAU,GACpB,CACL,IACM,CACd,CAAC;AACN,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"formula-modal.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/formula-modal.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"formula-modal.d.ts","sourceRoot":"","sources":["../../../src/components/field-config-panel/formula-modal.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,EAAE,EAAkC,MAAM,OAAO,CAAC;AAG3D,OAAO,EACH,qBAAqB,EACrB,mBAAmB,EACnB,eAAe,EACf,iBAAiB,EACpB,MAAM,uBAAuB,CAAC;AAyC/B,MAAM,WAAW,iBAAiB;IAC9B,cAAc,EAAE,iBAAiB,GAAG,SAAS,CAAC;IAC9C,aAAa,CAAC,EAAE,qBAAqB,CAAC;IACtC,eAAe,EAAE,mBAAmB,EAAE,CAAC;IACvC,0BAA0B,CAAC,EAAE,eAAe,EAAE,CAAC;IAC/C,OAAO,IAAI,IAAI,CAAC;IAChB,MAAM,CAAC,OAAO,EAAE,iBAAiB,EAAE,MAAM,EAAE,qBAAqB,GAAG,IAAI,CAAC;CAC3E;AAED,eAAO,MAAM,YAAY,EAAE,EAAE,CAAC,iBAAiB,CA6J9C,CAAC"}
|