@kp-ui/lowcode 1.0.90 → 1.0.91
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/index.js.map +1 -1
- package/package.json +4 -3
- package/src/components/CustomRender/components/AttachmentRender.vue.js +1 -1
- package/src/components/CustomRender/components/AttachmentRender.vue2.js.map +1 -1
- package/src/components/code-editor/index.vue.js +1 -1
- package/src/components/code-editor/index.vue2.js +0 -3
- package/src/components/code-editor/index.vue2.js.map +1 -1
- package/src/components/form-designer/form-widget/container-widget/data-table-widget.vue.js +3 -3
- package/src/components/form-designer/form-widget/container-widget/data-table-widget.vue.js.map +1 -1
- package/src/components/form-designer/form-widget/container-widget/data-table-widget.vue2.js +3 -0
- package/src/components/form-designer/form-widget/container-widget/data-table-widget.vue2.js.map +1 -1
- package/src/components/form-designer/form-widget/container-widget/vf-box-widget.vue.js +2 -2
- package/src/components/form-designer/form-widget/container-widget/vf-box-widget.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/form-crud-setting.vue.js +3 -3
- package/src/components/form-designer/setting-panel/form-crud-setting.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/form-setting.vue.js +1 -1
- package/src/components/form-designer/setting-panel/form-setting.vue2.js +2 -3
- package/src/components/form-designer/setting-panel/form-setting.vue2.js.map +1 -1
- package/src/components/form-designer/setting-panel/index.vue.js +1 -1
- package/src/components/form-designer/setting-panel/index.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/option-items-setting.vue.js +2 -416
- package/src/components/form-designer/setting-panel/option-items-setting.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/option-items-setting.vue2.js +257 -0
- package/src/components/form-designer/setting-panel/option-items-setting.vue2.js.map +1 -0
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/customRowEvent/data-table-customRow-editor.vue.js +0 -4
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/customRowEvent/data-table-customRow-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-dsEnabled-editor.vue.js +2 -2
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-dsEnabled-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-pagination-editor.vue.js +3 -3
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-pagination-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-selections-editor.vue.js +3 -4
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-selections-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-tableColumns-editor.vue.js +1 -1
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-tableColumns-editor.vue2.js +5 -2
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-tableColumns-editor.vue2.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/formCode-editor.vue.js +1 -9
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/formCode-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/disabled-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/disabled-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onAppendButtonClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onAppendButtonClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onBeforeUpload-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onBeforeUpload-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onBlur-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onBlur-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCancelButtonClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCancelButtonClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCellClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCellClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCellDoubleClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCellDoubleClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onChange-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onChange-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onClickIcon-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onClickIcon-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCreated-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCreated-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCurrentPageChange-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCurrentPageChange-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDialogBeforeClose-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDialogBeforeClose-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDialogOpened-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDialogOpened-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDisableOperationButton-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDisableOperationButton-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDrawerBeforeClose-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDrawerBeforeClose-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDrawerOpened-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDrawerOpened-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onFileRemove.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onFileRemove.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onFocus-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onFocus-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetOperationButtonLabel-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetOperationButtonLabel-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetRowClassName-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetRowClassName-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetSpanMethod-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetSpanMethod-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onHeaderClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onHeaderClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onHideOperationButton-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onHideOperationButton-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onInput-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onInput-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onMenuClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onMenuClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onMounted-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onMounted-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onOkButtonClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onOkButtonClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onOperationButtonClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onOperationButtonClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onPageSizeChange-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onPageSizeChange-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRemoteQuery-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRemoteQuery-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRowClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRowClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRowDoubleClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRowDoubleClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSelectionChange-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSelectionChange-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowAdd-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowAdd-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowChange-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowChange-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowDelete-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowDelete-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowInsert-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowInsert-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onTabClick-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onTabClick-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onTableChange-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onTableChange-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onUploadError-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onUploadError-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onUploadSuccess-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onUploadSuccess-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onValidate-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onValidate-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onVformAdd-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onVformAdd-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/field-html-text/htmlContent-editor.vue.js +4 -4
- package/src/components/form-designer/setting-panel/property-editor/field-html-text/htmlContent-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/hidden-editor.vue.js +0 -1
- package/src/components/form-designer/setting-panel/property-editor/hidden-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/labelIconClass-editor.vue.js +3 -3
- package/src/components/form-designer/setting-panel/property-editor/labelIconClass-editor.vue.js.map +1 -1
- package/src/components/form-designer/setting-panel/property-editor/optionItems-editor.vue.js +2 -2
- package/src/components/form-designer/setting-panel/property-editor/optionItems-editor.vue.js.map +1 -1
- package/src/components/form-designer/toolbar-panel/index.vue.js +1 -1
- package/src/components/form-designer/toolbar-panel/index.vue2.js +11 -30
- package/src/components/form-designer/toolbar-panel/index.vue2.js.map +1 -1
- package/src/components/form-designer/widget-panel/index.vue.js +1 -1
- package/src/components/form-designer/widget-panel/index.vue.js.map +1 -1
- package/src/components/form-render/container-item/container-item-wrapper.vue.js.map +1 -1
- package/src/components/form-render/container-item/data-table-item.vue.js +8 -3
- package/src/components/form-render/container-item/data-table-item.vue.js.map +1 -1
- package/src/components/form-render/dynamic-drawer.vue.js +7 -5
- package/src/components/form-render/dynamic-drawer.vue.js.map +1 -1
- package/src/components/http-editor/index.vue.js +361 -294
- package/src/components/http-editor/index.vue.js.map +1 -1
- package/src/components/http-editor/index.vue2.js +1 -134
- package/src/components/http-editor/index.vue2.js.map +1 -1
- package/src/components/public/ActionButtonListDialog.vue.js +1 -1
- package/src/components/public/ActionButtonListDialog.vue.js.map +1 -1
- package/src/components/public/ActionButtonListDialog.vue2.js +5 -1
- package/src/components/public/ActionButtonListDialog.vue2.js.map +1 -1
- package/src/components/public/methoad-item.vue.js +0 -1
- package/src/components/public/methoad-item.vue.js.map +1 -1
- package/src/components/svg-icon/index.vue.js +2 -54
- package/src/components/svg-icon/index.vue.js.map +1 -1
- package/src/components/svg-icon/index.vue2.js +49 -0
- package/src/components/svg-icon/index.vue2.js.map +1 -0
- package/src/utils/i18n.js.map +1 -1
- package/styles/style.css +1 -1
- package/types/install.d.ts +14 -3
- package/types/install.d.ts.map +1 -1
- package/types/src/components/CustomRender/components/AttachmentRender.d.ts.map +1 -1
- package/types/src/components/code-editor/index.d.ts.map +1 -1
- package/types/src/components/form-designer/form-widget/container-widget/container-wrapper.d.ts +44 -0
- package/types/src/components/form-designer/form-widget/container-widget/container-wrapper.d.ts.map +1 -0
- package/types/src/components/form-designer/form-widget/field-widget/form-item-wrapper.d.ts +79 -0
- package/types/src/components/form-designer/form-widget/field-widget/form-item-wrapper.d.ts.map +1 -0
- package/types/src/components/form-designer/form-widget/field-widget/static-content-wrapper.d.ts +78 -0
- package/types/src/components/form-designer/form-widget/field-widget/static-content-wrapper.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/index.d.ts +2 -2
- package/types/src/components/form-render/container-item/container-item-wrapper.d.ts +10 -0
- package/types/src/components/form-render/container-item/container-item-wrapper.d.ts.map +1 -0
- package/types/src/components/form-render/index.d.ts +8 -8
- package/types/src/components/svg-icon/index.d.ts +4 -43
- package/types/src/components/svg-icon/index.d.ts.map +1 -1
- package/types/src/components/svg-icon/types.d.ts +19 -0
- package/types/src/components/svg-icon/types.d.ts.map +1 -0
- package/types/src/components.d.ts +11 -0
- package/types/src/env.d.ts +5 -4
- package/types/src/hooks/useLowcode.d.ts +36 -36
- package/types/src/main.d.ts.map +1 -1
- package/types/src/utils/i18n.d.ts +6 -6
- package/types/src/utils/i18n.d.ts.map +1 -1
- package/stats.html +0 -4949
|
@@ -29,7 +29,6 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
29
29
|
}, {
|
|
30
30
|
default: withCtx(() => [
|
|
31
31
|
createVNode(_component_a_button, {
|
|
32
|
-
type: "info",
|
|
33
32
|
plain: "",
|
|
34
33
|
shape: "round",
|
|
35
34
|
class: normalizeClass([$props.eventHandled ? "button-text-highlight" : ""]),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"onUploadError-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onUploadError-editor.vue"],"sourcesContent":["<template>\n
|
|
1
|
+
{"version":3,"file":"onUploadError-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onUploadError-editor.vue"],"sourcesContent":["<template>\n <a-form-item label=\"onUploadError\" label-width=\"150px\">\n <a-button\n plain\n shape=\"round\"\n :class=\"[eventHandled ? 'button-text-highlight' : '']\"\n @click=\"editEventHandler('onUploadError', eventParams)\"\n >\n {{ i18nt('designer.setting.addEventHandler') }}</a-button\n >\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n import eventMixin from '@/components/form-designer/setting-panel/property-editor/event-handler/eventMixin';\n\n export default {\n name: 'onUploadError-editor',\n mixins: [i18n, eventMixin],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object,\n eventHandled: {\n type: Boolean,\n default: false\n }\n },\n data() {\n return {\n eventParams: ['error', 'file', 'fileList']\n };\n }\n };\n</script>\n"],"names":["_createBlock","_createVNode"],"mappings":";;;;AAiBI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,MAAM,UAAU;AAAA,EACzB,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA,IACb,cAAc;AAAA,MACV,MAAM;AAAA,MACN,SAAS;AAAA,IACb;AAAA;EAEJ,OAAO;AACH,WAAO;AAAA,MACH,aAAa,CAAC,SAAS,QAAQ,UAAU;AAAA;EAEjD;;;;;sBAhCJA,YASc,wBAAA;AAAA,IATD,OAAM;AAAA,IAAgB,eAAY;AAAA;qBAC3C,MAOC;AAAA,MAPDC,YAOC,qBAAA;AAAA,QANG,OAAA;AAAA,QACA,OAAM;AAAA,QACL,uBAAQ,OAAA,eAAY,0BAAA,EAAA,CAAA;AAAA,QACpB,SAAK,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAE,KAAA,iBAAgB,iBAAkB,MAAA,WAAW;AAAA;yBAErD,MAA+C;AAAA,0CAA5C,KAAA,MAAK,kCAAA,CAAA,GAAA,CAAA;AAAA;;;;;;;;"}
|
|
@@ -29,7 +29,6 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
29
29
|
}, {
|
|
30
30
|
default: withCtx(() => [
|
|
31
31
|
createVNode(_component_a_button, {
|
|
32
|
-
type: "info",
|
|
33
32
|
plain: "",
|
|
34
33
|
shape: "round",
|
|
35
34
|
class: normalizeClass([$props.eventHandled ? "button-text-highlight" : ""]),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"onUploadSuccess-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onUploadSuccess-editor.vue"],"sourcesContent":["<template>\n
|
|
1
|
+
{"version":3,"file":"onUploadSuccess-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onUploadSuccess-editor.vue"],"sourcesContent":["<template>\n <a-form-item label=\"onUploadSuccess\" label-width=\"150px\">\n <a-button\n plain\n shape=\"round\"\n :class=\"[eventHandled ? 'button-text-highlight' : '']\"\n @click=\"editEventHandler('onUploadSuccess', eventParams)\"\n >\n {{ i18nt('designer.setting.addEventHandler') }}</a-button\n >\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n import eventMixin from '@/components/form-designer/setting-panel/property-editor/event-handler/eventMixin';\n\n export default {\n name: 'onUploadSuccess-editor',\n mixins: [i18n, eventMixin],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object,\n eventHandled: {\n type: Boolean,\n default: false\n }\n },\n data() {\n return {\n eventParams: ['result', 'file', 'fileList']\n };\n }\n };\n</script>\n"],"names":["_createBlock","_createVNode"],"mappings":";;;;AAiBI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,MAAM,UAAU;AAAA,EACzB,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA,IACb,cAAc;AAAA,MACV,MAAM;AAAA,MACN,SAAS;AAAA,IACb;AAAA;EAEJ,OAAO;AACH,WAAO;AAAA,MACH,aAAa,CAAC,UAAU,QAAQ,UAAU;AAAA;EAElD;;;;;sBAhCJA,YASc,wBAAA;AAAA,IATD,OAAM;AAAA,IAAkB,eAAY;AAAA;qBAC7C,MAOC;AAAA,MAPDC,YAOC,qBAAA;AAAA,QANG,OAAA;AAAA,QACA,OAAM;AAAA,QACL,uBAAQ,OAAA,eAAY,0BAAA,EAAA,CAAA;AAAA,QACpB,SAAK,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAE,KAAA,iBAAgB,mBAAoB,MAAA,WAAW;AAAA;yBAEvD,MAA+C;AAAA,0CAA5C,KAAA,MAAK,kCAAA,CAAA,GAAA,CAAA;AAAA;;;;;;;;"}
|
|
@@ -30,7 +30,6 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
30
30
|
}, {
|
|
31
31
|
default: withCtx(() => [
|
|
32
32
|
createVNode(_component_a_button, {
|
|
33
|
-
type: "info",
|
|
34
33
|
plain: "",
|
|
35
34
|
shape: "round",
|
|
36
35
|
class: normalizeClass([$props.eventHandled ? "button-text-highlight" : ""]),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"onValidate-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onValidate-editor.vue"],"sourcesContent":["<template>\n
|
|
1
|
+
{"version":3,"file":"onValidate-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onValidate-editor.vue"],"sourcesContent":["<template>\n <a-form-item label=\"onValidate\" labelAlign=\"left\" label-width=\"150px\">\n <a-button\n plain\n shape=\"round\"\n :class=\"[eventHandled ? 'button-text-highlight' : '']\"\n @click=\"editEventHandler('onValidate', eventParams)\"\n >\n {{ i18nt('designer.setting.addEventHandler') }}\n </a-button>\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n import eventMixin from '@/components/form-designer/setting-panel/property-editor/event-handler/eventMixin';\n\n export default {\n name: 'onValidate-editor',\n mixins: [i18n, eventMixin],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object,\n eventHandled: {\n type: Boolean,\n default: false\n }\n },\n data() {\n return {\n eventParams: ['rule', 'value']\n };\n }\n };\n</script>\n"],"names":["_createBlock","_createVNode"],"mappings":";;;;AAiBI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,MAAM,UAAU;AAAA,EACzB,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA,IACb,cAAc;AAAA,MACV,MAAM;AAAA,MACN,SAAS;AAAA,IACb;AAAA;EAEJ,OAAO;AACH,WAAO;AAAA,MACH,aAAa,CAAC,QAAQ,OAAO;AAAA;EAErC;;;;;sBAhCJA,YASc,wBAAA;AAAA,IATD,OAAM;AAAA,IAAa,YAAW;AAAA,IAAO,eAAY;AAAA;qBAC1D,MAOW;AAAA,MAPXC,YAOW,qBAAA;AAAA,QANP,OAAA;AAAA,QACA,OAAM;AAAA,QACL,uBAAQ,OAAA,eAAY,0BAAA,EAAA,CAAA;AAAA,QACpB,SAAK,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAE,KAAA,iBAAgB,cAAe,MAAA,WAAW;AAAA;yBAElD,MAA+C;AAAA,0CAA5C,KAAA,MAAK,kCAAA,CAAA,GAAA,CAAA;AAAA;;;;;;;;"}
|
|
@@ -30,7 +30,6 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
30
30
|
}, {
|
|
31
31
|
default: withCtx(() => [
|
|
32
32
|
createVNode(_component_a_button, {
|
|
33
|
-
type: "info",
|
|
34
33
|
plain: "",
|
|
35
34
|
shape: "round",
|
|
36
35
|
class: normalizeClass([$props.eventHandled ? "button-text-highlight" : ""]),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"onVformAdd-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onVformAdd-editor.vue"],"sourcesContent":["<template>\n
|
|
1
|
+
{"version":3,"file":"onVformAdd-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/event-handler/onVformAdd-editor.vue"],"sourcesContent":["<template>\n <a-form-item label=\"onCreated\" labelAlign=\"left\" label-width=\"150px\">\n <a-button\n plain\n shape=\"round\"\n :class=\"[eventHandled ? 'button-text-highlight' : '']\"\n @click=\"editEventHandler('onCreated', eventParams)\"\n >\n {{ i18nt('designer.setting.addEventHandler') }}\n </a-button>\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n import eventMixin from '@/components/form-designer/setting-panel/property-editor/event-handler/eventMixin';\n\n export default {\n name: 'onVformAdd-editor',\n mixins: [i18n, eventMixin],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object,\n eventHandled: {\n type: Boolean,\n default: false\n }\n },\n data() {\n return {\n eventParams: []\n };\n }\n };\n</script>\n"],"names":["_createBlock","_createVNode"],"mappings":";;;;AAiBI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,MAAM,UAAU;AAAA,EACzB,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA,IACb,cAAc;AAAA,MACV,MAAM;AAAA,MACN,SAAS;AAAA,IACb;AAAA;EAEJ,OAAO;AACH,WAAO;AAAA,MACH,aAAa,CAAA;AAAA;EAErB;;;;;sBAhCJA,YASc,wBAAA;AAAA,IATD,OAAM;AAAA,IAAY,YAAW;AAAA,IAAO,eAAY;AAAA;qBACzD,MAOW;AAAA,MAPXC,YAOW,qBAAA;AAAA,QANP,OAAA;AAAA,QACA,OAAM;AAAA,QACL,uBAAQ,OAAA,eAAY,0BAAA,EAAA,CAAA;AAAA,QACpB,SAAK,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAE,KAAA,iBAAgB,aAAc,MAAA,WAAW;AAAA;yBAEjD,MAA+C;AAAA,0CAA5C,KAAA,MAAK,kCAAA,CAAA,GAAA,CAAA;AAAA;;;;;;;;"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import i18n from "../../../../../utils/i18n.js";
|
|
2
|
-
import { resolveComponent, createElementBlock, openBlock, createVNode, withCtx } from "vue";
|
|
2
|
+
import { resolveComponent, createElementBlock, openBlock, Fragment, createVNode, withCtx } from "vue";
|
|
3
3
|
/* empty css */
|
|
4
4
|
import _export_sfc from "../../../../../../_virtual/_plugin-vue_export-helper.js";
|
|
5
5
|
const _sfc_main = {
|
|
@@ -14,7 +14,7 @@ const _sfc_main = {
|
|
|
14
14
|
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
15
15
|
const _component_a_form_item = resolveComponent("a-form-item");
|
|
16
16
|
const _component_a_textarea = resolveComponent("a-textarea");
|
|
17
|
-
return openBlock(), createElementBlock(
|
|
17
|
+
return openBlock(), createElementBlock(Fragment, null, [
|
|
18
18
|
createVNode(_component_a_form_item, {
|
|
19
19
|
label: _ctx.i18nt("designer.setting.htmlContent")
|
|
20
20
|
}, null, 8, ["label"]),
|
|
@@ -29,9 +29,9 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
29
29
|
]),
|
|
30
30
|
_: 1
|
|
31
31
|
})
|
|
32
|
-
]);
|
|
32
|
+
], 64);
|
|
33
33
|
}
|
|
34
|
-
const htmlContentEditor = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-
|
|
34
|
+
const htmlContentEditor = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-be634f5e"]]);
|
|
35
35
|
export {
|
|
36
36
|
htmlContentEditor as default
|
|
37
37
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"htmlContent-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/field-html-text/htmlContent-editor.vue"],"sourcesContent":["<template>\n
|
|
1
|
+
{"version":3,"file":"htmlContent-editor.vue.js","sources":["../../../../../../../src/components/form-designer/setting-panel/property-editor/field-html-text/htmlContent-editor.vue"],"sourcesContent":["<template>\n <a-form-item :label=\"i18nt('designer.setting.htmlContent')\" />\n <a-form-item label-width=\"0\">\n <a-textarea v-model:value=\"optionModel.htmlContent\" :rows=\"5\" class=\"html-content-editor\" />\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n\n export default {\n name: 'htmlContent-editor',\n mixins: [i18n],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object\n }\n };\n</script>\n\n<style scoped>\n .html-content-editor {\n font-size: 13px;\n }\n</style>\n"],"names":["_createVNode"],"mappings":";;;;AAUI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,IAAI;AAAA,EACb,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA,EACjB;;;;;;IAhBJA,YAA8D,wBAAA;AAAA,MAAhD,OAAO,KAAA,MAAK,8BAAA;AAAA;IAC1BA,YAEc,wBAAA,EAFD,eAAY,IAAG,GAAA;AAAA,uBACxB,MAA4F;AAAA,QAA5FA,YAA4F,uBAAA;AAAA,UAAxE,OAAO,OAAA,YAAY;AAAA,UAAZ,kBAAA,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAA,OAAA,YAAY,cAAW;AAAA,UAAG,MAAM;AAAA,UAAG,OAAM;AAAA;;;;;;;"}
|
|
@@ -33,7 +33,6 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
33
33
|
"onUpdate:checked": _cache[0] || (_cache[0] = ($event) => $props.optionModel.hidden = $event)
|
|
34
34
|
}, null, 8, ["checked"]),
|
|
35
35
|
createVNode(_component_a_button, {
|
|
36
|
-
type: "info",
|
|
37
36
|
shape: "round",
|
|
38
37
|
class: normalizeClass([!!$props.optionModel.onHidden ? "button-text-highlight" : ""]),
|
|
39
38
|
onClick: _cache[1] || (_cache[1] = ($event) => _ctx.editEventHandler("onHidden", $data.eventParams))
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hidden-editor.vue.js","sources":["../../../../../../src/components/form-designer/setting-panel/property-editor/hidden-editor.vue"],"sourcesContent":["<template>\n
|
|
1
|
+
{"version":3,"file":"hidden-editor.vue.js","sources":["../../../../../../src/components/form-designer/setting-panel/property-editor/hidden-editor.vue"],"sourcesContent":["<template>\n <a-form-item :label=\"i18nt('designer.setting.hidden')\">\n <a-space>\n <a-switch v-model:checked=\"optionModel.hidden\" />\n <a-button\n shape=\"round\"\n :class=\"[!!optionModel.onHidden ? 'button-text-highlight' : '']\"\n @click=\"editEventHandler('onHidden', eventParams)\"\n >\n 编辑函数\n </a-button>\n </a-space>\n </a-form-item>\n <a-form-item :label=\"`隐藏时是否占位`\" v-if=\"!!optionModel.hidden\">\n <a-space>\n <a-switch v-model:checked=\"optionModel.holdHidden\" />\n </a-space>\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n import eventMixin from '@/components/form-designer/setting-panel/property-editor/event-handler/eventMixin';\n\n export default {\n name: 'hidden-editor',\n mixins: [i18n, eventMixin],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object\n },\n data() {\n return {\n eventParams: ['event']\n };\n }\n };\n</script>\n\n<style scoped></style>\n"],"names":["_createVNode","_normalizeClass","_createBlock"],"mappings":";;;;AAwBI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,MAAM,UAAU;AAAA,EACzB,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA;EAEjB,OAAO;AACH,WAAO;AAAA,MACH,aAAa,CAAC,OAAO;AAAA;EAE7B;;;;;;;;IAnCJA,YAWc,wBAAA;AAAA,MAXA,OAAO,KAAA,MAAK,yBAAA;AAAA;uBACtB,MASU;AAAA,QATVA,YASU,oBAAA,MAAA;AAAA,2BARN,MAAiD;AAAA,YAAjDA,YAAiD,qBAAA;AAAA,cAA/B,SAAS,OAAA,YAAY;AAAA,cAAZ,oBAAA,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAA,OAAA,YAAY,SAAM;AAAA;YAC7CA,YAMW,qBAAA;AAAA,cALP,OAAM;AAAA,cACL,OAAKC,eAAA,CAAA,CAAA,CAAK,OAAA,YAAY,WAAQ,0BAAA,EAAA,CAAA;AAAA,cAC9B,SAAK,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAE,KAAA,iBAAgB,YAAa,MAAA,WAAW;AAAA;+BACnD,MAED,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA;AAAA,gCAFC,QAED;AAAA;;;;;;;;;;IAGgC,CAAA,CAAA,OAAA,YAAY,uBAApDC,YAIc,wBAAA;AAAA;MAJA,OAAO;AAAA;uBACjB,MAEU;AAAA,QAFVF,YAEU,oBAAA,MAAA;AAAA,2BADN,MAAqD;AAAA,YAArDA,YAAqD,qBAAA;AAAA,cAAnC,SAAS,OAAA,YAAY;AAAA,cAAZ,oBAAA,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAA,OAAA,YAAY,aAAU;AAAA;;;;;;;;;;"}
|
package/src/components/form-designer/setting-panel/property-editor/labelIconClass-editor.vue.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import i18n from "../../../../utils/i18n.js";
|
|
2
|
-
import { resolveComponent, createElementBlock, openBlock, createVNode, withCtx, createTextVNode, toDisplayString } from "vue";
|
|
2
|
+
import { resolveComponent, createElementBlock, openBlock, Fragment, createVNode, withCtx, createTextVNode, toDisplayString } from "vue";
|
|
3
3
|
import _export_sfc from "../../../../../_virtual/_plugin-vue_export-helper.js";
|
|
4
4
|
const _sfc_main = {
|
|
5
5
|
name: "labelIconClass-editor",
|
|
@@ -14,7 +14,7 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
14
14
|
const _component_a_divider = resolveComponent("a-divider");
|
|
15
15
|
const _component_a_form_item = resolveComponent("a-form-item");
|
|
16
16
|
const _component_a_input = resolveComponent("a-input");
|
|
17
|
-
return openBlock(), createElementBlock(
|
|
17
|
+
return openBlock(), createElementBlock(Fragment, null, [
|
|
18
18
|
createVNode(_component_a_form_item, { "label-width": "0" }, {
|
|
19
19
|
default: withCtx(() => [
|
|
20
20
|
createVNode(_component_a_divider, { class: "custom-divider" }, {
|
|
@@ -38,7 +38,7 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
38
38
|
]),
|
|
39
39
|
_: 1
|
|
40
40
|
}, 8, ["label"])
|
|
41
|
-
]);
|
|
41
|
+
], 64);
|
|
42
42
|
}
|
|
43
43
|
const labelIconClassEditor = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
|
|
44
44
|
export {
|
package/src/components/form-designer/setting-panel/property-editor/labelIconClass-editor.vue.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"labelIconClass-editor.vue.js","sources":["../../../../../../src/components/form-designer/setting-panel/property-editor/labelIconClass-editor.vue"],"sourcesContent":["<template>\n
|
|
1
|
+
{"version":3,"file":"labelIconClass-editor.vue.js","sources":["../../../../../../src/components/form-designer/setting-panel/property-editor/labelIconClass-editor.vue"],"sourcesContent":["<template>\n <a-form-item label-width=\"0\">\n <a-divider class=\"custom-divider\">\n {{ i18nt('designer.setting.customLabelIcon') }}\n </a-divider>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelIconClass')\">\n <a-input type=\"text\" v-model:value=\"optionModel.labelIconClass\" />\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n\n export default {\n name: 'labelIconClass-editor',\n mixins: [i18n],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object\n }\n };\n</script>\n"],"names":["_createVNode"],"mappings":";;;AAcI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,IAAI;AAAA,EACb,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA,EACjB;;;;;;;IApBJA,YAIc,wBAAA,EAJD,eAAY,IAAG,GAAA;AAAA,uBACxB,MAEY;AAAA,QAFZA,YAEY,sBAAA,EAFD,OAAM,iBAAgB,GAAA;AAAA,2BAC7B,MAA+C;AAAA,4CAA5C,KAAA,MAAK,kCAAA,CAAA,GAAA,CAAA;AAAA;;;;;;IAGhBA,YAEc,wBAAA;AAAA,MAFA,OAAO,KAAA,MAAK,iCAAA;AAAA;uBACtB,MAAkE;AAAA,QAAlEA,YAAkE,oBAAA;AAAA,UAAzD,MAAK;AAAA,UAAe,OAAO,OAAA,YAAY;AAAA,UAAZ,kBAAA,OAAA,CAAA,MAAA,OAAA,CAAA,IAAA,YAAA,OAAA,YAAY,iBAAc;AAAA;;;;;;;"}
|
package/src/components/form-designer/setting-panel/property-editor/optionItems-editor.vue.js
CHANGED
|
@@ -2,7 +2,7 @@ import i18n from "../../../../utils/i18n.js";
|
|
|
2
2
|
import OptionItemsSetting from "../option-items-setting.vue.js";
|
|
3
3
|
import propertyMixin from "./propertyMixin.js";
|
|
4
4
|
import { getDSByName } from "../../../../utils/util.js";
|
|
5
|
-
import
|
|
5
|
+
import _sfc_main$1 from "../../../http-editor/index.vue.js";
|
|
6
6
|
import { resolveComponent, createElementBlock, openBlock, Fragment, createVNode, createBlock, createCommentVNode, withCtx, createTextVNode, toDisplayString } from "vue";
|
|
7
7
|
import _export_sfc from "../../../../../_virtual/_plugin-vue_export-helper.js";
|
|
8
8
|
const _sfc_main = {
|
|
@@ -15,7 +15,7 @@ const _sfc_main = {
|
|
|
15
15
|
},
|
|
16
16
|
components: {
|
|
17
17
|
OptionItemsSetting,
|
|
18
|
-
HttpEditor
|
|
18
|
+
HttpEditor: _sfc_main$1
|
|
19
19
|
},
|
|
20
20
|
data() {
|
|
21
21
|
return {
|
package/src/components/form-designer/setting-panel/property-editor/optionItems-editor.vue.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"optionItems-editor.vue.js","sources":["../../../../../../src/components/form-designer/setting-panel/property-editor/optionItems-editor.vue"],"sourcesContent":["<template>\n <a-form-item label-width=\"0\">\n <a-divider class=\"custom-divider-margin-top\">\n {{ i18nt('designer.setting.optionsSetting') }}\n </a-divider>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelKeyName')\">\n <a-input size=\"small\" v-model:value=\"optionModel.labelKey\" allowClear />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.valueKeyName')\">\n <a-input size=\"small\" v-model:value=\"optionModel.valueKey\" allowClear />\n </a-form-item>\n <a-form-item v-if=\"hasConfig('childrenKey')\" :label=\"i18nt('designer.setting.childrenKeyName')\">\n <a-input size=\"small\" v-model:value=\"optionModel.childrenKey\" allowClear />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.dsEnabled')\">\n <a-switch v-model:checked=\"optionModel.dsEnabled\" />\n </a-form-item>\n <HttpEditor\n v-if=\"!!optionModel.dsEnabled\"\n :designer=\"designer\"\n :selected-widget=\"selectedWidget\"\n :optionModel=\"optionModel\"\n />\n <a-form-item v-if=\"!optionModel.dsEnabled\" label-width=\"0\">\n <option-items-setting :designer=\"designer\" :selected-widget=\"selectedWidget\" />\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n import OptionItemsSetting from '@/components/form-designer/setting-panel/option-items-setting';\n import propertyMixin from '@/components/form-designer/setting-panel/property-editor/propertyMixin';\n import { getDSByName } from '@/utils/util';\n import HttpEditor from '@/components/http-editor/index.vue';\n export default {\n name: 'optionItems-editor',\n mixins: [i18n, propertyMixin],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object\n },\n components: {\n OptionItemsSetting,\n HttpEditor\n },\n data() {\n return {\n dataSetList: []\n };\n },\n computed: {\n dataSourceList() {\n if (!this.designer.formConfig || !this.designer.formConfig.dataSources) {\n return [];\n } else {\n return this.designer.formConfig.dataSources;\n }\n }\n },\n watch: {\n selectedWidget: {\n handler(val, oldVal) {\n if (!val) {\n return;\n }\n\n this.loadDataSet(val.options.dsName);\n },\n immediate: true\n }\n },\n methods: {\n loadDataSet(dsName) {\n this.dataSetList.length = 0;\n if (!dsName) {\n return;\n }\n\n const dsModel = getDSByName(this.designer.formConfig, dsName);\n if (!!dsModel && !!dsModel.dataSets) {\n dsModel.dataSets.forEach(dSet => {\n this.dataSetList.push({\n name: dSet.name,\n remark: dSet.remark\n });\n });\n }\n },\n\n getDataSetList() {\n this.optionModel.dataSetName = '';\n this.loadDataSet(this.optionModel.dsName);\n }\n }\n };\n</script>\n\n<style scoped></style>\n"],"names":["_createVNode","_createBlock"],"mappings":";;;;;;;AAmCI,MAAK,YAAU;AAAA,EACX,MAAM;AAAA,EACN,QAAQ,CAAC,MAAM,aAAa;AAAA,EAC5B,OAAO;AAAA,IACH,UAAU;AAAA,IACV,gBAAgB;AAAA,IAChB,aAAa;AAAA;EAEjB,YAAY;AAAA,IACR;AAAA,IACA;
|
|
1
|
+
{"version":3,"file":"optionItems-editor.vue.js","sources":["../../../../../../src/components/form-designer/setting-panel/property-editor/optionItems-editor.vue"],"sourcesContent":["<template>\n <a-form-item label-width=\"0\">\n <a-divider class=\"custom-divider-margin-top\">\n {{ i18nt('designer.setting.optionsSetting') }}\n </a-divider>\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.labelKeyName')\">\n <a-input size=\"small\" v-model:value=\"optionModel.labelKey\" allowClear />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.valueKeyName')\">\n <a-input size=\"small\" v-model:value=\"optionModel.valueKey\" allowClear />\n </a-form-item>\n <a-form-item v-if=\"hasConfig('childrenKey')\" :label=\"i18nt('designer.setting.childrenKeyName')\">\n <a-input size=\"small\" v-model:value=\"optionModel.childrenKey\" allowClear />\n </a-form-item>\n <a-form-item :label=\"i18nt('designer.setting.dsEnabled')\">\n <a-switch v-model:checked=\"optionModel.dsEnabled\" />\n </a-form-item>\n <HttpEditor\n v-if=\"!!optionModel.dsEnabled\"\n :designer=\"designer\"\n :selected-widget=\"selectedWidget\"\n :optionModel=\"optionModel\"\n />\n <a-form-item v-if=\"!optionModel.dsEnabled\" label-width=\"0\">\n <option-items-setting :designer=\"designer\" :selected-widget=\"selectedWidget\" />\n </a-form-item>\n</template>\n\n<script>\n import i18n from '@/utils/i18n';\n import OptionItemsSetting from '@/components/form-designer/setting-panel/option-items-setting';\n import propertyMixin from '@/components/form-designer/setting-panel/property-editor/propertyMixin';\n import { getDSByName } from '@/utils/util';\n import HttpEditor from '@/components/http-editor/index.vue';\n export default {\n name: 'optionItems-editor',\n mixins: [i18n, propertyMixin],\n props: {\n designer: Object,\n selectedWidget: Object,\n optionModel: Object\n },\n components: {\n OptionItemsSetting,\n HttpEditor\n },\n data() {\n return {\n dataSetList: []\n };\n },\n computed: {\n dataSourceList() {\n if (!this.designer.formConfig || !this.designer.formConfig.dataSources) {\n return [];\n } else {\n return this.designer.formConfig.dataSources;\n }\n }\n },\n watch: {\n selectedWidget: {\n handler(val, oldVal) {\n if (!val) {\n return;\n }\n\n this.loadDataSet(val.options.dsName);\n },\n immediate: true\n }\n },\n methods: {\n loadDataSet(dsName) {\n this.dataSetList.length = 0;\n if (!dsName) {\n return;\n }\n\n const dsModel = getDSByName(this.designer.formConfig, dsName);\n if (!!dsModel && !!dsModel.dataSets) {\n dsModel.dataSets.forEach(dSet => {\n this.dataSetList.push({\n name: dSet.name,\n remark: dSet.remark\n });\n });\n }\n },\n\n getDataSetList() {\n this.optionModel.dataSetName = '';\n this.loadDataSet(this.optionModel.dsName);\n }\n }\n };\n</script>\n\n<style scoped></style>\n"],"names":["HttpEditor","_createVNode","_createBlock"],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _sfc_main from "./index.vue2.js";
|
|
2
2
|
/* empty css */
|
|
3
3
|
import _export_sfc from "../../../../_virtual/_plugin-vue_export-helper.js";
|
|
4
|
-
const ToolbarPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-
|
|
4
|
+
const ToolbarPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-78a1e8e5"]]);
|
|
5
5
|
export {
|
|
6
6
|
ToolbarPanel as default
|
|
7
7
|
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { defineComponent, defineAsyncComponent, getCurrentInstance, inject, ref, computed,
|
|
1
|
+
import { defineComponent, defineAsyncComponent, getCurrentInstance, inject, ref, computed, onMounted, resolveComponent, createElementBlock, openBlock, createElementVNode, createVNode, withCtx, normalizeStyle, unref, createTextVNode, toDisplayString, createBlock, createCommentVNode, Fragment, renderList, renderSlot, normalizeClass, nextTick } from "vue";
|
|
2
2
|
import { addWindowResizeHandler, copyToClipboard, getQueryParam } from "../../../utils/util.js";
|
|
3
3
|
import { useI18n } from "../../../utils/i18n.js";
|
|
4
4
|
import { saveAs } from "file-saver";
|
|
@@ -31,7 +31,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
31
31
|
const nodeTree = ref(null);
|
|
32
32
|
const preForm = ref(null);
|
|
33
33
|
const importJsonEditorRef = ref(null);
|
|
34
|
-
|
|
34
|
+
ref(null);
|
|
35
35
|
const vfCtx = ref({ type: "add", ...getLocat() });
|
|
36
36
|
const designerConfig = ref(getDesignerConfig());
|
|
37
37
|
const toolbarWidth = ref(460);
|
|
@@ -44,23 +44,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
44
44
|
const exportTemplate = ref("");
|
|
45
45
|
ref("");
|
|
46
46
|
const formDataJson = ref("");
|
|
47
|
-
|
|
47
|
+
ref("");
|
|
48
48
|
const htmlCode = ref("");
|
|
49
49
|
const testFormData = ref({
|
|
50
50
|
select62173: 2
|
|
51
51
|
});
|
|
52
|
-
const testOptionData = ref({
|
|
53
|
-
select62173: [
|
|
54
|
-
{ label: "01", value: 1 },
|
|
55
|
-
{ label: "22", value: 2 },
|
|
56
|
-
{ label: "333", value: 3 }
|
|
57
|
-
],
|
|
58
|
-
select001: [
|
|
59
|
-
{ label: "辣椒", value: 1 },
|
|
60
|
-
{ label: "菠萝", value: 2 },
|
|
61
|
-
{ label: "丑橘子", value: 3 }
|
|
62
|
-
]
|
|
63
|
-
});
|
|
64
52
|
const formJson = computed(() => {
|
|
65
53
|
return {
|
|
66
54
|
widgetList: cloneDeep(props.designer.widgetList),
|
|
@@ -79,12 +67,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
79
67
|
const designerDsv = computed(() => {
|
|
80
68
|
return props.globalDsv;
|
|
81
69
|
});
|
|
82
|
-
watch(
|
|
83
|
-
() => props.designer.widgetList,
|
|
84
|
-
(val) => {
|
|
85
|
-
},
|
|
86
|
-
{ deep: true }
|
|
87
|
-
);
|
|
88
70
|
onMounted(() => {
|
|
89
71
|
const maxTBWidth = designerConfig.value.toolbarMaxWidth || 460;
|
|
90
72
|
const minTBWidth = designerConfig.value.toolbarMinWidth || 300;
|
|
@@ -254,7 +236,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
254
236
|
const widgetList = cloneDeep(props.designer.widgetList);
|
|
255
237
|
const formConfig = cloneDeep(props.designer.formConfig);
|
|
256
238
|
exportTemplate.value = JSON.stringify({ widgetList, formConfig }, null, " ");
|
|
257
|
-
|
|
239
|
+
showFormDataDialogFlag.value = true;
|
|
258
240
|
};
|
|
259
241
|
const showData = async () => {
|
|
260
242
|
const formConfig = props.designer.formConfig;
|
|
@@ -278,7 +260,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
278
260
|
};
|
|
279
261
|
const copyFormDataJson = (e) => {
|
|
280
262
|
copyToClipboard(
|
|
281
|
-
|
|
263
|
+
exportTemplate.value,
|
|
282
264
|
e,
|
|
283
265
|
message,
|
|
284
266
|
i18nt("designer.hint.copyJsonSuccess"),
|
|
@@ -400,8 +382,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
400
382
|
createVNode(_component_a_drawer, {
|
|
401
383
|
title: unref(i18nt)("designer.toolbar.nodeTreeTitle"),
|
|
402
384
|
direction: "ltr",
|
|
403
|
-
|
|
404
|
-
"onUpdate:
|
|
385
|
+
open: showNodeTreeDrawerFlag.value,
|
|
386
|
+
"onUpdate:open": _cache[5] || (_cache[5] = ($event) => showNodeTreeDrawerFlag.value = $event),
|
|
405
387
|
width: 280,
|
|
406
388
|
"destroy-on-close": true,
|
|
407
389
|
class: "node-tree-drawer"
|
|
@@ -419,7 +401,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
419
401
|
}, null, 8, ["treeData"])
|
|
420
402
|
]),
|
|
421
403
|
_: 1
|
|
422
|
-
}, 8, ["title", "
|
|
404
|
+
}, 8, ["title", "open"]),
|
|
423
405
|
createElementVNode("div", _hoisted_3, [
|
|
424
406
|
createElementVNode("div", _hoisted_4, [
|
|
425
407
|
showToolButton("clearDesignerButton") ? (openBlock(), createBlock(_component_a_button, {
|
|
@@ -571,12 +553,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
571
553
|
"form-json": unref(cloneDeep)(formJson.value),
|
|
572
554
|
"form-data": testFormData.value,
|
|
573
555
|
"preview-state": true,
|
|
574
|
-
"option-data": testOptionData.value,
|
|
575
556
|
"global-dsv": designerDsv.value,
|
|
576
557
|
onAppendButtonClick: testOnAppendButtonClick,
|
|
577
558
|
onButtonClick: testOnButtonClick,
|
|
578
559
|
onFormChange: handleFormChange
|
|
579
|
-
}, null, 8, ["vfCtx", "form-json", "form-data", "
|
|
560
|
+
}, null, 8, ["vfCtx", "form-json", "form-data", "global-dsv"])
|
|
580
561
|
], 2)
|
|
581
562
|
])
|
|
582
563
|
]),
|
|
@@ -605,7 +586,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
605
586
|
createVNode(_component_a_button, {
|
|
606
587
|
type: "primary",
|
|
607
588
|
class: "copy-form-data-json-btn",
|
|
608
|
-
"data-clipboard-text":
|
|
589
|
+
"data-clipboard-text": exportTemplate.value,
|
|
609
590
|
onClick: copyFormDataJson
|
|
610
591
|
}, {
|
|
611
592
|
default: withCtx(() => [
|
|
@@ -632,7 +613,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
632
613
|
createVNode(unref(CodeEditor), {
|
|
633
614
|
mode: "json",
|
|
634
615
|
readonly: true,
|
|
635
|
-
value:
|
|
616
|
+
value: exportTemplate.value
|
|
636
617
|
}, null, 8, ["value"])
|
|
637
618
|
]),
|
|
638
619
|
_: 1
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.vue2.js","sources":["../../../../../src/components/form-designer/toolbar-panel/index.vue"],"sourcesContent":["<template>\n <div class=\"toolbar-container\">\n <div class=\"left-toolbar\">\n <a-button type=\"link\" @click=\"changeLeftWidth()\">\n <svg-icon\n :style=\"`transform:${leftWidth === 0 ? 'rotate(180deg)' : 'rotate(0deg)'}`\"\n icon-class=\"a-ipadarrow_back\"\n />\n </a-button>\n <a-button\n type=\"link\"\n :disabled=\"undoDisabled\"\n :title=\"i18nt('designer.toolbar.undoHint')\"\n @click=\"undoHistory\"\n >\n <svg-icon icon-class=\"undo\"\n /></a-button>\n <a-button\n type=\"link\"\n :disabled=\"redoDisabled\"\n :title=\"i18nt('designer.toolbar.redoHint')\"\n @click=\"redoHistory\"\n >\n <svg-icon icon-class=\"redo\"\n /></a-button>\n <a-radio-group v-model:value=\"layoutType\">\n <a-radio-button\n value=\"PC\"\n :type=\"layoutType === 'PC' ? 'primary' : ''\"\n @click=\"changeLayoutType('PC')\"\n >\n {{ i18nt('designer.toolbar.pcLayout') }}</a-radio-button\n >\n <a-radio-button\n value=\"Pad\"\n :type=\"layoutType === 'Pad' ? 'primary' : ''\"\n @click=\"changeLayoutType('Pad')\"\n >\n {{ i18nt('designer.toolbar.padLayout') }}</a-radio-button\n >\n <a-radio-button\n :type=\"layoutType === 'H5' ? 'primary' : ''\"\n @click=\"changeLayoutType('H5')\"\n value=\"H5\"\n >\n {{ i18nt('designer.toolbar.mobileLayout') }}</a-radio-button\n >\n </a-radio-group>\n <a-button\n style=\"margin-left: 20px\"\n :title=\"i18nt('designer.toolbar.nodeTreeHint')\"\n @click=\"showNodeTreeDrawer\"\n >\n <svg-icon icon-class=\"node-tree\"\n /></a-button>\n </div>\n\n <a-drawer\n :title=\"i18nt('designer.toolbar.nodeTreeTitle')\"\n direction=\"ltr\"\n v-model:visible=\"showNodeTreeDrawerFlag\"\n :width=\"280\"\n :destroy-on-close=\"true\"\n class=\"node-tree-drawer\"\n >\n <a-tree\n ref=\"nodeTree\"\n :treeData=\"nodeTreeData\"\n default-expand-all\n highlight-current\n class=\"node-tree\"\n icon-class=\"el-icon-arrow-right\"\n :fieldNames=\"{ children: 'children', title: 'label', key: 'id' }\"\n />\n </a-drawer>\n\n <div class=\"right-toolbar\">\n <div class=\"right-toolbar-con\">\n <a-button\n v-if=\"showToolButton('clearDesignerButton')\"\n type=\"link\"\n @click=\"clearFormWidget\"\n >\n <svg-icon icon-class=\"el-delete\" />{{ i18nt('designer.toolbar.clear') }}\n </a-button>\n <a-button\n v-if=\"showToolButton('previewFormButton')\"\n type=\"link\"\n @click=\"previewForm\"\n >\n <svg-icon icon-class=\"el-view\" />{{ i18nt('designer.toolbar.preview') }}\n </a-button>\n <a-button v-if=\"showToolButton('importJsonButton')\" type=\"link\" @click=\"importJson\">\n {{ i18nt('designer.toolbar.importJson') }}\n </a-button>\n <a-button v-if=\"showToolButton('exportJsonButton')\" type=\"link\" @click=\"exportJson\">\n {{ i18nt('designer.toolbar.exportJson') }}\n </a-button>\n <a-button v-if=\"showToolButton('exportCodeButton')\" type=\"link\" @click=\"saveJson\">\n 保存\n </a-button>\n <a-button type=\"link\" @click=\"changeRightWidth()\">\n <svg-icon\n :style=\"`transform:${rightWidth === 0 ? 'rotate(0deg)' : 'rotate(180deg)'}`\"\n icon-class=\"a-ipadarrow_back\"\n />\n </a-button>\n <template v-for=\"(idx, slotName) in $slots\">\n <slot :name=\"slotName\"></slot>\n </template>\n </div>\n </div>\n\n <TpfModal\n :title=\"i18nt('designer.toolbar.preview')\"\n v-model:visible=\"showPreviewDialogFlag\"\n :show-close=\"true\"\n :close-on-click-modal=\"false\"\n :close-on-press-escape=\"false\"\n center\n class=\"drag-dialog\"\n width=\"75%\"\n :fullscreen=\"true\"\n >\n <div>\n <div\n class=\"form-render-wrapper\"\n :class=\"[\n layoutType === 'H5' ? 'h5-layout' : layoutType === 'Pad' ? 'pad-layout' : ''\n ]\"\n >\n <VFormRender\n :vfCtx=\"vfCtx\"\n ref=\"preForm\"\n :form-json=\"cloneDeep(formJson)\"\n :form-data=\"testFormData\"\n :preview-state=\"true\"\n :option-data=\"testOptionData\"\n :global-dsv=\"designerDsv\"\n @appendButtonClick=\"testOnAppendButtonClick\"\n @buttonClick=\"testOnButtonClick\"\n @formChange=\"handleFormChange\"\n />\n </div>\n </div>\n <template #footerRight>\n <!-- <a-button @click=\"insertData\">新增一个数据</a-button> -->\n <a-button @click=\"showData\">数据回显</a-button>\n <a-button type=\"primary\" @click=\"getFormData\">\n {{ i18nt('designer.hint.getFormData') }}\n </a-button>\n <a-button type=\"primary\" @click=\"resetForm\">\n {{ i18nt('designer.hint.resetForm') }}\n </a-button>\n <a-button type=\"primary\" @click=\"setFormDisabled\">\n {{ i18nt('designer.hint.disableForm') }}\n </a-button>\n <a-button type=\"primary\" @click=\"setFormEnabled\">\n {{ i18nt('designer.hint.enableForm') }}\n </a-button>\n <a-button @click=\"showPreviewDialogFlag = false\">\n {{ i18nt('designer.hint.closePreview') }}\n </a-button>\n </template>\n </TpfModal>\n\n <TpfCodeEditor\n ref=\"importJsonEditorRef\"\n :isShowEventFooter=\"false\"\n :event-header=\"i18nt('designer.hint.importJsonHint')\"\n v-model=\"importTemplate\"\n mode=\"json\"\n :width=\"1200\"\n height=\"70vh\"\n :title=\"i18nt('designer.toolbar.importJson')\"\n @set-code=\"doJsonImport\"\n />\n\n <TpfModal\n :title=\"i18nt('designer.hint.exportFormData')\"\n v-model:visible=\"showFormDataDialogFlag\"\n width=\"1200px\"\n >\n <CodeEditor :mode=\"'json'\" :readonly=\"true\" :value=\"formDataJson\" />\n <template #footerRight>\n <a-button\n type=\"primary\"\n class=\"copy-form-data-json-btn\"\n :data-clipboard-text=\"formDataRawJson\"\n @click=\"copyFormDataJson\"\n >\n {{ i18nt('designer.hint.copyFormData') }}\n </a-button>\n <a-button @click=\"saveFormData\">{{ i18nt('designer.hint.saveFormData') }}</a-button>\n <a-button @click=\"showFormDataDialogFlag = false\">\n {{ i18nt('designer.hint.closePreview') }}\n </a-button>\n </template>\n </TpfModal>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n import { ref, computed, nextTick, onMounted, watch } from 'vue';\n import { defineAsyncComponent, inject } from 'vue';\n import {\n copyToClipboard,\n generateId,\n getQueryParam,\n traverseAllWidgets,\n addWindowResizeHandler\n } from '@/utils/util';\n import { useI18n } from '@/utils/i18n';\n import { generateCode } from '@/utils/code-generator';\n // import { genSFC } from '@/utils/sfc-generator';\n // import loadBeautifier from '@/utils/beautifierLoader';\n import { saveAs } from 'file-saver';\n import axios from 'axios';\n import SvgIcon from '@/components/svg-icon/index.vue';\n import { fmtHttpParams } from '@/utils/request/fmtHttpParams';\n import { getLocat } from '@kp-ui/tool';\n import { cloneDeep } from 'lodash-es';\n import { CodeEditor, TpfModal, TpfCodeEditor } from 'tmgc2-share';\n import { message } from 'ant-design-vue';\n import { getCurrentInstance } from 'vue';\n\n // 组件定义\n const VFormRender = defineAsyncComponent(() => import('@/components/form-render/index.vue'));\n\n const ctx = getCurrentInstance();\n // Props 定义\n interface Props {\n leftWidth: number;\n rightWidth: number;\n changeRightWidth: () => void;\n changeLeftWidth: () => void;\n designer: any; // 可以根据实际类型定义更具体的类型\n saveJsonApi?: (formJson: any) => void;\n globalDsv?: Record<string, any>;\n }\n\n const props = withDefaults(defineProps<Props>(), {\n globalDsv: () => ({})\n });\n\n // Inject\n const getDesignerConfig = inject('getDesignerConfig') as () => any;\n\n // Refs\n const nodeTree = ref<any>(null);\n const preForm = ref<any>(null);\n const importJsonEditorRef = ref<any>(null);\n const exportJsonEditorRef = ref<any>(null);\n\n // 响应式数据\n const vfCtx = ref({ type: 'add', ...getLocat() });\n const designerConfig = ref(getDesignerConfig());\n const toolbarWidth = ref(460);\n const showPreviewDialogFlag = ref(false);\n const showImportJsonDialogFlag = ref(false);\n const showFormDataDialogFlag = ref(false);\n const showNodeTreeDrawerFlag = ref(false);\n const nodeTreeData = ref<any[]>([]);\n const importTemplate = ref('');\n const exportTemplate = ref('');\n const jsonRawContent = ref('');\n const formDataJson = ref('');\n const formDataRawJson = ref('');\n const htmlCode = ref('');\n\n const testFormData = ref({\n select62173: 2\n });\n\n const testOptionData = ref({\n select62173: [\n { label: '01', value: 1 },\n { label: '22', value: 2 },\n { label: '333', value: 3 }\n ],\n select001: [\n { label: '辣椒', value: 1 },\n { label: '菠萝', value: 2 },\n { label: '丑橘子', value: 3 }\n ]\n });\n\n // 计算属性\n const formJson = computed(() => {\n return {\n widgetList: cloneDeep(props.designer.widgetList),\n formConfig: cloneDeep(props.designer.formConfig)\n };\n });\n\n const undoDisabled = computed(() => {\n return !props.designer.undoEnabled();\n });\n\n const redoDisabled = computed(() => {\n return !props.designer.redoEnabled();\n });\n\n const layoutType = computed(() => {\n return props.designer.getLayoutType();\n });\n\n const designerDsv = computed(() => {\n return props.globalDsv;\n });\n\n // 监听器\n watch(\n () => props.designer.widgetList,\n val => {\n //console.log('test-----', val)\n //refreshNodeTree()\n },\n { deep: true }\n );\n\n // 生命周期钩子\n onMounted(() => {\n const maxTBWidth = designerConfig.value.toolbarMaxWidth || 460;\n const minTBWidth = designerConfig.value.toolbarMinWidth || 300;\n const newTBWidth = window.innerWidth - 260 - 300 - 320 - 80;\n toolbarWidth.value =\n newTBWidth >= maxTBWidth\n ? maxTBWidth\n : newTBWidth <= minTBWidth\n ? minTBWidth\n : newTBWidth;\n addWindowResizeHandler(() => {\n nextTick(() => {\n const newTBWidth2 = window.innerWidth - 260 - 300 - 320 - 80;\n toolbarWidth.value =\n newTBWidth2 >= maxTBWidth\n ? maxTBWidth\n : newTBWidth2 <= minTBWidth\n ? minTBWidth\n : newTBWidth2;\n });\n });\n });\n\n // 方法\n const { i18nt } = useI18n();\n\n const saveJson = () => {\n if (props.saveJsonApi) {\n props.saveJsonApi(formJson.value);\n }\n };\n\n const setReadMode = () => {\n preForm.value.setFormData({\n fileupload26481: [\n {\n fileCode: '89046755221505',\n fileName: '首页-透明工厂.png',\n guidebookId: 89046782484481,\n id: 89046782484482\n }\n ]\n });\n // preForm.value.setReadMode(!preForm.value.getReadMode());\n };\n\n const showToolButton = (configName: string): boolean => {\n if (designerConfig.value[configName] === undefined) {\n return true;\n }\n\n return !!designerConfig.value[configName];\n };\n\n const buildTreeNodeOfWidget = (widget: any, treeNode: any[]) => {\n const curNode = {\n id: widget.id,\n label: widget.options.label || widget.type,\n children: [] as any[]\n };\n treeNode.push(curNode);\n\n if (widget.category === undefined) {\n return;\n }\n\n if (widget.type === 'grid') {\n widget.cols.map((col: any) => {\n const colNode = {\n id: col.id,\n label: col.options.name || widget.type,\n children: [] as any[]\n };\n curNode.children.push(colNode);\n col.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, colNode.children);\n });\n });\n } else if (widget.type === 'table') {\n //TODO: 需要考虑合并单元格!!\n widget.rows.map((row: any) => {\n const rowNode = {\n id: row.id,\n label: 'table-row',\n selectable: false,\n children: [] as any[]\n };\n curNode.children.push(rowNode);\n\n row.cols.map((cell: any) => {\n if (!!cell.merged) {\n //跳过合并单元格!!\n return;\n }\n\n const rowChildren = rowNode.children;\n const cellNode = {\n id: cell.id,\n label: 'table-cell',\n children: [] as any[]\n };\n rowChildren.push(cellNode);\n\n cell.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, cellNode.children);\n });\n });\n });\n } else if (widget.type === 'tab') {\n widget.tabs.map((tab: any) => {\n const tabNode = {\n id: tab.id,\n label: tab.options.name || widget.type,\n selectable: false,\n children: [] as any[]\n };\n curNode.children.push(tabNode);\n tab.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, tabNode.children);\n });\n });\n } else if (widget.type === 'sub-form') {\n widget.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, curNode.children);\n });\n } else if (widget.category === 'container') {\n //自定义容器\n widget.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, curNode.children);\n });\n }\n };\n\n const refreshNodeTree = () => {\n nodeTreeData.value.length = 0;\n props.designer.widgetList.forEach((wItem: any) => {\n buildTreeNodeOfWidget(wItem, nodeTreeData.value);\n });\n };\n\n const showNodeTreeDrawer = () => {\n refreshNodeTree();\n showNodeTreeDrawerFlag.value = true;\n nextTick(() => {\n if (!!props.designer.selectedId) {\n //同步当前选中组件到节点树!!!\n nodeTree.value.setCurrentKey(props.designer.selectedId);\n }\n });\n };\n\n const saveImportTemplate = value => {\n saveAsFile(value, `vform${generateId()}.json`);\n };\n\n const undoHistory = () => {\n props.designer.undoHistoryStep();\n };\n\n const redoHistory = () => {\n props.designer.redoHistoryStep();\n };\n\n const changeLayoutType = (newType: string) => {\n props.designer.changeLayoutType(newType);\n };\n\n const clearFormWidget = () => {\n props.designer.clearDesigner();\n props.designer.formWidget.clearWidgetRefList();\n message.success('ok');\n };\n\n const previewForm = () => {\n showPreviewDialogFlag.value = true;\n // ctx!.proxy.$openCustomerModal({\n // ...vfCtx.value,\n // width: '90%'\n // });\n };\n\n const saveAsFile = (fileContent: string, defaultFileName: string) => {\n const value = 'json.json' || defaultFileName;\n\n if (getQueryParam('vscode') == 1) {\n vsSaveFile(value, fileContent);\n return;\n }\n\n const fileBlob = new Blob([fileContent], { type: 'text/plain;charset=utf-8' });\n saveAs(fileBlob, value);\n };\n\n const vsSaveFile = (fileName: string, fileContent: string) => {\n const msgObj = {\n cmd: 'writeFile',\n data: {\n fileName,\n code: fileContent\n }\n };\n window.parent.postMessage(msgObj, '*');\n };\n\n const importJson = () => {\n importTemplate.value = JSON.stringify(props.designer.getImportTemplate(), null, ' ');\n\n importJsonEditorRef.value.open();\n showImportJsonDialogFlag.value = true;\n };\n\n const doJsonImport = () => {\n try {\n const importObj = JSON.parse(importTemplate.value);\n if (!importObj || !importObj.formConfig) {\n throw new Error(i18nt('designer.hint.invalidJsonFormat'));\n }\n\n props.designer.loadFormJson(importObj);\n\n showImportJsonDialogFlag.value = false;\n message.success(i18nt('designer.hint.importJsonSuccess'));\n\n props.designer.emitHistoryChange();\n\n props.designer.emitEvent('form-json-imported', []);\n } catch (ex) {\n message.error(ex + '');\n }\n };\n\n const exportJson = () => {\n const widgetList = cloneDeep(props.designer.widgetList);\n const formConfig = cloneDeep(props.designer.formConfig);\n exportTemplate.value = JSON.stringify({ widgetList, formConfig }, null, ' ');\n exportJsonEditorRef.value.open();\n };\n\n const copyFormJson = (e: Event) => {\n copyToClipboard(\n jsonRawContent.value,\n e,\n message,\n i18nt('designer.hint.copyJsonSuccess'),\n i18nt('designer.hint.copyJsonFail')\n );\n };\n\n const showData = async () => {\n const formConfig = props.designer.formConfig;\n const { id: _id } = getLocat();\n const dsResult = await fmtHttpParams(formConfig.serveList.vformDetail, { _id });\n const leaveDates = [{ date: '2024-10-28' }, { date: '2024-10-29' }, { date: '2024-10-20' }];\n\n preForm.value.getWidgetRef('leaveDates').setValue(leaveDates);\n preForm.value.setFormData({\n ...dsResult\n });\n preForm.value.setReadMode(true);\n };\n\n const getFormData = () => {\n console.log(preForm.value);\n\n preForm.value\n .getFormData()\n .then((formData: any) => {\n formDataJson.value = JSON.stringify(formData, null, ' ');\n showFormDataDialogFlag.value = true;\n })\n .catch((error: any) => {\n message.error(error);\n });\n };\n\n const copyFormDataJson = (e: Event) => {\n copyToClipboard(\n formDataRawJson.value,\n e,\n message,\n i18nt('designer.hint.copyJsonSuccess'),\n i18nt('designer.hint.copyJsonFail')\n );\n };\n\n const saveFormData = () => {\n saveAsFile(htmlCode.value, `formData${generateId()}.json`);\n };\n\n const resetForm = () => {\n preForm.value.resetForm();\n };\n\n const setFormDisabled = () => {\n preForm.value.disableForm();\n };\n\n const setFormEnabled = () => {\n preForm.value.enableForm();\n };\n\n const handleFormChange = (fieldName: string, newValue: any, oldValue: any, formModel: any) => {\n console.log('formModel', formModel);\n };\n\n const testOnAppendButtonClick = (clickedWidget: any) => {\n console.log('test', clickedWidget);\n };\n\n const testOnButtonClick = (button: any) => {\n console.log('test', button);\n };\n\n const findWidgetById = (wId: string) => {\n let foundW = null;\n traverseAllWidgets(props.designer.widgetList, (w: any) => {\n if (w.id === wId) {\n foundW = w;\n }\n });\n\n return foundW;\n };\n\n const onNodeTreeClick = (nodeData: any, node: any, nodeEl: any) => {\n if (nodeData.selectable !== undefined && !nodeData.selectable) {\n message.info(i18nt('designer.hint.currentNodeCannotBeSelected'));\n } else {\n const selectedId = nodeData.id;\n const foundW = findWidgetById(selectedId);\n if (!!foundW) {\n props.designer.setSelected(foundW);\n }\n }\n };\n</script>\n\n<style lang=\"scss\" scoped>\n .toolbar-container {\n width: 100%;\n display: flex;\n height: 42px;\n align-items: center;\n justify-content: space-between;\n }\n\n .left-toolbar {\n display: flex;\n margin-top: 4px;\n font-size: 16px;\n }\n\n .right-toolbar {\n display: flex;\n line-height: 42px;\n overflow: hidden;\n\n .right-toolbar-con {\n text-align: left;\n }\n\n :deep(.svg-icon) {\n margin-left: 0;\n margin-right: 0.05em;\n }\n }\n\n .no-box-shadow {\n box-shadow: none;\n }\n\n .form-render-wrapper.h5-layout {\n margin: 0 auto;\n width: 420px;\n border-radius: 15px;\n //border-width: 10px;\n box-shadow: 0 0 1px 10px #495060;\n height: calc(100vh - 175px);\n overflow-y: auto;\n overflow-x: hidden;\n }\n\n .form-render-wrapper.pad-layout {\n margin: 0 auto;\n width: 960px;\n border-radius: 15px;\n //border-width: 10px;\n box-shadow: 0 0 1px 10px #495060;\n height: calc(100vh - 175px);\n overflow-y: auto;\n overflow-x: hidden;\n }\n\n .node-tree-drawer {\n :deep(.el-drawer) {\n padding: 10px;\n overflow: auto;\n }\n\n :deep(.el-drawer__header) {\n margin-bottom: 12px;\n padding: 5px 5px 0;\n }\n\n :deep(.el-drawer__body) {\n padding-left: 5px;\n }\n }\n\n /*.node-tree-scroll-bar {*/\n /* height: 100%;*/\n /* overflow: auto;*/\n /*}*/\n\n :deep(.node-tree) {\n .el-tree > .el-tree-node:after {\n border-top: none;\n }\n .el-tree-node {\n position: relative;\n padding-left: 12px;\n }\n\n .el-tree-node__content {\n padding-left: 0 !important;\n }\n\n .el-tree-node__expand-icon.is-leaf {\n display: none;\n }\n\n .el-tree-node__children {\n padding-left: 12px;\n overflow: visible !important; /* 加入此行让el-tree宽度自动撑开,超出宽度el-draw自动出现水平滚动条! */\n }\n\n .el-tree-node :last-child:before {\n height: 38px;\n }\n\n .el-tree > .el-tree-node:before {\n border-left: none;\n }\n\n .el-tree > .el-tree-node:after {\n border-top: none;\n }\n\n .el-tree-node:before {\n content: '';\n left: -4px;\n position: absolute;\n right: auto;\n border-width: 1px;\n }\n\n .el-tree-node:after {\n content: '';\n left: -4px;\n position: absolute;\n right: auto;\n border-width: 1px;\n }\n\n .el-tree-node:before {\n border-left: 1px dashed #4386c6;\n bottom: 0px;\n height: 100%;\n top: -10px;\n width: 1px;\n }\n\n .el-tree-node:after {\n border-top: 1px dashed #4386c6;\n height: 20px;\n top: 12px;\n width: 16px;\n }\n\n .el-tree-node.is-current > .el-tree-node__content {\n background: #c2d6ea !important;\n }\n\n .el-tree-node__expand-icon {\n margin-left: -3px;\n padding: 6px 6px 6px 0px;\n font-size: 16px;\n }\n }\n</style>\n"],"names":["_openBlock","_createElementBlock","_createElementVNode","_createVNode","changeLeftWidth","leftWidth","_unref","_createBlock","changeRightWidth","rightWidth","_Fragment","_renderList","$slots","_renderSlot"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.vue2.js","sources":["../../../../../src/components/form-designer/toolbar-panel/index.vue"],"sourcesContent":["<template>\n <div class=\"toolbar-container\">\n <div class=\"left-toolbar\">\n <a-button type=\"link\" @click=\"changeLeftWidth()\">\n <svg-icon\n :style=\"`transform:${leftWidth === 0 ? 'rotate(180deg)' : 'rotate(0deg)'}`\"\n icon-class=\"a-ipadarrow_back\"\n />\n </a-button>\n <a-button\n type=\"link\"\n :disabled=\"undoDisabled\"\n :title=\"i18nt('designer.toolbar.undoHint')\"\n @click=\"undoHistory\"\n >\n <svg-icon icon-class=\"undo\"\n /></a-button>\n <a-button\n type=\"link\"\n :disabled=\"redoDisabled\"\n :title=\"i18nt('designer.toolbar.redoHint')\"\n @click=\"redoHistory\"\n >\n <svg-icon icon-class=\"redo\"\n /></a-button>\n <a-radio-group v-model:value=\"layoutType\">\n <a-radio-button\n value=\"PC\"\n :type=\"layoutType === 'PC' ? 'primary' : ''\"\n @click=\"changeLayoutType('PC')\"\n >\n {{ i18nt('designer.toolbar.pcLayout') }}</a-radio-button\n >\n <a-radio-button\n value=\"Pad\"\n :type=\"layoutType === 'Pad' ? 'primary' : ''\"\n @click=\"changeLayoutType('Pad')\"\n >\n {{ i18nt('designer.toolbar.padLayout') }}</a-radio-button\n >\n <a-radio-button\n :type=\"layoutType === 'H5' ? 'primary' : ''\"\n @click=\"changeLayoutType('H5')\"\n value=\"H5\"\n >\n {{ i18nt('designer.toolbar.mobileLayout') }}</a-radio-button\n >\n </a-radio-group>\n <a-button\n style=\"margin-left: 20px\"\n :title=\"i18nt('designer.toolbar.nodeTreeHint')\"\n @click=\"showNodeTreeDrawer\"\n >\n <svg-icon icon-class=\"node-tree\"\n /></a-button>\n </div>\n\n <a-drawer\n :title=\"i18nt('designer.toolbar.nodeTreeTitle')\"\n direction=\"ltr\"\n v-model:open=\"showNodeTreeDrawerFlag\"\n :width=\"280\"\n :destroy-on-close=\"true\"\n class=\"node-tree-drawer\"\n >\n <a-tree\n ref=\"nodeTree\"\n :treeData=\"nodeTreeData\"\n default-expand-all\n highlight-current\n class=\"node-tree\"\n icon-class=\"el-icon-arrow-right\"\n :fieldNames=\"{ children: 'children', title: 'label', key: 'id' }\"\n />\n </a-drawer>\n\n <div class=\"right-toolbar\">\n <div class=\"right-toolbar-con\">\n <a-button\n v-if=\"showToolButton('clearDesignerButton')\"\n type=\"link\"\n @click=\"clearFormWidget\"\n >\n <svg-icon icon-class=\"el-delete\" />{{ i18nt('designer.toolbar.clear') }}\n </a-button>\n <a-button\n v-if=\"showToolButton('previewFormButton')\"\n type=\"link\"\n @click=\"previewForm\"\n >\n <svg-icon icon-class=\"el-view\" />{{ i18nt('designer.toolbar.preview') }}\n </a-button>\n <a-button v-if=\"showToolButton('importJsonButton')\" type=\"link\" @click=\"importJson\">\n {{ i18nt('designer.toolbar.importJson') }}\n </a-button>\n <a-button v-if=\"showToolButton('exportJsonButton')\" type=\"link\" @click=\"exportJson\">\n {{ i18nt('designer.toolbar.exportJson') }}\n </a-button>\n <a-button v-if=\"showToolButton('exportCodeButton')\" type=\"link\" @click=\"saveJson\">\n 保存\n </a-button>\n <a-button type=\"link\" @click=\"changeRightWidth()\">\n <svg-icon\n :style=\"`transform:${rightWidth === 0 ? 'rotate(0deg)' : 'rotate(180deg)'}`\"\n icon-class=\"a-ipadarrow_back\"\n />\n </a-button>\n <template v-for=\"(idx, slotName) in $slots\">\n <slot :name=\"slotName\"></slot>\n </template>\n </div>\n </div>\n\n <TpfModal\n :title=\"i18nt('designer.toolbar.preview')\"\n v-model:visible=\"showPreviewDialogFlag\"\n :show-close=\"true\"\n :close-on-click-modal=\"false\"\n :close-on-press-escape=\"false\"\n center\n class=\"drag-dialog\"\n width=\"75%\"\n :fullscreen=\"true\"\n >\n <div>\n <div\n class=\"form-render-wrapper\"\n :class=\"[\n layoutType === 'H5' ? 'h5-layout' : layoutType === 'Pad' ? 'pad-layout' : ''\n ]\"\n >\n <VFormRender\n :vfCtx=\"vfCtx\"\n ref=\"preForm\"\n :form-json=\"cloneDeep(formJson)\"\n :form-data=\"testFormData\"\n :preview-state=\"true\"\n :global-dsv=\"designerDsv\"\n @appendButtonClick=\"testOnAppendButtonClick\"\n @buttonClick=\"testOnButtonClick\"\n @formChange=\"handleFormChange\"\n />\n </div>\n </div>\n <template #footerRight>\n <!-- <a-button @click=\"insertData\">新增一个数据</a-button> -->\n <a-button @click=\"showData\">数据回显</a-button>\n <a-button type=\"primary\" @click=\"getFormData\">\n {{ i18nt('designer.hint.getFormData') }}\n </a-button>\n <a-button type=\"primary\" @click=\"resetForm\">\n {{ i18nt('designer.hint.resetForm') }}\n </a-button>\n <a-button type=\"primary\" @click=\"setFormDisabled\">\n {{ i18nt('designer.hint.disableForm') }}\n </a-button>\n <a-button type=\"primary\" @click=\"setFormEnabled\">\n {{ i18nt('designer.hint.enableForm') }}\n </a-button>\n <a-button @click=\"showPreviewDialogFlag = false\">\n {{ i18nt('designer.hint.closePreview') }}\n </a-button>\n </template>\n </TpfModal>\n\n <TpfCodeEditor\n ref=\"importJsonEditorRef\"\n :isShowEventFooter=\"false\"\n :event-header=\"i18nt('designer.hint.importJsonHint')\"\n v-model=\"importTemplate\"\n mode=\"json\"\n :width=\"1200\"\n height=\"70vh\"\n :title=\"i18nt('designer.toolbar.importJson')\"\n @set-code=\"doJsonImport\"\n />\n\n <TpfModal\n :title=\"i18nt('designer.hint.exportFormData')\"\n v-model:visible=\"showFormDataDialogFlag\"\n width=\"1200px\"\n >\n <CodeEditor :mode=\"'json'\" :readonly=\"true\" :value=\"exportTemplate\" />\n <template #footerRight>\n <a-button\n type=\"primary\"\n class=\"copy-form-data-json-btn\"\n :data-clipboard-text=\"exportTemplate\"\n @click=\"copyFormDataJson\"\n >\n {{ i18nt('designer.hint.copyFormData') }}\n </a-button>\n <a-button @click=\"saveFormData\">{{ i18nt('designer.hint.saveFormData') }}</a-button>\n <a-button @click=\"showFormDataDialogFlag = false\">\n {{ i18nt('designer.hint.closePreview') }}\n </a-button>\n </template>\n </TpfModal>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n import { ref, computed, nextTick, onMounted, watch } from 'vue';\n import { defineAsyncComponent, inject } from 'vue';\n import {\n copyToClipboard,\n generateId,\n getQueryParam,\n traverseAllWidgets,\n addWindowResizeHandler\n } from '@/utils/util';\n import { useI18n } from '@/utils/i18n';\n import { generateCode } from '@/utils/code-generator';\n // import { genSFC } from '@/utils/sfc-generator';\n // import loadBeautifier from '@/utils/beautifierLoader';\n import { saveAs } from 'file-saver';\n import axios from 'axios';\n import SvgIcon from '@/components/svg-icon/index.vue';\n import { fmtHttpParams } from '@/utils/request/fmtHttpParams';\n import { getLocat } from '@kp-ui/tool';\n import { cloneDeep } from 'lodash-es';\n import { CodeEditor, TpfModal, TpfCodeEditor } from 'tmgc2-share';\n import { message } from 'ant-design-vue';\n import { getCurrentInstance } from 'vue';\n\n // 组件定义\n const VFormRender = defineAsyncComponent(() => import('@/components/form-render/index.vue'));\n\n const ctx = getCurrentInstance();\n // Props 定义\n interface Props {\n leftWidth: number;\n rightWidth: number;\n changeRightWidth: () => void;\n changeLeftWidth: () => void;\n designer: any; // 可以根据实际类型定义更具体的类型\n saveJsonApi?: (formJson: any) => void;\n globalDsv?: Record<string, any>;\n }\n\n const props = withDefaults(defineProps<Props>(), {\n globalDsv: () => ({})\n });\n\n // Inject\n const getDesignerConfig = inject('getDesignerConfig') as () => any;\n\n // Refs\n const nodeTree = ref<any>(null);\n const preForm = ref<any>(null);\n const importJsonEditorRef = ref<any>(null);\n const exportJsonEditorRef = ref<any>(null);\n\n // 响应式数据\n const vfCtx = ref({ type: 'add', ...getLocat() });\n const designerConfig = ref(getDesignerConfig());\n const toolbarWidth = ref(460);\n const showPreviewDialogFlag = ref(false);\n const showImportJsonDialogFlag = ref(false);\n const showFormDataDialogFlag = ref(false);\n const showNodeTreeDrawerFlag = ref(false);\n const nodeTreeData = ref<any[]>([]);\n const importTemplate = ref('');\n const exportTemplate = ref('');\n const jsonRawContent = ref('');\n const formDataJson = ref('');\n const formDataRawJson = ref('');\n const htmlCode = ref('');\n\n const testFormData = ref({\n select62173: 2\n });\n\n // 计算属性\n const formJson = computed(() => {\n return {\n widgetList: cloneDeep(props.designer.widgetList),\n formConfig: cloneDeep(props.designer.formConfig)\n };\n });\n\n const undoDisabled = computed(() => {\n return !props.designer.undoEnabled();\n });\n\n const redoDisabled = computed(() => {\n return !props.designer.redoEnabled();\n });\n\n const layoutType = computed(() => {\n return props.designer.getLayoutType();\n });\n\n const designerDsv = computed(() => {\n return props.globalDsv;\n });\n\n // 生命周期钩子\n onMounted(() => {\n const maxTBWidth = designerConfig.value.toolbarMaxWidth || 460;\n const minTBWidth = designerConfig.value.toolbarMinWidth || 300;\n const newTBWidth = window.innerWidth - 260 - 300 - 320 - 80;\n toolbarWidth.value =\n newTBWidth >= maxTBWidth\n ? maxTBWidth\n : newTBWidth <= minTBWidth\n ? minTBWidth\n : newTBWidth;\n addWindowResizeHandler(() => {\n nextTick(() => {\n const newTBWidth2 = window.innerWidth - 260 - 300 - 320 - 80;\n toolbarWidth.value =\n newTBWidth2 >= maxTBWidth\n ? maxTBWidth\n : newTBWidth2 <= minTBWidth\n ? minTBWidth\n : newTBWidth2;\n });\n });\n });\n\n // 方法\n const { i18nt } = useI18n();\n\n const saveJson = () => {\n if (props.saveJsonApi) {\n props.saveJsonApi(formJson.value);\n }\n };\n\n const showToolButton = (configName: string): boolean => {\n if (designerConfig.value[configName] === undefined) {\n return true;\n }\n\n return !!designerConfig.value[configName];\n };\n\n const buildTreeNodeOfWidget = (widget: any, treeNode: any[]) => {\n const curNode = {\n id: widget.id,\n label: widget.options.label || widget.type,\n children: [] as any[]\n };\n treeNode.push(curNode);\n\n if (widget.category === undefined) {\n return;\n }\n\n if (widget.type === 'grid') {\n widget.cols.map((col: any) => {\n const colNode = {\n id: col.id,\n label: col.options.name || widget.type,\n children: [] as any[]\n };\n curNode.children.push(colNode);\n col.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, colNode.children);\n });\n });\n } else if (widget.type === 'table') {\n //TODO: 需要考虑合并单元格!!\n widget.rows.map((row: any) => {\n const rowNode = {\n id: row.id,\n label: 'table-row',\n selectable: false,\n children: [] as any[]\n };\n curNode.children.push(rowNode);\n\n row.cols.map((cell: any) => {\n if (!!cell.merged) {\n //跳过合并单元格!!\n return;\n }\n\n const rowChildren = rowNode.children;\n const cellNode = {\n id: cell.id,\n label: 'table-cell',\n children: [] as any[]\n };\n rowChildren.push(cellNode);\n\n cell.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, cellNode.children);\n });\n });\n });\n } else if (widget.type === 'tab') {\n widget.tabs.map((tab: any) => {\n const tabNode = {\n id: tab.id,\n label: tab.options.name || widget.type,\n selectable: false,\n children: [] as any[]\n };\n curNode.children.push(tabNode);\n tab.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, tabNode.children);\n });\n });\n } else if (widget.type === 'sub-form') {\n widget.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, curNode.children);\n });\n } else if (widget.category === 'container') {\n //自定义容器\n widget.widgetList.map((wChild: any) => {\n buildTreeNodeOfWidget(wChild, curNode.children);\n });\n }\n };\n\n const refreshNodeTree = () => {\n nodeTreeData.value.length = 0;\n props.designer.widgetList.forEach((wItem: any) => {\n buildTreeNodeOfWidget(wItem, nodeTreeData.value);\n });\n };\n\n const showNodeTreeDrawer = () => {\n refreshNodeTree();\n showNodeTreeDrawerFlag.value = true;\n nextTick(() => {\n if (!!props.designer.selectedId) {\n //同步当前选中组件到节点树!!!\n nodeTree.value.setCurrentKey(props.designer.selectedId);\n }\n });\n };\n\n const saveImportTemplate = value => {\n saveAsFile(value, `vform${generateId()}.json`);\n };\n\n const undoHistory = () => {\n props.designer.undoHistoryStep();\n };\n\n const redoHistory = () => {\n props.designer.redoHistoryStep();\n };\n\n const changeLayoutType = (newType: string) => {\n props.designer.changeLayoutType(newType);\n };\n\n const clearFormWidget = () => {\n props.designer.clearDesigner();\n props.designer.formWidget.clearWidgetRefList();\n message.success('ok');\n };\n\n const previewForm = () => {\n showPreviewDialogFlag.value = true;\n // ctx!.proxy.$openCustomerModal({\n // ...vfCtx.value,\n // width: '90%'\n // });\n };\n\n const saveAsFile = (fileContent: string, defaultFileName: string) => {\n const value = 'json.json' || defaultFileName;\n\n if (getQueryParam('vscode') == 1) {\n vsSaveFile(value, fileContent);\n return;\n }\n\n const fileBlob = new Blob([fileContent], { type: 'text/plain;charset=utf-8' });\n saveAs(fileBlob, value);\n };\n\n const vsSaveFile = (fileName: string, fileContent: string) => {\n const msgObj = {\n cmd: 'writeFile',\n data: {\n fileName,\n code: fileContent\n }\n };\n window.parent.postMessage(msgObj, '*');\n };\n\n const importJson = () => {\n importTemplate.value = JSON.stringify(props.designer.getImportTemplate(), null, ' ');\n\n importJsonEditorRef.value.open();\n showImportJsonDialogFlag.value = true;\n };\n\n const doJsonImport = () => {\n try {\n const importObj = JSON.parse(importTemplate.value);\n if (!importObj || !importObj.formConfig) {\n throw new Error(i18nt('designer.hint.invalidJsonFormat'));\n }\n\n props.designer.loadFormJson(importObj);\n\n showImportJsonDialogFlag.value = false;\n message.success(i18nt('designer.hint.importJsonSuccess'));\n\n props.designer.emitHistoryChange();\n\n props.designer.emitEvent('form-json-imported', []);\n } catch (ex) {\n message.error(ex + '');\n }\n };\n\n const exportJson = () => {\n const widgetList = cloneDeep(props.designer.widgetList);\n const formConfig = cloneDeep(props.designer.formConfig);\n exportTemplate.value = JSON.stringify({ widgetList, formConfig }, null, ' ');\n // exportJsonEditorRef.value.open();\n showFormDataDialogFlag.value = true;\n };\n\n const showData = async () => {\n const formConfig = props.designer.formConfig;\n const { id: _id } = getLocat();\n const dsResult = await fmtHttpParams(formConfig.serveList.vformDetail, { _id });\n const leaveDates = [{ date: '2024-10-28' }, { date: '2024-10-29' }, { date: '2024-10-20' }];\n\n preForm.value.getWidgetRef('leaveDates').setValue(leaveDates);\n preForm.value.setFormData({\n ...dsResult\n });\n preForm.value.setReadMode(true);\n };\n\n const getFormData = () => {\n console.log(preForm.value);\n\n preForm.value\n .getFormData()\n .then((formData: any) => {\n formDataJson.value = JSON.stringify(formData, null, ' ');\n showFormDataDialogFlag.value = true;\n })\n .catch((error: any) => {\n message.error(error);\n });\n };\n\n const copyFormDataJson = (e: Event) => {\n copyToClipboard(\n exportTemplate.value,\n e,\n message,\n i18nt('designer.hint.copyJsonSuccess'),\n i18nt('designer.hint.copyJsonFail')\n );\n };\n\n const saveFormData = () => {\n saveAsFile(htmlCode.value, `formData${generateId()}.json`);\n };\n\n const resetForm = () => {\n preForm.value.resetForm();\n };\n\n const setFormDisabled = () => {\n preForm.value.disableForm();\n };\n\n const setFormEnabled = () => {\n preForm.value.enableForm();\n };\n\n const handleFormChange = (fieldName: string, newValue: any, oldValue: any, formModel: any) => {\n console.log('formModel', formModel);\n };\n\n const testOnAppendButtonClick = (clickedWidget: any) => {\n console.log('test', clickedWidget);\n };\n\n const testOnButtonClick = (button: any) => {\n console.log('test', button);\n };\n\n const findWidgetById = (wId: string) => {\n let foundW = null;\n traverseAllWidgets(props.designer.widgetList, (w: any) => {\n if (w.id === wId) {\n foundW = w;\n }\n });\n\n return foundW;\n };\n\n const onNodeTreeClick = (nodeData: any, node: any, nodeEl: any) => {\n if (nodeData.selectable !== undefined && !nodeData.selectable) {\n message.info(i18nt('designer.hint.currentNodeCannotBeSelected'));\n } else {\n const selectedId = nodeData.id;\n const foundW = findWidgetById(selectedId);\n if (!!foundW) {\n props.designer.setSelected(foundW);\n }\n }\n };\n</script>\n\n<style lang=\"scss\" scoped>\n .toolbar-container {\n width: 100%;\n display: flex;\n height: 42px;\n align-items: center;\n justify-content: space-between;\n }\n\n .left-toolbar {\n display: flex;\n margin-top: 4px;\n font-size: 16px;\n }\n\n .right-toolbar {\n display: flex;\n line-height: 42px;\n overflow: hidden;\n\n .right-toolbar-con {\n text-align: left;\n }\n\n :deep(.svg-icon) {\n margin-left: 0;\n margin-right: 0.05em;\n }\n }\n\n .no-box-shadow {\n box-shadow: none;\n }\n\n .form-render-wrapper.h5-layout {\n margin: 0 auto;\n width: 420px;\n border-radius: 15px;\n //border-width: 10px;\n box-shadow: 0 0 1px 10px #495060;\n height: calc(100vh - 175px);\n overflow-y: auto;\n overflow-x: hidden;\n }\n\n .form-render-wrapper.pad-layout {\n margin: 0 auto;\n width: 960px;\n border-radius: 15px;\n //border-width: 10px;\n box-shadow: 0 0 1px 10px #495060;\n height: calc(100vh - 175px);\n overflow-y: auto;\n overflow-x: hidden;\n }\n\n .node-tree-drawer {\n :deep(.el-drawer) {\n padding: 10px;\n overflow: auto;\n }\n\n :deep(.el-drawer__header) {\n margin-bottom: 12px;\n padding: 5px 5px 0;\n }\n\n :deep(.el-drawer__body) {\n padding-left: 5px;\n }\n }\n\n /*.node-tree-scroll-bar {*/\n /* height: 100%;*/\n /* overflow: auto;*/\n /*}*/\n\n :deep(.node-tree) {\n .el-tree > .el-tree-node:after {\n border-top: none;\n }\n .el-tree-node {\n position: relative;\n padding-left: 12px;\n }\n\n .el-tree-node__content {\n padding-left: 0 !important;\n }\n\n .el-tree-node__expand-icon.is-leaf {\n display: none;\n }\n\n .el-tree-node__children {\n padding-left: 12px;\n overflow: visible !important; /* 加入此行让el-tree宽度自动撑开,超出宽度el-draw自动出现水平滚动条! */\n }\n\n .el-tree-node :last-child:before {\n height: 38px;\n }\n\n .el-tree > .el-tree-node:before {\n border-left: none;\n }\n\n .el-tree > .el-tree-node:after {\n border-top: none;\n }\n\n .el-tree-node:before {\n content: '';\n left: -4px;\n position: absolute;\n right: auto;\n border-width: 1px;\n }\n\n .el-tree-node:after {\n content: '';\n left: -4px;\n position: absolute;\n right: auto;\n border-width: 1px;\n }\n\n .el-tree-node:before {\n border-left: 1px dashed #4386c6;\n bottom: 0px;\n height: 100%;\n top: -10px;\n width: 1px;\n }\n\n .el-tree-node:after {\n border-top: 1px dashed #4386c6;\n height: 20px;\n top: 12px;\n width: 16px;\n }\n\n .el-tree-node.is-current > .el-tree-node__content {\n background: #c2d6ea !important;\n }\n\n .el-tree-node__expand-icon {\n margin-left: -3px;\n padding: 6px 6px 6px 0px;\n font-size: 16px;\n }\n }\n</style>\n"],"names":["_openBlock","_createElementBlock","_createElementVNode","_createVNode","changeLeftWidth","leftWidth","_unref","_createBlock","changeRightWidth","rightWidth","_Fragment","_renderList","$slots","_renderSlot"],"mappings":"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"}
|
|
@@ -383,7 +383,7 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
383
383
|
])
|
|
384
384
|
]);
|
|
385
385
|
}
|
|
386
|
-
const WidgetPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-
|
|
386
|
+
const WidgetPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-86d2fd5e"]]);
|
|
387
387
|
export {
|
|
388
388
|
WidgetPanel as default
|
|
389
389
|
};
|