@things-factory/meta-ui 9.0.0-beta.27 → 9.0.0-beta.29
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-client/bootstrap.d.ts +7 -0
- package/dist-client/bootstrap.js +142 -0
- package/dist-client/bootstrap.js.map +1 -0
- package/dist-client/component/filter/filter-form-meta-code-select.d.ts +4 -0
- package/dist-client/component/filter/filter-form-meta-code-select.js +80 -0
- package/dist-client/component/filter/filter-form-meta-code-select.js.map +1 -0
- package/dist-client/component/filter/filter-form-meta-object-select.d.ts +4 -0
- package/dist-client/component/filter/filter-form-meta-object-select.js +82 -0
- package/dist-client/component/filter/filter-form-meta-object-select.js.map +1 -0
- package/dist-client/component/filter/filter-grist-meta-code-select.d.ts +3 -0
- package/dist-client/component/filter/filter-grist-meta-code-select.js +76 -0
- package/dist-client/component/filter/filter-grist-meta-code-select.js.map +1 -0
- package/dist-client/component/filter/filter-grist-meta-object-select.d.ts +3 -0
- package/dist-client/component/filter/filter-grist-meta-object-select.js +81 -0
- package/dist-client/component/filter/filter-grist-meta-object-select.js.map +1 -0
- package/dist-client/component/grist/editor/grist-editor-code-input.d.ts +15 -0
- package/dist-client/component/grist/editor/grist-editor-code-input.js +81 -0
- package/dist-client/component/grist/editor/grist-editor-code-input.js.map +1 -0
- package/dist-client/component/grist/editor/grist-editor-meta-code-selector.d.ts +15 -0
- package/dist-client/component/grist/editor/grist-editor-meta-code-selector.js +130 -0
- package/dist-client/component/grist/editor/grist-editor-meta-code-selector.js.map +1 -0
- package/dist-client/component/grist/editor/grist-editor-meta-object-selector.d.ts +15 -0
- package/dist-client/component/grist/editor/grist-editor-meta-object-selector.js +98 -0
- package/dist-client/component/grist/editor/grist-editor-meta-object-selector.js.map +1 -0
- package/dist-client/component/grist/renderer/grist-renderer-code-input.d.ts +1 -0
- package/dist-client/component/grist/renderer/grist-renderer-code-input.js +19 -0
- package/dist-client/component/grist/renderer/grist-renderer-code-input.js.map +1 -0
- package/dist-client/component/grist/renderer/grist-renderer-meta-code-selector.d.ts +1 -0
- package/dist-client/component/grist/renderer/grist-renderer-meta-code-selector.js +29 -0
- package/dist-client/component/grist/renderer/grist-renderer-meta-code-selector.js.map +1 -0
- package/dist-client/component/grist/renderer/grist-renderer-meta-object-selector.d.ts +1 -0
- package/dist-client/component/grist/renderer/grist-renderer-meta-object-selector.js +23 -0
- package/dist-client/component/grist/renderer/grist-renderer-meta-object-selector.js.map +1 -0
- package/dist-client/component/popup/code-input-editor-popup.d.ts +36 -0
- package/dist-client/component/popup/code-input-editor-popup.js +103 -0
- package/dist-client/component/popup/code-input-editor-popup.js.map +1 -0
- package/dist-client/component/popup/file-upload-popup.d.ts +1 -0
- package/dist-client/component/popup/file-upload-popup.js +118 -0
- package/dist-client/component/popup/file-upload-popup.js.map +1 -0
- package/dist-client/component/popup/meta-object-selector-popup.d.ts +60 -0
- package/dist-client/component/popup/meta-object-selector-popup.js +300 -0
- package/dist-client/component/popup/meta-object-selector-popup.js.map +1 -0
- package/dist-client/component/popup/record-based-code-editor-popup.d.ts +52 -0
- package/dist-client/component/popup/record-based-code-editor-popup.js +174 -0
- package/dist-client/component/popup/record-based-code-editor-popup.js.map +1 -0
- package/dist-client/dynamic-menus.d.ts +1 -0
- package/dist-client/dynamic-menus.js +16 -0
- package/dist-client/dynamic-menus.js.map +1 -0
- package/dist-client/index.d.ts +17 -0
- package/dist-client/index.js +18 -0
- package/dist-client/index.js.map +1 -0
- package/dist-client/load-components.d.ts +15 -0
- package/dist-client/load-components.js +17 -0
- package/dist-client/load-components.js.map +1 -0
- package/dist-client/mixin/meta-base-mixin.d.ts +89 -0
- package/dist-client/mixin/meta-base-mixin.js +287 -0
- package/dist-client/mixin/meta-base-mixin.js.map +1 -0
- package/dist-client/mixin/meta-basic-grist-mixin.d.ts +108 -0
- package/dist-client/mixin/meta-basic-grist-mixin.js +253 -0
- package/dist-client/mixin/meta-basic-grist-mixin.js.map +1 -0
- package/dist-client/mixin/meta-button-mixin.d.ts +106 -0
- package/dist-client/mixin/meta-button-mixin.js +106 -0
- package/dist-client/mixin/meta-button-mixin.js.map +1 -0
- package/dist-client/mixin/meta-form-mixin.d.ts +153 -0
- package/dist-client/mixin/meta-form-mixin.js +373 -0
- package/dist-client/mixin/meta-form-mixin.js.map +1 -0
- package/dist-client/mixin/meta-grist-tab-mixin.d.ts +132 -0
- package/dist-client/mixin/meta-grist-tab-mixin.js +301 -0
- package/dist-client/mixin/meta-grist-tab-mixin.js.map +1 -0
- package/dist-client/mixin/meta-main-tab-mixin.d.ts +109 -0
- package/dist-client/mixin/meta-main-tab-mixin.js +242 -0
- package/dist-client/mixin/meta-main-tab-mixin.js.map +1 -0
- package/dist-client/mixin/meta-master-detail-mixin.d.ts +172 -0
- package/dist-client/mixin/meta-master-detail-mixin.js +359 -0
- package/dist-client/mixin/meta-master-detail-mixin.js.map +1 -0
- package/dist-client/mixin/meta-service-mixin.d.ts +66 -0
- package/dist-client/mixin/meta-service-mixin.js +268 -0
- package/dist-client/mixin/meta-service-mixin.js.map +1 -0
- package/dist-client/mixin/meta-tab-detail-mixin.d.ts +110 -0
- package/dist-client/mixin/meta-tab-detail-mixin.js +255 -0
- package/dist-client/mixin/meta-tab-detail-mixin.js.map +1 -0
- package/dist-client/mixin/meta-tab-mixin.d.ts +108 -0
- package/dist-client/mixin/meta-tab-mixin.js +168 -0
- package/dist-client/mixin/meta-tab-mixin.js.map +1 -0
- package/dist-client/pages/activity/meta-activity-define-page.d.ts +1 -0
- package/dist-client/pages/activity/meta-activity-define-page.js +398 -0
- package/dist-client/pages/activity/meta-activity-define-page.js.map +1 -0
- package/dist-client/pages/activity/meta-activity-list-page.d.ts +1 -0
- package/dist-client/pages/activity/meta-activity-list-page.js +223 -0
- package/dist-client/pages/activity/meta-activity-list-page.js.map +1 -0
- package/dist-client/pages/activity/meta-activity-viewer-element.d.ts +25 -0
- package/dist-client/pages/activity/meta-activity-viewer-element.js +29 -0
- package/dist-client/pages/activity/meta-activity-viewer-element.js.map +1 -0
- package/dist-client/pages/activity/meta-activity-writer-element.d.ts +27 -0
- package/dist-client/pages/activity/meta-activity-writer-element.js +38 -0
- package/dist-client/pages/activity/meta-activity-writer-element.js.map +1 -0
- package/dist-client/pages/activity/meta-activiy-mixin.d.ts +17 -0
- package/dist-client/pages/activity/meta-activiy-mixin.js +70 -0
- package/dist-client/pages/activity/meta-activiy-mixin.js.map +1 -0
- package/dist-client/pages/button-role/button-role-detail.d.ts +74 -0
- package/dist-client/pages/button-role/button-role-detail.js +39 -0
- package/dist-client/pages/button-role/button-role-detail.js.map +1 -0
- package/dist-client/pages/button-role/button-role-page.d.ts +82 -0
- package/dist-client/pages/button-role/button-role-page.js +21 -0
- package/dist-client/pages/button-role/button-role-page.js.map +1 -0
- package/dist-client/pages/doc-number/doc-number-page.d.ts +1 -0
- package/dist-client/pages/doc-number/doc-number-page.js +20 -0
- package/dist-client/pages/doc-number/doc-number-page.js.map +1 -0
- package/dist-client/pages/doc-number/next-doc-number-popup.d.ts +1 -0
- package/dist-client/pages/doc-number/next-doc-number-popup.js +21 -0
- package/dist-client/pages/doc-number/next-doc-number-popup.js.map +1 -0
- package/dist-client/pages/entity/config-entity.d.ts +1 -0
- package/dist-client/pages/entity/config-entity.js +801 -0
- package/dist-client/pages/entity/config-entity.js.map +1 -0
- package/dist-client/pages/entity/main-menu-selector.d.ts +61 -0
- package/dist-client/pages/entity/main-menu-selector.js +233 -0
- package/dist-client/pages/entity/main-menu-selector.js.map +1 -0
- package/dist-client/pages/history/history-copy-list-popup.d.ts +50 -0
- package/dist-client/pages/history/history-copy-list-popup.js +122 -0
- package/dist-client/pages/history/history-copy-list-popup.js.map +1 -0
- package/dist-client/pages/history/history-json-list-popup.d.ts +50 -0
- package/dist-client/pages/history/history-json-list-popup.js +132 -0
- package/dist-client/pages/history/history-json-list-popup.js.map +1 -0
- package/dist-client/pages/menu/dynamic-menu-template.d.ts +1 -0
- package/dist-client/pages/menu/dynamic-menu-template.js +80 -0
- package/dist-client/pages/menu/dynamic-menu-template.js.map +1 -0
- package/dist-client/pages/menu/dynamic-menu.d.ts +83 -0
- package/dist-client/pages/menu/dynamic-menu.js +663 -0
- package/dist-client/pages/menu/dynamic-menu.js.map +1 -0
- package/dist-client/pages/menu/export-menu-popup.d.ts +55 -0
- package/dist-client/pages/menu/export-menu-popup.js +392 -0
- package/dist-client/pages/menu/export-menu-popup.js.map +1 -0
- package/dist-client/pages/meta-form-element.d.ts +63 -0
- package/dist-client/pages/meta-form-element.js +8 -0
- package/dist-client/pages/meta-form-element.js.map +1 -0
- package/dist-client/pages/meta-grist-element.d.ts +70 -0
- package/dist-client/pages/meta-grist-element.js +11 -0
- package/dist-client/pages/meta-grist-element.js.map +1 -0
- package/dist-client/pages/meta-grist-page.d.ts +70 -0
- package/dist-client/pages/meta-grist-page.js +14 -0
- package/dist-client/pages/meta-grist-page.js.map +1 -0
- package/dist-client/pages/meta-grist-tab-element.d.ts +82 -0
- package/dist-client/pages/meta-grist-tab-element.js +14 -0
- package/dist-client/pages/meta-grist-tab-element.js.map +1 -0
- package/dist-client/pages/meta-grist-tab-page.d.ts +82 -0
- package/dist-client/pages/meta-grist-tab-page.js +14 -0
- package/dist-client/pages/meta-grist-tab-page.js.map +1 -0
- package/dist-client/pages/meta-main-tab-element.d.ts +75 -0
- package/dist-client/pages/meta-main-tab-element.js +11 -0
- package/dist-client/pages/meta-main-tab-element.js.map +1 -0
- package/dist-client/pages/meta-main-tab-page.d.ts +75 -0
- package/dist-client/pages/meta-main-tab-page.js +14 -0
- package/dist-client/pages/meta-main-tab-page.js.map +1 -0
- package/dist-client/pages/meta-master-detail-element.d.ts +80 -0
- package/dist-client/pages/meta-master-detail-element.js +11 -0
- package/dist-client/pages/meta-master-detail-element.js.map +1 -0
- package/dist-client/pages/meta-master-detail-page.d.ts +80 -0
- package/dist-client/pages/meta-master-detail-page.js +14 -0
- package/dist-client/pages/meta-master-detail-page.js.map +1 -0
- package/dist-client/pages/meta-tab-detail-element.d.ts +76 -0
- package/dist-client/pages/meta-tab-detail-element.js +11 -0
- package/dist-client/pages/meta-tab-detail-element.js.map +1 -0
- package/dist-client/pages/meta-tab-detail-page.d.ts +76 -0
- package/dist-client/pages/meta-tab-detail-page.js +14 -0
- package/dist-client/pages/meta-tab-detail-page.js.map +1 -0
- package/dist-client/pages/meta-tab-element.d.ts +57 -0
- package/dist-client/pages/meta-tab-element.js +13 -0
- package/dist-client/pages/meta-tab-element.js.map +1 -0
- package/dist-client/pages/printer-device/printer-device-page.d.ts +1 -0
- package/dist-client/pages/printer-device/printer-device-page.js +20 -0
- package/dist-client/pages/printer-device/printer-device-page.js.map +1 -0
- package/dist-client/pages/template/doc-template-page.d.ts +1 -0
- package/dist-client/pages/template/doc-template-page.js +20 -0
- package/dist-client/pages/template/doc-template-page.js.map +1 -0
- package/dist-client/pages/template/template-file-page.d.ts +1 -0
- package/dist-client/pages/template/template-file-page.js +20 -0
- package/dist-client/pages/template/template-file-page.js.map +1 -0
- package/dist-client/pages/terms/config-terminology.d.ts +1 -0
- package/dist-client/pages/terms/config-terminology.js +188 -0
- package/dist-client/pages/terms/config-terminology.js.map +1 -0
- package/dist-client/pages/work-code/work-code-detail-popup.d.ts +69 -0
- package/dist-client/pages/work-code/work-code-detail-popup.js +13 -0
- package/dist-client/pages/work-code/work-code-detail-popup.js.map +1 -0
- package/dist-client/pages/work-code/work-code-page.d.ts +1 -0
- package/dist-client/pages/work-code/work-code-page.js +19 -0
- package/dist-client/pages/work-code/work-code-page.js.map +1 -0
- package/dist-client/route.d.ts +1 -0
- package/dist-client/route.js +30 -0
- package/dist-client/route.js.map +1 -0
- package/dist-client/tsconfig.tsbuildinfo +1 -0
- package/dist-client/utils/grist-default-value.d.ts +8 -0
- package/dist-client/utils/grist-default-value.js +33 -0
- package/dist-client/utils/grist-default-value.js.map +1 -0
- package/dist-client/utils/meta-api.d.ts +572 -0
- package/dist-client/utils/meta-api.js +728 -0
- package/dist-client/utils/meta-api.js.map +1 -0
- package/dist-client/utils/meta-crypto.d.ts +4 -0
- package/dist-client/utils/meta-crypto.js +45 -0
- package/dist-client/utils/meta-crypto.js.map +1 -0
- package/dist-client/utils/meta-ui-util.d.ts +566 -0
- package/dist-client/utils/meta-ui-util.js +2985 -0
- package/dist-client/utils/meta-ui-util.js.map +1 -0
- package/dist-client/utils/rest-service-util.d.ts +120 -0
- package/dist-client/utils/rest-service-util.js +291 -0
- package/dist-client/utils/rest-service-util.js.map +1 -0
- package/dist-client/utils/service-util.d.ts +286 -0
- package/dist-client/utils/service-util.js +1204 -0
- package/dist-client/utils/service-util.js.map +1 -0
- package/dist-client/utils/terms-util.d.ts +81 -0
- package/dist-client/utils/terms-util.js +105 -0
- package/dist-client/utils/terms-util.js.map +1 -0
- package/dist-client/utils/ui-util.d.ts +153 -0
- package/dist-client/utils/ui-util.js +307 -0
- package/dist-client/utils/ui-util.js.map +1 -0
- package/dist-client/utils/value-util.d.ts +99 -0
- package/dist-client/utils/value-util.js +214 -0
- package/dist-client/utils/value-util.js.map +1 -0
- package/dist-server/activity/CommonActivity.d.ts +2 -0
- package/dist-server/activity/CommonActivity.js +58 -0
- package/dist-server/activity/CommonActivity.js.map +1 -0
- package/dist-server/index.d.ts +2 -0
- package/dist-server/index.js +6 -0
- package/dist-server/index.js.map +1 -0
- package/dist-server/routes.d.ts +1 -0
- package/dist-server/routes.js +58 -0
- package/dist-server/routes.js.map +1 -0
- package/dist-server/service/button-role/button-role-mutation.d.ts +9 -0
- package/dist-server/service/button-role/button-role-mutation.js +112 -0
- package/dist-server/service/button-role/button-role-mutation.js.map +1 -0
- package/dist-server/service/button-role/button-role-query.d.ts +11 -0
- package/dist-server/service/button-role/button-role-query.js +79 -0
- package/dist-server/service/button-role/button-role-query.js.map +1 -0
- package/dist-server/service/button-role/button-role-type.d.ts +15 -0
- package/dist-server/service/button-role/button-role-type.js +57 -0
- package/dist-server/service/button-role/button-role-type.js.map +1 -0
- package/dist-server/service/button-role/button-role.d.ts +15 -0
- package/dist-server/service/button-role/button-role.js +69 -0
- package/dist-server/service/button-role/button-role.js.map +1 -0
- package/dist-server/service/button-role/index.d.ts +5 -0
- package/dist-server/service/button-role/index.js +9 -0
- package/dist-server/service/button-role/index.js.map +1 -0
- package/dist-server/service/dynamic-menu/dynamic-menu-query.d.ts +11 -0
- package/dist-server/service/dynamic-menu/dynamic-menu-query.js +244 -0
- package/dist-server/service/dynamic-menu/dynamic-menu-query.js.map +1 -0
- package/dist-server/service/dynamic-menu/dynamic-menu-type.d.ts +30 -0
- package/dist-server/service/dynamic-menu/dynamic-menu-type.js +109 -0
- package/dist-server/service/dynamic-menu/dynamic-menu-type.js.map +1 -0
- package/dist-server/service/dynamic-menu/index.d.ts +2 -0
- package/dist-server/service/dynamic-menu/index.js +6 -0
- package/dist-server/service/dynamic-menu/index.js.map +1 -0
- package/dist-server/service/entity-event-subscriber/entity-event-subscriber.d.ts +6 -0
- package/dist-server/service/entity-event-subscriber/entity-event-subscriber.js +71 -0
- package/dist-server/service/entity-event-subscriber/entity-event-subscriber.js.map +1 -0
- package/dist-server/service/entity-event-subscriber/index.d.ts +2 -0
- package/dist-server/service/entity-event-subscriber/index.js +6 -0
- package/dist-server/service/entity-event-subscriber/index.js.map +1 -0
- package/dist-server/service/index.d.ts +9 -0
- package/dist-server/service/index.js +42 -0
- package/dist-server/service/index.js.map +1 -0
- package/dist-server/service/menu-button-auth/index.d.ts +5 -0
- package/dist-server/service/menu-button-auth/index.js +9 -0
- package/dist-server/service/menu-button-auth/index.js.map +1 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-mutation.d.ts +10 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-mutation.js +127 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-mutation.js.map +1 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-query.d.ts +16 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-query.js +167 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-query.js.map +1 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-type.d.ts +24 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-type.js +90 -0
- package/dist-server/service/menu-button-auth/menu-button-auth-type.js.map +1 -0
- package/dist-server/service/menu-button-auth/menu-button-auth.d.ts +23 -0
- package/dist-server/service/menu-button-auth/menu-button-auth.js +102 -0
- package/dist-server/service/menu-button-auth/menu-button-auth.js.map +1 -0
- package/dist-server/service/meta-activity/index.d.ts +3 -0
- package/dist-server/service/meta-activity/index.js +7 -0
- package/dist-server/service/meta-activity/index.js.map +1 -0
- package/dist-server/service/meta-activity/meta-activity-mutation.d.ts +18 -0
- package/dist-server/service/meta-activity/meta-activity-mutation.js +183 -0
- package/dist-server/service/meta-activity/meta-activity-mutation.js.map +1 -0
- package/dist-server/service/meta-activity/meta-activity-query.d.ts +10 -0
- package/dist-server/service/meta-activity/meta-activity-query.js +66 -0
- package/dist-server/service/meta-activity/meta-activity-query.js.map +1 -0
- package/dist-server/service/meta-activity/meta-activity-type.d.ts +21 -0
- package/dist-server/service/meta-activity/meta-activity-type.js +80 -0
- package/dist-server/service/meta-activity/meta-activity-type.js.map +1 -0
- package/dist-server/service/set-translations/index.d.ts +2 -0
- package/dist-server/service/set-translations/index.js +6 -0
- package/dist-server/service/set-translations/index.js.map +1 -0
- package/dist-server/service/set-translations/set-translation-resolver.d.ts +4 -0
- package/dist-server/service/set-translations/set-translation-resolver.js +67 -0
- package/dist-server/service/set-translations/set-translation-resolver.js.map +1 -0
- package/dist-server/service/work-code/index.d.ts +5 -0
- package/dist-server/service/work-code/index.js +9 -0
- package/dist-server/service/work-code/index.js.map +1 -0
- package/dist-server/service/work-code/work-code-mutation.d.ts +10 -0
- package/dist-server/service/work-code/work-code-mutation.js +136 -0
- package/dist-server/service/work-code/work-code-mutation.js.map +1 -0
- package/dist-server/service/work-code/work-code-query.d.ts +14 -0
- package/dist-server/service/work-code/work-code-query.js +106 -0
- package/dist-server/service/work-code/work-code-query.js.map +1 -0
- package/dist-server/service/work-code/work-code-type.d.ts +23 -0
- package/dist-server/service/work-code/work-code-type.js +89 -0
- package/dist-server/service/work-code/work-code-type.js.map +1 -0
- package/dist-server/service/work-code/work-code.d.ts +20 -0
- package/dist-server/service/work-code/work-code.js +94 -0
- package/dist-server/service/work-code/work-code.js.map +1 -0
- package/dist-server/service/work-code-detail/index.d.ts +5 -0
- package/dist-server/service/work-code-detail/index.js +9 -0
- package/dist-server/service/work-code-detail/index.js.map +1 -0
- package/dist-server/service/work-code-detail/work-code-detail-mutation.d.ts +10 -0
- package/dist-server/service/work-code-detail/work-code-detail-mutation.js +138 -0
- package/dist-server/service/work-code-detail/work-code-detail-mutation.js.map +1 -0
- package/dist-server/service/work-code-detail/work-code-detail-query.d.ts +13 -0
- package/dist-server/service/work-code-detail/work-code-detail-query.js +89 -0
- package/dist-server/service/work-code-detail/work-code-detail-query.js.map +1 -0
- package/dist-server/service/work-code-detail/work-code-detail-type.d.ts +20 -0
- package/dist-server/service/work-code-detail/work-code-detail-type.js +74 -0
- package/dist-server/service/work-code-detail/work-code-detail-type.js.map +1 -0
- package/dist-server/service/work-code-detail/work-code-detail.d.ts +19 -0
- package/dist-server/service/work-code-detail/work-code-detail.js +93 -0
- package/dist-server/service/work-code-detail/work-code-detail.js.map +1 -0
- package/dist-server/tsconfig.tsbuildinfo +1 -0
- package/package.json +10 -10
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import '@material/web/icon/icon.js';
|
|
2
|
+
import { client, gqlContext } from '@things-factory/shell';
|
|
3
|
+
import { css, html, LitElement } from 'lit';
|
|
4
|
+
import { SingleColumnFormStyles } from '@things-factory/form-ui';
|
|
5
|
+
import { CommonHeaderStyles } from '@operato/styles';
|
|
6
|
+
import gql from 'graphql-tag';
|
|
7
|
+
import { TermsUtil } from '../../utils/terms-util';
|
|
8
|
+
import { ServiceUtil } from '../../utils/service-util';
|
|
9
|
+
import { MetaApi } from '../../utils/meta-api';
|
|
10
|
+
class FileUploadPopup extends LitElement {
|
|
11
|
+
static get styles() {
|
|
12
|
+
return [
|
|
13
|
+
CommonHeaderStyles,
|
|
14
|
+
SingleColumnFormStyles,
|
|
15
|
+
css `
|
|
16
|
+
:host {
|
|
17
|
+
padding: 10px;
|
|
18
|
+
display: flex;
|
|
19
|
+
flex-direction: column;
|
|
20
|
+
overflow-x: overlay;
|
|
21
|
+
background-color: var(--md-sys-color-background);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.input-container {
|
|
25
|
+
display: flex;
|
|
26
|
+
}
|
|
27
|
+
`
|
|
28
|
+
];
|
|
29
|
+
}
|
|
30
|
+
static get properties() {
|
|
31
|
+
return {
|
|
32
|
+
templateTypes: Array
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
async connectedCallback() {
|
|
36
|
+
super.connectedCallback();
|
|
37
|
+
this.templateTypes = await ServiceUtil.codeItems('TEMPLATE_TYPES');
|
|
38
|
+
}
|
|
39
|
+
render() {
|
|
40
|
+
return html `
|
|
41
|
+
<div>
|
|
42
|
+
<form id="input-form" class="single-column-form">
|
|
43
|
+
<fieldset>
|
|
44
|
+
<legend>${TermsUtil.tLabel('file_upload')}</legend>
|
|
45
|
+
<label>${TermsUtil.tLabel('file_upload')}</label>
|
|
46
|
+
<file-uploader custom-input id="uploadTemplate" name="attachments"></file-uploader>
|
|
47
|
+
|
|
48
|
+
<label>${TermsUtil.tLabel('category')}</label>
|
|
49
|
+
<select name="category" required>
|
|
50
|
+
<option value="">${TermsUtil.tText('please_select_upload_category')}</option>
|
|
51
|
+
${(this.templateTypes || []).map(templateType => {
|
|
52
|
+
const { name, description } = templateType;
|
|
53
|
+
return html ` <option value="${name}">${name} ${description ? ` (${description})` : ''}</option> `;
|
|
54
|
+
})}
|
|
55
|
+
</select>
|
|
56
|
+
|
|
57
|
+
<label>${TermsUtil.tLabel('description')}</label>
|
|
58
|
+
<input name="description" />
|
|
59
|
+
</fieldset>
|
|
60
|
+
</form>
|
|
61
|
+
</div>
|
|
62
|
+
|
|
63
|
+
<div class="footer">
|
|
64
|
+
<div filler></div>
|
|
65
|
+
<button @click=${this._createAttachment} done>
|
|
66
|
+
<md-icon>attach_file_add</md-icon>${TermsUtil.tButton('create')}
|
|
67
|
+
</button>
|
|
68
|
+
</div>
|
|
69
|
+
`;
|
|
70
|
+
}
|
|
71
|
+
get _template() {
|
|
72
|
+
return this.renderRoot.querySelector('#uploadTemplate');
|
|
73
|
+
}
|
|
74
|
+
async _createAttachment() {
|
|
75
|
+
try {
|
|
76
|
+
const attachment = this._getAttachmentInfo();
|
|
77
|
+
const response = await client.mutate({
|
|
78
|
+
mutation: gql `
|
|
79
|
+
mutation ($attachment: NewAttachment!) {
|
|
80
|
+
createAttachment(attachment: $attachment) {
|
|
81
|
+
id
|
|
82
|
+
name
|
|
83
|
+
path
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
`,
|
|
87
|
+
variables: {
|
|
88
|
+
attachment
|
|
89
|
+
},
|
|
90
|
+
context: Object.assign(Object.assign({}, gqlContext()), { hasUpload: true })
|
|
91
|
+
});
|
|
92
|
+
if (!response.errors) {
|
|
93
|
+
history.back();
|
|
94
|
+
this.dispatchEvent(new CustomEvent('template-uploaded', { bubbles: true, composed: true, cancelable: true }));
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
catch (e) {
|
|
98
|
+
MetaApi.showAlertPopup('label.error', e.message, 'error', 'confirm');
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
_getAttachmentInfo() {
|
|
102
|
+
if (this.renderRoot.querySelector('form').checkValidity()) {
|
|
103
|
+
return {
|
|
104
|
+
file: this._template.files[0],
|
|
105
|
+
category: this._getInputByName('category').value,
|
|
106
|
+
description: this._getInputByName('description').value
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
throw new Error(TermsUtil.tText('text.attachment_info_not_valid'));
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
_getInputByName(name) {
|
|
114
|
+
return this.renderRoot.querySelector(`select[name=${name}], input[name=${name}]`);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
window.customElements.define('file-upload-popup', FileUploadPopup);
|
|
118
|
+
//# sourceMappingURL=file-upload-popup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-upload-popup.js","sourceRoot":"","sources":["../../../client/component/popup/file-upload-popup.js"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport { client, gqlContext } from '@things-factory/shell'\nimport { css, html, LitElement } from 'lit'\nimport { SingleColumnFormStyles } from '@things-factory/form-ui'\nimport { CommonHeaderStyles } from '@operato/styles'\nimport gql from 'graphql-tag'\nimport { TermsUtil } from '../../utils/terms-util'\nimport { ServiceUtil } from '../../utils/service-util'\nimport { MetaApi } from '../../utils/meta-api'\n\nclass FileUploadPopup extends LitElement {\n static get styles() {\n return [\n CommonHeaderStyles,\n SingleColumnFormStyles,\n css`\n :host {\n padding: 10px;\n display: flex;\n flex-direction: column;\n overflow-x: overlay;\n background-color: var(--md-sys-color-background);\n }\n\n .input-container {\n display: flex;\n }\n `\n ]\n }\n\n static get properties() {\n return {\n templateTypes: Array\n }\n }\n\n async connectedCallback() {\n super.connectedCallback()\n this.templateTypes = await ServiceUtil.codeItems('TEMPLATE_TYPES')\n }\n\n render() {\n return html`\n <div>\n <form id=\"input-form\" class=\"single-column-form\">\n <fieldset>\n <legend>${TermsUtil.tLabel('file_upload')}</legend>\n <label>${TermsUtil.tLabel('file_upload')}</label>\n <file-uploader custom-input id=\"uploadTemplate\" name=\"attachments\"></file-uploader>\n\n <label>${TermsUtil.tLabel('category')}</label>\n <select name=\"category\" required>\n <option value=\"\">${TermsUtil.tText('please_select_upload_category')}</option>\n ${(this.templateTypes || []).map(templateType => {\n const { name, description } = templateType\n return html` <option value=\"${name}\">${name} ${description ? ` (${description})` : ''}</option> `\n })}\n </select>\n\n <label>${TermsUtil.tLabel('description')}</label>\n <input name=\"description\" />\n </fieldset>\n </form>\n </div>\n\n <div class=\"footer\">\n <div filler></div>\n <button @click=${this._createAttachment} done>\n <md-icon>attach_file_add</md-icon>${TermsUtil.tButton('create')}\n </button>\n </div>\n `\n }\n\n get _template() {\n return this.renderRoot.querySelector('#uploadTemplate')\n }\n\n async _createAttachment() {\n try {\n const attachment = this._getAttachmentInfo()\n const response = await client.mutate({\n mutation: gql`\n mutation ($attachment: NewAttachment!) {\n createAttachment(attachment: $attachment) {\n id\n name\n path\n }\n }\n `,\n variables: {\n attachment\n },\n context: {\n ...gqlContext(),\n hasUpload: true\n }\n })\n\n if (!response.errors) {\n history.back()\n this.dispatchEvent(new CustomEvent('template-uploaded', { bubbles: true, composed: true, cancelable: true }))\n }\n } catch (e) {\n MetaApi.showAlertPopup('label.error', e.message, 'error', 'confirm')\n }\n }\n\n _getAttachmentInfo() {\n if (this.renderRoot.querySelector('form').checkValidity()) {\n return {\n file: this._template.files[0],\n category: this._getInputByName('category').value,\n description: this._getInputByName('description').value\n }\n } else {\n throw new Error(TermsUtil.tText('text.attachment_info_not_valid'))\n }\n }\n\n _getInputByName(name) {\n return this.renderRoot.querySelector(`select[name=${name}], input[name=${name}]`)\n }\n}\n\nwindow.customElements.define('file-upload-popup', FileUploadPopup)\n"]}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import '@material/web/icon/icon.js';
|
|
2
|
+
import { LitElement, PropertyValues } from 'lit';
|
|
3
|
+
import { ColumnConfig, FetchOption, FetchResult, GristRecord } from '@operato/data-grist';
|
|
4
|
+
export declare class MetaObjectSelectorPopup extends LitElement {
|
|
5
|
+
static styles: import("lit").CSSResult[];
|
|
6
|
+
value?: string;
|
|
7
|
+
gridConfig: any;
|
|
8
|
+
basicArgs?: FetchOption;
|
|
9
|
+
options: FetchOption & {
|
|
10
|
+
menu_template?: any;
|
|
11
|
+
filterFields?: any[];
|
|
12
|
+
codeField?: string;
|
|
13
|
+
nameField?: string;
|
|
14
|
+
dispField?: string;
|
|
15
|
+
queryName: string;
|
|
16
|
+
select?: (ColumnConfig & {
|
|
17
|
+
options: any;
|
|
18
|
+
select_opt: any;
|
|
19
|
+
object_opt: any;
|
|
20
|
+
})[];
|
|
21
|
+
};
|
|
22
|
+
confirmCallback?: (record?: Partial<GristRecord>) => void;
|
|
23
|
+
selectedRecords: GristRecord[];
|
|
24
|
+
private grist;
|
|
25
|
+
private foundationFilters;
|
|
26
|
+
private record;
|
|
27
|
+
connectedCallback(): Promise<void>;
|
|
28
|
+
firstUpdated(changes: PropertyValues<this>): Promise<void>;
|
|
29
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
30
|
+
/**
|
|
31
|
+
* @description 컬럼 조회
|
|
32
|
+
***************************
|
|
33
|
+
* @returns
|
|
34
|
+
*/
|
|
35
|
+
fetchHandler({ page, limit, sorters, filters }: FetchOption): Promise<FetchResult>;
|
|
36
|
+
/**
|
|
37
|
+
* @description 비우기
|
|
38
|
+
***************************
|
|
39
|
+
* @returns
|
|
40
|
+
*/
|
|
41
|
+
clickEmpty(e: any): Promise<void>;
|
|
42
|
+
/**
|
|
43
|
+
* @description 취소
|
|
44
|
+
***************************
|
|
45
|
+
* @returns
|
|
46
|
+
*/
|
|
47
|
+
clickCancel(e: any): Promise<void>;
|
|
48
|
+
/**
|
|
49
|
+
* @description 선택
|
|
50
|
+
***************************
|
|
51
|
+
* @returns
|
|
52
|
+
*/
|
|
53
|
+
clickSelect(e: any): Promise<void>;
|
|
54
|
+
/**
|
|
55
|
+
* @description 확정
|
|
56
|
+
***************************
|
|
57
|
+
* @param {*} record
|
|
58
|
+
*/
|
|
59
|
+
selectRecord(record: any): Promise<void>;
|
|
60
|
+
}
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
|
2
|
+
import '@material/web/icon/icon.js';
|
|
3
|
+
import { css, html, LitElement } from 'lit';
|
|
4
|
+
import { customElement, property, query } from 'lit/decorators.js';
|
|
5
|
+
import { closePopup } from '@operato/popup';
|
|
6
|
+
import { isMobileDevice, adjustFilters } from '@operato/utils';
|
|
7
|
+
import { CommonGristStyles, CommonHeaderStyles } from '@operato/styles';
|
|
8
|
+
import { DataGrist } from '@operato/data-grist';
|
|
9
|
+
import { TermsUtil } from '../../utils/terms-util';
|
|
10
|
+
import { ValueUtil } from '../../utils/value-util';
|
|
11
|
+
import { ServiceUtil } from '../../utils/service-util';
|
|
12
|
+
import { MetaApi } from '../../utils/meta-api';
|
|
13
|
+
import { MetaUiUtil } from '../../utils/meta-ui-util';
|
|
14
|
+
let MetaObjectSelectorPopup = class MetaObjectSelectorPopup extends LitElement {
|
|
15
|
+
constructor() {
|
|
16
|
+
super(...arguments);
|
|
17
|
+
this.selectedRecords = [];
|
|
18
|
+
this.foundationFilters = [];
|
|
19
|
+
}
|
|
20
|
+
async connectedCallback() {
|
|
21
|
+
const { select, sorters, filters, codeField, nameField, dispField, filterFields: optionFilterFields, menu_template } = this.options || {};
|
|
22
|
+
// 숨김 검색 조건
|
|
23
|
+
this.foundationFilters = filters ? filters : this.basicArgs && this.basicArgs.filters ? this.basicArgs.filters : [];
|
|
24
|
+
this.foundationFilters = this.foundationFilters.map(x => {
|
|
25
|
+
let { name, operator, value } = x;
|
|
26
|
+
if (value.startsWith('::')) {
|
|
27
|
+
value = ValueUtil.getParams(this.record, ...value.substring(2).split('.'));
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
name,
|
|
31
|
+
operator,
|
|
32
|
+
value
|
|
33
|
+
};
|
|
34
|
+
});
|
|
35
|
+
// 기본 정렬
|
|
36
|
+
let sortFields = sorters ? sorters : this.basicArgs && this.basicArgs.sorters ? this.basicArgs.sorters : [];
|
|
37
|
+
// 기본 검색 조건
|
|
38
|
+
let filterFields = optionFilterFields
|
|
39
|
+
? optionFilterFields
|
|
40
|
+
: (menu_template === null || menu_template === void 0 ? void 0 : menu_template.search) && (menu_template === null || menu_template === void 0 ? void 0 : menu_template.search.length) > 0
|
|
41
|
+
? menu_template.search
|
|
42
|
+
: [];
|
|
43
|
+
// 그리드 컬럼
|
|
44
|
+
let gridColumns = select;
|
|
45
|
+
// 기본 검색 조건이 없으면 코드 (code-selector), 또는 이름 (object-selector)
|
|
46
|
+
if (!filterFields || filterFields.length == 0) {
|
|
47
|
+
let defaultFilter;
|
|
48
|
+
if (codeField)
|
|
49
|
+
defaultFilter = codeField;
|
|
50
|
+
if (nameField)
|
|
51
|
+
defaultFilter = nameField;
|
|
52
|
+
if (defaultFilter) {
|
|
53
|
+
filterFields.push({
|
|
54
|
+
name: defaultFilter,
|
|
55
|
+
operator: 'eq'
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
let selectFields = [...MetaApi.getGristGuttersConfig(true, false)];
|
|
60
|
+
if (gridColumns && gridColumns.length > 0) {
|
|
61
|
+
for (let idx = 0; idx < gridColumns.length; idx++) {
|
|
62
|
+
let { type = 'string', name, hidden = false, record = { align: 'left' }, header = undefined, sortable = false, width = 135, options = undefined, select_opt = undefined, object_opt = undefined } = gridColumns[idx];
|
|
63
|
+
if (select_opt)
|
|
64
|
+
options = select_opt;
|
|
65
|
+
if (object_opt)
|
|
66
|
+
options = object_opt;
|
|
67
|
+
if (['resource-object', 'object'].includes(type)) {
|
|
68
|
+
type = 'meta-object-selector';
|
|
69
|
+
}
|
|
70
|
+
else if (['resource-code-selector'].includes(type)) {
|
|
71
|
+
type = 'meta-code-selector';
|
|
72
|
+
}
|
|
73
|
+
if (name == 'id') {
|
|
74
|
+
selectFields.push({
|
|
75
|
+
type: 'string',
|
|
76
|
+
name: name,
|
|
77
|
+
hidden: true
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
if (type == 'boolean-all') {
|
|
82
|
+
type = 'boolean';
|
|
83
|
+
}
|
|
84
|
+
let columnConfig = MetaApi.getGristColumnConfig2(type, name, header ? header : name, record.align ? record.align : 'left', false, sortable, Number(width));
|
|
85
|
+
if (type.startsWith('meta-') && object_opt && object_opt.menu) {
|
|
86
|
+
options = await MetaUiUtil.getGristMetaObjectOptions(type, options);
|
|
87
|
+
}
|
|
88
|
+
if (type === 'select') {
|
|
89
|
+
if (Array.isArray(options)) {
|
|
90
|
+
columnConfig.record.options = options;
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
if (options.type === 'code') {
|
|
94
|
+
// 공통 코드
|
|
95
|
+
columnConfig.record.options = await ServiceUtil.getCodeSelectorData(options.values ? options.values : options.name);
|
|
96
|
+
}
|
|
97
|
+
else if (options.type === 'scenario') {
|
|
98
|
+
// 시나리오
|
|
99
|
+
columnConfig.record.options = await ServiceUtil.getCodeByScenario(options.name, options.args);
|
|
100
|
+
}
|
|
101
|
+
else if (options.type === 'entity') {
|
|
102
|
+
// 엔티티
|
|
103
|
+
columnConfig.record.options = await ServiceUtil.getCodeByEntity(options.args);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
else if (type === 'meta-object-selector') {
|
|
108
|
+
// object-option
|
|
109
|
+
columnConfig.record.options = Object.assign({}, options);
|
|
110
|
+
}
|
|
111
|
+
else if (type == 'meta-code-selector') {
|
|
112
|
+
if (options.dispField) {
|
|
113
|
+
options.codes = await ServiceUtil.getCodeByEntity(options);
|
|
114
|
+
}
|
|
115
|
+
columnConfig.record.options = Object.assign({}, options);
|
|
116
|
+
}
|
|
117
|
+
columnConfig.hidden = hidden;
|
|
118
|
+
selectFields.push(columnConfig);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
selectFields.push(MetaApi.getGristColumnConfig2('string', codeField, codeField, 'left', false, true, 180));
|
|
124
|
+
if (dispField) {
|
|
125
|
+
selectFields.push(MetaApi.getGristColumnConfig2('string', dispField, dispField, 'left', false, true, 300));
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
selectFields.forEach(x => {
|
|
129
|
+
let filters = filterFields.filter(y => (typeof y === 'string' ? x.name == y : x.name == y.name));
|
|
130
|
+
if (filters && filters.length > 0) {
|
|
131
|
+
x.filter = typeof filters[0] === 'string' ? 'search' : filters[0];
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
let gridConfig = {
|
|
135
|
+
rows: MetaApi.getGristSelectableConfig(false),
|
|
136
|
+
pagination: MetaApi.getGristPagination100Config(),
|
|
137
|
+
columns: selectFields,
|
|
138
|
+
sorters: [...sortFields]
|
|
139
|
+
};
|
|
140
|
+
gridConfig.rows.handlers = {
|
|
141
|
+
click: 'select-row-toggle',
|
|
142
|
+
dblclick: (columns, data, column, record, rowIndex, field) => {
|
|
143
|
+
this.selectRecord(record);
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
gridConfig.rows.appendable = false;
|
|
147
|
+
this.gridConfig = gridConfig;
|
|
148
|
+
await super.connectedCallback();
|
|
149
|
+
}
|
|
150
|
+
async firstUpdated(changes) {
|
|
151
|
+
await super.firstUpdated(changes);
|
|
152
|
+
}
|
|
153
|
+
render() {
|
|
154
|
+
return html `
|
|
155
|
+
<ox-grist
|
|
156
|
+
id="ox-grist"
|
|
157
|
+
.config=${this.gridConfig}
|
|
158
|
+
.mode=${isMobileDevice() ? 'LIST' : 'GRID'}
|
|
159
|
+
auto-fetch
|
|
160
|
+
.fetchHandler=${this.fetchHandler.bind(this)}
|
|
161
|
+
>
|
|
162
|
+
<div slot="headroom" class="header">
|
|
163
|
+
<div class="filters">
|
|
164
|
+
<ox-filters-form></ox-filters-form>
|
|
165
|
+
</div>
|
|
166
|
+
</div>
|
|
167
|
+
</ox-grist>
|
|
168
|
+
|
|
169
|
+
<div class="footer">
|
|
170
|
+
<button @click=${this.clickEmpty.bind(this)}>
|
|
171
|
+
<md-icon>check_box_outline_blank</md-icon>${TermsUtil.tButton('empty')}
|
|
172
|
+
</button>
|
|
173
|
+
<div filler></div>
|
|
174
|
+
<button @click=${this.clickCancel.bind(this)}><md-icon>cancel</md-icon>${TermsUtil.tButton('cancel')}</button>
|
|
175
|
+
<button @click=${this.clickSelect.bind(this)} done>
|
|
176
|
+
<md-icon>done</md-icon>${TermsUtil.tButton('select')}
|
|
177
|
+
</button>
|
|
178
|
+
</div>
|
|
179
|
+
`;
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* @description 컬럼 조회
|
|
183
|
+
***************************
|
|
184
|
+
* @returns
|
|
185
|
+
*/
|
|
186
|
+
async fetchHandler({ page = 0, limit = 0, sorters = [], filters = [] }) {
|
|
187
|
+
const { menu_template, queryName } = this.options || {};
|
|
188
|
+
// let resFilter = [...this.foundationFilters]
|
|
189
|
+
// filters.forEach((x: any) => {
|
|
190
|
+
// let dupFilter = resFilter.filter(y => x.name == y.name)
|
|
191
|
+
// if (dupFilter && dupFilter.length > 0) {
|
|
192
|
+
// delete resFilter[x.name]
|
|
193
|
+
// }
|
|
194
|
+
// resFilter.push(x)
|
|
195
|
+
// })
|
|
196
|
+
let resFilter = adjustFilters([...this.foundationFilters], filters);
|
|
197
|
+
let queryAfterSetFields = ValueUtil.getParams(menu_template ? menu_template.gql || {} : {}, 'query', 'after_set_fields');
|
|
198
|
+
let selectSkipFields = Object.keys(queryAfterSetFields || {});
|
|
199
|
+
// 조회 컬럼 추출 후 조회
|
|
200
|
+
let selectFields = MetaApi.getSelectColumns(this.gridConfig.columns.filter(x => !selectSkipFields.includes(x.name)));
|
|
201
|
+
// 조회 실행
|
|
202
|
+
let result = await MetaApi.searchByPagination(queryName, resFilter, sorters, page, limit, selectFields);
|
|
203
|
+
return result;
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* @description 비우기
|
|
207
|
+
***************************
|
|
208
|
+
* @returns
|
|
209
|
+
*/
|
|
210
|
+
async clickEmpty(e) {
|
|
211
|
+
this.confirmCallback && this.confirmCallback();
|
|
212
|
+
closePopup(this);
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* @description 취소
|
|
216
|
+
***************************
|
|
217
|
+
* @returns
|
|
218
|
+
*/
|
|
219
|
+
async clickCancel(e) {
|
|
220
|
+
closePopup(this);
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* @description 선택
|
|
224
|
+
***************************
|
|
225
|
+
* @returns
|
|
226
|
+
*/
|
|
227
|
+
async clickSelect(e) {
|
|
228
|
+
let selected = this.grist.selected;
|
|
229
|
+
if (!selected || selected.length == 0) {
|
|
230
|
+
MetaApi.showToast('info', TermsUtil.tText('NOTHING_SELECTED'));
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
this.selectRecord(selected[0]);
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* @description 확정
|
|
237
|
+
***************************
|
|
238
|
+
* @param {*} record
|
|
239
|
+
*/
|
|
240
|
+
async selectRecord(record) {
|
|
241
|
+
this.confirmCallback && this.confirmCallback(record);
|
|
242
|
+
closePopup(this);
|
|
243
|
+
}
|
|
244
|
+
};
|
|
245
|
+
MetaObjectSelectorPopup.styles = [
|
|
246
|
+
CommonGristStyles,
|
|
247
|
+
CommonHeaderStyles,
|
|
248
|
+
css `
|
|
249
|
+
:host {
|
|
250
|
+
display: flex;
|
|
251
|
+
flex-direction: column;
|
|
252
|
+
|
|
253
|
+
background-color: var(--md-sys-color-surface);
|
|
254
|
+
|
|
255
|
+
width: var(--overlay-center-normal-width, 50%);
|
|
256
|
+
height: var(--overlay-center-normal-height, 50%);
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
ox-grist {
|
|
260
|
+
flex: 1;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
ox-filters-form {
|
|
264
|
+
flex: 1;
|
|
265
|
+
}
|
|
266
|
+
`
|
|
267
|
+
];
|
|
268
|
+
__decorate([
|
|
269
|
+
property({ type: String }),
|
|
270
|
+
__metadata("design:type", String)
|
|
271
|
+
], MetaObjectSelectorPopup.prototype, "value", void 0);
|
|
272
|
+
__decorate([
|
|
273
|
+
property({ type: Object }),
|
|
274
|
+
__metadata("design:type", Object)
|
|
275
|
+
], MetaObjectSelectorPopup.prototype, "gridConfig", void 0);
|
|
276
|
+
__decorate([
|
|
277
|
+
property({ type: Object }),
|
|
278
|
+
__metadata("design:type", Object)
|
|
279
|
+
], MetaObjectSelectorPopup.prototype, "basicArgs", void 0);
|
|
280
|
+
__decorate([
|
|
281
|
+
property({ type: Object }),
|
|
282
|
+
__metadata("design:type", Object)
|
|
283
|
+
], MetaObjectSelectorPopup.prototype, "options", void 0);
|
|
284
|
+
__decorate([
|
|
285
|
+
property({ type: Object }),
|
|
286
|
+
__metadata("design:type", Function)
|
|
287
|
+
], MetaObjectSelectorPopup.prototype, "confirmCallback", void 0);
|
|
288
|
+
__decorate([
|
|
289
|
+
property({ type: Array }),
|
|
290
|
+
__metadata("design:type", Array)
|
|
291
|
+
], MetaObjectSelectorPopup.prototype, "selectedRecords", void 0);
|
|
292
|
+
__decorate([
|
|
293
|
+
query('ox-grist'),
|
|
294
|
+
__metadata("design:type", DataGrist)
|
|
295
|
+
], MetaObjectSelectorPopup.prototype, "grist", void 0);
|
|
296
|
+
MetaObjectSelectorPopup = __decorate([
|
|
297
|
+
customElement('meta-object-selector-popup')
|
|
298
|
+
], MetaObjectSelectorPopup);
|
|
299
|
+
export { MetaObjectSelectorPopup };
|
|
300
|
+
//# sourceMappingURL=meta-object-selector-popup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"meta-object-selector-popup.js","sourceRoot":"","sources":["../../../client/component/popup/meta-object-selector-popup.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport { css, html, LitElement, PropertyValues } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { closePopup } from '@operato/popup'\nimport { isMobileDevice, adjustFilters } from '@operato/utils'\nimport { CommonGristStyles, CommonHeaderStyles } from '@operato/styles'\nimport { ColumnConfig, DataGrist, FetchOption, FetchResult, GristRecord, QueryFilter } from '@operato/data-grist'\n\nimport { TermsUtil } from '../../utils/terms-util'\nimport { ValueUtil } from '../../utils/value-util'\nimport { ServiceUtil } from '../../utils/service-util'\nimport { MetaApi } from '../../utils/meta-api'\nimport { MetaUiUtil } from '../../utils/meta-ui-util'\n\n@customElement('meta-object-selector-popup')\nexport class MetaObjectSelectorPopup extends LitElement {\n static styles = [\n CommonGristStyles,\n CommonHeaderStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n\n background-color: var(--md-sys-color-surface);\n\n width: var(--overlay-center-normal-width, 50%);\n height: var(--overlay-center-normal-height, 50%);\n }\n\n ox-grist {\n flex: 1;\n }\n\n ox-filters-form {\n flex: 1;\n }\n `\n ]\n\n @property({ type: String }) value?: string\n @property({ type: Object }) gridConfig: any\n @property({ type: Object }) basicArgs?: FetchOption\n @property({ type: Object }) options!: FetchOption & {\n menu_template?: any\n filterFields?: any[]\n codeField?: string\n nameField?: string\n dispField?: string\n queryName: string\n select?: (ColumnConfig & {\n options: any\n select_opt: any\n object_opt: any\n })[]\n }\n @property({ type: Object }) confirmCallback?: (record?: Partial<GristRecord>) => void\n @property({ type: Array }) selectedRecords: GristRecord[] = []\n\n @query('ox-grist') private grist!: DataGrist\n\n private foundationFilters: QueryFilter[] = []\n private record: any\n\n async connectedCallback() {\n const {\n select,\n sorters,\n filters,\n codeField,\n nameField,\n dispField,\n filterFields: optionFilterFields,\n menu_template\n } = this.options || {}\n\n // 숨김 검색 조건\n this.foundationFilters = filters ? filters : this.basicArgs && this.basicArgs.filters ? this.basicArgs.filters : []\n\n this.foundationFilters = this.foundationFilters.map(x => {\n let { name, operator, value } = x\n\n if (value.startsWith('::')) {\n value = ValueUtil.getParams(this.record, ...value.substring(2).split('.'))\n }\n\n return {\n name,\n operator,\n value\n }\n })\n\n // 기본 정렬\n let sortFields = sorters ? sorters : this.basicArgs && this.basicArgs.sorters ? this.basicArgs.sorters : []\n\n // 기본 검색 조건\n let filterFields = optionFilterFields\n ? optionFilterFields\n : menu_template?.search && menu_template?.search.length > 0\n ? menu_template.search\n : []\n\n // 그리드 컬럼\n let gridColumns = select\n\n // 기본 검색 조건이 없으면 코드 (code-selector), 또는 이름 (object-selector)\n if (!filterFields || filterFields.length == 0) {\n let defaultFilter\n\n if (codeField) defaultFilter = codeField\n if (nameField) defaultFilter = nameField\n\n if (defaultFilter) {\n filterFields.push({\n name: defaultFilter,\n operator: 'eq'\n })\n }\n }\n\n let selectFields = [...MetaApi.getGristGuttersConfig(true, false)]\n\n if (gridColumns && gridColumns.length > 0) {\n for (let idx = 0; idx < gridColumns.length; idx++) {\n let {\n type = 'string',\n name,\n hidden = false,\n record = { align: 'left' },\n header = undefined,\n sortable = false,\n width = 135,\n options = undefined,\n select_opt = undefined,\n object_opt = undefined\n } = gridColumns[idx]\n\n if (select_opt) options = select_opt\n if (object_opt) options = object_opt\n\n if (['resource-object', 'object'].includes(type)) {\n type = 'meta-object-selector'\n } else if (['resource-code-selector'].includes(type)) {\n type = 'meta-code-selector'\n }\n\n if (name == 'id') {\n selectFields.push({\n type: 'string',\n name: name,\n hidden: true\n })\n } else {\n if (type == 'boolean-all') {\n type = 'boolean'\n }\n\n let columnConfig = MetaApi.getGristColumnConfig2(\n type,\n name,\n header ? (header as unknown as string) : name,\n record.align ? record.align : 'left',\n false,\n sortable,\n Number(width)\n )\n\n if (type.startsWith('meta-') && object_opt && object_opt.menu) {\n options = await MetaUiUtil.getGristMetaObjectOptions(type, options)\n }\n\n if (type === 'select') {\n if (Array.isArray(options)) {\n columnConfig.record.options = options\n } else {\n if (options.type === 'code') {\n // 공통 코드\n columnConfig.record.options = await ServiceUtil.getCodeSelectorData(\n options.values ? options.values : options.name\n )\n } else if (options.type === 'scenario') {\n // 시나리오\n columnConfig.record.options = await ServiceUtil.getCodeByScenario(options.name, options.args)\n } else if (options.type === 'entity') {\n // 엔티티\n columnConfig.record.options = await ServiceUtil.getCodeByEntity(options.args)\n }\n }\n } else if (type === 'meta-object-selector') {\n // object-option\n columnConfig.record.options = { ...options }\n } else if (type == 'meta-code-selector') {\n if (options.dispField) {\n options.codes = await ServiceUtil.getCodeByEntity(options)\n }\n\n columnConfig.record.options = { ...options }\n }\n\n columnConfig.hidden = hidden\n\n selectFields.push(columnConfig)\n }\n }\n } else {\n selectFields.push(MetaApi.getGristColumnConfig2('string', codeField!, codeField!, 'left', false, true, 180))\n\n if (dispField) {\n selectFields.push(MetaApi.getGristColumnConfig2('string', dispField, dispField, 'left', false, true, 300))\n }\n }\n\n selectFields.forEach(x => {\n let filters = filterFields.filter(y => (typeof y === 'string' ? x.name == y : x.name == y.name))\n\n if (filters && filters.length > 0) {\n x.filter = typeof filters[0] === 'string' ? 'search' : filters[0]\n }\n })\n\n let gridConfig = {\n rows: MetaApi.getGristSelectableConfig(false),\n pagination: MetaApi.getGristPagination100Config(),\n columns: selectFields,\n sorters: [...sortFields]\n }\n\n gridConfig.rows.handlers = {\n click: 'select-row-toggle',\n dblclick: (columns, data, column, record, rowIndex, field) => {\n this.selectRecord(record)\n }\n }\n\n gridConfig.rows.appendable = false\n\n this.gridConfig = gridConfig\n\n await super.connectedCallback()\n }\n\n async firstUpdated(changes: PropertyValues<this>) {\n await super.firstUpdated(changes)\n }\n\n render() {\n return html`\n <ox-grist\n id=\"ox-grist\"\n .config=${this.gridConfig}\n .mode=${isMobileDevice() ? 'LIST' : 'GRID'}\n auto-fetch\n .fetchHandler=${this.fetchHandler.bind(this)}\n >\n <div slot=\"headroom\" class=\"header\">\n <div class=\"filters\">\n <ox-filters-form></ox-filters-form>\n </div>\n </div>\n </ox-grist>\n\n <div class=\"footer\">\n <button @click=${this.clickEmpty.bind(this)}>\n <md-icon>check_box_outline_blank</md-icon>${TermsUtil.tButton('empty')}\n </button>\n <div filler></div>\n <button @click=${this.clickCancel.bind(this)}><md-icon>cancel</md-icon>${TermsUtil.tButton('cancel')}</button>\n <button @click=${this.clickSelect.bind(this)} done>\n <md-icon>done</md-icon>${TermsUtil.tButton('select')}\n </button>\n </div>\n `\n }\n\n /**\n * @description 컬럼 조회\n ***************************\n * @returns\n */\n async fetchHandler({ page = 0, limit = 0, sorters = [], filters = [] }: FetchOption): Promise<FetchResult> {\n const { menu_template, queryName } = this.options || {}\n\n // let resFilter = [...this.foundationFilters]\n\n // filters.forEach((x: any) => {\n // let dupFilter = resFilter.filter(y => x.name == y.name)\n // if (dupFilter && dupFilter.length > 0) {\n // delete resFilter[x.name]\n // }\n\n // resFilter.push(x)\n // })\n\n let resFilter = adjustFilters([...this.foundationFilters], filters)\n\n let queryAfterSetFields = ValueUtil.getParams(\n menu_template ? menu_template.gql || {} : {},\n 'query',\n 'after_set_fields'\n )\n let selectSkipFields = Object.keys(queryAfterSetFields || {})\n\n // 조회 컬럼 추출 후 조회\n let selectFields = MetaApi.getSelectColumns(this.gridConfig.columns.filter(x => !selectSkipFields.includes(x.name)))\n\n // 조회 실행\n let result = await MetaApi.searchByPagination(queryName, resFilter, sorters, page, limit, selectFields)\n\n return result\n }\n\n /**\n * @description 비우기\n ***************************\n * @returns\n */\n async clickEmpty(e) {\n this.confirmCallback && this.confirmCallback()\n closePopup(this)\n }\n /**\n * @description 취소\n ***************************\n * @returns\n */\n async clickCancel(e) {\n closePopup(this)\n }\n /**\n * @description 선택\n ***************************\n * @returns\n */\n async clickSelect(e) {\n let selected = this.grist.selected\n\n if (!selected || selected.length == 0) {\n MetaApi.showToast('info', TermsUtil.tText('NOTHING_SELECTED'))\n return\n }\n\n this.selectRecord(selected[0])\n }\n\n /**\n * @description 확정\n ***************************\n * @param {*} record\n */\n async selectRecord(record) {\n this.confirmCallback && this.confirmCallback(record)\n closePopup(this)\n }\n}\n"]}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import '@material/web/icon/icon.js';
|
|
2
|
+
import '@operato/input/ox-input-code.js';
|
|
3
|
+
import { LitElement, PropertyValues } from 'lit';
|
|
4
|
+
/**
|
|
5
|
+
* 레코드 기반 코드 편집기 팝업
|
|
6
|
+
*/
|
|
7
|
+
export declare class RecordBasedCodeEditorPopup extends LitElement {
|
|
8
|
+
static styles: import("lit").CSSResult[];
|
|
9
|
+
private config?;
|
|
10
|
+
private record?;
|
|
11
|
+
private value?;
|
|
12
|
+
private codeValue?;
|
|
13
|
+
private codeEditor;
|
|
14
|
+
/**
|
|
15
|
+
* 그리드 버튼 (grid-custom) 선택시 코드 편집기 팝업을 띄우는 버튼 로직
|
|
16
|
+
{
|
|
17
|
+
"type": "popup", -> 팝업 표시 (고정값)
|
|
18
|
+
"title": "template", -> 코드 에디터에서 팝업 타이틀에 표시할 타이틀 정보 (변수값)
|
|
19
|
+
"title_detail": "name", -> 코드 에디터에서 팝업 타이틀에 표시할 레코드의 필드 정보 (변수값)
|
|
20
|
+
"size": "large", -> 팝업 사이즈 (full, large, medium, small)
|
|
21
|
+
"popup_field": "record", -> 코드 에디터에서 레코드를 받을 필드명 (고정값)
|
|
22
|
+
"parent_field": "id", -> 부모 레코드 ID 필드 값 (고정값)
|
|
23
|
+
"value_field": "template", -> 코드 에디터에 표시할 레코드 필드 정보 (변수값)
|
|
24
|
+
"menu": "code-editor", -> 코드 에디터 이름 정보 (고정값)
|
|
25
|
+
"tagname": "record-code-editor-popup", -> 코드 에디터 태그 명 (고정값)
|
|
26
|
+
"location": "@things-factory/meta-ui/dist-client/component/popup/record-code-editor-popup", -> 코드 에디터 파일 위치 (고정값)
|
|
27
|
+
"save_action": {
|
|
28
|
+
"func_name": "updateDocTemplate", -> 업데이트 함수 명
|
|
29
|
+
"func_type": "DocTemplatePatch"
|
|
30
|
+
},
|
|
31
|
+
"param": [
|
|
32
|
+
"grist_one" -> 파라미터 전달 모드 - 그리드 선택 값 전달 (고정값)
|
|
33
|
+
],
|
|
34
|
+
"after": "fetch" -> 팝업 닫기 후 액션 (Optional)
|
|
35
|
+
}
|
|
36
|
+
*/
|
|
37
|
+
connectedCallback(): Promise<void>;
|
|
38
|
+
firstUpdated(changes: PropertyValues<this>): Promise<void>;
|
|
39
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
40
|
+
/**
|
|
41
|
+
* @description 저장
|
|
42
|
+
***************************
|
|
43
|
+
* @returns
|
|
44
|
+
*/
|
|
45
|
+
clickSave(e: any): Promise<void>;
|
|
46
|
+
/**
|
|
47
|
+
* @description 취소
|
|
48
|
+
***************************
|
|
49
|
+
* @returns
|
|
50
|
+
*/
|
|
51
|
+
clickCancel(e: any): Promise<void>;
|
|
52
|
+
}
|