@cozeloop/components 0.0.12-beta-1778488172610 → 0.0.12-beta-1378.344125032425
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/es/index.css +0 -49
- package/dist/es/index.mjs +17 -510
- package/dist/lib/base-search-select/base-search-form-select.js +6 -0
- package/dist/lib/base-search-select/base-search-form-select.js.map +1 -0
- package/dist/lib/base-search-select/base-search-select.js +130 -0
- package/dist/lib/base-search-select/base-search-select.js.map +1 -0
- package/dist/lib/base-search-select/index.js +3 -0
- package/dist/lib/base-search-select/index.js.map +1 -0
- package/dist/lib/base-search-select/types.js +2 -0
- package/dist/lib/base-search-select/types.js.map +1 -0
- package/dist/lib/base-search-select/utils.js +48 -0
- package/dist/lib/base-search-select/utils.js.map +1 -0
- package/dist/lib/basic-card/index.js +4 -0
- package/dist/lib/basic-card/index.js.map +1 -0
- package/dist/lib/card-pane/index.js +9 -0
- package/dist/lib/card-pane/index.js.map +1 -0
- package/dist/lib/chip-select/index.js +6 -0
- package/dist/lib/chip-select/index.js.map +1 -0
- package/dist/lib/codemirror-editor/code-editor.d.ts +2 -23
- package/dist/lib/codemirror-editor/code-editor.js +135 -0
- package/dist/lib/codemirror-editor/code-editor.js.map +1 -0
- package/dist/lib/codemirror-editor/index.js +7 -0
- package/dist/lib/codemirror-editor/index.js.map +1 -0
- package/dist/lib/codemirror-editor/json-editor.js +104 -0
- package/dist/lib/codemirror-editor/json-editor.js.map +1 -0
- package/dist/lib/codemirror-editor/raw-code-editor.js +104 -0
- package/dist/lib/codemirror-editor/raw-code-editor.js.map +1 -0
- package/dist/lib/codemirror-editor/raw-text-editor.js +33 -0
- package/dist/lib/codemirror-editor/raw-text-editor.js.map +1 -0
- package/dist/lib/codemirror-editor/text-editor.d.ts +2 -23
- package/dist/lib/codemirror-editor/text-editor.js +50 -0
- package/dist/lib/codemirror-editor/text-editor.js.map +1 -0
- package/dist/lib/codemirror-editor/themes/coze-dark.js +113 -0
- package/dist/lib/codemirror-editor/themes/coze-dark.js.map +1 -0
- package/dist/lib/codemirror-editor/themes/coze-light.js +119 -0
- package/dist/lib/codemirror-editor/themes/coze-light.js.map +1 -0
- package/dist/lib/collapse-card/index.js +31 -0
- package/dist/lib/collapse-card/index.js.map +1 -0
- package/dist/lib/collapse-item/index.js +9 -0
- package/dist/lib/collapse-item/index.js.map +1 -0
- package/dist/lib/collapsible-card/index.js +13 -0
- package/dist/lib/collapsible-card/index.js.map +1 -0
- package/dist/lib/column-manage-storage/index.js +48 -0
- package/dist/lib/column-manage-storage/index.js.map +1 -0
- package/dist/lib/columns-select/index.js +78 -0
- package/dist/lib/columns-select/index.js.map +1 -0
- package/dist/lib/copyable/index.js +12 -0
- package/dist/lib/copyable/index.js.map +1 -0
- package/dist/lib/edit-icon-button/index.js +13 -0
- package/dist/lib/edit-icon-button/index.js.map +1 -0
- package/dist/lib/footer-actions/index.js +8 -0
- package/dist/lib/footer-actions/index.js.map +1 -0
- package/dist/lib/hooks/use-infinite-scroll.js +133 -0
- package/dist/lib/hooks/use-infinite-scroll.js.map +1 -0
- package/dist/lib/hooks/use-mouse-down-offset.js +39 -0
- package/dist/lib/hooks/use-mouse-down-offset.js.map +1 -0
- package/dist/lib/hooks/use-unsave-leave-warning.js +26 -0
- package/dist/lib/hooks/use-unsave-leave-warning.js.map +1 -0
- package/dist/lib/id-render/icon-button-container.js +7 -0
- package/dist/lib/id-render/icon-button-container.js.map +1 -0
- package/dist/lib/id-render/index.js +22 -0
- package/dist/lib/id-render/index.js.map +1 -0
- package/dist/lib/index-controller/record-navigation.js +10 -0
- package/dist/lib/index-controller/record-navigation.js.map +1 -0
- package/dist/lib/index-controller/use-item-index-controller.js +123 -0
- package/dist/lib/index-controller/use-item-index-controller.js.map +1 -0
- package/dist/lib/index.d.ts +0 -6
- package/dist/lib/index.js +77 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/infinite-scroll-table/index.js +35 -0
- package/dist/lib/infinite-scroll-table/index.js.map +1 -0
- package/dist/lib/info-tooltip/index.js +9 -0
- package/dist/lib/info-tooltip/index.js.map +1 -0
- package/dist/lib/input-components/radio-button.js +21 -0
- package/dist/lib/input-components/radio-button.js.map +1 -0
- package/dist/lib/input-slider/index.js +81 -0
- package/dist/lib/input-slider/index.js.map +1 -0
- package/dist/lib/input-with-count/index.js +7 -0
- package/dist/lib/input-with-count/index.js.map +1 -0
- package/dist/lib/jump-button/jump-icon-button.js +7 -0
- package/dist/lib/jump-button/jump-icon-button.js.map +1 -0
- package/dist/lib/large-txt-render/index.js +27 -0
- package/dist/lib/large-txt-render/index.js.map +1 -0
- package/dist/lib/layout/content.js +5 -0
- package/dist/lib/layout/content.js.map +1 -0
- package/dist/lib/layout/header.js +6 -0
- package/dist/lib/layout/header.js.map +1 -0
- package/dist/lib/layout/index.js +9 -0
- package/dist/lib/layout/index.js.map +1 -0
- package/dist/lib/layout/tabs.js +10 -0
- package/dist/lib/layout/tabs.js.map +1 -0
- package/dist/lib/lazy-load-component/index.js +42 -0
- package/dist/lib/lazy-load-component/index.js.map +1 -0
- package/dist/lib/link-button/index.js +23 -0
- package/dist/lib/link-button/index.js.map +1 -0
- package/dist/lib/logic-editor/index.js +3 -0
- package/dist/lib/logic-editor/index.js.map +1 -0
- package/dist/lib/logic-editor/logic-editor.js +70 -0
- package/dist/lib/logic-editor/logic-editor.js.map +1 -0
- package/dist/lib/logic-editor/logic-left-render.js +62 -0
- package/dist/lib/logic-editor/logic-left-render.js.map +1 -0
- package/dist/lib/logic-editor/logic-operator-render.js +31 -0
- package/dist/lib/logic-editor/logic-operator-render.js.map +1 -0
- package/dist/lib/logic-editor/logic-right-render.js +26 -0
- package/dist/lib/logic-editor/logic-right-render.js.map +1 -0
- package/dist/lib/logic-editor/logic-types.js +144 -0
- package/dist/lib/logic-editor/logic-types.js.map +1 -0
- package/dist/lib/logic-editor/utils.js +18 -0
- package/dist/lib/logic-editor/utils.js.map +1 -0
- package/dist/lib/logic-expr/consts.js +5 -0
- package/dist/lib/logic-expr/consts.js.map +1 -0
- package/dist/lib/logic-expr/expr-group-render.js +60 -0
- package/dist/lib/logic-expr/expr-group-render.js.map +1 -0
- package/dist/lib/logic-expr/expr-render.js +84 -0
- package/dist/lib/logic-expr/expr-render.js.map +1 -0
- package/dist/lib/logic-expr/index.js +2 -0
- package/dist/lib/logic-expr/index.js.map +1 -0
- package/dist/lib/logic-expr/logic-expr.js +187 -0
- package/dist/lib/logic-expr/logic-expr.js.map +1 -0
- package/dist/lib/logic-expr/logic-not.js +20 -0
- package/dist/lib/logic-expr/logic-not.js.map +1 -0
- package/dist/lib/logic-expr/logic-toggle.js +32 -0
- package/dist/lib/logic-expr/logic-toggle.js.map +1 -0
- package/dist/lib/logic-expr/types.js +2 -0
- package/dist/lib/logic-expr/types.js.map +1 -0
- package/dist/lib/loop-icons/index.js +3 -0
- package/dist/lib/loop-icons/index.js.map +1 -0
- package/dist/lib/loop-radio-group/index.js +7 -0
- package/dist/lib/loop-radio-group/index.js.map +1 -0
- package/dist/lib/multi-modal-dataset-item-render/audio-render/index.js +34 -0
- package/dist/lib/multi-modal-dataset-item-render/audio-render/index.js.map +1 -0
- package/dist/lib/multi-modal-dataset-item-render/index.js +3 -0
- package/dist/lib/multi-modal-dataset-item-render/index.js.map +1 -0
- package/dist/lib/multi-modal-dataset-item-render/video-render/index.js +47 -0
- package/dist/lib/multi-modal-dataset-item-render/video-render/index.js.map +1 -0
- package/dist/lib/multi-part-editor/components/image-item-renderer.js +58 -0
- package/dist/lib/multi-part-editor/components/image-item-renderer.js.map +1 -0
- package/dist/lib/multi-part-editor/components/multipart-item-renderer.js +26 -0
- package/dist/lib/multi-part-editor/components/multipart-item-renderer.js.map +1 -0
- package/dist/lib/multi-part-editor/components/url-input-modal.js +151 -0
- package/dist/lib/multi-part-editor/components/url-input-modal.js.map +1 -0
- package/dist/lib/multi-part-editor/components/video-item-renderer.js +58 -0
- package/dist/lib/multi-part-editor/components/video-item-renderer.js.map +1 -0
- package/dist/lib/multi-part-editor/index.js +301 -0
- package/dist/lib/multi-part-editor/index.js.map +1 -0
- package/dist/lib/multi-part-editor/multi-part-render.js +40 -0
- package/dist/lib/multi-part-editor/multi-part-render.js.map +1 -0
- package/dist/lib/multi-part-editor/type.js +27 -0
- package/dist/lib/multi-part-editor/type.js.map +1 -0
- package/dist/lib/multi-part-editor/upload-button.js +104 -0
- package/dist/lib/multi-part-editor/upload-button.js.map +1 -0
- package/dist/lib/multi-part-editor/utils.js +43 -0
- package/dist/lib/multi-part-editor/utils.js.map +1 -0
- package/dist/lib/open-detail-button/index.js +12 -0
- package/dist/lib/open-detail-button/index.js.map +1 -0
- package/dist/lib/ops-agent/fox-icon.js +8 -0
- package/dist/lib/ops-agent/fox-icon.js.map +1 -0
- package/dist/lib/page-content/index.js +24 -0
- package/dist/lib/page-content/index.js.map +1 -0
- package/dist/lib/primary-page/index.js +2 -0
- package/dist/lib/primary-page/index.js.map +1 -0
- package/dist/lib/primary-page/primary-header.js +4 -0
- package/dist/lib/primary-page/primary-header.js.map +1 -0
- package/dist/lib/primary-title/index.js +8 -0
- package/dist/lib/primary-title/index.js.map +1 -0
- package/dist/lib/resizable-side-sheet/index.js +32 -0
- package/dist/lib/resizable-side-sheet/index.js.map +1 -0
- package/dist/lib/resize-sidesheet/index.js +15 -0
- package/dist/lib/resize-sidesheet/index.js.map +1 -0
- package/dist/lib/resize-sidesheet/use-drag.js +30 -0
- package/dist/lib/resize-sidesheet/use-drag.js.map +1 -0
- package/dist/lib/schema-editor/index.js +5 -0
- package/dist/lib/schema-editor/index.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/array-field-item.js +19 -0
- package/dist/lib/semi-schema-form/components/tmpls/array-field-item.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/array-field.js +39 -0
- package/dist/lib/semi-schema-form/components/tmpls/array-field.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/base-input.js +32 -0
- package/dist/lib/semi-schema-form/components/tmpls/base-input.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/description-field.js +13 -0
- package/dist/lib/semi-schema-form/components/tmpls/description-field.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/error-list.js +14 -0
- package/dist/lib/semi-schema-form/components/tmpls/error-list.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/field-error.js +16 -0
- package/dist/lib/semi-schema-form/components/tmpls/field-error.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/field.js +21 -0
- package/dist/lib/semi-schema-form/components/tmpls/field.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/icon-button.js +29 -0
- package/dist/lib/semi-schema-form/components/tmpls/icon-button.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/index.js +31 -0
- package/dist/lib/semi-schema-form/components/tmpls/index.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/object-field.js +81 -0
- package/dist/lib/semi-schema-form/components/tmpls/object-field.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/submit.js +13 -0
- package/dist/lib/semi-schema-form/components/tmpls/submit.js.map +1 -0
- package/dist/lib/semi-schema-form/components/tmpls/title-field.js +12 -0
- package/dist/lib/semi-schema-form/components/tmpls/title-field.js.map +1 -0
- package/dist/lib/semi-schema-form/components/widgets/checkbox.js +26 -0
- package/dist/lib/semi-schema-form/components/widgets/checkbox.js.map +1 -0
- package/dist/lib/semi-schema-form/components/widgets/checkboxs.js +27 -0
- package/dist/lib/semi-schema-form/components/widgets/checkboxs.js.map +1 -0
- package/dist/lib/semi-schema-form/components/widgets/index.js +15 -0
- package/dist/lib/semi-schema-form/components/widgets/index.js.map +1 -0
- package/dist/lib/semi-schema-form/components/widgets/radio.js +27 -0
- package/dist/lib/semi-schema-form/components/widgets/radio.js.map +1 -0
- package/dist/lib/semi-schema-form/components/widgets/range.js +26 -0
- package/dist/lib/semi-schema-form/components/widgets/range.js.map +1 -0
- package/dist/lib/semi-schema-form/components/widgets/select.js +44 -0
- package/dist/lib/semi-schema-form/components/widgets/select.js.map +1 -0
- package/dist/lib/semi-schema-form/components/widgets/textarea.js +18 -0
- package/dist/lib/semi-schema-form/components/widgets/textarea.js.map +1 -0
- package/dist/lib/semi-schema-form/index.js +9 -0
- package/dist/lib/semi-schema-form/index.js.map +1 -0
- package/dist/lib/sentinel-form/enum.js +15 -0
- package/dist/lib/sentinel-form/enum.js.map +1 -0
- package/dist/lib/sentinel-form/index.d.ts +1 -1
- package/dist/lib/sentinel-form/index.js +323 -0
- package/dist/lib/sentinel-form/index.js.map +1 -0
- package/dist/lib/step-nav/index.js +13 -0
- package/dist/lib/step-nav/index.js.map +1 -0
- package/dist/lib/table/index.js +7 -0
- package/dist/lib/table/index.js.map +1 -0
- package/dist/lib/table/sort-icon.js +31 -0
- package/dist/lib/table/sort-icon.js.map +1 -0
- package/dist/lib/table/table-with-pagination.js +74 -0
- package/dist/lib/table/table-with-pagination.js.map +1 -0
- package/dist/lib/table/table-without-pagniation.js +37 -0
- package/dist/lib/table/table-without-pagniation.js.map +1 -0
- package/dist/lib/table-batch-operate/table-batch-operation.js +17 -0
- package/dist/lib/table-batch-operate/table-batch-operation.js.map +1 -0
- package/dist/lib/table-batch-operate/use-batch-operate.js +71 -0
- package/dist/lib/table-batch-operate/use-batch-operate.js.map +1 -0
- package/dist/lib/table-col-actions/index.js +39 -0
- package/dist/lib/table-col-actions/index.js.map +1 -0
- package/dist/lib/table-cols-config/index.js +60 -0
- package/dist/lib/table-cols-config/index.js.map +1 -0
- package/dist/lib/table-cols-config/type.js +2 -0
- package/dist/lib/table-cols-config/type.js.map +1 -0
- package/dist/lib/table-cols-config/use-hidden-col-keys.js +32 -0
- package/dist/lib/table-cols-config/use-hidden-col-keys.js.map +1 -0
- package/dist/lib/table-cols-config/util.js +39 -0
- package/dist/lib/table-cols-config/util.js.map +1 -0
- package/dist/lib/table-empty/index.js +9 -0
- package/dist/lib/table-empty/index.js.map +1 -0
- package/dist/lib/table-header/index.d.ts +1 -1
- package/dist/lib/table-header/index.js +12 -0
- package/dist/lib/table-header/index.js.map +1 -0
- package/dist/lib/tabs/index.js +9 -0
- package/dist/lib/tabs/index.js.map +1 -0
- package/dist/lib/text-area-pro/index.js +10 -0
- package/dist/lib/text-area-pro/index.js.map +1 -0
- package/dist/lib/text-with-copy/index.js +25 -0
- package/dist/lib/text-with-copy/index.js.map +1 -0
- package/dist/lib/title-with-sub/index.js +6 -0
- package/dist/lib/title-with-sub/index.js.map +1 -0
- package/dist/lib/tooltip-when-disabled/index.js +9 -0
- package/dist/lib/tooltip-when-disabled/index.js.map +1 -0
- package/dist/lib/tooltip-with-disabled/index.js +9 -0
- package/dist/lib/tooltip-with-disabled/index.js.map +1 -0
- package/dist/lib/tsconfig.build.tsbuildinfo +1 -0
- package/dist/lib/upload/index.js +25 -0
- package/dist/lib/upload/index.js.map +1 -0
- package/dist/lib/user-profile/index.js +21 -0
- package/dist/lib/user-profile/index.js.map +1 -0
- package/dist/lib/utils/basic.js +30 -0
- package/dist/lib/utils/basic.js.map +1 -0
- package/dist/lib/version-list/version-descriptions.js +15 -0
- package/dist/lib/version-list/version-descriptions.js.map +1 -0
- package/dist/lib/version-list/version-item.js +6 -0
- package/dist/lib/version-list/version-item.js.map +1 -0
- package/dist/lib/version-list/version-list.js +12 -0
- package/dist/lib/version-list/version-list.js.map +1 -0
- package/dist/lib/version-list/version-switch-panel.js +11 -0
- package/dist/lib/version-list/version-switch-panel.js.map +1 -0
- package/package.json +31 -23
- package/dist/lib/accessible-option-label/index.d.ts +0 -14
- package/dist/lib/banner/index.d.ts +0 -8
- package/dist/lib/code-editor/index.d.ts +0 -3
- package/dist/lib/code-editor-with-loading/index.d.ts +0 -10
- package/dist/lib/input-number-bigint/__tests__/input-number-bigint.test.d.ts +0 -1
- package/dist/lib/input-number-bigint/index.d.ts +0 -3
- package/dist/lib/rich-text-editor/editor.d.ts +0 -2
- package/dist/lib/rich-text-editor/index.d.ts +0 -2
- package/dist/lib/rich-text-editor/mention-extension.d.ts +0 -16
- package/dist/lib/rich-text-editor/mention-node-view.d.ts +0 -4
- package/dist/lib/rich-text-editor/types.d.ts +0 -45
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { ariaDescribedByIds, } from '@rjsf/utils';
|
|
3
|
+
import { Checkbox } from '@coze-arch/coze-design';
|
|
4
|
+
/** The `CheckBoxWidget` is a widget for rendering boolean properties.
|
|
5
|
+
* It is typically used to represent a boolean.
|
|
6
|
+
*
|
|
7
|
+
* @param props - The `WidgetProps` for this component
|
|
8
|
+
*/
|
|
9
|
+
export default function CheckboxWidget(props) {
|
|
10
|
+
const { autofocus, disabled, formContext, id,
|
|
11
|
+
// label,
|
|
12
|
+
// hideLabel,
|
|
13
|
+
onBlur, onChange, onFocus, readonly, value, } = props;
|
|
14
|
+
const { readonlyAsDisabled = true } = formContext;
|
|
15
|
+
const handleChange = ({ target }) => onChange(target.checked);
|
|
16
|
+
const handleBlur = ({ target }) => onBlur(id, target && target.checked);
|
|
17
|
+
const handleFocus = ({ target }) => onFocus(id, target && target.checked);
|
|
18
|
+
// Antd's typescript definitions do not contain the following props that are actually necessary and, if provided,
|
|
19
|
+
// they are used, so hacking them in via by spreading `extraProps` on the component to avoid typescript errors
|
|
20
|
+
const extraProps = {
|
|
21
|
+
onBlur: !readonly ? handleBlur : undefined,
|
|
22
|
+
onFocus: !readonly ? handleFocus : undefined,
|
|
23
|
+
};
|
|
24
|
+
return (_jsx(Checkbox, { autoFocus: autofocus, checked: typeof value === 'undefined' ? false : value, disabled: disabled || (readonlyAsDisabled && readonly), id: id, onChange: !readonly ? handleChange : undefined, ...extraProps, "aria-describedby": ariaDescribedByIds(id) }));
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=checkbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkbox.js","sourceRoot":"","sources":["../../../../../src/semi-schema-form/components/widgets/checkbox.tsx"],"names":[],"mappings":";AAEA,OAAO,EACL,kBAAkB,GAOnB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,QAAQ,EAAsB,MAAM,wBAAwB,CAAC;AAEtE;;;;GAIG;AACH,MAAM,CAAC,OAAO,UAAU,cAAc,CAIpC,KAA2B;IAC3B,MAAM,EACJ,SAAS,EACT,QAAQ,EACR,WAAW,EACX,EAAE;IACF,SAAS;IACT,aAAa;IACb,MAAM,EACN,QAAQ,EACR,OAAO,EACP,QAAQ,EACR,KAAK,GACN,GAAG,KAAK,CAAC;IACV,MAAM,EAAE,kBAAkB,GAAG,IAAI,EAAE,GAAG,WAAgC,CAAC;IAEvE,MAAM,YAAY,GAA8B,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAC7D,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAE3B,MAAM,UAAU,GAAG,CAAC,EAAE,MAAM,EAAgC,EAAE,EAAE,CAC9D,MAAM,CAAC,EAAE,EAAE,MAAM,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC;IAEvC,MAAM,WAAW,GAAG,CAAC,EAAE,MAAM,EAAgC,EAAE,EAAE,CAC/D,OAAO,CAAC,EAAE,EAAE,MAAM,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC;IAExC,iHAAiH;IACjH,8GAA8G;IAC9G,MAAM,UAAU,GAAG;QACjB,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;QAC1C,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;KAC7C,CAAC;IACF,OAAO,CACL,KAAC,QAAQ,IACP,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,KAAK,KAAK,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,EACrD,QAAQ,EAAE,QAAQ,IAAI,CAAC,kBAAkB,IAAI,QAAQ,CAAC,EACtD,EAAE,EAAE,EAAE,EACN,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,KAC1C,UAAU,sBACI,kBAAkB,CAAI,EAAE,CAAC,GAGlC,CACZ,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { ariaDescribedByIds, enumOptionsIndexForValue, enumOptionsValueForIndex, optionId, } from '@rjsf/utils';
|
|
3
|
+
import { Checkbox } from '@coze-arch/coze-design';
|
|
4
|
+
/** The `CheckboxesWidget` is a widget for rendering checkbox groups.
|
|
5
|
+
* It is typically used to represent an array of enums.
|
|
6
|
+
*
|
|
7
|
+
* @param props - The `WidgetProps` for this component
|
|
8
|
+
*/
|
|
9
|
+
export default function CheckboxesWidget({ autofocus, disabled, formContext, id, onBlur, onChange, onFocus, options, readonly, value, }) {
|
|
10
|
+
const { readonlyAsDisabled = true } = formContext;
|
|
11
|
+
const { enumOptions, enumDisabled, inline, emptyValue } = options;
|
|
12
|
+
const handleChange = nextValue => onChange(enumOptionsValueForIndex(nextValue, enumOptions, emptyValue));
|
|
13
|
+
const handleBlur = ({ target }) => onBlur(id, enumOptionsValueForIndex(target.value, enumOptions, emptyValue));
|
|
14
|
+
const handleFocus = ({ target }) => onFocus(id, enumOptionsValueForIndex(target.value, enumOptions, emptyValue));
|
|
15
|
+
// Antd's typescript definitions do not contain the following props that are actually necessary and, if provided,
|
|
16
|
+
// they are used, so hacking them in via by spreading `extraProps` on the component to avoid typescript errors
|
|
17
|
+
const extraProps = {
|
|
18
|
+
id,
|
|
19
|
+
onBlur: !readonly ? handleBlur : undefined,
|
|
20
|
+
onFocus: !readonly ? handleFocus : undefined,
|
|
21
|
+
};
|
|
22
|
+
const selectedIndexes = enumOptionsIndexForValue(value, enumOptions, true);
|
|
23
|
+
return Array.isArray(enumOptions) && enumOptions.length > 0 ? (_jsx(_Fragment, { children: _jsx(Checkbox.Group, { disabled: disabled || (readonlyAsDisabled && readonly), name: id, onChange: !readonly ? handleChange : undefined, value: selectedIndexes, ...extraProps, "aria-describedby": ariaDescribedByIds(id), children: Array.isArray(enumOptions) &&
|
|
24
|
+
enumOptions.map((option, i) => (_jsxs("span", { children: [_jsx(Checkbox, { id: optionId(id, i), autoFocus: i === 0 ? autofocus : false, disabled: Array.isArray(enumDisabled) &&
|
|
25
|
+
enumDisabled.indexOf(option.value) !== -1, value: String(i), children: option.label }), !inline && _jsx("br", {})] }, i))) }) })) : null;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=checkboxs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkboxs.js","sourceRoot":"","sources":["../../../../../src/semi-schema-form/components/widgets/checkboxs.tsx"],"names":[],"mappings":";AAEA,OAAO,EACL,kBAAkB,EAClB,wBAAwB,EACxB,wBAAwB,EACxB,QAAQ,GAMT,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,QAAQ,EAA2B,MAAM,wBAAwB,CAAC;AAE3E;;;;GAIG;AACH,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAItC,EACA,SAAS,EACT,QAAQ,EACR,WAAW,EACX,EAAE,EACF,MAAM,EACN,QAAQ,EACR,OAAO,EACP,OAAO,EACP,QAAQ,EACR,KAAK,GACgB;IACrB,MAAM,EAAE,kBAAkB,GAAG,IAAI,EAAE,GAAG,WAAgC,CAAC;IAEvE,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAElE,MAAM,YAAY,GAAmC,SAAS,CAAC,EAAE,CAC/D,QAAQ,CAAC,wBAAwB,CAAI,SAAS,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,CAAC;IAE5E,MAAM,UAAU,GAAG,CAAC,EAAE,MAAM,EAAgC,EAAE,EAAE,CAC9D,MAAM,CACJ,EAAE,EACF,wBAAwB,CAAI,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,UAAU,CAAC,CACnE,CAAC;IAEJ,MAAM,WAAW,GAAG,CAAC,EAAE,MAAM,EAAgC,EAAE,EAAE,CAC/D,OAAO,CACL,EAAE,EACF,wBAAwB,CAAI,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,UAAU,CAAC,CACnE,CAAC;IAEJ,iHAAiH;IACjH,8GAA8G;IAC9G,MAAM,UAAU,GAAG;QACjB,EAAE;QACF,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;QAC1C,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;KAC7C,CAAC;IAEF,MAAM,eAAe,GAAG,wBAAwB,CAC9C,KAAK,EACL,WAAW,EACX,IAAI,CACO,CAAC;IAEd,OAAO,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAC5D,4BACE,KAAC,QAAQ,CAAC,KAAK,IACb,QAAQ,EAAE,QAAQ,IAAI,CAAC,kBAAkB,IAAI,QAAQ,CAAC,EACtD,IAAI,EAAE,EAAE,EACR,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,EAC9C,KAAK,EAAE,eAAe,KAClB,UAAU,sBACI,kBAAkB,CAAI,EAAE,CAAC,YAE1C,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC;gBACzB,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC,CAC7B,2BACE,KAAC,QAAQ,IACP,EAAE,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC,EACnB,SAAS,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,EACtC,QAAQ,EACN,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC;gCAC3B,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAE3C,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,YAEf,MAAM,CAAC,KAAK,GACJ,EACV,CAAC,MAAM,IAAI,cAAM,KAZT,CAAC,CAaL,CACR,CAAC,GACW,GAChB,CACJ,CAAC,CAAC,CAAC,IAAI,CAAC;AACX,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import TextAreaWidget from './textarea';
|
|
2
|
+
import SelectWidget from './select';
|
|
3
|
+
import RangeWidget from './range';
|
|
4
|
+
import RadioWidget from './radio';
|
|
5
|
+
import CheckboxesWidget from './checkboxs';
|
|
6
|
+
import CheckboxWidget from './checkbox';
|
|
7
|
+
export const widgets = {
|
|
8
|
+
TextAreaWidget,
|
|
9
|
+
SelectWidget,
|
|
10
|
+
CheckboxWidget,
|
|
11
|
+
CheckboxesWidget,
|
|
12
|
+
RadioWidget,
|
|
13
|
+
RangeWidget,
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/semi-schema-form/components/widgets/index.ts"],"names":[],"mappings":"AAEA,OAAO,cAAc,MAAM,YAAY,CAAC;AACxC,OAAO,YAAY,MAAM,UAAU,CAAC;AACpC,OAAO,WAAW,MAAM,SAAS,CAAC;AAClC,OAAO,WAAW,MAAM,SAAS,CAAC;AAClC,OAAO,gBAAgB,MAAM,aAAa,CAAC;AAC3C,OAAO,cAAc,MAAM,YAAY,CAAC;AAExC,MAAM,CAAC,MAAM,OAAO,GAAwB;IAC1C,cAAc;IACd,YAAY;IACZ,cAAc;IACd,gBAAgB;IAChB,WAAW;IACX,WAAW;CACZ,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { ariaDescribedByIds, enumOptionsIndexForValue, enumOptionsValueForIndex, } from '@rjsf/utils';
|
|
3
|
+
import { Radio } from '@coze-arch/coze-design';
|
|
4
|
+
/** The `RadioWidget` is a widget for rendering a radio group.
|
|
5
|
+
* It is typically used with a string property constrained with enum options.
|
|
6
|
+
*
|
|
7
|
+
* @param props - The `WidgetProps` for this component
|
|
8
|
+
*/
|
|
9
|
+
export default function RadioWidget({ autofocus, disabled, formContext, id, onBlur, onChange, onFocus, options, readonly, value, }) {
|
|
10
|
+
const { readonlyAsDisabled = true } = formContext;
|
|
11
|
+
const { enumOptions, enumDisabled, emptyValue } = options;
|
|
12
|
+
const handleChange = ({ target: { value: nextValue }, }) => onChange(enumOptionsValueForIndex(nextValue, enumOptions, emptyValue));
|
|
13
|
+
const handleBlur = ({ target }) => onBlur(id, enumOptionsValueForIndex(target && target.value, enumOptions, emptyValue));
|
|
14
|
+
const handleFocus = ({ target }) => onFocus(id, enumOptionsValueForIndex(target && target.value, enumOptions, emptyValue));
|
|
15
|
+
const selectedIndexes = enumOptionsIndexForValue(value, enumOptions);
|
|
16
|
+
// Antd's typescript definitions do not contain the following props that are actually necessary and, if provided,
|
|
17
|
+
// they are used, so hacking them in via by spreading `extraProps` on the component to avoid typescript errors
|
|
18
|
+
const extraProps = {
|
|
19
|
+
onBlur: !readonly ? handleBlur : undefined,
|
|
20
|
+
onFocus: !readonly ? handleFocus : undefined,
|
|
21
|
+
};
|
|
22
|
+
return (_jsx(Radio.Group, { disabled: disabled || (readonlyAsDisabled && readonly), id: id, name: id, onChange: !readonly ? handleChange : undefined, ...extraProps, value: selectedIndexes, "aria-describedby": ariaDescribedByIds(id), children: Array.isArray(enumOptions) &&
|
|
23
|
+
enumOptions.map((option, i) => (_jsx(Radio, { name: id, autoFocus: i === 0 ? autofocus : false, disabled: disabled ||
|
|
24
|
+
(Array.isArray(enumDisabled) &&
|
|
25
|
+
enumDisabled.indexOf(option.value) !== -1), value: String(i), children: option.label }, i))) }));
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=radio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"radio.js","sourceRoot":"","sources":["../../../../../src/semi-schema-form/components/widgets/radio.tsx"],"names":[],"mappings":";AAEA,OAAO,EACL,kBAAkB,EAClB,wBAAwB,EACxB,wBAAwB,GAMzB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,KAAK,EAAwB,MAAM,wBAAwB,CAAC;AAErE;;;;GAIG;AACH,MAAM,CAAC,OAAO,UAAU,WAAW,CAIjC,EACA,SAAS,EACT,QAAQ,EACR,WAAW,EACX,EAAE,EACF,MAAM,EACN,QAAQ,EACR,OAAO,EACP,OAAO,EACP,QAAQ,EACR,KAAK,GACgB;IACrB,MAAM,EAAE,kBAAkB,GAAG,IAAI,EAAE,GAAG,WAAgC,CAAC;IAEvE,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAE1D,MAAM,YAAY,GAAgC,CAAC,EACjD,MAAM,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,GAC7B,EAAE,EAAE,CACH,QAAQ,CAAC,wBAAwB,CAAI,SAAS,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,CAAC;IAE5E,MAAM,UAAU,GAAG,CAAC,EAAE,MAAM,EAAgC,EAAE,EAAE,CAC9D,MAAM,CACJ,EAAE,EACF,wBAAwB,CACtB,MAAM,IAAI,MAAM,CAAC,KAAK,EACtB,WAAW,EACX,UAAU,CACX,CACF,CAAC;IAEJ,MAAM,WAAW,GAAG,CAAC,EAAE,MAAM,EAAgC,EAAE,EAAE,CAC/D,OAAO,CACL,EAAE,EACF,wBAAwB,CACtB,MAAM,IAAI,MAAM,CAAC,KAAK,EACtB,WAAW,EACX,UAAU,CACX,CACF,CAAC;IAEJ,MAAM,eAAe,GAAG,wBAAwB,CAC9C,KAAK,EACL,WAAW,CACF,CAAC;IAEZ,iHAAiH;IACjH,8GAA8G;IAC9G,MAAM,UAAU,GAAG;QACjB,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;QAC1C,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;KAC7C,CAAC;IAEF,OAAO,CACL,KAAC,KAAK,CAAC,KAAK,IACV,QAAQ,EAAE,QAAQ,IAAI,CAAC,kBAAkB,IAAI,QAAQ,CAAC,EACtD,EAAE,EAAE,EAAE,EACN,IAAI,EAAE,EAAE,EACR,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,KAC1C,UAAU,EACd,KAAK,EAAE,eAAe,sBACJ,kBAAkB,CAAI,EAAE,CAAC,YAE1C,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC;YACzB,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC,CAC7B,KAAC,KAAK,IACJ,IAAI,EAAE,EAAE,EACR,SAAS,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,EACtC,QAAQ,EACN,QAAQ;oBACR,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC;wBAC1B,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAG9C,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,YAEf,MAAM,CAAC,KAAK,IAHR,CAAC,CAIA,CACT,CAAC,GACQ,CACf,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { ariaDescribedByIds, rangeSpec, } from '@rjsf/utils';
|
|
3
|
+
import { Slider } from '@coze-arch/coze-design';
|
|
4
|
+
/** The `RangeWidget` component uses the `BaseInputTemplate` changing the type to `range` and wrapping the result
|
|
5
|
+
* in a div, with the value along side it.
|
|
6
|
+
*
|
|
7
|
+
* @param props - The `WidgetProps` for this component
|
|
8
|
+
*/
|
|
9
|
+
export default function RangeWidget(props) {
|
|
10
|
+
const { autofocus, disabled, formContext, id, onBlur, onChange, onFocus, options, placeholder, readonly, schema, value, } = props;
|
|
11
|
+
const { readonlyAsDisabled = true } = formContext;
|
|
12
|
+
const { min, max, step } = rangeSpec(schema);
|
|
13
|
+
const emptyValue = options.emptyValue || '';
|
|
14
|
+
const handleChange = nextValue => onChange(typeof nextValue === 'undefined' ? emptyValue : nextValue);
|
|
15
|
+
const handleBlur = () => onBlur(id, value);
|
|
16
|
+
const handleFocus = () => onFocus(id, value);
|
|
17
|
+
// Antd's typescript definitions do not contain the following props that are actually necessary and, if provided,
|
|
18
|
+
// they are used, so hacking them in via by spreading `extraProps` on the component to avoid typescript errors
|
|
19
|
+
const extraProps = {
|
|
20
|
+
placeholder,
|
|
21
|
+
onBlur: !readonly ? handleBlur : undefined,
|
|
22
|
+
onFocus: !readonly ? handleFocus : undefined,
|
|
23
|
+
};
|
|
24
|
+
return (_jsx(Slider, { autoFocus: autofocus, disabled: disabled || (readonlyAsDisabled && readonly), id: id, max: max, min: min, onChange: !readonly ? handleChange : undefined, range: false, step: step, value: value, ...extraProps, "aria-describedby": ariaDescribedByIds(id) }));
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=range.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"range.js","sourceRoot":"","sources":["../../../../../src/semi-schema-form/components/widgets/range.tsx"],"names":[],"mappings":";AACA,OAAO,EACL,kBAAkB,EAClB,SAAS,GAMV,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,MAAM,EAAoB,MAAM,wBAAwB,CAAC;AAElE;;;;GAIG;AACH,MAAM,CAAC,OAAO,UAAU,WAAW,CAIjC,KAA2B;IAC3B,MAAM,EACJ,SAAS,EACT,QAAQ,EACR,WAAW,EACX,EAAE,EACF,MAAM,EACN,QAAQ,EACR,OAAO,EACP,OAAO,EACP,WAAW,EACX,QAAQ,EACR,MAAM,EACN,KAAK,GACN,GAAG,KAAK,CAAC;IACV,MAAM,EAAE,kBAAkB,GAAG,IAAI,EAAE,GAAG,WAAgC,CAAC;IAEvE,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IAE7C,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,IAAI,EAAE,CAAC;IAE5C,MAAM,YAAY,GAA4B,SAAS,CAAC,EAAE,CACxD,QAAQ,CAAC,OAAO,SAAS,KAAK,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAEtE,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IAE3C,MAAM,WAAW,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IAE7C,iHAAiH;IACjH,8GAA8G;IAC9G,MAAM,UAAU,GAAG;QACjB,WAAW;QACX,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;QAC1C,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;KAC7C,CAAC;IAEF,OAAO,CACL,KAAC,MAAM,IACL,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,QAAQ,IAAI,CAAC,kBAAkB,IAAI,QAAQ,CAAC,EACtD,EAAE,EAAE,EAAE,EACN,GAAG,EAAE,GAAG,EACR,GAAG,EAAE,GAAG,EACR,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,EAC9C,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,KACR,UAAU,sBACI,kBAAkB,CAAI,EAAE,CAAC,GAC3C,CACH,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo } from 'react';
|
|
3
|
+
import { ariaDescribedByIds, enumOptionsIndexForValue, enumOptionsValueForIndex, } from '@rjsf/utils';
|
|
4
|
+
import { Select, } from '@coze-arch/coze-design';
|
|
5
|
+
const SELECT_STYLE = {
|
|
6
|
+
width: '100%',
|
|
7
|
+
};
|
|
8
|
+
/** The `SelectWidget` is a widget for rendering dropdowns.
|
|
9
|
+
* It is typically used with string properties constrained with enum options.
|
|
10
|
+
*
|
|
11
|
+
* @param props - The `WidgetProps` for this component
|
|
12
|
+
*/
|
|
13
|
+
export default function SelectWidget({ autofocus, disabled, formContext = {}, id, multiple, onBlur, onChange, onFocus, options, placeholder, readonly, value, }) {
|
|
14
|
+
const { readonlyAsDisabled = true } = formContext;
|
|
15
|
+
const { enumOptions, enumDisabled, emptyValue } = options;
|
|
16
|
+
const handleChange = nextValue => {
|
|
17
|
+
if (typeof nextValue === 'object' && !Array.isArray(nextValue)) {
|
|
18
|
+
throw new Error('Object type value is not supported');
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
onChange(typeof nextValue === 'undefined'
|
|
22
|
+
? undefined
|
|
23
|
+
: enumOptionsValueForIndex(nextValue, enumOptions, emptyValue));
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
const handleBlur = () => onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));
|
|
27
|
+
const handleFocus = () => onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));
|
|
28
|
+
const selectedIndexes = enumOptionsIndexForValue(value, enumOptions, multiple);
|
|
29
|
+
const selectOptions = useMemo(() => {
|
|
30
|
+
if (Array.isArray(enumOptions)) {
|
|
31
|
+
const opts = enumOptions.map(({ value: optionValue, label: optionLabel }, index) => ({
|
|
32
|
+
disabled: Array.isArray(enumDisabled) &&
|
|
33
|
+
enumDisabled.indexOf(optionValue) !== -1,
|
|
34
|
+
key: String(index),
|
|
35
|
+
value: String(index),
|
|
36
|
+
label: optionLabel,
|
|
37
|
+
}));
|
|
38
|
+
return opts;
|
|
39
|
+
}
|
|
40
|
+
return undefined;
|
|
41
|
+
}, [enumDisabled, enumOptions]);
|
|
42
|
+
return (_jsx(Select, { autoFocus: autofocus, disabled: disabled || (readonlyAsDisabled && readonly), id: id, multiple: multiple, onBlur: !readonly ? handleBlur : undefined, onChange: !readonly ? handleChange : undefined, onFocus: !readonly ? handleFocus : undefined, placeholder: placeholder, style: SELECT_STYLE, value: selectedIndexes, "aria-describedby": ariaDescribedByIds(id), optionList: selectOptions }));
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=select.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../src/semi-schema-form/components/widgets/select.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { ariaDescribedByIds, } from '@rjsf/utils';
|
|
3
|
+
import { TextArea } from '@coze-arch/coze-design';
|
|
4
|
+
const INPUT_STYLE = {
|
|
5
|
+
width: '100%',
|
|
6
|
+
};
|
|
7
|
+
/** The `TextareaWidget` is a widget for rendering input fields as textarea.
|
|
8
|
+
*
|
|
9
|
+
* @param props - The `WidgetProps` for this component
|
|
10
|
+
*/
|
|
11
|
+
export default function TextareaWidget({ disabled, formContext, id, onBlur, onChange, onFocus, options, placeholder, readonly, value, }) {
|
|
12
|
+
const { readonlyAsDisabled = true } = formContext;
|
|
13
|
+
const handleChange = nextValue => onChange(nextValue === '' ? options.emptyValue : nextValue);
|
|
14
|
+
const handleBlur = ({ target }) => onBlur(id, target && target.value);
|
|
15
|
+
const handleFocus = ({ target }) => onFocus(id, target && target.value);
|
|
16
|
+
return (_jsx(TextArea, { disabled: disabled || (readonlyAsDisabled && readonly), id: id, name: id, onBlur: !readonly ? handleBlur : undefined, onChange: !readonly ? handleChange : undefined, onFocus: !readonly ? handleFocus : undefined, placeholder: placeholder, rows: options.rows || 4, style: INPUT_STYLE, value: value, "aria-describedby": ariaDescribedByIds(id) }));
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=textarea.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"textarea.js","sourceRoot":"","sources":["../../../../../src/semi-schema-form/components/widgets/textarea.tsx"],"names":[],"mappings":";AAEA,OAAO,EACL,kBAAkB,GAMnB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,QAAQ,EAAsB,MAAM,wBAAwB,CAAC;AAEtE,MAAM,WAAW,GAAG;IAClB,KAAK,EAAE,MAAM;CACd,CAAC;AAEF;;;GAGG;AACH,MAAM,CAAC,OAAO,UAAU,cAAc,CAIpC,EACA,QAAQ,EACR,WAAW,EACX,EAAE,EACF,MAAM,EACN,QAAQ,EACR,OAAO,EACP,OAAO,EACP,WAAW,EACX,QAAQ,EACR,KAAK,GACgB;IACrB,MAAM,EAAE,kBAAkB,GAAG,IAAI,EAAE,GAAG,WAAgC,CAAC;IAEvE,MAAM,YAAY,GAA8B,SAAS,CAAC,EAAE,CAC1D,QAAQ,CAAC,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAE9D,MAAM,UAAU,GAAG,CAAC,EAAE,MAAM,EAAmC,EAAE,EAAE,CACjE,MAAM,CAAC,EAAE,EAAE,MAAM,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC;IAErC,MAAM,WAAW,GAAG,CAAC,EAAE,MAAM,EAAmC,EAAE,EAAE,CAClE,OAAO,CAAC,EAAE,EAAE,MAAM,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC;IAEtC,OAAO,CACL,KAAC,QAAQ,IACP,QAAQ,EAAE,QAAQ,IAAI,CAAC,kBAAkB,IAAI,QAAQ,CAAC,EACtD,EAAE,EAAE,EAAE,EACN,IAAI,EAAE,EAAE,EACR,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,EAC1C,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,EAC9C,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,EAC5C,WAAW,EAAE,WAAW,EACxB,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,EACvB,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,KAAK,sBACM,kBAAkB,CAAI,EAAE,CAAC,GAC3C,CACH,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { withTheme } from '@rjsf/core';
|
|
2
|
+
export { default as schemaValidators } from '@rjsf/validator-ajv8';
|
|
3
|
+
import { widgets } from './components/widgets';
|
|
4
|
+
import { templates } from './components/tmpls';
|
|
5
|
+
export const SemiSchemaForm = withTheme({
|
|
6
|
+
widgets,
|
|
7
|
+
templates,
|
|
8
|
+
});
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/semi-schema-form/index.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvC,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAEnE,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAE/C,MAAM,CAAC,MAAM,cAAc,GAAG,SAAS,CAAC;IACtC,OAAO;IACP,SAAS;CACV,CAAC,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export var EventNames;
|
|
2
|
+
(function (EventNames) {
|
|
3
|
+
// 进入相关
|
|
4
|
+
EventNames["INIT_LOOP_FORM"] = "init_loop_form";
|
|
5
|
+
// 保点击保存,表单报错
|
|
6
|
+
EventNames["LOOP_FORM_FIELD_VALIDATE_ERROR"] = "loop_form_field_validate_error";
|
|
7
|
+
// 点击保存,接口报错
|
|
8
|
+
EventNames["LOOP_FORM_SUBMIT_INTERFACE_ERROR"] = "loop_form_submit_interface_error";
|
|
9
|
+
// 点击保存,成功
|
|
10
|
+
EventNames["LOOP_FORM_SUBMIT_SUCCESS"] = "loop_form_submit_success";
|
|
11
|
+
// 离开表单
|
|
12
|
+
EventNames["LOOP_FORM_FIELD_CHANGE_TIMELINE"] = "loop_form_field_change_timeline";
|
|
13
|
+
EventNames["LOOP_FORM_CLOSE"] = "loop_form_close";
|
|
14
|
+
})(EventNames || (EventNames = {}));
|
|
15
|
+
//# sourceMappingURL=enum.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enum.js","sourceRoot":"","sources":["../../../src/sentinel-form/enum.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,UAeX;AAfD,WAAY,UAAU;IACpB,OAAO;IACP,+CAAiC,CAAA;IACjC,aAAa;IACb,+EAAiE,CAAA;IAEjE,YAAY;IACZ,mFAAqE,CAAA;IAErE,UAAU;IACV,mEAAqD,CAAA;IAErD,OAAO;IACP,iFAAmE,CAAA;IACnE,iDAAmC,CAAA;AACrC,CAAC,EAfW,UAAU,KAAV,UAAU,QAerB"}
|
|
@@ -0,0 +1,323 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/* eslint-disable @typescript-eslint/no-magic-numbers */
|
|
3
|
+
/* eslint-disable max-lines-per-function */
|
|
4
|
+
/* eslint-disable security/detect-object-injection */
|
|
5
|
+
/* eslint-disable @coze-arch/max-line-per-function -- 监控逻辑较多,函数较长,后续可拆分 */
|
|
6
|
+
/* eslint-disable @typescript-eslint/no-explicit-any -- 表单组件需要处理任意类型的表单数据与第三方库接口 */
|
|
7
|
+
import { forwardRef, isValidElement, useCallback, useImperativeHandle, useMemo, useRef, useState, useEffect, } from 'react';
|
|
8
|
+
import { nanoid } from 'nanoid';
|
|
9
|
+
import { debounce } from 'lodash-es';
|
|
10
|
+
import dayjs from 'dayjs';
|
|
11
|
+
import { useReportEvent } from '@cozeloop/config-provider';
|
|
12
|
+
import { Form } from '@coze-arch/coze-design';
|
|
13
|
+
import { EventNames } from './enum';
|
|
14
|
+
function safeStringify(obj) {
|
|
15
|
+
return JSON.stringify(obj, (_, value) => {
|
|
16
|
+
if (isValidElement(value)) {
|
|
17
|
+
return '[ReactElement]';
|
|
18
|
+
}
|
|
19
|
+
if (typeof value === 'function') {
|
|
20
|
+
return '[Function]';
|
|
21
|
+
}
|
|
22
|
+
if (value instanceof HTMLElement) {
|
|
23
|
+
return '[HTMLElement]';
|
|
24
|
+
}
|
|
25
|
+
return value;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
const SentinelFormInner = ({ formID, children, onValueChange, onSubmit, getFormApi, ...props }, ref) => {
|
|
29
|
+
const sendEvent = useReportEvent();
|
|
30
|
+
const sessionID = useMemo(() => nanoid(), []);
|
|
31
|
+
const formRef = useRef(null);
|
|
32
|
+
const instanceRef = useRef(null);
|
|
33
|
+
const startTimeRef = useRef(0);
|
|
34
|
+
const interfaceErrorCount = useRef(0);
|
|
35
|
+
const validateErrorCount = useRef(0);
|
|
36
|
+
const firstValidateSuccess = useRef(true);
|
|
37
|
+
const noOperation = useRef(true);
|
|
38
|
+
const noSubmit = useRef(true);
|
|
39
|
+
const submitSuccess = useRef(false);
|
|
40
|
+
const validateErrorLog = debounce((error) => {
|
|
41
|
+
firstValidateSuccess.current = false;
|
|
42
|
+
validateErrorCount.current = validateErrorCount.current + 1;
|
|
43
|
+
const validateErrorTime = Date.now();
|
|
44
|
+
const errorKeys = Object.keys(error) || [];
|
|
45
|
+
sendEvent(EventNames.LOOP_FORM_FIELD_VALIDATE_ERROR, {
|
|
46
|
+
form_id: formID,
|
|
47
|
+
session_id: sessionID,
|
|
48
|
+
form_item_error_count: errorKeys.length,
|
|
49
|
+
form_item_error_detail: JSON.stringify(error || {}),
|
|
50
|
+
time: validateErrorTime,
|
|
51
|
+
time_str: dayjs(validateErrorTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
52
|
+
});
|
|
53
|
+
}, 500);
|
|
54
|
+
// 提交日志:仅用于接口错误统计与成功上报,不处理校验错误
|
|
55
|
+
const submitLog = useCallback(async (isInterfaceError, error) => {
|
|
56
|
+
noSubmit.current = false;
|
|
57
|
+
if (isInterfaceError) {
|
|
58
|
+
firstValidateSuccess.current = false;
|
|
59
|
+
interfaceErrorCount.current = interfaceErrorCount.current + 1;
|
|
60
|
+
sendEvent?.(EventNames.LOOP_FORM_SUBMIT_INTERFACE_ERROR, {
|
|
61
|
+
form_id: formID,
|
|
62
|
+
session_id: sessionID,
|
|
63
|
+
form_interface_error_detail: JSON.stringify(error || {}),
|
|
64
|
+
time: Date.now(),
|
|
65
|
+
time_str: dayjs(Date.now()).format('YYYY-MM-DD HH:mm:ss'),
|
|
66
|
+
});
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
const values = await formRef?.current?.formApi?.getValues();
|
|
70
|
+
submitSuccess.current = true;
|
|
71
|
+
const formItemShow = Object.keys(values);
|
|
72
|
+
const formItemFilled = formItemShow.filter(key => values[key]);
|
|
73
|
+
const successTime = Date.now();
|
|
74
|
+
sendEvent?.(EventNames.LOOP_FORM_SUBMIT_SUCCESS, {
|
|
75
|
+
form_id: formID,
|
|
76
|
+
session_id: sessionID,
|
|
77
|
+
// 完成耗时
|
|
78
|
+
form_complete_consume_time: Date.now() - startTimeRef.current,
|
|
79
|
+
// 接口报错次数,需要计算
|
|
80
|
+
form_interface_error: interfaceErrorCount.current,
|
|
81
|
+
// 一次点击成功次数 pv
|
|
82
|
+
form_once_success_submit: interfaceErrorCount.current === 0 && firstValidateSuccess.current,
|
|
83
|
+
// 表单填写项
|
|
84
|
+
form_item_filled: JSON.stringify(formItemFilled),
|
|
85
|
+
// 表单展现项
|
|
86
|
+
form_item_show: JSON.stringify(formItemShow),
|
|
87
|
+
// 表单项使用率
|
|
88
|
+
form_item_used_percent: formItemFilled.length / formItemShow.length,
|
|
89
|
+
form_values: safeStringify(values),
|
|
90
|
+
time: successTime,
|
|
91
|
+
time_str: dayjs(successTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
92
|
+
});
|
|
93
|
+
}, [formID, sessionID]);
|
|
94
|
+
// 劫持 validate,确保任何方式获取到的 formApi 都会命中被包装的 validate
|
|
95
|
+
const hijackValidate = useCallback((instance) => {
|
|
96
|
+
if (!instance) {
|
|
97
|
+
return instance;
|
|
98
|
+
}
|
|
99
|
+
const FLAG = '__validateHijacked__';
|
|
100
|
+
if (instance[FLAG]) {
|
|
101
|
+
return instance;
|
|
102
|
+
}
|
|
103
|
+
const originalValidate = typeof instance.validate === 'function'
|
|
104
|
+
? instance.validate.bind(instance)
|
|
105
|
+
: null;
|
|
106
|
+
if (originalValidate) {
|
|
107
|
+
instance.validate = (...args) => {
|
|
108
|
+
try {
|
|
109
|
+
const maybePromise = originalValidate(...args);
|
|
110
|
+
return Promise.resolve(maybePromise).catch(err => {
|
|
111
|
+
// 校验失败:直接上报校验错误,不触发 submitLog
|
|
112
|
+
validateErrorLog(err);
|
|
113
|
+
throw err;
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
catch (err) {
|
|
117
|
+
validateErrorLog(err);
|
|
118
|
+
throw err;
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
instance[FLAG] = true;
|
|
122
|
+
}
|
|
123
|
+
if (!instance?.submitLog) {
|
|
124
|
+
instance.submitLog = submitLog;
|
|
125
|
+
}
|
|
126
|
+
return instance;
|
|
127
|
+
}, [submitLog]);
|
|
128
|
+
const operationTimelineRef = useRef({});
|
|
129
|
+
// 关闭标签页/浏览器上报所需:保证拿到最新的 formID/sessionID 与避免重复上报
|
|
130
|
+
const formIdRef = useRef(formID);
|
|
131
|
+
const sessionIdRef = useRef(sessionID);
|
|
132
|
+
const flushedRef = useRef(false);
|
|
133
|
+
const latestValuesRef = useRef('');
|
|
134
|
+
useEffect(() => {
|
|
135
|
+
formIdRef.current = formID;
|
|
136
|
+
}, [formID]);
|
|
137
|
+
useEffect(() => {
|
|
138
|
+
sessionIdRef.current = sessionID;
|
|
139
|
+
}, [sessionID]);
|
|
140
|
+
// 空闲状态相关
|
|
141
|
+
const [isIdle, setIsIdle] = useState(false);
|
|
142
|
+
const [idleStartTime, setIdleStartTime] = useState(null);
|
|
143
|
+
const IDLE_THRESHOLD = 5000; // 空闲阈值,单位毫秒(5秒)
|
|
144
|
+
const IDLE_CHECK_INTERVAL = 1000; // 空闲检查间隔,单位毫秒(1秒)
|
|
145
|
+
// 记录最后一次用户活跃时间
|
|
146
|
+
const [lastActiveTime, setLastActiveTime] = useState(Date.now());
|
|
147
|
+
const handleValueChange = changedValues => {
|
|
148
|
+
noOperation.current = false;
|
|
149
|
+
for (const key in changedValues) {
|
|
150
|
+
if (Object.prototype.hasOwnProperty.call(changedValues, key)) {
|
|
151
|
+
const currentTime = Date.now();
|
|
152
|
+
setLastActiveTime(currentTime); // 更新最后活跃时间
|
|
153
|
+
if (!operationTimelineRef.current[key]) {
|
|
154
|
+
// 首次操作该字段,初始化操作记录
|
|
155
|
+
operationTimelineRef.current = {
|
|
156
|
+
...operationTimelineRef.current,
|
|
157
|
+
[key]: [
|
|
158
|
+
{
|
|
159
|
+
startTime: currentTime,
|
|
160
|
+
startTimeStr: dayjs(currentTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
161
|
+
endTime: currentTime,
|
|
162
|
+
endTimeStr: dayjs(currentTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
163
|
+
duration: 0,
|
|
164
|
+
idleTime: 0, // 初始无效空闲时间为0
|
|
165
|
+
},
|
|
166
|
+
],
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
const lastOperation = operationTimelineRef.current[key][operationTimelineRef.current[key].length - 1];
|
|
171
|
+
const totalDurationSinceLast = currentTime - lastOperation.startTime; // 本次操作从上次开始到现在的总时长
|
|
172
|
+
let idleTimeDeducted = 0;
|
|
173
|
+
if (isIdle && idleStartTime !== null) {
|
|
174
|
+
// 如果之前处于空闲状态,扣除这段空闲时间
|
|
175
|
+
idleTimeDeducted = currentTime - idleStartTime;
|
|
176
|
+
setIsIdle(false); // 重置空闲状态
|
|
177
|
+
}
|
|
178
|
+
const effectiveDuration = totalDurationSinceLast - idleTimeDeducted;
|
|
179
|
+
const newOperation = {
|
|
180
|
+
startTime: currentTime,
|
|
181
|
+
startTimeStr: dayjs(currentTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
182
|
+
endTime: currentTime,
|
|
183
|
+
endTimeStr: dayjs(currentTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
184
|
+
duration: effectiveDuration,
|
|
185
|
+
idleTime: idleTimeDeducted,
|
|
186
|
+
};
|
|
187
|
+
// 更新操作时间轴,添加新的操作记录
|
|
188
|
+
operationTimelineRef.current = {
|
|
189
|
+
...operationTimelineRef.current,
|
|
190
|
+
[key]: [...operationTimelineRef.current[key], newOperation],
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
const onFormClose = () => {
|
|
197
|
+
const closeTime = Date.now();
|
|
198
|
+
sendEvent?.(EventNames.LOOP_FORM_CLOSE, {
|
|
199
|
+
form_id: formIdRef.current,
|
|
200
|
+
session_id: sessionIdRef.current,
|
|
201
|
+
// 无表单操作 pv
|
|
202
|
+
form_no_operation: noOperation.current,
|
|
203
|
+
// 有表单操作,无表单提交操作次数 pv
|
|
204
|
+
form_operation_no_submit: !noOperation.current && noSubmit.current,
|
|
205
|
+
// 表单是否提交成功
|
|
206
|
+
form_operation_submit_success: submitSuccess.current,
|
|
207
|
+
// 接口报错次数, 需要计算
|
|
208
|
+
form_request_error_times: interfaceErrorCount.current,
|
|
209
|
+
// 表单项报错次数
|
|
210
|
+
form_item_error_times: validateErrorCount.current,
|
|
211
|
+
form_values: latestValuesRef.current,
|
|
212
|
+
time: closeTime,
|
|
213
|
+
time_str: dayjs(closeTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
214
|
+
});
|
|
215
|
+
};
|
|
216
|
+
const onValuesChange = (values, changedValues) => {
|
|
217
|
+
try {
|
|
218
|
+
latestValuesRef.current = safeStringify(values);
|
|
219
|
+
}
|
|
220
|
+
catch (err) {
|
|
221
|
+
console.error(err);
|
|
222
|
+
}
|
|
223
|
+
handleValueChange(changedValues);
|
|
224
|
+
onValueChange?.(values, changedValues);
|
|
225
|
+
};
|
|
226
|
+
useEffect(() => {
|
|
227
|
+
if (sessionID && formID) {
|
|
228
|
+
startTimeRef.current = Date.now();
|
|
229
|
+
}
|
|
230
|
+
}, [formID, sessionID]);
|
|
231
|
+
// 定时检测用户是否进入空闲状态
|
|
232
|
+
useEffect(() => {
|
|
233
|
+
const idleChecker = setInterval(() => {
|
|
234
|
+
if (!isIdle && Date.now() - lastActiveTime > IDLE_THRESHOLD) {
|
|
235
|
+
setIsIdle(true);
|
|
236
|
+
setIdleStartTime(Date.now());
|
|
237
|
+
}
|
|
238
|
+
}, IDLE_CHECK_INTERVAL); // 每秒检查一次
|
|
239
|
+
return () => clearInterval(idleChecker);
|
|
240
|
+
}, [isIdle, lastActiveTime]);
|
|
241
|
+
// 初始化: 进入表单时间
|
|
242
|
+
useEffect(() => {
|
|
243
|
+
if (sessionID && formID) {
|
|
244
|
+
const initTime = Date.now();
|
|
245
|
+
sendEvent?.(EventNames.INIT_LOOP_FORM, {
|
|
246
|
+
form_id: formID,
|
|
247
|
+
session_id: sessionID,
|
|
248
|
+
time: initTime,
|
|
249
|
+
time_str: dayjs(initTime).format('YYYY-MM-DD HH:mm:ss'),
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
return () => {
|
|
253
|
+
if (formID && sessionID && !flushedRef.current) {
|
|
254
|
+
flushedRef.current = true;
|
|
255
|
+
try {
|
|
256
|
+
sendEvent?.(EventNames.LOOP_FORM_FIELD_CHANGE_TIMELINE, {
|
|
257
|
+
form_id: formID,
|
|
258
|
+
session_id: sessionID,
|
|
259
|
+
time_line: JSON.stringify(operationTimelineRef.current),
|
|
260
|
+
});
|
|
261
|
+
}
|
|
262
|
+
catch (err) {
|
|
263
|
+
console.error(err);
|
|
264
|
+
}
|
|
265
|
+
finally {
|
|
266
|
+
onFormClose();
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
};
|
|
270
|
+
}, [formID, sessionID]);
|
|
271
|
+
// 关注页面关闭(tab 关闭/浏览器退出/导航离开等),不处理页面隐藏
|
|
272
|
+
useEffect(() => {
|
|
273
|
+
const flushOnClose = () => {
|
|
274
|
+
if (flushedRef.current) {
|
|
275
|
+
return;
|
|
276
|
+
}
|
|
277
|
+
const fid = formIdRef.current;
|
|
278
|
+
const sid = sessionIdRef.current;
|
|
279
|
+
if (!fid || !sid) {
|
|
280
|
+
return;
|
|
281
|
+
}
|
|
282
|
+
flushedRef.current = true;
|
|
283
|
+
try {
|
|
284
|
+
sendEvent?.(EventNames.LOOP_FORM_FIELD_CHANGE_TIMELINE, {
|
|
285
|
+
form_id: fid,
|
|
286
|
+
session_id: sid,
|
|
287
|
+
time_line: JSON.stringify(operationTimelineRef.current),
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
catch (err) {
|
|
291
|
+
console.error(err);
|
|
292
|
+
}
|
|
293
|
+
finally {
|
|
294
|
+
onFormClose();
|
|
295
|
+
}
|
|
296
|
+
};
|
|
297
|
+
// 仅监听会导致页面真正卸载的事件
|
|
298
|
+
window.addEventListener('pagehide', flushOnClose);
|
|
299
|
+
window.addEventListener('beforeunload', flushOnClose);
|
|
300
|
+
return () => {
|
|
301
|
+
window.removeEventListener('pagehide', flushOnClose);
|
|
302
|
+
window.removeEventListener('beforeunload', flushOnClose);
|
|
303
|
+
};
|
|
304
|
+
}, []);
|
|
305
|
+
useImperativeHandle(ref, () => {
|
|
306
|
+
const newFormApi = hijackValidate(formRef?.current?.formApi);
|
|
307
|
+
const result = {
|
|
308
|
+
...(formRef?.current || {}),
|
|
309
|
+
formApi: newFormApi,
|
|
310
|
+
submitLog,
|
|
311
|
+
};
|
|
312
|
+
return result;
|
|
313
|
+
});
|
|
314
|
+
return (_jsx(Form, { ref: formRef, onValueChange: onValuesChange, getFormApi: instance => {
|
|
315
|
+
const hijacked = hijackValidate(instance);
|
|
316
|
+
instanceRef.current = hijacked;
|
|
317
|
+
getFormApi?.(hijacked);
|
|
318
|
+
}, onSubmit: values => {
|
|
319
|
+
onSubmit?.(values);
|
|
320
|
+
}, onSubmitFail: validateErrorLog, ...props, children: children }));
|
|
321
|
+
};
|
|
322
|
+
export const SentinelForm = forwardRef(SentinelFormInner);
|
|
323
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sentinel-form/index.tsx"],"names":[],"mappings":";AAAA,wDAAwD;AACxD,2CAA2C;AAC3C,qDAAqD;AACrD,0EAA0E;AAC1E,mFAAmF;AACnF,OAAO,EACL,UAAU,EACV,cAAc,EACd,WAAW,EACX,mBAAmB,EACnB,OAAO,EACP,MAAM,EACN,QAAQ,EACR,SAAS,GACV,MAAM,OAAO,CAAC;AAGf,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAsB,IAAI,EAAgB,MAAM,wBAAwB,CAAC;AAEhF,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEpC,SAAS,aAAa,CAAC,GAAY;IACjC,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;QACtC,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,gBAAgB,CAAC;QAC1B,CAAC;QACD,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE,CAAC;YAChC,OAAO,YAAY,CAAC;QACtB,CAAC;QACD,IAAI,KAAK,YAAY,WAAW,EAAE,CAAC;YACjC,OAAO,eAAe,CAAC;QACzB,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC;AAsBD,MAAM,iBAAiB,GAAG,CACxB,EACE,MAAM,EACN,QAAQ,EACR,aAAa,EACb,QAAQ,EACR,UAAU,EACV,GAAG,KAAK,EACa,EACvB,GAA4B,EAC5B,EAAE;IACF,MAAM,SAAS,GAAG,cAAc,EAAE,CAAC;IACnC,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAC9C,MAAM,OAAO,GAAG,MAAM,CAAM,IAAI,CAAC,CAAC;IAClC,MAAM,WAAW,GAAG,MAAM,CAAM,IAAI,CAAC,CAAC;IACtC,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IAC/B,MAAM,mBAAmB,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IACtC,MAAM,kBAAkB,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IACrC,MAAM,oBAAoB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1C,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;IACjC,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;IAC9B,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEpC,MAAM,gBAAgB,GAAG,QAAQ,CAAC,CAAC,KAAU,EAAE,EAAE;QAC/C,oBAAoB,CAAC,OAAO,GAAG,KAAK,CAAC;QACrC,kBAAkB,CAAC,OAAO,GAAG,kBAAkB,CAAC,OAAO,GAAG,CAAC,CAAC;QAE5D,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACrC,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QAC3C,SAAS,CAAC,UAAU,CAAC,8BAA8B,EAAE;YACnD,OAAO,EAAE,MAAM;YACf,UAAU,EAAE,SAAS;YACrB,qBAAqB,EAAE,SAAS,CAAC,MAAM;YACvC,sBAAsB,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC;YACnD,IAAI,EAAE,iBAAiB;YACvB,QAAQ,EAAE,KAAK,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;SACjE,CAAC,CAAC;IACL,CAAC,EAAE,GAAG,CAAC,CAAC;IAER,8BAA8B;IAC9B,MAAM,SAAS,GAAG,WAAW,CAC3B,KAAK,EAAE,gBAA0B,EAAE,KAAW,EAAE,EAAE;QAChD,QAAQ,CAAC,OAAO,GAAG,KAAK,CAAC;QACzB,IAAI,gBAAgB,EAAE,CAAC;YACrB,oBAAoB,CAAC,OAAO,GAAG,KAAK,CAAC;YACrC,mBAAmB,CAAC,OAAO,GAAG,mBAAmB,CAAC,OAAO,GAAG,CAAC,CAAC;YAC9D,SAAS,EAAE,CAAC,UAAU,CAAC,gCAAgC,EAAE;gBACvD,OAAO,EAAE,MAAM;gBACf,UAAU,EAAE,SAAS;gBACrB,2BAA2B,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC;gBACxD,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE;gBAChB,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;aAC1D,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;QAC5D,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC;QAC7B,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzC,MAAM,cAAc,GAAG,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAC/D,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,SAAS,EAAE,CAAC,UAAU,CAAC,wBAAwB,EAAE;YAC/C,OAAO,EAAE,MAAM;YACf,UAAU,EAAE,SAAS;YACrB,OAAO;YACP,0BAA0B,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,YAAY,CAAC,OAAO;YAC7D,cAAc;YACd,oBAAoB,EAAE,mBAAmB,CAAC,OAAO;YACjD,cAAc;YACd,wBAAwB,EACtB,mBAAmB,CAAC,OAAO,KAAK,CAAC,IAAI,oBAAoB,CAAC,OAAO;YACnE,QAAQ;YACR,gBAAgB,EAAE,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC;YAChD,QAAQ;YACR,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC5C,SAAS;YACT,sBAAsB,EAAE,cAAc,CAAC,MAAM,GAAG,YAAY,CAAC,MAAM;YACnE,WAAW,EAAE,aAAa,CAAC,MAAM,CAAC;YAClC,IAAI,EAAE,WAAW;YACjB,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;SAC3D,CAAC,CAAC;IACL,CAAC,EACD,CAAC,MAAM,EAAE,SAAS,CAAC,CACpB,CAAC;IAEF,mDAAmD;IACnD,MAAM,cAAc,GAAG,WAAW,CAChC,CAAC,QAAa,EAAE,EAAE;QAChB,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,MAAM,IAAI,GAAG,sBAAsB,CAAC;QACpC,IAAI,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YACnB,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,MAAM,gBAAgB,GACpB,OAAO,QAAQ,CAAC,QAAQ,KAAK,UAAU;YACrC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC;YAClC,CAAC,CAAC,IAAI,CAAC;QACX,IAAI,gBAAgB,EAAE,CAAC;YACrB,QAAQ,CAAC,QAAQ,GAAG,CAAC,GAAG,IAAW,EAAE,EAAE;gBACrC,IAAI,CAAC;oBACH,MAAM,YAAY,GAAG,gBAAgB,CAAC,GAAG,IAAI,CAAC,CAAC;oBAC/C,OAAO,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;wBAC/C,8BAA8B;wBAC9B,gBAAgB,CAAC,GAAG,CAAC,CAAC;wBACtB,MAAM,GAAG,CAAC;oBACZ,CAAC,CAAC,CAAC;gBACL,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,gBAAgB,CAAC,GAAG,CAAC,CAAC;oBACtB,MAAM,GAAG,CAAC;gBACZ,CAAC;YACH,CAAC,CAAC;YACF,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;QACxB,CAAC;QACD,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC;YACzB,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC;QACjC,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC,EACD,CAAC,SAAS,CAAC,CACZ,CAAC;IAEF,MAAM,oBAAoB,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;IACxC,iDAAiD;IACjD,MAAM,SAAS,GAAG,MAAM,CAAS,MAAM,CAAC,CAAC;IACzC,MAAM,YAAY,GAAG,MAAM,CAAS,SAAS,CAAC,CAAC;IAC/C,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACjC,MAAM,eAAe,GAAG,MAAM,CAAS,EAAE,CAAC,CAAC;IAE3C,SAAS,CAAC,GAAG,EAAE;QACb,SAAS,CAAC,OAAO,GAAG,MAAM,CAAC;IAC7B,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,SAAS,CAAC,GAAG,EAAE;QACb,YAAY,CAAC,OAAO,GAAG,SAAS,CAAC;IACnC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,SAAS;IACT,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC5C,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAC;IACxE,MAAM,cAAc,GAAG,IAAI,CAAC,CAAC,gBAAgB;IAC7C,MAAM,mBAAmB,GAAG,IAAI,CAAC,CAAC,kBAAkB;IACpD,eAAe;IACf,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;IAEjE,MAAM,iBAAiB,GAAG,aAAa,CAAC,EAAE;QACxC,WAAW,CAAC,OAAO,GAAG,KAAK,CAAC;QAC5B,KAAK,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;YAChC,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC,EAAE,CAAC;gBAC7D,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBAC/B,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW;gBAE3C,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;oBACvC,kBAAkB;oBAClB,oBAAoB,CAAC,OAAO,GAAG;wBAC7B,GAAG,oBAAoB,CAAC,OAAO;wBAC/B,CAAC,GAAG,CAAC,EAAE;4BACL;gCACE,SAAS,EAAE,WAAW;gCACtB,YAAY,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;gCAC9D,OAAO,EAAE,WAAW;gCACpB,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;gCAC5D,QAAQ,EAAE,CAAC;gCACX,QAAQ,EAAE,CAAC,EAAE,aAAa;6BAC3B;yBACF;qBACF,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACN,MAAM,aAAa,GACjB,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,CAC/B,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAC7C,CAAC;oBACJ,MAAM,sBAAsB,GAAG,WAAW,GAAG,aAAa,CAAC,SAAS,CAAC,CAAC,mBAAmB;oBACzF,IAAI,gBAAgB,GAAG,CAAC,CAAC;oBAEzB,IAAI,MAAM,IAAI,aAAa,KAAK,IAAI,EAAE,CAAC;wBACrC,sBAAsB;wBACtB,gBAAgB,GAAG,WAAW,GAAG,aAAa,CAAC;wBAC/C,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;oBAC7B,CAAC;oBAED,MAAM,iBAAiB,GAAG,sBAAsB,GAAG,gBAAgB,CAAC;oBACpE,MAAM,YAAY,GAAG;wBACnB,SAAS,EAAE,WAAW;wBACtB,YAAY,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;wBAC9D,OAAO,EAAE,WAAW;wBACpB,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;wBAC5D,QAAQ,EAAE,iBAAiB;wBAC3B,QAAQ,EAAE,gBAAgB;qBAC3B,CAAC;oBAEF,mBAAmB;oBACnB,oBAAoB,CAAC,OAAO,GAAG;wBAC7B,GAAG,oBAAoB,CAAC,OAAO;wBAC/B,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,YAAY,CAAC;qBAC5D,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC7B,SAAS,EAAE,CAAC,UAAU,CAAC,eAAe,EAAE;YACtC,OAAO,EAAE,SAAS,CAAC,OAAO;YAC1B,UAAU,EAAE,YAAY,CAAC,OAAO;YAChC,WAAW;YACX,iBAAiB,EAAE,WAAW,CAAC,OAAO;YACtC,qBAAqB;YACrB,wBAAwB,EAAE,CAAC,WAAW,CAAC,OAAO,IAAI,QAAQ,CAAC,OAAO;YAClE,WAAW;YACX,6BAA6B,EAAE,aAAa,CAAC,OAAO;YACpD,gBAAgB;YAChB,wBAAwB,EAAE,mBAAmB,CAAC,OAAO;YACrD,UAAU;YACV,qBAAqB,EAAE,kBAAkB,CAAC,OAAO;YACjD,WAAW,EAAE,eAAe,CAAC,OAAO;YACpC,IAAI,EAAE,SAAS;YACf,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;SACzD,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,CAAC,MAAW,EAAE,aAAkB,EAAE,EAAE;QACzD,IAAI,CAAC;YACH,eAAe,CAAC,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;QAClD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACrB,CAAC;QACD,iBAAiB,CAAC,aAAa,CAAC,CAAC;QACjC,aAAa,EAAE,CAAC,MAAW,EAAE,aAA2B,CAAC,CAAC;IAC5D,CAAC,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,IAAI,MAAM,EAAE,CAAC;YACxB,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACpC,CAAC;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAExB,iBAAiB;IACjB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;YACnC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,cAAc,GAAG,cAAc,EAAE,CAAC;gBAC5D,SAAS,CAAC,IAAI,CAAC,CAAC;gBAChB,gBAAgB,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YAC/B,CAAC;QACH,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,SAAS;QAElC,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;IAC1C,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC;IAE7B,cAAc;IACd,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,IAAI,MAAM,EAAE,CAAC;YACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAC5B,SAAS,EAAE,CAAC,UAAU,CAAC,cAAc,EAAE;gBACrC,OAAO,EAAE,MAAM;gBACf,UAAU,EAAE,SAAS;gBACrB,IAAI,EAAE,QAAQ;gBACd,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC;aACxD,CAAC,CAAC;QACL,CAAC;QAED,OAAO,GAAG,EAAE;YACV,IAAI,MAAM,IAAI,SAAS,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;gBAC/C,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC;gBAC1B,IAAI,CAAC;oBACH,SAAS,EAAE,CAAC,UAAU,CAAC,+BAA+B,EAAE;wBACtD,OAAO,EAAE,MAAM;wBACf,UAAU,EAAE,SAAS;wBACrB,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,OAAO,CAAC;qBACxD,CAAC,CAAC;gBACL,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACrB,CAAC;wBAAS,CAAC;oBACT,WAAW,EAAE,CAAC;gBAChB,CAAC;YACH,CAAC;QACH,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAExB,qCAAqC;IACrC,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,YAAY,GAAG,GAAG,EAAE;YACxB,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;gBACvB,OAAO;YACT,CAAC;YACD,MAAM,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC;YAC9B,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,CAAC;YACjC,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACjB,OAAO;YACT,CAAC;YACD,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC;YAE1B,IAAI,CAAC;gBACH,SAAS,EAAE,CAAC,UAAU,CAAC,+BAA+B,EAAE;oBACtD,OAAO,EAAE,GAAG;oBACZ,UAAU,EAAE,GAAG;oBACf,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,OAAO,CAAC;iBACxD,CAAC,CAAC;YACL,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACrB,CAAC;oBAAS,CAAC;gBACT,WAAW,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC;QAEF,kBAAkB;QAClB,MAAM,CAAC,gBAAgB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QAClD,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE,YAAY,CAAC,CAAC;QAEtD,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,mBAAmB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;YACrD,MAAM,CAAC,mBAAmB,CAAC,cAAc,EAAE,YAAY,CAAC,CAAC;QAC3D,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,mBAAmB,CAAC,GAAG,EAAE,GAAG,EAAE;QAC5B,MAAM,UAAU,GAAQ,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAClE,MAAM,MAAM,GAAuB;YACjC,GAAG,CAAC,OAAO,EAAE,OAAO,IAAI,EAAE,CAAC;YAC3B,OAAO,EAAE,UAAU;YACnB,SAAS;SACV,CAAC;QACF,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,OAAO,CACL,KAAC,IAAI,IACH,GAAG,EAAE,OAAO,EACZ,aAAa,EAAE,cAAc,EAC7B,UAAU,EAAE,QAAQ,CAAC,EAAE;YACrB,MAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC;YAC1C,WAAW,CAAC,OAAO,GAAG,QAAQ,CAAC;YAC/B,UAAU,EAAE,CAAC,QAAQ,CAAC,CAAC;QACzB,CAAC,EACD,QAAQ,EAAE,MAAM,CAAC,EAAE;YACjB,QAAQ,EAAE,CAAC,MAAW,CAAC,CAAC;QAC1B,CAAC,EACD,YAAY,EAAE,gBAAgB,KACzB,KAA4B,YAEhC,QAAQ,GACJ,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,UAAU,CAAC,iBAAiB,CAIxC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import { IconCozCheckMarkFill } from '@coze-arch/coze-design/icons';
|
|
4
|
+
import { Typography } from '@coze-arch/coze-design';
|
|
5
|
+
import styles from './index.module.less';
|
|
6
|
+
export function StepNav({ currentStep, stepItems, onStepChange, clickToChange, }) {
|
|
7
|
+
const activeStepIndex = stepItems.findIndex(item => item.key === currentStep);
|
|
8
|
+
return (_jsx("div", { className: styles['step-nav'], children: stepItems.map((item, index) => (_jsx(Typography.Text, { className: classNames(styles['tab-step'], {
|
|
9
|
+
[styles['tab-active']]: currentStep === item.key || index <= activeStepIndex,
|
|
10
|
+
'cursor-pointer': clickToChange,
|
|
11
|
+
}), icon: index < activeStepIndex ? (_jsx("span", { className: styles['tab-icon'], children: _jsx(IconCozCheckMarkFill, {}) })) : (_jsx("span", { className: styles['tab-icon'], children: item?.icon ?? index + 1 })), onClick: () => clickToChange && onStepChange?.(item.key), children: item.label }, item.key))) }));
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=index.js.map
|