@qxs-bns/components 0.0.91 → 0.0.92
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/es/base/define.mjs +1 -1
- package/es/base/define.mjs.map +1 -1
- package/es/base/uid.mjs +1 -1
- package/es/base/uid.mjs.map +1 -1
- package/es/data-chart.mjs +15 -14
- package/es/data-chart.mjs.map +1 -1
- package/es/editor/blocksuite-editor.mjs +62 -51
- package/es/editor/blocksuite-editor.mjs.map +1 -1
- package/es/editor/content-format.mjs +8 -1
- package/es/editor/content-format.mjs.map +1 -1
- package/es/editor/index.mjs +1 -1
- package/es/editor/index.mjs.map +1 -1
- package/es/editor/toolbar.mjs +1 -1
- package/es/editor/toolbar.mjs.map +1 -1
- package/es/entry-data-chart.mjs +1 -1
- package/es/entry-editor.mjs +1 -1
- package/es/entry-file-upload.mjs +1 -1
- package/es/entry-fixed-action-bar.mjs +1 -1
- package/es/entry-icon.mjs +1 -1
- package/es/entry-image-upload.mjs +1 -1
- package/es/entry-photo-crop-tool.mjs +1 -1
- package/es/entry-subject.mjs +1 -1
- package/es/file-upload.mjs +25 -18
- package/es/file-upload.mjs.map +1 -1
- package/es/fixed-action-bar.mjs +5 -5
- package/es/fixed-action-bar.mjs.map +1 -1
- package/es/icon.mjs +7 -7
- package/es/icon.mjs.map +1 -1
- package/es/image-upload.mjs +26 -26
- package/es/image-upload.mjs.map +1 -1
- package/es/index.mjs +1 -1
- package/es/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.mjs +59 -1
- package/es/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.mjs.map +1 -1
- package/es/node_modules/.pnpm/turndown-plugin-gfm@1.0.2/node_modules/turndown-plugin-gfm/lib/turndown-plugin-gfm.es.mjs +16 -1
- package/es/node_modules/.pnpm/turndown-plugin-gfm@1.0.2/node_modules/turndown-plugin-gfm/lib/turndown-plugin-gfm.es.mjs.map +1 -1
- package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.mjs +62 -0
- package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.mjs.map +1 -0
- package/es/photo-crop-tool.mjs +12 -12
- package/es/photo-crop-tool.mjs.map +1 -1
- package/es/subject/action.mjs +58 -58
- package/es/subject/action.mjs.map +1 -1
- package/es/subject/blank-fill.mjs +80 -80
- package/es/subject/blank-fill.mjs.map +1 -1
- package/es/subject/draft.mjs +1 -1
- package/es/subject/draft.mjs.map +1 -1
- package/es/subject/layout.mjs +4 -4
- package/es/subject/layout.mjs.map +1 -1
- package/es/subject/page-end.mjs +5 -5
- package/es/subject/page-end.mjs.map +1 -1
- package/es/subject/pagination.mjs +1 -1
- package/es/subject/pagination.mjs.map +1 -1
- package/es/subject/runtime.mjs +1 -1
- package/es/subject/runtime.mjs.map +1 -1
- package/es/subject/scale.mjs +53 -50
- package/es/subject/scale.mjs.map +1 -1
- package/es/subject/shared-methods.mjs +1 -1
- package/es/subject/shared-methods.mjs.map +1 -1
- package/es/subject/shared-styles.mjs +53 -15
- package/es/subject/shared-styles.mjs.map +1 -1
- package/es/subject/single-interactions.mjs +2 -0
- package/es/subject/single-interactions.mjs.map +1 -0
- package/es/subject/single-model.mjs +2 -0
- package/es/subject/single-model.mjs.map +1 -0
- package/es/subject/single-state.mjs +2 -0
- package/es/subject/single-state.mjs.map +1 -0
- package/es/subject/single.mjs +177 -177
- package/es/subject/single.mjs.map +1 -1
- package/es/subject/sort-controller.mjs +1 -1
- package/es/subject/sort-controller.mjs.map +1 -1
- package/es/subject/sortable.mjs +13 -13
- package/es/subject/sortable.mjs.map +1 -1
- package/es/subject/sorting-card.mjs +12 -12
- package/es/subject/sorting-card.mjs.map +1 -1
- package/es/subject/subject-shared.mjs +2 -0
- package/es/subject/subject-shared.mjs.map +1 -0
- package/es/subject/text-fill.mjs +73 -73
- package/es/subject/text-fill.mjs.map +1 -1
- package/es/subject/title-prefix.mjs +1 -1
- package/es/subject/title-prefix.mjs.map +1 -1
- package/es/subject/types.mjs +1 -1
- package/es/subject/types.mjs.map +1 -1
- package/lib/base/define.cjs +1 -1
- package/lib/base/define.cjs.map +1 -1
- package/lib/base/uid.cjs +1 -1
- package/lib/base/uid.cjs.map +1 -1
- package/lib/data-chart.cjs +16 -15
- package/lib/data-chart.cjs.map +1 -1
- package/lib/editor/blocksuite-editor.cjs +62 -51
- package/lib/editor/blocksuite-editor.cjs.map +1 -1
- package/lib/editor/content-format.cjs +8 -1
- package/lib/editor/content-format.cjs.map +1 -1
- package/lib/editor/index.cjs +1 -1
- package/lib/editor/index.cjs.map +1 -1
- package/lib/editor/toolbar.cjs +1 -1
- package/lib/editor/toolbar.cjs.map +1 -1
- package/lib/entry-data-chart.cjs +1 -1
- package/lib/entry-editor.cjs +1 -1
- package/lib/entry-file-upload.cjs +1 -1
- package/lib/entry-fixed-action-bar.cjs +1 -1
- package/lib/entry-icon.cjs +1 -1
- package/lib/entry-image-upload.cjs +1 -1
- package/lib/entry-photo-crop-tool.cjs +1 -1
- package/lib/entry-subject.cjs +1 -1
- package/lib/file-upload.cjs +24 -17
- package/lib/file-upload.cjs.map +1 -1
- package/lib/fixed-action-bar.cjs +6 -6
- package/lib/fixed-action-bar.cjs.map +1 -1
- package/lib/icon.cjs +9 -9
- package/lib/icon.cjs.map +1 -1
- package/lib/image-upload.cjs +26 -26
- package/lib/image-upload.cjs.map +1 -1
- package/lib/index.cjs +1 -1
- package/lib/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.cjs +59 -1
- package/lib/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.cjs.map +1 -1
- package/lib/node_modules/.pnpm/turndown-plugin-gfm@1.0.2/node_modules/turndown-plugin-gfm/lib/turndown-plugin-gfm.es.cjs +16 -1
- package/lib/node_modules/.pnpm/turndown-plugin-gfm@1.0.2/node_modules/turndown-plugin-gfm/lib/turndown-plugin-gfm.es.cjs.map +1 -1
- package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.cjs +62 -0
- package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.cjs.map +1 -0
- package/lib/photo-crop-tool.cjs +11 -11
- package/lib/photo-crop-tool.cjs.map +1 -1
- package/lib/subject/action.cjs +42 -42
- package/lib/subject/action.cjs.map +1 -1
- package/lib/subject/blank-fill.cjs +80 -80
- package/lib/subject/blank-fill.cjs.map +1 -1
- package/lib/subject/draft.cjs +1 -1
- package/lib/subject/draft.cjs.map +1 -1
- package/lib/subject/layout.cjs +4 -4
- package/lib/subject/layout.cjs.map +1 -1
- package/lib/subject/page-end.cjs +4 -4
- package/lib/subject/page-end.cjs.map +1 -1
- package/lib/subject/pagination.cjs +1 -1
- package/lib/subject/pagination.cjs.map +1 -1
- package/lib/subject/runtime.cjs +1 -1
- package/lib/subject/runtime.cjs.map +1 -1
- package/lib/subject/scale.cjs +53 -50
- package/lib/subject/scale.cjs.map +1 -1
- package/lib/subject/shared-methods.cjs +1 -1
- package/lib/subject/shared-methods.cjs.map +1 -1
- package/lib/subject/shared-styles.cjs +54 -16
- package/lib/subject/shared-styles.cjs.map +1 -1
- package/lib/subject/single-interactions.cjs +2 -0
- package/lib/subject/single-interactions.cjs.map +1 -0
- package/lib/subject/single-model.cjs +2 -0
- package/lib/subject/single-model.cjs.map +1 -0
- package/lib/subject/single-state.cjs +2 -0
- package/lib/subject/single-state.cjs.map +1 -0
- package/lib/subject/single.cjs +177 -177
- package/lib/subject/single.cjs.map +1 -1
- package/lib/subject/sort-controller.cjs +1 -1
- package/lib/subject/sort-controller.cjs.map +1 -1
- package/lib/subject/sortable.cjs +15 -15
- package/lib/subject/sortable.cjs.map +1 -1
- package/lib/subject/sorting-card.cjs +12 -12
- package/lib/subject/sorting-card.cjs.map +1 -1
- package/lib/subject/subject-shared.cjs +2 -0
- package/lib/subject/subject-shared.cjs.map +1 -0
- package/lib/subject/text-fill.cjs +81 -81
- package/lib/subject/text-fill.cjs.map +1 -1
- package/lib/subject/title-prefix.cjs +1 -1
- package/lib/subject/title-prefix.cjs.map +1 -1
- package/lib/subject/types.cjs +1 -1
- package/lib/subject/types.cjs.map +1 -1
- package/package.json +5 -5
- package/types/editor/blocksuite-editor.d.ts +2 -0
- package/types/editor/toolbar.d.ts +1 -1
- package/types/file-upload.d.ts +2 -0
- package/types/subject/blank-fill.d.ts +1 -1
- package/types/subject/runtime.d.ts +1 -1
- package/types/subject/scale.d.ts +1 -1
- package/types/subject/single-interactions.d.ts +46 -0
- package/types/subject/single-model.d.ts +88 -0
- package/types/subject/single-state.d.ts +42 -0
- package/types/subject/single.d.ts +7 -85
- package/types/subject/sortable.d.ts +1 -1
- package/types/subject/subject-shared.d.ts +43 -0
- package/types/subject/text-fill.d.ts +1 -1
- package/README.md +0 -562
- package/es/node_modules/.pnpm/@iconify_vue@5.0.0_vue@3.5.18_typescript@5.9.2_/node_modules/@iconify/vue/dist/iconify.mjs +0 -2
- package/es/node_modules/.pnpm/@iconify_vue@5.0.0_vue@3.5.18_typescript@5.9.2_/node_modules/@iconify/vue/dist/iconify.mjs.map +0 -1
- package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.mjs +0 -2
- package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.mjs.map +0 -1
- package/es/package.json.mjs +0 -2
- package/es/package.json.mjs.map +0 -1
- package/es/src/alert/index.mjs +0 -2
- package/es/src/alert/index.mjs.map +0 -1
- package/es/src/alert/src/alert.mjs +0 -2
- package/es/src/alert/src/alert.mjs.map +0 -1
- package/es/src/components.mjs +0 -2
- package/es/src/components.mjs.map +0 -1
- package/es/src/data-chart/index.mjs +0 -2
- package/es/src/data-chart/index.mjs.map +0 -1
- package/es/src/defaults.mjs +0 -2
- package/es/src/defaults.mjs.map +0 -1
- package/es/src/dialog/src/dialog.mjs +0 -2
- package/es/src/dialog/src/dialog.mjs.map +0 -1
- package/es/src/feedback-plugin/index.mjs +0 -2
- package/es/src/feedback-plugin/index.mjs.map +0 -1
- package/es/src/file-upload/index.mjs +0 -2
- package/es/src/file-upload/index.mjs.map +0 -1
- package/es/src/icon/index.mjs +0 -2
- package/es/src/icon/index.mjs.map +0 -1
- package/es/src/icon/src/icon.mjs +0 -2
- package/es/src/icon/src/icon.mjs.map +0 -1
- package/es/src/image-upload/index.mjs +0 -2
- package/es/src/image-upload/index.mjs.map +0 -1
- package/es/src/make-installer.mjs +0 -2
- package/es/src/make-installer.mjs.map +0 -1
- package/es/src/message/src/message.mjs +0 -2
- package/es/src/message/src/message.mjs.map +0 -1
- package/es/src/photo-crop-tool/index.mjs +0 -2
- package/es/src/photo-crop-tool/index.mjs.map +0 -1
- package/es/src/tiny-mce-editor/index.mjs +0 -2
- package/es/src/tiny-mce-editor/index.mjs.map +0 -1
- package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue.mjs +0 -2
- package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue.mjs.map +0 -1
- package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue2.mjs +0 -2
- package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue2.mjs.map +0 -1
- package/es/src/ui/button/index.mjs +0 -2
- package/es/src/ui/button/index.mjs.map +0 -1
- package/es/src/ui/checkbox/index.mjs +0 -2
- package/es/src/ui/checkbox/index.mjs.map +0 -1
- package/es/src/ui/dialog/index.mjs +0 -2
- package/es/src/ui/dialog/index.mjs.map +0 -1
- package/es/src/ui/input/index.mjs +0 -2
- package/es/src/ui/input/index.mjs.map +0 -1
- package/es/src/ui/input-number/index.mjs +0 -2
- package/es/src/ui/input-number/index.mjs.map +0 -1
- package/es/src/ui/layout/index.mjs +0 -2
- package/es/src/ui/layout/index.mjs.map +0 -1
- package/es/src/ui/link/index.mjs +0 -2
- package/es/src/ui/link/index.mjs.map +0 -1
- package/es/src/ui/popover/index.mjs +0 -2
- package/es/src/ui/popover/index.mjs.map +0 -1
- package/es/src/ui/radio/index.mjs +0 -2
- package/es/src/ui/radio/index.mjs.map +0 -1
- package/es/src/ui/scrollbar/index.mjs +0 -2
- package/es/src/ui/scrollbar/index.mjs.map +0 -1
- package/es/src/ui/select/index.mjs +0 -2
- package/es/src/ui/select/index.mjs.map +0 -1
- package/es/src/ui/table/index.mjs +0 -2
- package/es/src/ui/table/index.mjs.map +0 -1
- package/es/src/ui/tag/index.mjs +0 -2
- package/es/src/ui/tag/index.mjs.map +0 -1
- package/es/src/wc-bridge.mjs +0 -2
- package/es/src/wc-bridge.mjs.map +0 -1
- package/es/src/withInstall.mjs +0 -2
- package/es/src/withInstall.mjs.map +0 -1
- package/lib/node_modules/.pnpm/@iconify_vue@5.0.0_vue@3.5.18_typescript@5.9.2_/node_modules/@iconify/vue/dist/iconify.cjs +0 -2
- package/lib/node_modules/.pnpm/@iconify_vue@5.0.0_vue@3.5.18_typescript@5.9.2_/node_modules/@iconify/vue/dist/iconify.cjs.map +0 -1
- package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.cjs +0 -2
- package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.cjs.map +0 -1
- package/lib/package.json.cjs +0 -2
- package/lib/package.json.cjs.map +0 -1
- package/lib/src/alert/index.cjs +0 -2
- package/lib/src/alert/index.cjs.map +0 -1
- package/lib/src/alert/src/alert.cjs +0 -2
- package/lib/src/alert/src/alert.cjs.map +0 -1
- package/lib/src/components.cjs +0 -2
- package/lib/src/components.cjs.map +0 -1
- package/lib/src/data-chart/index.cjs +0 -2
- package/lib/src/data-chart/index.cjs.map +0 -1
- package/lib/src/defaults.cjs +0 -2
- package/lib/src/defaults.cjs.map +0 -1
- package/lib/src/dialog/src/dialog.cjs +0 -2
- package/lib/src/dialog/src/dialog.cjs.map +0 -1
- package/lib/src/feedback-plugin/index.cjs +0 -2
- package/lib/src/feedback-plugin/index.cjs.map +0 -1
- package/lib/src/file-upload/index.cjs +0 -2
- package/lib/src/file-upload/index.cjs.map +0 -1
- package/lib/src/icon/index.cjs +0 -2
- package/lib/src/icon/index.cjs.map +0 -1
- package/lib/src/icon/src/icon.cjs +0 -2
- package/lib/src/icon/src/icon.cjs.map +0 -1
- package/lib/src/image-upload/index.cjs +0 -2
- package/lib/src/image-upload/index.cjs.map +0 -1
- package/lib/src/make-installer.cjs +0 -2
- package/lib/src/make-installer.cjs.map +0 -1
- package/lib/src/message/src/message.cjs +0 -2
- package/lib/src/message/src/message.cjs.map +0 -1
- package/lib/src/photo-crop-tool/index.cjs +0 -2
- package/lib/src/photo-crop-tool/index.cjs.map +0 -1
- package/lib/src/tiny-mce-editor/index.cjs +0 -2
- package/lib/src/tiny-mce-editor/index.cjs.map +0 -1
- package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue.cjs +0 -2
- package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue.cjs.map +0 -1
- package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue2.cjs +0 -2
- package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue2.cjs.map +0 -1
- package/lib/src/ui/button/index.cjs +0 -2
- package/lib/src/ui/button/index.cjs.map +0 -1
- package/lib/src/ui/checkbox/index.cjs +0 -2
- package/lib/src/ui/checkbox/index.cjs.map +0 -1
- package/lib/src/ui/dialog/index.cjs +0 -2
- package/lib/src/ui/dialog/index.cjs.map +0 -1
- package/lib/src/ui/input/index.cjs +0 -2
- package/lib/src/ui/input/index.cjs.map +0 -1
- package/lib/src/ui/input-number/index.cjs +0 -2
- package/lib/src/ui/input-number/index.cjs.map +0 -1
- package/lib/src/ui/layout/index.cjs +0 -2
- package/lib/src/ui/layout/index.cjs.map +0 -1
- package/lib/src/ui/link/index.cjs +0 -2
- package/lib/src/ui/link/index.cjs.map +0 -1
- package/lib/src/ui/popover/index.cjs +0 -2
- package/lib/src/ui/popover/index.cjs.map +0 -1
- package/lib/src/ui/radio/index.cjs +0 -2
- package/lib/src/ui/radio/index.cjs.map +0 -1
- package/lib/src/ui/scrollbar/index.cjs +0 -2
- package/lib/src/ui/scrollbar/index.cjs.map +0 -1
- package/lib/src/ui/select/index.cjs +0 -2
- package/lib/src/ui/select/index.cjs.map +0 -1
- package/lib/src/ui/table/index.cjs +0 -2
- package/lib/src/ui/table/index.cjs.map +0 -1
- package/lib/src/ui/tag/index.cjs +0 -2
- package/lib/src/ui/tag/index.cjs.map +0 -1
- package/lib/src/wc-bridge.cjs +0 -2
- package/lib/src/wc-bridge.cjs.map +0 -1
- package/lib/src/withInstall.cjs +0 -2
- package/lib/src/withInstall.cjs.map +0 -1
- package/types/index.d.ts.map +0 -1
- package/types/src/alert/index.d.ts +0 -66
- package/types/src/alert/index.d.ts.map +0 -1
- package/types/src/alert/src/alert.d.ts +0 -73
- package/types/src/alert/src/alert.d.ts.map +0 -1
- package/types/src/components.d.ts +0 -10
- package/types/src/components.d.ts.map +0 -1
- package/types/src/data-chart/index.d.ts +0 -13
- package/types/src/data-chart/index.d.ts.map +0 -1
- package/types/src/defaults.d.ts +0 -6
- package/types/src/defaults.d.ts.map +0 -1
- package/types/src/dialog/index.d.ts +0 -3
- package/types/src/dialog/index.d.ts.map +0 -1
- package/types/src/dialog/src/dialog.d.ts +0 -25
- package/types/src/dialog/src/dialog.d.ts.map +0 -1
- package/types/src/feedback-plugin/index.d.ts +0 -9
- package/types/src/feedback-plugin/index.d.ts.map +0 -1
- package/types/src/file-upload/index.d.ts +0 -12
- package/types/src/file-upload/index.d.ts.map +0 -1
- package/types/src/icon/index.d.ts +0 -56
- package/types/src/icon/index.d.ts.map +0 -1
- package/types/src/icon/src/icon.d.ts +0 -62
- package/types/src/icon/src/icon.d.ts.map +0 -1
- package/types/src/image-upload/index.d.ts +0 -12
- package/types/src/image-upload/index.d.ts.map +0 -1
- package/types/src/make-installer.d.ts +0 -6
- package/types/src/make-installer.d.ts.map +0 -1
- package/types/src/message/index.d.ts +0 -3
- package/types/src/message/index.d.ts.map +0 -1
- package/types/src/message/src/message.d.ts +0 -21
- package/types/src/message/src/message.d.ts.map +0 -1
- package/types/src/message/src/toaster.vue.d.ts +0 -3
- package/types/src/message/src/toaster.vue.d.ts.map +0 -1
- package/types/src/photo-crop-tool/index.d.ts +0 -12
- package/types/src/photo-crop-tool/index.d.ts.map +0 -1
- package/types/src/subject-action/index.d.ts +0 -93
- package/types/src/subject-action/index.d.ts.map +0 -1
- package/types/src/subject-action/src/subject-action.vue.d.ts +0 -92
- package/types/src/subject-action/src/subject-action.vue.d.ts.map +0 -1
- package/types/src/subject-layout/index.d.ts +0 -30
- package/types/src/subject-layout/index.d.ts.map +0 -1
- package/types/src/subject-layout/src/subject-layout.vue.d.ts +0 -20
- package/types/src/subject-layout/src/subject-layout.vue.d.ts.map +0 -1
- package/types/src/subject-list/index.d.ts +0 -20
- package/types/src/subject-list/index.d.ts.map +0 -1
- package/types/src/subject-list/src/components/SubjectPageEnd.vue.d.ts +0 -24
- package/types/src/subject-list/src/components/SubjectPageEnd.vue.d.ts.map +0 -1
- package/types/src/subject-list/src/components/subject-blank-fill.vue.d.ts +0 -32
- package/types/src/subject-list/src/components/subject-blank-fill.vue.d.ts.map +0 -1
- package/types/src/subject-list/src/components/subject-scale.vue.d.ts +0 -29
- package/types/src/subject-list/src/components/subject-scale.vue.d.ts.map +0 -1
- package/types/src/subject-list/src/components/subject-single.vue.d.ts +0 -37
- package/types/src/subject-list/src/components/subject-single.vue.d.ts.map +0 -1
- package/types/src/subject-list/src/components/subject-text-fill.vue.d.ts +0 -34
- package/types/src/subject-list/src/components/subject-text-fill.vue.d.ts.map +0 -1
- package/types/src/subject-list/src/subject-list.vue.d.ts +0 -21
- package/types/src/subject-list/src/subject-list.vue.d.ts.map +0 -1
- package/types/src/subject-type/index.d.ts +0 -8
- package/types/src/subject-type/index.d.ts.map +0 -1
- package/types/src/subject-type/src/subject-type.vue.d.ts +0 -7
- package/types/src/subject-type/src/subject-type.vue.d.ts.map +0 -1
- package/types/src/tiny-mce-editor/index.d.ts +0 -20
- package/types/src/tiny-mce-editor/index.d.ts.map +0 -1
- package/types/src/tiny-mce-editor/src/tiny-mce-editor.vue.d.ts +0 -32
- package/types/src/tiny-mce-editor/src/tiny-mce-editor.vue.d.ts.map +0 -1
- package/types/src/ui/button/index.d.ts +0 -96
- package/types/src/ui/button/index.d.ts.map +0 -1
- package/types/src/ui/checkbox/index.d.ts +0 -111
- package/types/src/ui/checkbox/index.d.ts.map +0 -1
- package/types/src/ui/dialog/index.d.ts +0 -134
- package/types/src/ui/dialog/index.d.ts.map +0 -1
- package/types/src/ui/index.d.ts +0 -16
- package/types/src/ui/index.d.ts.map +0 -1
- package/types/src/ui/input/index.d.ts +0 -132
- package/types/src/ui/input/index.d.ts.map +0 -1
- package/types/src/ui/input-number/index.d.ts +0 -106
- package/types/src/ui/input-number/index.d.ts.map +0 -1
- package/types/src/ui/layout/index.d.ts +0 -373
- package/types/src/ui/layout/index.d.ts.map +0 -1
- package/types/src/ui/link/index.d.ts +0 -57
- package/types/src/ui/link/index.d.ts.map +0 -1
- package/types/src/ui/popover/index.d.ts +0 -89
- package/types/src/ui/popover/index.d.ts.map +0 -1
- package/types/src/ui/radio/index.d.ts +0 -84
- package/types/src/ui/radio/index.d.ts.map +0 -1
- package/types/src/ui/scrollbar/index.d.ts +0 -35
- package/types/src/ui/scrollbar/index.d.ts.map +0 -1
- package/types/src/ui/select/index.d.ts +0 -113
- package/types/src/ui/select/index.d.ts.map +0 -1
- package/types/src/ui/table/index.d.ts +0 -152
- package/types/src/ui/table/index.d.ts.map +0 -1
- package/types/src/ui/tag/index.d.ts +0 -69
- package/types/src/ui/tag/index.d.ts.map +0 -1
- package/types/src/wc-bridge.d.ts +0 -23
- package/types/src/wc-bridge.d.ts.map +0 -1
- package/types/src/withInstall.d.ts +0 -4
- package/types/src/withInstall.d.ts.map +0 -1
- package/types/tsconfig.tsbuildinfo +0 -1
package/lib/subject/scale.cjs
CHANGED
|
@@ -1,32 +1,35 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("lit"),i=require("lit/decorators.js"),_=require("../base/define.cjs"),S=require("../editor/toolbar.cjs"),p=require("./shared-methods.cjs"),u=require("./shared-styles.cjs"),c=require("./subject-shared.cjs"),m=require("./sorting-card.cjs"),h=require("./types.cjs");var T=Object.defineProperty,j=Object.getOwnPropertyDescriptor,s=(o,t,e,l)=>{for(var r=l>1?void 0:l?j(t,e):t,a=o.length-1,d;a>=0;a--)(d=o[a])&&(r=(l?d(t,e,r):d(r))||r);return l&&r&&T(t,e,r),r};function f(){return{title:""}}function v(){return Array.from({length:5},f)}function b(o){const t={...o,title:c.trimText(o?.title??o?.answer??"")},e=o?.answerId??o?.examAnswerId;return e!==void 0&&(t.answerId=e),delete t.answer,delete t.examAnswerId,delete t.isCorrect,t}function q(o){return Array.isArray(o)?o.map(b):[]}function $(o){return Array.isArray(o)?o.map(t=>String(t??"").trim()).filter(Boolean):[]}function E(o){return o.split(`
|
|
2
|
+
`).map(t=>t.trim()).filter(Boolean)}function Q(o,t){const e={...b(o),orderIndex:t+1,answer:c.trimText(o?.title??o?.answer??"")};return e.title=c.trimText(e.title??""),e.answerId!==void 0&&(e.examAnswerId=e.answerId),e.answerId===void 0&&delete e.answerId,delete e.isCorrect,e}const A=n.html`<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><line x1="12" y1="5" x2="12" y2="19"/><line x1="5" y1="12" x2="19" y2="12"/></svg>`,I=n.html`<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><line x1="5" y1="12" x2="19" y2="12"/></svg>`;exports.QxsScale=class extends n.LitElement{constructor(){super(...arguments),this["order-index"]=0,this.title="",this["custom-id"]="",this["is-edit"]=!1,this["is-save"]=!1,this["is-set"]=!1,this["show-action"]=!0,this["show-add"]=!0,this["hide-add-rich-text"]=!1,this["show-rich-text"]=!1,this["show-delete-action"]=!0,this["show-save-action"]=!0,this.sorting=!1,this["show-analysis"]=!1,this.analysis="",this["rich-text-content"]="",this["exam-answer-relation-type"]=0,this["upload-image"]=async t=>new Promise((e,l)=>{const r=new FileReader;r.onload=a=>e(a.target?.result),r.onerror=l,r.readAsDataURL(t)}),this._answers=v(),this._scaleQuestions=[],this._rowTitle="",this._title="",this._analysis="",this._showRichText=!1,this._richText="",this["model-value"]="",this["use-model"]=!1,this.TITLE_MAX=200}get"answer-list"(){return this._answers}set"answer-list"(t){const e=q(t);this._answers=e.length?e:v(),this.requestUpdate("answer-list")}get"scale-question-list"(){return this._scaleQuestions}set"scale-question-list"(t){this._scaleQuestions=$(t),this.requestUpdate("scale-question-list")}get"scale-questions"(){return this._scaleQuestions}set"scale-questions"(t){this["scale-question-list"]=t,this.requestUpdate("scale-questions")}willUpdate(t){const e=t.has("title")||t.has("answer-list")||t.has("rich-text-content")||t.has("scale-question-list")||t.has("scale-questions");(t.has("is-edit")&&this["is-edit"]||!this["is-edit"]&&e)&&this._syncProps(),t.has("model-value")&&this["use-model"]&&(this._title=this["model-value"])}_syncProps(){this._title=this.title||"",this._analysis=this.analysis||"",this._rowTitle=this._scaleQuestions.join(`
|
|
3
|
+
`),this._richText=this["rich-text-content"]||"",this._showRichText=!!this["rich-text-content"]}_emit(t,e){p.emitSubjectEvent(this,t,e)}_onTitleInput(t){const e=t.target;e.value.length>this.TITLE_MAX&&(e.value=e.value.slice(0,this.TITLE_MAX)),this._title=e.value,this["use-model"]&&p.emitSubjectModelValue(this,this._title)}_resolvedQuestions(){const t=this["is-edit"]?this._rowTitle:this._scaleQuestions.join(`
|
|
4
|
+
`);return E(t)}_resolvedAnswers(){const t=this["is-edit"]?this._answers:this["answer-list"];return Array.isArray(t)?t.map(b):[]}_createAnswerCountError(t){return new c.SubjectError("量表题选项数量必须在 3-5 个之间!","ANSWER_COUNT_INVALID","answers",t)}async toJSON(){return new Promise((t,e)=>{const l={customId:this["custom-id"]||void 0,answerType:h.SubjectType.SCALE,orderIndex:this["order-index"]},r=c.trimText(this["is-edit"]?this._title:this.title||""),a=this._resolvedAnswers(),d=this._resolvedQuestions(),w=this["is-edit"]?this._richText:this["rich-text-content"]||"",g=this["show-rich-text"]&&(this["is-edit"]?this._showRichText:!!this["rich-text-content"]);if(!r){e(new c.SubjectError("题目标题不能为空!","EMPTY_TITLE","title",l));return}if(a.length<3||a.length>5){e(this._createAnswerCountError(l));return}for(let x=0;x<a.length;x++)if(!a[x].title){e(new c.SubjectError(`选项${String.fromCharCode(65+x)}未填写。`,"ANSWER_EMPTY","answers",l));return}if(d.length===0){e(new c.SubjectError("行标题不能为空!","EMPTY_ROW_TITLE","rowTitle",l));return}const y={answerType:h.SubjectType.SCALE,examTypeEnum:h.SubjectType.SCALE,title:r,answers:a.map(Q),scaleQuestionList:d,analysis:c.trimText(this["is-edit"]?this._analysis:this.analysis||""),examRichTextContent:g?w:"",isSetCorrectAnswer:!1};this["custom-id"]&&(y.customId=this["custom-id"]),this["exam-answer-relation-type"]&&(y.examAnswerRelationType=this["exam-answer-relation-type"]),t(y)})}async _save(t){t?.stopImmediatePropagation();try{const e=await this.toJSON();this._emit("save",e)}catch(e){p.showSubjectToast(e.message)}}validate(){const t=[],e={customId:this["custom-id"]||void 0,answerType:h.SubjectType.SCALE,orderIndex:this["order-index"]},l=c.trimText(this["is-edit"]?this._title:this.title||""),r=this._resolvedAnswers(),a=this._resolvedQuestions();return l||t.push(new c.SubjectError("题目标题不能为空!","EMPTY_TITLE","title",e)),r.length<3||r.length>5?(t.push(this._createAnswerCountError(e)),t):(r.forEach((d,w)=>{d.title||t.push(new c.SubjectError(`选项${String.fromCharCode(65+w)}未填写`,"ANSWER_EMPTY","answers",e))}),a.length===0&&t.push(new c.SubjectError("行标题不能为空!","EMPTY_ROW_TITLE","rowTitle",e)),t)}_renderPreview(){const t=this._resolvedAnswers(),e=this._resolvedQuestions(),l=Math.floor(100/((t.length||1)+1)),r=p.buildSubjectPreviewTitle(this["subject-prefix"],this["order-index"],this.title);return n.html`
|
|
2
5
|
<div class="preview">
|
|
3
6
|
<div class="preview-header">
|
|
4
7
|
<div class="preview-title-row">
|
|
5
|
-
<span class="title">${
|
|
8
|
+
<span class="title">${r}</span>
|
|
6
9
|
<span class="preview-type">量表题</span>
|
|
7
10
|
</div>
|
|
8
|
-
${this["show-rich-text"]&&this["rich-text-content"]?
|
|
11
|
+
${this["show-rich-text"]&&this["rich-text-content"]?n.html`<div class="rich-text" .innerHTML=${this["rich-text-content"]}></div>`:""}
|
|
9
12
|
</div>
|
|
10
13
|
<div class="scale-table-wrap">
|
|
11
14
|
<table class="scale-table">
|
|
12
15
|
<thead>
|
|
13
16
|
<tr>
|
|
14
|
-
<th style="width:${
|
|
15
|
-
${
|
|
17
|
+
<th style="width:${l}%">问题</th>
|
|
18
|
+
${t.map(a=>n.html`<th style="width:${l}%">${a.title}</th>`)}
|
|
16
19
|
</tr>
|
|
17
20
|
</thead>
|
|
18
21
|
<tbody>
|
|
19
|
-
${
|
|
22
|
+
${e.map(a=>n.html`
|
|
20
23
|
<tr>
|
|
21
|
-
<td>${
|
|
22
|
-
${
|
|
24
|
+
<td>${a}</td>
|
|
25
|
+
${t.map(()=>n.html`<td><input type="radio" disabled /></td>`)}
|
|
23
26
|
</tr>
|
|
24
27
|
`)}
|
|
25
28
|
</tbody>
|
|
26
29
|
</table>
|
|
27
30
|
</div>
|
|
28
31
|
</div>
|
|
29
|
-
`}_renderEdit(){return
|
|
32
|
+
`}_renderEdit(){return n.html`
|
|
30
33
|
<div class="edit-form">
|
|
31
34
|
<div class="edit-row">
|
|
32
35
|
<div class="label"><span>题目:</span></div>
|
|
@@ -65,26 +68,26 @@
|
|
|
65
68
|
</div>
|
|
66
69
|
<div class="edit-column">
|
|
67
70
|
<div class="edit-column-title">评分选项</div>
|
|
68
|
-
${this._answers.map((e
|
|
71
|
+
${this._answers.map((t,e)=>n.html`
|
|
69
72
|
<div class="answer-item">
|
|
70
|
-
<span class="label">${String.fromCharCode(65+
|
|
73
|
+
<span class="label">${String.fromCharCode(65+e)}.</span>
|
|
71
74
|
<div class="input">
|
|
72
75
|
<input
|
|
73
76
|
type="text"
|
|
74
|
-
.value=${
|
|
77
|
+
.value=${t.title}
|
|
75
78
|
maxlength="10"
|
|
76
|
-
@input=${
|
|
77
|
-
placeholder="选项${
|
|
79
|
+
@input=${l=>{const r=l.target.value;this._answers=this._answers.map((a,d)=>d===e?{...a,title:r}:a)}}
|
|
80
|
+
placeholder="选项${e+1}"
|
|
78
81
|
/>
|
|
79
82
|
</div>
|
|
80
83
|
<span
|
|
81
84
|
class="icon"
|
|
82
|
-
@click=${()=>{this._answers.length<5&&(this._answers=[...this._answers,
|
|
83
|
-
>${
|
|
85
|
+
@click=${()=>{this._answers.length<5&&(this._answers=[...this._answers,f()])}}
|
|
86
|
+
>${A}</span>
|
|
84
87
|
<span
|
|
85
88
|
class="icon ${this._answers.length<3?"disabled":""}"
|
|
86
|
-
@click=${()=>{this._answers.length>3&&(this._answers=this._answers.filter((
|
|
87
|
-
>${
|
|
89
|
+
@click=${()=>{this._answers.length>3&&(this._answers=this._answers.filter((l,r)=>r!==e))}}
|
|
90
|
+
>${I}</span>
|
|
88
91
|
</div>
|
|
89
92
|
`)}
|
|
90
93
|
<div class="edit-note">量表题需保持 3-5 个选项,保存时会校验。</div>
|
|
@@ -93,20 +96,20 @@
|
|
|
93
96
|
</div>
|
|
94
97
|
</div>
|
|
95
98
|
|
|
96
|
-
${this["show-rich-text"]&&this._showRichText?
|
|
99
|
+
${this["show-rich-text"]&&this._showRichText?n.html`
|
|
97
100
|
<div class="edit-row">
|
|
98
101
|
<div class="label"><span>副文本:</span></div>
|
|
99
102
|
<div class="row-body">
|
|
100
103
|
<slot name="sub-text">
|
|
101
104
|
<qxs-blocksuite-editor
|
|
102
105
|
.content=${this._richText}
|
|
103
|
-
.toolbar=${
|
|
106
|
+
.toolbar=${S.SUB_TEXT_EDITOR_TOOLBAR}
|
|
104
107
|
.upload-image=${this["upload-image"]}
|
|
105
108
|
?is-edit=${!0}
|
|
106
109
|
@input=${t=>{this._richText=t.target.getContent()}}
|
|
107
110
|
></qxs-blocksuite-editor>
|
|
108
111
|
</slot>
|
|
109
|
-
${this["show-action"]?"":
|
|
112
|
+
${this["show-action"]?"":n.html`
|
|
110
113
|
<div class="flex-justify-end" style="margin-top:8px">
|
|
111
114
|
<span
|
|
112
115
|
class="el-link danger"
|
|
@@ -118,7 +121,7 @@
|
|
|
118
121
|
</div>
|
|
119
122
|
`:""}
|
|
120
123
|
|
|
121
|
-
${this["show-analysis"]?
|
|
124
|
+
${this["show-analysis"]?n.html`
|
|
122
125
|
<div class="edit-row">
|
|
123
126
|
<div class="label"><span>解析:</span></div>
|
|
124
127
|
<div class="row-body">
|
|
@@ -134,10 +137,10 @@
|
|
|
134
137
|
</div>
|
|
135
138
|
`:""}
|
|
136
139
|
</div>
|
|
137
|
-
`}_renderSorting(){const t=
|
|
140
|
+
`}_renderSorting(){const t=c.trimText(this["is-edit"]?this._title:this.title||"")||"未命名题目",e=p.buildSubjectSortingTitle(this["subject-prefix"],this["order-index"],t);return m.renderSortingCard(e,h.SubjectTypeLabel[h.SubjectType.SCALE]||h.SubjectType.SCALE)}render(){if(this.sorting)return this._renderSorting();const t=this["is-edit"]?n.html`<div slot="edit">${this._renderEdit()}</div>`:n.html`<div slot="preview">${this._renderPreview()}</div>`;return n.html`
|
|
138
141
|
<qxs-subject-layout .show-edit=${this["is-edit"]}>
|
|
139
|
-
${
|
|
140
|
-
${this["show-action"]?
|
|
142
|
+
${t}
|
|
143
|
+
${this["show-action"]?n.html`
|
|
141
144
|
<qxs-subject-action
|
|
142
145
|
.is-edit=${this["is-edit"]}
|
|
143
146
|
.is-set=${this["is-set"]}
|
|
@@ -151,38 +154,38 @@
|
|
|
151
154
|
@delete=${()=>this._emit("delete")}
|
|
152
155
|
@save=${this._save}
|
|
153
156
|
@edit=${()=>this._emit("edit")}
|
|
154
|
-
@add=${
|
|
157
|
+
@add=${e=>this._emit("add",e.detail)}
|
|
155
158
|
@on-show-rich-text=${()=>{this._showRichText=!this._showRichText,this._showRichText||(this._richText="")}}
|
|
156
159
|
></qxs-subject-action>
|
|
157
160
|
`:""}
|
|
158
161
|
<slot name="action"></slot>
|
|
159
162
|
</qxs-subject-layout>
|
|
160
|
-
`}}
|
|
163
|
+
`}};exports.QxsScale.styles=[m.sortingCardStyles,u.subjectHostStyles,u.subjectControlResetStyles,u.subjectPreviewBaseStyles,u.subjectFormBaseStyles,u.subjectTextareaStyles,n.css`
|
|
161
164
|
.scale-table-wrap {
|
|
162
165
|
margin-top: 18px;
|
|
163
|
-
border: 1px solid #e5e7eb;
|
|
166
|
+
border: 1px solid var(--qxs-subject-border-light, #e5e7eb);
|
|
164
167
|
border-radius: 12px;
|
|
165
|
-
background: #fff;
|
|
168
|
+
background: var(--qxs-subject-fill-blank, #fff);
|
|
166
169
|
overflow: hidden;
|
|
167
170
|
}
|
|
168
|
-
.scale-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; color: #4b5563; }
|
|
169
|
-
.scale-table th, .scale-table td { border-bottom: 1px solid #eef2f7; padding: 10px 8px; text-align: center; vertical-align: middle; }
|
|
170
|
-
.scale-table thead th { font-size: 12px; font-weight: 600; color: #8b95a7; background: #f8fafc; }
|
|
171
|
+
.scale-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; color: var(--qxs-subject-text-soft, #4b5563); }
|
|
172
|
+
.scale-table th, .scale-table td { border-bottom: 1px solid var(--qxs-subject-border-extra-light, #eef2f7); padding: 10px 8px; text-align: center; vertical-align: middle; }
|
|
173
|
+
.scale-table thead th { font-size: 12px; font-weight: 600; color: var(--qxs-subject-text-muted, #8b95a7); background: var(--qxs-subject-fill-lighter, #f8fafc); }
|
|
171
174
|
.scale-table thead th:first-child,
|
|
172
175
|
.scale-table tbody td:first-child {
|
|
173
|
-
color: #303133;
|
|
176
|
+
color: var(--qxs-subject-text-primary, #303133);
|
|
174
177
|
text-align: left;
|
|
175
178
|
font-weight: 600;
|
|
176
179
|
}
|
|
177
180
|
.scale-table thead th:first-child {
|
|
178
|
-
background: #f3f4f6;
|
|
181
|
+
background: var(--qxs-subject-fill-extra-light, #f3f4f6);
|
|
179
182
|
}
|
|
180
183
|
.scale-table tbody td:first-child {
|
|
181
|
-
background: #fafafa;
|
|
184
|
+
background: var(--qxs-subject-fill-light, #fafafa);
|
|
182
185
|
}
|
|
183
186
|
.scale-table tbody tr:last-child td { border-bottom: none; }
|
|
184
187
|
.scale-table input[type="radio"] {
|
|
185
|
-
accent-color: #3D61E3;
|
|
188
|
+
accent-color: var(--qxs-subject-color-primary, #3D61E3);
|
|
186
189
|
}
|
|
187
190
|
|
|
188
191
|
.flex { display: flex; }
|
|
@@ -203,47 +206,47 @@
|
|
|
203
206
|
font-size: 12px;
|
|
204
207
|
line-height: 1.4;
|
|
205
208
|
font-weight: 600;
|
|
206
|
-
color: #8b95a7;
|
|
209
|
+
color: var(--qxs-subject-text-muted, #8b95a7);
|
|
207
210
|
letter-spacing: 0.02em;
|
|
208
211
|
}
|
|
209
212
|
.edit-note {
|
|
210
213
|
font-size: 12px;
|
|
211
214
|
line-height: 1.6;
|
|
212
|
-
color: #909399;
|
|
215
|
+
color: var(--qxs-subject-text-secondary, #909399);
|
|
213
216
|
}
|
|
214
217
|
|
|
215
218
|
textarea, input[type="text"] { white-space: pre-wrap; }
|
|
216
219
|
input[type="text"] {
|
|
217
|
-
border: 1px solid #dcdfe6; border-radius: 6px; padding: 7px 11px;
|
|
220
|
+
border: 1px solid var(--qxs-subject-border, #dcdfe6); border-radius: 6px; padding: 7px 11px;
|
|
218
221
|
font-size: 13px; font-family: inherit; width: 100%; transition: border-color .2s;
|
|
219
222
|
line-height: 1.5; display: block; box-sizing: border-box;
|
|
220
223
|
}
|
|
221
|
-
input[type="text"]:focus { border-color: #3D61E3; outline: none; }
|
|
222
|
-
input[type="text"]:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }
|
|
224
|
+
input[type="text"]:focus { border-color: var(--qxs-subject-color-primary, #3D61E3); outline: none; }
|
|
225
|
+
input[type="text"]:disabled { background: var(--qxs-subject-fill-light, #f5f7fa); color: var(--qxs-subject-text-disabled, #c0c4cc); cursor: not-allowed; }
|
|
223
226
|
|
|
224
|
-
.el-link { color: #3D61E3; cursor: pointer; font-size: 12px; }
|
|
225
|
-
.el-link.danger { color: #f56c6c; }
|
|
227
|
+
.el-link { color: var(--qxs-subject-color-primary, #3D61E3); cursor: pointer; font-size: 12px; }
|
|
228
|
+
.el-link.danger { color: var(--qxs-subject-color-danger, #f56c6c); }
|
|
226
229
|
|
|
227
230
|
.answer-item { display: flex; align-items: center; gap: 8px; }
|
|
228
|
-
.answer-item .label { min-width: 28px; font-size: 13px; font-weight: 600; color: #6b7280; letter-spacing: 0; }
|
|
231
|
+
.answer-item .label { min-width: 28px; font-size: 13px; font-weight: 600; color: var(--qxs-subject-text-soft, #6b7280); letter-spacing: 0; }
|
|
229
232
|
.answer-item .input { flex: 1; max-width: 220px; }
|
|
230
233
|
.answer-item .input input {
|
|
231
234
|
height: 36px; padding: 0 10px;
|
|
232
235
|
font-size: 13px; line-height: 32px;
|
|
233
|
-
border: 1px solid #dcdfe6; border-radius: 6px; width: 100%;
|
|
236
|
+
border: 1px solid var(--qxs-subject-border, #dcdfe6); border-radius: 6px; width: 100%;
|
|
234
237
|
transition: border-color .2s; box-sizing: border-box;
|
|
235
238
|
}
|
|
236
|
-
.answer-item .input input:focus { border-color: #3D61E3; outline: none; }
|
|
239
|
+
.answer-item .input input:focus { border-color: var(--qxs-subject-color-primary, #3D61E3); outline: none; }
|
|
237
240
|
|
|
238
241
|
.answer-item .icon {
|
|
239
242
|
margin-left: 6px; cursor: pointer; display: inline-flex;
|
|
240
243
|
align-items: center; justify-content: center;
|
|
241
244
|
width: 24px; height: 24px; border-radius: 4px;
|
|
242
|
-
border: 1px solid #dcdfe6; background: #fff; color: #909399;
|
|
245
|
+
border: 1px solid var(--qxs-subject-border, #dcdfe6); background: var(--qxs-subject-fill-blank, #fff); color: var(--qxs-subject-text-secondary, #909399);
|
|
243
246
|
transition: all 0.2s;
|
|
244
247
|
}
|
|
245
|
-
.answer-item .icon:hover { color: #3D61E3; border-color: #3D61E3; background: #ecf5ff; }
|
|
246
|
-
.answer-item .icon.disabled { color: #e4e7ed; border-color: #e4e7ed; cursor: not-allowed; }
|
|
248
|
+
.answer-item .icon:hover { color: var(--qxs-subject-color-primary, #3D61E3); border-color: var(--qxs-subject-color-primary, #3D61E3); background: var(--qxs-subject-fill-soft-primary, #ecf5ff); }
|
|
249
|
+
.answer-item .icon.disabled { color: var(--qxs-subject-border-light, #e4e7ed); border-color: var(--qxs-subject-border-light, #e4e7ed); cursor: not-allowed; }
|
|
247
250
|
|
|
248
251
|
.row-title-textarea { min-height: 220px; }
|
|
249
252
|
|
|
@@ -263,5 +266,5 @@
|
|
|
263
266
|
gap: 16px;
|
|
264
267
|
}
|
|
265
268
|
}
|
|
266
|
-
`]
|
|
269
|
+
`];s([i.property({type:Number,attribute:"order-index"})],exports.QxsScale.prototype,"order-index",2);s([i.property({type:String,attribute:"subject-prefix"})],exports.QxsScale.prototype,"subject-prefix",2);s([i.property({type:String})],exports.QxsScale.prototype,"title",2);s([i.property({type:String,attribute:"custom-id"})],exports.QxsScale.prototype,"custom-id",2);s([i.property({type:Boolean,attribute:"is-edit"})],exports.QxsScale.prototype,"is-edit",2);s([i.property({type:Boolean,attribute:"is-save"})],exports.QxsScale.prototype,"is-save",2);s([i.property({type:Boolean,attribute:"is-set"})],exports.QxsScale.prototype,"is-set",2);s([i.property({type:Boolean,attribute:"show-action"})],exports.QxsScale.prototype,"show-action",2);s([i.property({type:Boolean,attribute:"show-add"})],exports.QxsScale.prototype,"show-add",2);s([i.property({type:Boolean,attribute:"hide-add-rich-text"})],exports.QxsScale.prototype,"hide-add-rich-text",2);s([i.property({type:Boolean,attribute:"show-rich-text"})],exports.QxsScale.prototype,"show-rich-text",2);s([i.property({type:Boolean,attribute:"show-delete-action"})],exports.QxsScale.prototype,"show-delete-action",2);s([i.property({type:Boolean,attribute:"show-save-action"})],exports.QxsScale.prototype,"show-save-action",2);s([i.property({type:Boolean,reflect:!0})],exports.QxsScale.prototype,"sorting",2);s([i.property({type:Boolean,attribute:"show-analysis"})],exports.QxsScale.prototype,"show-analysis",2);s([i.property({type:String})],exports.QxsScale.prototype,"analysis",2);s([i.property({type:String,attribute:"rich-text-content"})],exports.QxsScale.prototype,"rich-text-content",2);s([i.property({type:Number,attribute:"exam-answer-relation-type"})],exports.QxsScale.prototype,"exam-answer-relation-type",2);s([i.property({type:Object,attribute:"upload-image"})],exports.QxsScale.prototype,"upload-image",2);s([i.property({type:Array,attribute:"answer-list"})],exports.QxsScale.prototype,"answer-list",1);s([i.property({type:Array,attribute:"scale-question-list"})],exports.QxsScale.prototype,"scale-question-list",1);s([i.property({type:Array,attribute:"scale-questions"})],exports.QxsScale.prototype,"scale-questions",1);s([i.state()],exports.QxsScale.prototype,"_answers",2);s([i.state()],exports.QxsScale.prototype,"_scaleQuestions",2);s([i.state()],exports.QxsScale.prototype,"_rowTitle",2);s([i.state()],exports.QxsScale.prototype,"_title",2);s([i.state()],exports.QxsScale.prototype,"_analysis",2);s([i.state()],exports.QxsScale.prototype,"_showRichText",2);s([i.state()],exports.QxsScale.prototype,"_richText",2);s([i.property({type:String,attribute:"model-value"})],exports.QxsScale.prototype,"model-value",2);s([i.property({type:Boolean,attribute:"use-model"})],exports.QxsScale.prototype,"use-model",2);exports.QxsScale=s([_.safeCustomElement("qxs-scale")],exports.QxsScale);
|
|
267
270
|
//# sourceMappingURL=scale.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scale.cjs","sources":["../../../../packages/components/src/subject/scale.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { SUB_TEXT_EDITOR_TOOLBAR } from '../editor/toolbar'\nimport { buildSubjectPreviewTitle, buildSubjectSortingTitle, emitSubjectEvent, emitSubjectModelValue, showSubjectToast } from './shared-methods'\nimport { subjectControlResetStyles, subjectFormBaseStyles, subjectHostStyles, subjectPreviewBaseStyles, subjectTextareaStyles } from './shared-styles'\nimport { SubjectError, trimText } from './single'\nimport { renderSortingCard, sortingCardStyles } from './sorting-card'\nimport { SubjectType, SubjectTypeLabel } from './types'\n\ninterface ScaleAnswer {\n title: string\n answerId?: string | number\n orderIndex?: number\n isCorrect?: boolean\n [key: string]: any\n}\n\nfunction createEmptyScaleAnswer(): ScaleAnswer {\n return { title: '' }\n}\n\nfunction createDefaultScaleAnswers(): ScaleAnswer[] {\n return Array.from({ length: 5 }, createEmptyScaleAnswer)\n}\n\nfunction normalizeScaleAnswer(answer: any): ScaleAnswer {\n const next: ScaleAnswer = {\n ...answer,\n title: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n const answerId = answer?.answerId ?? answer?.examAnswerId\n if (answerId !== undefined) {\n next.answerId = answerId\n }\n delete next.answer\n delete next.examAnswerId\n delete next.isCorrect\n return next\n}\n\nfunction normalizeScaleAnswers(value: any): ScaleAnswer[] {\n return Array.isArray(value) ? value.map(normalizeScaleAnswer) : []\n}\n\nfunction normalizeScaleQuestionList(value: any): string[] {\n if (!Array.isArray(value)) {\n return []\n }\n return value\n .map(item => String(item ?? '').trim())\n .filter(Boolean)\n}\n\nfunction splitScaleQuestionLines(value: string): string[] {\n return value\n .split('\\n')\n .map(item => item.trim())\n .filter(Boolean)\n}\n\nfunction serializeScaleAnswer(answer: any, index: number): ScaleAnswer {\n const next: ScaleAnswer = {\n ...normalizeScaleAnswer(answer),\n orderIndex: index + 1,\n answer: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n next.title = trimText(next.title ?? '')\n if (next.answerId !== undefined) {\n next.examAnswerId = next.answerId\n }\n if (next.answerId === undefined) {\n delete next.answerId\n }\n delete next.isCorrect\n return next\n}\n\nconst iconPlus = html`<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><line x1=\"12\" y1=\"5\" x2=\"12\" y2=\"19\"/><line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"/></svg>`\nconst iconRemove = html`<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"/></svg>`\n\n@safeCustomElement('qxs-scale')\nexport class QxsScale extends LitElement {\n static styles = [sortingCardStyles, subjectHostStyles, subjectControlResetStyles, subjectPreviewBaseStyles, subjectFormBaseStyles, subjectTextareaStyles, css`\n .scale-table-wrap {\n margin-top: 18px;\n border: 1px solid #e5e7eb;\n border-radius: 12px;\n background: #fff;\n overflow: hidden;\n }\n .scale-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; color: #4b5563; }\n .scale-table th, .scale-table td { border-bottom: 1px solid #eef2f7; padding: 10px 8px; text-align: center; vertical-align: middle; }\n .scale-table thead th { font-size: 12px; font-weight: 600; color: #8b95a7; background: #f8fafc; }\n .scale-table thead th:first-child,\n .scale-table tbody td:first-child {\n color: #303133;\n text-align: left;\n font-weight: 600;\n }\n .scale-table thead th:first-child {\n background: #f3f4f6;\n }\n .scale-table tbody td:first-child {\n background: #fafafa;\n }\n .scale-table tbody tr:last-child td { border-bottom: none; }\n .scale-table input[type=\"radio\"] {\n accent-color: #3D61E3;\n }\n\n .flex { display: flex; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .edit-grid {\n display: grid;\n grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);\n gap: 20px;\n }\n .edit-column {\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 10px;\n }\n .edit-column-title {\n font-size: 12px;\n line-height: 1.4;\n font-weight: 600;\n color: #8b95a7;\n letter-spacing: 0.02em;\n }\n .edit-note {\n font-size: 12px;\n line-height: 1.6;\n color: #909399;\n }\n\n textarea, input[type=\"text\"] { white-space: pre-wrap; }\n input[type=\"text\"] {\n border: 1px solid #dcdfe6; border-radius: 6px; padding: 7px 11px;\n font-size: 13px; font-family: inherit; width: 100%; transition: border-color .2s;\n line-height: 1.5; display: block; box-sizing: border-box;\n }\n input[type=\"text\"]:focus { border-color: #3D61E3; outline: none; }\n input[type=\"text\"]:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; }\n .el-link.danger { color: #f56c6c; }\n\n .answer-item { display: flex; align-items: center; gap: 8px; }\n .answer-item .label { min-width: 28px; font-size: 13px; font-weight: 600; color: #6b7280; letter-spacing: 0; }\n .answer-item .input { flex: 1; max-width: 220px; }\n .answer-item .input input {\n height: 36px; padding: 0 10px;\n font-size: 13px; line-height: 32px;\n border: 1px solid #dcdfe6; border-radius: 6px; width: 100%;\n transition: border-color .2s; box-sizing: border-box;\n }\n .answer-item .input input:focus { border-color: #3D61E3; outline: none; }\n\n .answer-item .icon {\n margin-left: 6px; cursor: pointer; display: inline-flex;\n align-items: center; justify-content: center;\n width: 24px; height: 24px; border-radius: 4px;\n border: 1px solid #dcdfe6; background: #fff; color: #909399;\n transition: all 0.2s;\n }\n .answer-item .icon:hover { color: #3D61E3; border-color: #3D61E3; background: #ecf5ff; }\n .answer-item .icon.disabled { color: #e4e7ed; border-color: #e4e7ed; cursor: not-allowed; }\n\n .row-title-textarea { min-height: 220px; }\n\n @media (max-width: 720px) {\n .edit-row {\n flex-direction: column;\n gap: 8px;\n }\n\n .edit-row > .label {\n min-width: 0;\n padding-top: 0;\n }\n\n .edit-grid {\n grid-template-columns: 1fr;\n gap: 16px;\n }\n }\n `]\n\n @property({ type: Number, attribute: 'order-index' }) 'order-index' = 0\n @property({ type: String, attribute: 'subject-prefix' }) 'subject-prefix'?: string\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Boolean, attribute: 'is-edit' }) 'is-edit' = false\n @property({ type: Boolean, attribute: 'is-save' }) 'is-save' = false\n @property({ type: Boolean, attribute: 'is-set' }) 'is-set' = false\n @property({ type: Boolean, attribute: 'show-action' }) 'show-action' = true\n @property({ type: Boolean, attribute: 'show-add' }) 'show-add' = true\n @property({ type: Boolean, attribute: 'hide-add-rich-text' }) 'hide-add-rich-text' = false\n @property({ type: Boolean, attribute: 'show-rich-text' }) 'show-rich-text' = false\n @property({ type: Boolean, attribute: 'show-delete-action' }) 'show-delete-action' = true\n @property({ type: Boolean, attribute: 'show-save-action' }) 'show-save-action' = true\n @property({ type: Boolean, reflect: true }) sorting = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = false\n @property({ type: String }) analysis = ''\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: Object, attribute: 'upload-image' })\n 'upload-image': (file: File) => Promise<string> = async (file: File) => {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = e => resolve(e.target?.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n }\n\n @property({ type: Array, attribute: 'answer-list' })\n get 'answer-list'() { return this._answers }\n\n set 'answer-list'(value: any) {\n const answers = normalizeScaleAnswers(value)\n this._answers = answers.length ? answers : createDefaultScaleAnswers()\n this.requestUpdate('answer-list')\n }\n\n @property({ type: Array, attribute: 'scale-question-list' })\n get 'scale-question-list'() { return this._scaleQuestions }\n\n set 'scale-question-list'(value: any) {\n this._scaleQuestions = normalizeScaleQuestionList(value)\n this.requestUpdate('scale-question-list')\n }\n\n @property({ type: Array, attribute: 'scale-questions' })\n get 'scale-questions'() { return this._scaleQuestions }\n\n set 'scale-questions'(value: any) {\n this['scale-question-list'] = value\n this.requestUpdate('scale-questions')\n }\n\n @state() private _answers: ScaleAnswer[] = createDefaultScaleAnswers()\n @state() private _scaleQuestions: string[] = []\n @state() private _rowTitle = ''\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _showRichText = false\n @state() private _richText = ''\n\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n private readonly TITLE_MAX = 200\n\n willUpdate(changed: Map<string, unknown>) {\n const shouldSyncProps = changed.has('title')\n || changed.has('answer-list')\n || changed.has('rich-text-content')\n || changed.has('scale-question-list')\n || changed.has('scale-questions')\n\n if ((changed.has('is-edit') && this['is-edit']) || (!this['is-edit'] && shouldSyncProps)) {\n this._syncProps()\n }\n\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value']\n }\n }\n\n private _syncProps() {\n this._title = this.title || ''\n this._analysis = this.analysis || ''\n this._rowTitle = this._scaleQuestions.join('\\n')\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n }\n\n private _emit(name: string, detail?: unknown) {\n emitSubjectEvent(this, name, detail)\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) {\n el.value = el.value.slice(0, this.TITLE_MAX)\n }\n this._title = el.value\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n }\n\n private _resolvedQuestions(): string[] {\n const rowTitle = this['is-edit'] ? this._rowTitle : this._scaleQuestions.join('\\n')\n return splitScaleQuestionLines(rowTitle)\n }\n\n private _resolvedAnswers(): ScaleAnswer[] {\n const answers = this['is-edit'] ? this._answers : this['answer-list']\n return Array.isArray(answers) ? answers.map(normalizeScaleAnswer) : []\n }\n\n private _createAnswerCountError(row: Record<string, unknown>) {\n return new SubjectError('量表题选项数量必须在 3-5 个之间!', 'ANSWER_COUNT_INVALID', 'answers', row)\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const richText = this['is-edit'] ? this._richText : this['rich-text-content'] || ''\n const showRichText = this['show-rich-text'] && (this['is-edit'] ? this._showRichText : !!this['rich-text-content'])\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n\n if (answers.length < 3 || answers.length > 5) {\n reject(this._createAnswerCountError(row))\n return\n }\n\n for (let i = 0; i < answers.length; i++) {\n if (!answers[i].title) {\n reject(new SubjectError(`选项${String.fromCharCode(65 + i)}未填写。`, 'ANSWER_EMPTY', 'answers', row))\n return\n }\n }\n\n if (questions.length === 0) {\n reject(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n return\n }\n\n const result: any = {\n answerType: SubjectType.SCALE,\n examTypeEnum: SubjectType.SCALE,\n title,\n answers: answers.map(serializeScaleAnswer),\n scaleQuestionList: questions,\n analysis: trimText(this['is-edit'] ? this._analysis : this.analysis || ''),\n examRichTextContent: showRichText ? richText : '',\n isSetCorrectAnswer: false,\n }\n\n if (this['custom-id']) {\n result.customId = this['custom-id']\n }\n if (this['exam-answer-relation-type']) {\n result.examAnswerRelationType = this['exam-answer-relation-type']\n }\n\n resolve(result)\n })\n }\n\n private async _save(e?: Event) {\n e?.stopImmediatePropagation()\n try {\n const data = await this.toJSON()\n this._emit('save', data)\n }\n catch (err: any) {\n showSubjectToast(err.message)\n }\n }\n\n validate(): SubjectError[] {\n const errors: SubjectError[] = []\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n\n if (answers.length < 3 || answers.length > 5) {\n errors.push(this._createAnswerCountError(row))\n return errors\n }\n\n answers.forEach((answer: ScaleAnswer, index: number) => {\n if (!answer.title) {\n errors.push(new SubjectError(`选项${String.fromCharCode(65 + index)}未填写`, 'ANSWER_EMPTY', 'answers', row))\n }\n })\n\n if (questions.length === 0) {\n errors.push(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n }\n\n return errors\n }\n\n private _renderPreview() {\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const colWidth = Math.floor(100 / ((answers.length || 1) + 1))\n const previewTitle = buildSubjectPreviewTitle(this['subject-prefix'], this['order-index'], this.title)\n\n return html`\n <div class=\"preview\">\n <div class=\"preview-header\">\n <div class=\"preview-title-row\">\n <span class=\"title\">${previewTitle}</span>\n <span class=\"preview-type\">量表题</span>\n </div>\n ${this['show-rich-text'] && this['rich-text-content'] ? html`<div class=\"rich-text\" .innerHTML=${this['rich-text-content']}></div>` : ''}\n </div>\n <div class=\"scale-table-wrap\">\n <table class=\"scale-table\">\n <thead>\n <tr>\n <th style=\"width:${colWidth}%\">问题</th>\n ${answers.map(answer => html`<th style=\"width:${colWidth}%\">${answer.title}</th>`)}\n </tr>\n </thead>\n <tbody>\n ${questions.map(question => html`\n <tr>\n <td>${question}</td>\n ${answers.map(() => html`<td><input type=\"radio\" disabled /></td>`)}\n </tr>\n `)}\n </tbody>\n </table>\n </div>\n </div>\n `\n }\n\n private _renderEdit() {\n return html`\n <div class=\"edit-form\">\n <div class=\"edit-row\">\n <div class=\"label\"><span>题目:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._title}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【量表题】请输入问题\"\n ></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n </div>\n </div>\n </div>\n\n <slot name=\"business-tag\"></slot>\n\n <div class=\"edit-row\">\n <div class=\"label\"><span>量表内容:</span></div>\n <div class=\"row-body\">\n <div class=\"edit-grid\">\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">行标题</div>\n <div class=\"el-input\">\n <textarea\n class=\"row-title-textarea\"\n .value=${this._rowTitle}\n @input=${(e: Event) => { this._rowTitle = (e.target as HTMLTextAreaElement).value }}\n @keydown=${(e: KeyboardEvent) => { e.stopPropagation() }}\n placeholder=\"请输入行标题\"\n ></textarea>\n </div>\n <div class=\"edit-note\">一行一个标题,预览时会自动整理空白行。</div>\n </div>\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">评分选项</div>\n ${this._answers.map((answer, index) => html`\n <div class=\"answer-item\">\n <span class=\"label\">${String.fromCharCode(65 + index)}.</span>\n <div class=\"input\">\n <input\n type=\"text\"\n .value=${answer.title}\n maxlength=\"10\"\n @input=${(e: Event) => {\n const value = (e.target as HTMLInputElement).value\n this._answers = this._answers.map((item, currentIndex) =>\n currentIndex === index ? { ...item, title: value } : item,\n )\n }}\n placeholder=\"选项${index + 1}\"\n />\n </div>\n <span\n class=\"icon\"\n @click=${() => {\n if (this._answers.length < 5) {\n this._answers = [...this._answers, createEmptyScaleAnswer()]\n }\n }}\n >${iconPlus}</span>\n <span\n class=\"icon ${this._answers.length < 3 ? 'disabled' : ''}\"\n @click=${() => {\n if (this._answers.length > 3) {\n this._answers = this._answers.filter((_, currentIndex) => currentIndex !== index)\n }\n }}\n >${iconRemove}</span>\n </div>\n `)}\n <div class=\"edit-note\">量表题需保持 3-5 个选项,保存时会校验。</div>\n </div>\n </div>\n </div>\n </div>\n\n ${this['show-rich-text'] && this._showRichText\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>副文本:</span></div>\n <div class=\"row-body\">\n <slot name=\"sub-text\">\n <qxs-blocksuite-editor\n .content=${this._richText}\n .toolbar=${SUB_TEXT_EDITOR_TOOLBAR}\n .upload-image=${this['upload-image']}\n ?is-edit=${true}\n @input=${(e: CustomEvent) => { this._richText = (e.target as any).getContent() }}\n ></qxs-blocksuite-editor>\n </slot>\n ${!this['show-action']\n ? html`\n <div class=\"flex-justify-end\" style=\"margin-top:8px\">\n <span\n class=\"el-link danger\"\n @click=${() => {\n this._showRichText = false\n this._richText = ''\n }}\n >删除富文本</span>\n </div>\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>解析:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"\n ></textarea>\n </div>\n </div>\n </div>\n `\n : ''}\n </div>\n `\n }\n\n private _renderSorting() {\n const title = trimText(this['is-edit'] ? this._title : this.title || '') || '未命名题目'\n const orderText = buildSubjectSortingTitle(this['subject-prefix'], this['order-index'], title)\n return renderSortingCard(orderText, SubjectTypeLabel[SubjectType.SCALE] || SubjectType.SCALE)\n }\n\n render() {\n if (this.sorting) {\n return this._renderSorting()\n }\n\n const content = this['is-edit']\n ? html`<div slot=\"edit\">${this._renderEdit()}</div>`\n : html`<div slot=\"preview\">${this._renderPreview()}</div>`\n\n return html`\n <qxs-subject-layout .show-edit=${this['is-edit']}>\n ${content}\n ${this['show-action']\n ? html`\n <qxs-subject-action\n .is-edit=${this['is-edit']}\n .is-set=${this['is-set']}\n .show-add=${this['show-add']}\n .show-rich-text=${this['show-rich-text'] && this._showRichText}\n .hide-add-rich-text=${!this['show-rich-text'] || this['hide-add-rich-text']}\n .show-delete-action=${this['show-delete-action']}\n .show-save-action=${this['show-save-action']}\n .show-other-option=${false}\n exam-answer-relation-type=${this['exam-answer-relation-type']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @add=${(e: CustomEvent) => this._emit('add', e.detail)}\n @on-show-rich-text=${() => {\n this._showRichText = !this._showRichText\n if (!this._showRichText) {\n this._richText = ''\n }\n }}\n ></qxs-subject-action>\n `\n : ''}\n <slot name=\"action\"></slot>\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["createEmptyScaleAnswer","title","createDefaultScaleAnswers","Array","from","length","normalizeScaleAnswer","answer","next","trimText","answerId","examAnswerId","isCorrect","serializeScaleAnswer","index","orderIndex","iconPlus","html","iconRemove","QxsScale","LitElement","constructor","super","arguments","this","sorting","analysis","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","_answers","_scaleQuestions","_rowTitle","_title","_analysis","_showRichText","_richText","TITLE_MAX","value","answers","isArray","map","normalizeScaleAnswers","requestUpdate","item","String","trim","filter","Boolean","normalizeScaleQuestionList","willUpdate","changed","shouldSyncProps","has","_syncProps","join","_emit","name","detail","emitSubjectEvent","_onTitleInput","el","slice","emitSubjectModelValue","_resolvedQuestions","rowTitle","split","_resolvedAnswers","_createAnswerCountError","row","SubjectError","toJSON","customId","answerType","SubjectType","SCALE","questions","richText","showRichText","i","fromCharCode","examTypeEnum","scaleQuestionList","examRichTextContent","isSetCorrectAnswer","examAnswerRelationType","_save","stopImmediatePropagation","data","err","showSubjectToast","message","validate","errors","push","forEach","_renderPreview","colWidth","Math","floor","previewTitle","buildSubjectPreviewTitle","question","_renderEdit","stopPropagation","currentIndex","_","SUB_TEXT_EDITOR_TOOLBAR","getContent","_renderSorting","orderText","buildSubjectSortingTitle","renderSortingCard","SubjectTypeLabel","render","content","styles","sortingCardStyles","subjectHostStyles","subjectControlResetStyles","subjectPreviewBaseStyles","subjectFormBaseStyles","subjectTextareaStyles","css","__decorateClass","property","type","Number","attribute","prototype","reflect","Object","state","safeCustomElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"scale.cjs","sources":["../../../../packages/components/src/subject/scale.ts"],"sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { SUB_TEXT_EDITOR_TOOLBAR } from '../editor/toolbar'\nimport { buildSubjectPreviewTitle, buildSubjectSortingTitle, emitSubjectEvent, emitSubjectModelValue, showSubjectToast } from './shared-methods'\nimport { subjectControlResetStyles, subjectFormBaseStyles, subjectHostStyles, subjectPreviewBaseStyles, subjectTextareaStyles } from './shared-styles'\nimport { SubjectError, trimText } from './subject-shared'\nimport { renderSortingCard, sortingCardStyles } from './sorting-card'\nimport { SubjectType, SubjectTypeLabel } from './types'\n\ninterface ScaleAnswer {\n title: string\n answerId?: string | number\n orderIndex?: number\n isCorrect?: boolean\n [key: string]: any\n}\n\nfunction createEmptyScaleAnswer(): ScaleAnswer {\n return { title: '' }\n}\n\nfunction createDefaultScaleAnswers(): ScaleAnswer[] {\n return Array.from({ length: 5 }, createEmptyScaleAnswer)\n}\n\nfunction normalizeScaleAnswer(answer: any): ScaleAnswer {\n const next: ScaleAnswer = {\n ...answer,\n title: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n const answerId = answer?.answerId ?? answer?.examAnswerId\n if (answerId !== undefined) {\n next.answerId = answerId\n }\n delete next.answer\n delete next.examAnswerId\n delete next.isCorrect\n return next\n}\n\nfunction normalizeScaleAnswers(value: any): ScaleAnswer[] {\n return Array.isArray(value) ? value.map(normalizeScaleAnswer) : []\n}\n\nfunction normalizeScaleQuestionList(value: any): string[] {\n if (!Array.isArray(value)) {\n return []\n }\n return value\n .map(item => String(item ?? '').trim())\n .filter(Boolean)\n}\n\nfunction splitScaleQuestionLines(value: string): string[] {\n return value\n .split('\\n')\n .map(item => item.trim())\n .filter(Boolean)\n}\n\nfunction serializeScaleAnswer(answer: any, index: number): ScaleAnswer {\n const next: ScaleAnswer = {\n ...normalizeScaleAnswer(answer),\n orderIndex: index + 1,\n answer: trimText(answer?.title ?? answer?.answer ?? ''),\n }\n next.title = trimText(next.title ?? '')\n if (next.answerId !== undefined) {\n next.examAnswerId = next.answerId\n }\n if (next.answerId === undefined) {\n delete next.answerId\n }\n delete next.isCorrect\n return next\n}\n\nconst iconPlus = html`<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><line x1=\"12\" y1=\"5\" x2=\"12\" y2=\"19\"/><line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"/></svg>`\nconst iconRemove = html`<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"/></svg>`\n\n@safeCustomElement('qxs-scale')\nexport class QxsScale extends LitElement {\n static styles = [sortingCardStyles, subjectHostStyles, subjectControlResetStyles, subjectPreviewBaseStyles, subjectFormBaseStyles, subjectTextareaStyles, css`\n .scale-table-wrap {\n margin-top: 18px;\n border: 1px solid var(--qxs-subject-border-light, #e5e7eb);\n border-radius: 12px;\n background: var(--qxs-subject-fill-blank, #fff);\n overflow: hidden;\n }\n .scale-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; color: var(--qxs-subject-text-soft, #4b5563); }\n .scale-table th, .scale-table td { border-bottom: 1px solid var(--qxs-subject-border-extra-light, #eef2f7); padding: 10px 8px; text-align: center; vertical-align: middle; }\n .scale-table thead th { font-size: 12px; font-weight: 600; color: var(--qxs-subject-text-muted, #8b95a7); background: var(--qxs-subject-fill-lighter, #f8fafc); }\n .scale-table thead th:first-child,\n .scale-table tbody td:first-child {\n color: var(--qxs-subject-text-primary, #303133);\n text-align: left;\n font-weight: 600;\n }\n .scale-table thead th:first-child {\n background: var(--qxs-subject-fill-extra-light, #f3f4f6);\n }\n .scale-table tbody td:first-child {\n background: var(--qxs-subject-fill-light, #fafafa);\n }\n .scale-table tbody tr:last-child td { border-bottom: none; }\n .scale-table input[type=\"radio\"] {\n accent-color: var(--qxs-subject-color-primary, #3D61E3);\n }\n\n .flex { display: flex; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .edit-grid {\n display: grid;\n grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);\n gap: 20px;\n }\n .edit-column {\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 10px;\n }\n .edit-column-title {\n font-size: 12px;\n line-height: 1.4;\n font-weight: 600;\n color: var(--qxs-subject-text-muted, #8b95a7);\n letter-spacing: 0.02em;\n }\n .edit-note {\n font-size: 12px;\n line-height: 1.6;\n color: var(--qxs-subject-text-secondary, #909399);\n }\n\n textarea, input[type=\"text\"] { white-space: pre-wrap; }\n input[type=\"text\"] {\n border: 1px solid var(--qxs-subject-border, #dcdfe6); border-radius: 6px; padding: 7px 11px;\n font-size: 13px; font-family: inherit; width: 100%; transition: border-color .2s;\n line-height: 1.5; display: block; box-sizing: border-box;\n }\n input[type=\"text\"]:focus { border-color: var(--qxs-subject-color-primary, #3D61E3); outline: none; }\n input[type=\"text\"]:disabled { background: var(--qxs-subject-fill-light, #f5f7fa); color: var(--qxs-subject-text-disabled, #c0c4cc); cursor: not-allowed; }\n\n .el-link { color: var(--qxs-subject-color-primary, #3D61E3); cursor: pointer; font-size: 12px; }\n .el-link.danger { color: var(--qxs-subject-color-danger, #f56c6c); }\n\n .answer-item { display: flex; align-items: center; gap: 8px; }\n .answer-item .label { min-width: 28px; font-size: 13px; font-weight: 600; color: var(--qxs-subject-text-soft, #6b7280); letter-spacing: 0; }\n .answer-item .input { flex: 1; max-width: 220px; }\n .answer-item .input input {\n height: 36px; padding: 0 10px;\n font-size: 13px; line-height: 32px;\n border: 1px solid var(--qxs-subject-border, #dcdfe6); border-radius: 6px; width: 100%;\n transition: border-color .2s; box-sizing: border-box;\n }\n .answer-item .input input:focus { border-color: var(--qxs-subject-color-primary, #3D61E3); outline: none; }\n\n .answer-item .icon {\n margin-left: 6px; cursor: pointer; display: inline-flex;\n align-items: center; justify-content: center;\n width: 24px; height: 24px; border-radius: 4px;\n border: 1px solid var(--qxs-subject-border, #dcdfe6); background: var(--qxs-subject-fill-blank, #fff); color: var(--qxs-subject-text-secondary, #909399);\n transition: all 0.2s;\n }\n .answer-item .icon:hover { color: var(--qxs-subject-color-primary, #3D61E3); border-color: var(--qxs-subject-color-primary, #3D61E3); background: var(--qxs-subject-fill-soft-primary, #ecf5ff); }\n .answer-item .icon.disabled { color: var(--qxs-subject-border-light, #e4e7ed); border-color: var(--qxs-subject-border-light, #e4e7ed); cursor: not-allowed; }\n\n .row-title-textarea { min-height: 220px; }\n\n @media (max-width: 720px) {\n .edit-row {\n flex-direction: column;\n gap: 8px;\n }\n\n .edit-row > .label {\n min-width: 0;\n padding-top: 0;\n }\n\n .edit-grid {\n grid-template-columns: 1fr;\n gap: 16px;\n }\n }\n `]\n\n @property({ type: Number, attribute: 'order-index' }) 'order-index' = 0\n @property({ type: String, attribute: 'subject-prefix' }) 'subject-prefix'?: string\n @property({ type: String }) title = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Boolean, attribute: 'is-edit' }) 'is-edit' = false\n @property({ type: Boolean, attribute: 'is-save' }) 'is-save' = false\n @property({ type: Boolean, attribute: 'is-set' }) 'is-set' = false\n @property({ type: Boolean, attribute: 'show-action' }) 'show-action' = true\n @property({ type: Boolean, attribute: 'show-add' }) 'show-add' = true\n @property({ type: Boolean, attribute: 'hide-add-rich-text' }) 'hide-add-rich-text' = false\n @property({ type: Boolean, attribute: 'show-rich-text' }) 'show-rich-text' = false\n @property({ type: Boolean, attribute: 'show-delete-action' }) 'show-delete-action' = true\n @property({ type: Boolean, attribute: 'show-save-action' }) 'show-save-action' = true\n @property({ type: Boolean, reflect: true }) sorting = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = false\n @property({ type: String }) analysis = ''\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: Object, attribute: 'upload-image' })\n 'upload-image': (file: File) => Promise<string> = async (file: File) => {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = e => resolve(e.target?.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n }\n\n @property({ type: Array, attribute: 'answer-list' })\n get 'answer-list'() { return this._answers }\n\n set 'answer-list'(value: any) {\n const answers = normalizeScaleAnswers(value)\n this._answers = answers.length ? answers : createDefaultScaleAnswers()\n this.requestUpdate('answer-list')\n }\n\n @property({ type: Array, attribute: 'scale-question-list' })\n get 'scale-question-list'() { return this._scaleQuestions }\n\n set 'scale-question-list'(value: any) {\n this._scaleQuestions = normalizeScaleQuestionList(value)\n this.requestUpdate('scale-question-list')\n }\n\n @property({ type: Array, attribute: 'scale-questions' })\n get 'scale-questions'() { return this._scaleQuestions }\n\n set 'scale-questions'(value: any) {\n this['scale-question-list'] = value\n this.requestUpdate('scale-questions')\n }\n\n @state() private _answers: ScaleAnswer[] = createDefaultScaleAnswers()\n @state() private _scaleQuestions: string[] = []\n @state() private _rowTitle = ''\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _showRichText = false\n @state() private _richText = ''\n\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n private readonly TITLE_MAX = 200\n\n willUpdate(changed: Map<string, unknown>) {\n const shouldSyncProps = changed.has('title')\n || changed.has('answer-list')\n || changed.has('rich-text-content')\n || changed.has('scale-question-list')\n || changed.has('scale-questions')\n\n if ((changed.has('is-edit') && this['is-edit']) || (!this['is-edit'] && shouldSyncProps)) {\n this._syncProps()\n }\n\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value']\n }\n }\n\n private _syncProps() {\n this._title = this.title || ''\n this._analysis = this.analysis || ''\n this._rowTitle = this._scaleQuestions.join('\\n')\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n }\n\n private _emit(name: string, detail?: unknown) {\n emitSubjectEvent(this, name, detail)\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) {\n el.value = el.value.slice(0, this.TITLE_MAX)\n }\n this._title = el.value\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n }\n\n private _resolvedQuestions(): string[] {\n const rowTitle = this['is-edit'] ? this._rowTitle : this._scaleQuestions.join('\\n')\n return splitScaleQuestionLines(rowTitle)\n }\n\n private _resolvedAnswers(): ScaleAnswer[] {\n const answers = this['is-edit'] ? this._answers : this['answer-list']\n return Array.isArray(answers) ? answers.map(normalizeScaleAnswer) : []\n }\n\n private _createAnswerCountError(row: Record<string, unknown>) {\n return new SubjectError('量表题选项数量必须在 3-5 个之间!', 'ANSWER_COUNT_INVALID', 'answers', row)\n }\n\n async toJSON(): Promise<any> {\n return new Promise((resolve, reject) => {\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const richText = this['is-edit'] ? this._richText : this['rich-text-content'] || ''\n const showRichText = this['show-rich-text'] && (this['is-edit'] ? this._showRichText : !!this['rich-text-content'])\n\n if (!title) {\n reject(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n return\n }\n\n if (answers.length < 3 || answers.length > 5) {\n reject(this._createAnswerCountError(row))\n return\n }\n\n for (let i = 0; i < answers.length; i++) {\n if (!answers[i].title) {\n reject(new SubjectError(`选项${String.fromCharCode(65 + i)}未填写。`, 'ANSWER_EMPTY', 'answers', row))\n return\n }\n }\n\n if (questions.length === 0) {\n reject(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n return\n }\n\n const result: any = {\n answerType: SubjectType.SCALE,\n examTypeEnum: SubjectType.SCALE,\n title,\n answers: answers.map(serializeScaleAnswer),\n scaleQuestionList: questions,\n analysis: trimText(this['is-edit'] ? this._analysis : this.analysis || ''),\n examRichTextContent: showRichText ? richText : '',\n isSetCorrectAnswer: false,\n }\n\n if (this['custom-id']) {\n result.customId = this['custom-id']\n }\n if (this['exam-answer-relation-type']) {\n result.examAnswerRelationType = this['exam-answer-relation-type']\n }\n\n resolve(result)\n })\n }\n\n private async _save(e?: Event) {\n e?.stopImmediatePropagation()\n try {\n const data = await this.toJSON()\n this._emit('save', data)\n }\n catch (err: any) {\n showSubjectToast(err.message)\n }\n }\n\n validate(): SubjectError[] {\n const errors: SubjectError[] = []\n const row = {\n customId: this['custom-id'] || undefined,\n answerType: SubjectType.SCALE,\n orderIndex: this['order-index'],\n }\n\n const title = trimText(this['is-edit'] ? this._title : this.title || '')\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n\n if (!title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n\n if (answers.length < 3 || answers.length > 5) {\n errors.push(this._createAnswerCountError(row))\n return errors\n }\n\n answers.forEach((answer: ScaleAnswer, index: number) => {\n if (!answer.title) {\n errors.push(new SubjectError(`选项${String.fromCharCode(65 + index)}未填写`, 'ANSWER_EMPTY', 'answers', row))\n }\n })\n\n if (questions.length === 0) {\n errors.push(new SubjectError('行标题不能为空!', 'EMPTY_ROW_TITLE', 'rowTitle', row))\n }\n\n return errors\n }\n\n private _renderPreview() {\n const answers = this._resolvedAnswers()\n const questions = this._resolvedQuestions()\n const colWidth = Math.floor(100 / ((answers.length || 1) + 1))\n const previewTitle = buildSubjectPreviewTitle(this['subject-prefix'], this['order-index'], this.title)\n\n return html`\n <div class=\"preview\">\n <div class=\"preview-header\">\n <div class=\"preview-title-row\">\n <span class=\"title\">${previewTitle}</span>\n <span class=\"preview-type\">量表题</span>\n </div>\n ${this['show-rich-text'] && this['rich-text-content'] ? html`<div class=\"rich-text\" .innerHTML=${this['rich-text-content']}></div>` : ''}\n </div>\n <div class=\"scale-table-wrap\">\n <table class=\"scale-table\">\n <thead>\n <tr>\n <th style=\"width:${colWidth}%\">问题</th>\n ${answers.map(answer => html`<th style=\"width:${colWidth}%\">${answer.title}</th>`)}\n </tr>\n </thead>\n <tbody>\n ${questions.map(question => html`\n <tr>\n <td>${question}</td>\n ${answers.map(() => html`<td><input type=\"radio\" disabled /></td>`)}\n </tr>\n `)}\n </tbody>\n </table>\n </div>\n </div>\n `\n }\n\n private _renderEdit() {\n return html`\n <div class=\"edit-form\">\n <div class=\"edit-row\">\n <div class=\"label\"><span>题目:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._title}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【量表题】请输入问题\"\n ></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n </div>\n </div>\n </div>\n\n <slot name=\"business-tag\"></slot>\n\n <div class=\"edit-row\">\n <div class=\"label\"><span>量表内容:</span></div>\n <div class=\"row-body\">\n <div class=\"edit-grid\">\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">行标题</div>\n <div class=\"el-input\">\n <textarea\n class=\"row-title-textarea\"\n .value=${this._rowTitle}\n @input=${(e: Event) => { this._rowTitle = (e.target as HTMLTextAreaElement).value }}\n @keydown=${(e: KeyboardEvent) => { e.stopPropagation() }}\n placeholder=\"请输入行标题\"\n ></textarea>\n </div>\n <div class=\"edit-note\">一行一个标题,预览时会自动整理空白行。</div>\n </div>\n <div class=\"edit-column\">\n <div class=\"edit-column-title\">评分选项</div>\n ${this._answers.map((answer, index) => html`\n <div class=\"answer-item\">\n <span class=\"label\">${String.fromCharCode(65 + index)}.</span>\n <div class=\"input\">\n <input\n type=\"text\"\n .value=${answer.title}\n maxlength=\"10\"\n @input=${(e: Event) => {\n const value = (e.target as HTMLInputElement).value\n this._answers = this._answers.map((item, currentIndex) =>\n currentIndex === index ? { ...item, title: value } : item,\n )\n }}\n placeholder=\"选项${index + 1}\"\n />\n </div>\n <span\n class=\"icon\"\n @click=${() => {\n if (this._answers.length < 5) {\n this._answers = [...this._answers, createEmptyScaleAnswer()]\n }\n }}\n >${iconPlus}</span>\n <span\n class=\"icon ${this._answers.length < 3 ? 'disabled' : ''}\"\n @click=${() => {\n if (this._answers.length > 3) {\n this._answers = this._answers.filter((_, currentIndex) => currentIndex !== index)\n }\n }}\n >${iconRemove}</span>\n </div>\n `)}\n <div class=\"edit-note\">量表题需保持 3-5 个选项,保存时会校验。</div>\n </div>\n </div>\n </div>\n </div>\n\n ${this['show-rich-text'] && this._showRichText\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>副文本:</span></div>\n <div class=\"row-body\">\n <slot name=\"sub-text\">\n <qxs-blocksuite-editor\n .content=${this._richText}\n .toolbar=${SUB_TEXT_EDITOR_TOOLBAR}\n .upload-image=${this['upload-image']}\n ?is-edit=${true}\n @input=${(e: CustomEvent) => { this._richText = (e.target as any).getContent() }}\n ></qxs-blocksuite-editor>\n </slot>\n ${!this['show-action']\n ? html`\n <div class=\"flex-justify-end\" style=\"margin-top:8px\">\n <span\n class=\"el-link danger\"\n @click=${() => {\n this._showRichText = false\n this._richText = ''\n }}\n >删除富文本</span>\n </div>\n `\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"edit-row\">\n <div class=\"label\"><span>解析:</span></div>\n <div class=\"row-body\">\n <div class=\"el-input\">\n <textarea\n rows=\"2\"\n .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"\n ></textarea>\n </div>\n </div>\n </div>\n `\n : ''}\n </div>\n `\n }\n\n private _renderSorting() {\n const title = trimText(this['is-edit'] ? this._title : this.title || '') || '未命名题目'\n const orderText = buildSubjectSortingTitle(this['subject-prefix'], this['order-index'], title)\n return renderSortingCard(orderText, SubjectTypeLabel[SubjectType.SCALE] || SubjectType.SCALE)\n }\n\n render() {\n if (this.sorting) {\n return this._renderSorting()\n }\n\n const content = this['is-edit']\n ? html`<div slot=\"edit\">${this._renderEdit()}</div>`\n : html`<div slot=\"preview\">${this._renderPreview()}</div>`\n\n return html`\n <qxs-subject-layout .show-edit=${this['is-edit']}>\n ${content}\n ${this['show-action']\n ? html`\n <qxs-subject-action\n .is-edit=${this['is-edit']}\n .is-set=${this['is-set']}\n .show-add=${this['show-add']}\n .show-rich-text=${this['show-rich-text'] && this._showRichText}\n .hide-add-rich-text=${!this['show-rich-text'] || this['hide-add-rich-text']}\n .show-delete-action=${this['show-delete-action']}\n .show-save-action=${this['show-save-action']}\n .show-other-option=${false}\n exam-answer-relation-type=${this['exam-answer-relation-type']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @add=${(e: CustomEvent) => this._emit('add', e.detail)}\n @on-show-rich-text=${() => {\n this._showRichText = !this._showRichText\n if (!this._showRichText) {\n this._richText = ''\n }\n }}\n ></qxs-subject-action>\n `\n : ''}\n <slot name=\"action\"></slot>\n </qxs-subject-layout>\n `\n }\n}\n\nexport function register() {}\n"],"names":["createEmptyScaleAnswer","createDefaultScaleAnswers","normalizeScaleAnswer","answer","next","trimText","answerId","normalizeScaleAnswers","value","normalizeScaleQuestionList","item","splitScaleQuestionLines","serializeScaleAnswer","index","iconPlus","html","iconRemove","QxsScale","LitElement","file","resolve","reject","reader","e","answers","changed","shouldSyncProps","name","detail","emitSubjectEvent","el","emitSubjectModelValue","rowTitle","row","SubjectError","SubjectType","title","questions","richText","showRichText","i","result","data","err","showSubjectToast","errors","colWidth","previewTitle","buildSubjectPreviewTitle","question","currentIndex","_","SUB_TEXT_EDITOR_TOOLBAR","orderText","buildSubjectSortingTitle","renderSortingCard","SubjectTypeLabel","content","sortingCardStyles","subjectHostStyles","subjectControlResetStyles","subjectPreviewBaseStyles","subjectFormBaseStyles","subjectTextareaStyles","css","__decorateClass","property","state","safeCustomElement"],"mappings":"uiBAkBA,SAASA,GAAsC,CAC7C,MAAO,CAAE,MAAO,EAAA,CAClB,CAEA,SAASC,GAA2C,CAClD,OAAO,MAAM,KAAK,CAAE,OAAQ,CAAA,EAAKD,CAAsB,CACzD,CAEA,SAASE,EAAqBC,EAA0B,CACtD,MAAMC,EAAoB,CACxB,GAAGD,EACH,MAAOE,EAAAA,SAASF,GAAQ,OAASA,GAAQ,QAAU,EAAE,CAAA,EAEjDG,EAAWH,GAAQ,UAAYA,GAAQ,aAC7C,OAAIG,IAAa,SACfF,EAAK,SAAWE,GAElB,OAAOF,EAAK,OACZ,OAAOA,EAAK,aACZ,OAAOA,EAAK,UACLA,CACT,CAEA,SAASG,EAAsBC,EAA2B,CACxD,OAAO,MAAM,QAAQA,CAAK,EAAIA,EAAM,IAAIN,CAAoB,EAAI,CAAA,CAClE,CAEA,SAASO,EAA2BD,EAAsB,CACxD,OAAK,MAAM,QAAQA,CAAK,EAGjBA,EACJ,IAAIE,GAAQ,OAAOA,GAAQ,EAAE,EAAE,KAAA,CAAM,EACrC,OAAO,OAAO,EAJR,CAAA,CAKX,CAEA,SAASC,EAAwBH,EAAyB,CACxD,OAAOA,EACJ,MAAM;AAAA,CAAI,EACV,IAAIE,GAAQA,EAAK,KAAA,CAAM,EACvB,OAAO,OAAO,CACnB,CAEA,SAASE,EAAqBT,EAAaU,EAA4B,CACrE,MAAMT,EAAoB,CACxB,GAAGF,EAAqBC,CAAM,EAC9B,WAAYU,EAAQ,EACpB,OAAQR,EAAAA,SAASF,GAAQ,OAASA,GAAQ,QAAU,EAAE,CAAA,EAExD,OAAAC,EAAK,MAAQC,EAAAA,SAASD,EAAK,OAAS,EAAE,EAClCA,EAAK,WAAa,SACpBA,EAAK,aAAeA,EAAK,UAEvBA,EAAK,WAAa,QACpB,OAAOA,EAAK,SAEd,OAAOA,EAAK,UACLA,CACT,CAEA,MAAMU,EAAWC,EAAAA,+NACXC,EAAaD,EAAAA,yLAGNE,QAAAA,SAAN,cAAuBC,EAAAA,UAAW,CAAlC,aAAA,CAAA,MAAA,GAAA,SAAA,EA6GiD,KAAA,aAAA,EAAgB,EAE1C,KAAA,MAAQ,GACgB,KAAA,WAAA,EAAc,GACf,KAAA,SAAA,EAAY,GACZ,KAAA,SAAA,EAAY,GACb,KAAA,QAAA,EAAW,GACN,KAAA,aAAA,EAAgB,GACnB,KAAA,UAAA,EAAa,GACH,KAAA,oBAAA,EAAuB,GAC3B,KAAA,gBAAA,EAAmB,GACf,KAAA,oBAAA,EAAuB,GACzB,KAAA,kBAAA,EAAqB,GACrC,KAAA,QAAU,GACG,KAAA,eAAA,EAAkB,GAC/C,KAAA,SAAW,GACqB,KAAA,mBAAA,EAAsB,GACd,KAAA,2BAAA,EAA8B,EAElG,KAAA,cAAA,EAAkD,MAAOC,GAChD,IAAI,QAAQ,CAACC,EAASC,IAAW,CACtC,MAAMC,EAAS,IAAI,WACnBA,EAAO,OAASC,GAAKH,EAAQG,EAAE,QAAQ,MAAgB,EACvDD,EAAO,QAAUD,EACjBC,EAAO,cAAcH,CAAI,CAC3B,CAAC,EA4BM,KAAQ,SAA0BlB,EAAA,EAClC,KAAQ,gBAA4B,CAAA,EACpC,KAAQ,UAAY,GACpB,KAAQ,OAAS,GACjB,KAAQ,UAAY,GACpB,KAAQ,cAAgB,GACxB,KAAQ,UAAY,GAEyB,KAAA,aAAA,EAAgB,GACjB,KAAA,WAAA,EAAc,GAEnE,KAAiB,UAAY,GAAA,CAnC7B,GAAI,eAAgB,CAAE,OAAO,KAAK,QAAS,CAE3C,GAAI,cAAcO,EAAY,CAC5B,MAAMgB,EAAUjB,EAAsBC,CAAK,EAC3C,KAAK,SAAWgB,EAAQ,OAASA,EAAUvB,EAAA,EAC3C,KAAK,cAAc,aAAa,CAClC,CAGA,GAAI,uBAAwB,CAAE,OAAO,KAAK,eAAgB,CAE1D,GAAI,sBAAsBO,EAAY,CACpC,KAAK,gBAAkBC,EAA2BD,CAAK,EACvD,KAAK,cAAc,qBAAqB,CAC1C,CAGA,GAAI,mBAAoB,CAAE,OAAO,KAAK,eAAgB,CAEtD,GAAI,kBAAkBA,EAAY,CAChC,KAAK,qBAAqB,EAAIA,EAC9B,KAAK,cAAc,iBAAiB,CACtC,CAeA,WAAWiB,EAA+B,CACxC,MAAMC,EAAkBD,EAAQ,IAAI,OAAO,GACtCA,EAAQ,IAAI,aAAa,GACzBA,EAAQ,IAAI,mBAAmB,GAC/BA,EAAQ,IAAI,qBAAqB,GACjCA,EAAQ,IAAI,iBAAiB,GAE7BA,EAAQ,IAAI,SAAS,GAAK,KAAK,SAAS,GAAO,CAAC,KAAK,SAAS,GAAKC,IACtE,KAAK,WAAA,EAGHD,EAAQ,IAAI,aAAa,GAAK,KAAK,WAAW,IAChD,KAAK,OAAS,KAAK,aAAa,EAEpC,CAEQ,YAAa,CACnB,KAAK,OAAS,KAAK,OAAS,GAC5B,KAAK,UAAY,KAAK,UAAY,GAClC,KAAK,UAAY,KAAK,gBAAgB,KAAK;AAAA,CAAI,EAC/C,KAAK,UAAY,KAAK,mBAAmB,GAAK,GAC9C,KAAK,cAAgB,CAAC,CAAC,KAAK,mBAAmB,CACjD,CAEQ,MAAME,EAAcC,EAAkB,CAC5CC,mBAAiB,KAAMF,EAAMC,CAAM,CACrC,CAEQ,cAAcL,EAAU,CAC9B,MAAMO,EAAKP,EAAE,OACTO,EAAG,MAAM,OAAS,KAAK,YACzBA,EAAG,MAAQA,EAAG,MAAM,MAAM,EAAG,KAAK,SAAS,GAE7C,KAAK,OAASA,EAAG,MACb,KAAK,WAAW,GAClBC,wBAAsB,KAAM,KAAK,MAAM,CAE3C,CAEQ,oBAA+B,CACrC,MAAMC,EAAW,KAAK,SAAS,EAAI,KAAK,UAAY,KAAK,gBAAgB,KAAK;AAAA,CAAI,EAClF,OAAOrB,EAAwBqB,CAAQ,CACzC,CAEQ,kBAAkC,CACxC,MAAMR,EAAU,KAAK,SAAS,EAAI,KAAK,SAAW,KAAK,aAAa,EACpE,OAAO,MAAM,QAAQA,CAAO,EAAIA,EAAQ,IAAItB,CAAoB,EAAI,CAAA,CACtE,CAEQ,wBAAwB+B,EAA8B,CAC5D,OAAO,IAAIC,EAAAA,aAAa,sBAAuB,uBAAwB,UAAWD,CAAG,CACvF,CAEA,MAAM,QAAuB,CAC3B,OAAO,IAAI,QAAQ,CAACb,EAASC,IAAW,CACtC,MAAMY,EAAM,CACV,SAAU,KAAK,WAAW,GAAK,OAC/B,WAAYE,EAAAA,YAAY,MACxB,WAAY,KAAK,aAAa,CAAA,EAG1BC,EAAQ/B,WAAS,KAAK,SAAS,EAAI,KAAK,OAAS,KAAK,OAAS,EAAE,EACjEmB,EAAU,KAAK,iBAAA,EACfa,EAAY,KAAK,mBAAA,EACjBC,EAAW,KAAK,SAAS,EAAI,KAAK,UAAY,KAAK,mBAAmB,GAAK,GAC3EC,EAAe,KAAK,gBAAgB,IAAM,KAAK,SAAS,EAAI,KAAK,cAAgB,CAAC,CAAC,KAAK,mBAAmB,GAEjH,GAAI,CAACH,EAAO,CACVf,EAAO,IAAIa,EAAAA,aAAa,YAAa,cAAe,QAASD,CAAG,CAAC,EACjE,MACF,CAEA,GAAIT,EAAQ,OAAS,GAAKA,EAAQ,OAAS,EAAG,CAC5CH,EAAO,KAAK,wBAAwBY,CAAG,CAAC,EACxC,MACF,CAEA,QAASO,EAAI,EAAGA,EAAIhB,EAAQ,OAAQgB,IAClC,GAAI,CAAChB,EAAQgB,CAAC,EAAE,MAAO,CACrBnB,EAAO,IAAIa,EAAAA,aAAa,KAAK,OAAO,aAAa,GAAKM,CAAC,CAAC,OAAQ,eAAgB,UAAWP,CAAG,CAAC,EAC/F,MACF,CAGF,GAAII,EAAU,SAAW,EAAG,CAC1BhB,EAAO,IAAIa,EAAAA,aAAa,WAAY,kBAAmB,WAAYD,CAAG,CAAC,EACvE,MACF,CAEA,MAAMQ,EAAc,CAClB,WAAYN,EAAAA,YAAY,MACxB,aAAcA,EAAAA,YAAY,MAC1B,MAAAC,EACA,QAASZ,EAAQ,IAAIZ,CAAoB,EACzC,kBAAmByB,EACnB,SAAUhC,EAAAA,SAAS,KAAK,SAAS,EAAI,KAAK,UAAY,KAAK,UAAY,EAAE,EACzE,oBAAqBkC,EAAeD,EAAW,GAC/C,mBAAoB,EAAA,EAGlB,KAAK,WAAW,IAClBG,EAAO,SAAW,KAAK,WAAW,GAEhC,KAAK,2BAA2B,IAClCA,EAAO,uBAAyB,KAAK,2BAA2B,GAGlErB,EAAQqB,CAAM,CAChB,CAAC,CACH,CAEA,MAAc,MAAMlB,EAAW,CAC7BA,GAAG,yBAAA,EACH,GAAI,CACF,MAAMmB,EAAO,MAAM,KAAK,OAAA,EACxB,KAAK,MAAM,OAAQA,CAAI,CACzB,OACOC,EAAU,CACfC,EAAAA,iBAAiBD,EAAI,OAAO,CAC9B,CACF,CAEA,UAA2B,CACzB,MAAME,EAAyB,CAAA,EACzBZ,EAAM,CACV,SAAU,KAAK,WAAW,GAAK,OAC/B,WAAYE,EAAAA,YAAY,MACxB,WAAY,KAAK,aAAa,CAAA,EAG1BC,EAAQ/B,WAAS,KAAK,SAAS,EAAI,KAAK,OAAS,KAAK,OAAS,EAAE,EACjEmB,EAAU,KAAK,iBAAA,EACfa,EAAY,KAAK,mBAAA,EAMvB,OAJKD,GACHS,EAAO,KAAK,IAAIX,EAAAA,aAAa,YAAa,cAAe,QAASD,CAAG,CAAC,EAGpET,EAAQ,OAAS,GAAKA,EAAQ,OAAS,GACzCqB,EAAO,KAAK,KAAK,wBAAwBZ,CAAG,CAAC,EACtCY,IAGTrB,EAAQ,QAAQ,CAACrB,EAAqBU,IAAkB,CACjDV,EAAO,OACV0C,EAAO,KAAK,IAAIX,EAAAA,aAAa,KAAK,OAAO,aAAa,GAAKrB,CAAK,CAAC,MAAO,eAAgB,UAAWoB,CAAG,CAAC,CAE3G,CAAC,EAEGI,EAAU,SAAW,GACvBQ,EAAO,KAAK,IAAIX,EAAAA,aAAa,WAAY,kBAAmB,WAAYD,CAAG,CAAC,EAGvEY,EACT,CAEQ,gBAAiB,CACvB,MAAMrB,EAAU,KAAK,iBAAA,EACfa,EAAY,KAAK,mBAAA,EACjBS,EAAW,KAAK,MAAM,MAAQtB,EAAQ,QAAU,GAAK,EAAE,EACvDuB,EAAeC,2BAAyB,KAAK,gBAAgB,EAAG,KAAK,aAAa,EAAG,KAAK,KAAK,EAErG,OAAOjC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA,kCAIuBgC,CAAY;AAAA;AAAA;AAAA,YAGlC,KAAK,gBAAgB,GAAK,KAAK,mBAAmB,EAAIhC,2CAAyC,KAAK,mBAAmB,CAAC,UAAY,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mCAM/G+B,CAAQ;AAAA,kBACzBtB,EAAQ,IAAIrB,GAAUY,EAAAA,wBAAwB+B,CAAQ,MAAM3C,EAAO,KAAK,OAAO,CAAC;AAAA;AAAA;AAAA;AAAA,gBAIlFkC,EAAU,IAAIY,GAAYlC,EAAAA;AAAAA;AAAAA,wBAElBkC,CAAQ;AAAA,oBACZzB,EAAQ,IAAI,IAAMT,EAAAA,8CAA8C,CAAC;AAAA;AAAA,eAEtE,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,KAMd,CAEQ,aAAc,CACpB,OAAOA,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,yBAQc,KAAK,MAAM;AAAA,4BACR,KAAK,SAAS;AAAA,yBAChBQ,GAAa,KAAK,cAAcA,CAAC,CAAC;AAAA;AAAA;AAAA,2CAGjB,KAAK,OAAO,MAAM,IAAI,KAAK,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,6BAgBlD,KAAK,SAAS;AAAA,6BACbA,GAAa,CAAE,KAAK,UAAaA,EAAE,OAA+B,KAAM,CAAC;AAAA,+BACvEA,GAAqB,CAAEA,EAAE,gBAAA,CAAkB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAQ1D,KAAK,SAAS,IAAI,CAACpB,EAAQU,IAAUE,EAAAA;AAAAA;AAAAA,0CAEb,OAAO,aAAa,GAAKF,CAAK,CAAC;AAAA;AAAA;AAAA;AAAA,iCAIxCV,EAAO,KAAK;AAAA;AAAA,iCAEXoB,GAAa,CACrB,MAAMf,EAASe,EAAE,OAA4B,MAC7C,KAAK,SAAW,KAAK,SAAS,IAAI,CAACb,EAAMwC,IACvCA,IAAiBrC,EAAQ,CAAE,GAAGH,EAAM,MAAOF,GAAUE,CAAA,CAEzD,CAAC;AAAA,yCACgBG,EAAQ,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,+BAKnB,IAAM,CACT,KAAK,SAAS,OAAS,IACzB,KAAK,SAAW,CAAC,GAAG,KAAK,SAAUb,GAAwB,EAE/D,CAAC;AAAA,uBACAc,CAAQ;AAAA;AAAA,oCAEK,KAAK,SAAS,OAAS,EAAI,WAAa,EAAE;AAAA,+BAC/C,IAAM,CACT,KAAK,SAAS,OAAS,IACzB,KAAK,SAAW,KAAK,SAAS,OAAO,CAACqC,EAAGD,IAAiBA,IAAiBrC,CAAK,EAEpF,CAAC;AAAA,uBACAG,CAAU;AAAA;AAAA,iBAEhB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAOR,KAAK,gBAAgB,GAAK,KAAK,cAC7BD,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,iCAMqB,KAAK,SAAS;AAAA,iCACdqC,EAAAA,uBAAuB;AAAA,sCAClB,KAAK,cAAc,CAAC;AAAA,iCACzB,EAAI;AAAA,+BACL7B,GAAmB,CAAE,KAAK,UAAaA,EAAE,OAAe,WAAA,CAAa,CAAC;AAAA;AAAA;AAAA,oBAGjF,KAAK,aAAa,EAYjB,GAXAR,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA,qCAIe,IAAM,CACb,KAAK,cAAgB,GACrB,KAAK,UAAY,EACnB,CAAC;AAAA;AAAA;AAAA,uBAIL;AAAA;AAAA;AAAA,cAIZ,EAAE;AAAA;AAAA,UAEJ,KAAK,eAAe,EAClBA,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,+BAOmB,KAAK,SAAS;AAAA,+BACbQ,GAAa,CAAE,KAAK,UAAaA,EAAE,OAA+B,KAAM,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,cAO7F,EAAE;AAAA;AAAA,KAGZ,CAEQ,gBAAiB,CACvB,MAAMa,EAAQ/B,EAAAA,SAAS,KAAK,SAAS,EAAI,KAAK,OAAS,KAAK,OAAS,EAAE,GAAK,QACtEgD,EAAYC,EAAAA,yBAAyB,KAAK,gBAAgB,EAAG,KAAK,aAAa,EAAGlB,CAAK,EAC7F,OAAOmB,EAAAA,kBAAkBF,EAAWG,EAAAA,iBAAiBrB,EAAAA,YAAY,KAAK,GAAKA,EAAAA,YAAY,KAAK,CAC9F,CAEA,QAAS,CACP,GAAI,KAAK,QACP,OAAO,KAAK,eAAA,EAGd,MAAMsB,EAAU,KAAK,SAAS,EAC1B1C,EAAAA,wBAAwB,KAAK,YAAA,CAAa,SAC1CA,EAAAA,2BAA2B,KAAK,eAAA,CAAgB,SAEpD,OAAOA,EAAAA;AAAAA,uCAC4B,KAAK,SAAS,CAAC;AAAA,UAC5C0C,CAAO;AAAA,UACP,KAAK,aAAa,EAChB1C,EAAAA;AAAAA;AAAAA,2BAEe,KAAK,SAAS,CAAC;AAAA,0BAChB,KAAK,QAAQ,CAAC;AAAA,4BACZ,KAAK,UAAU,CAAC;AAAA,kCACV,KAAK,gBAAgB,GAAK,KAAK,aAAa;AAAA,sCACxC,CAAC,KAAK,gBAAgB,GAAK,KAAK,oBAAoB,CAAC;AAAA,sCACrD,KAAK,oBAAoB,CAAC;AAAA,oCAC5B,KAAK,kBAAkB,CAAC;AAAA,qCACvB,EAAK;AAAA,4CACE,KAAK,2BAA2B,CAAC;AAAA,0BACnD,IAAM,KAAK,MAAM,QAAQ,CAAC;AAAA,wBAC5B,KAAK,KAAK;AAAA,wBACV,IAAM,KAAK,MAAM,MAAM,CAAC;AAAA,uBACxB,GAAmB,KAAK,MAAM,MAAO,EAAE,MAAM,CAAC;AAAA,qCACjC,IAAM,CACzB,KAAK,cAAgB,CAAC,KAAK,cACtB,KAAK,gBACR,KAAK,UAAY,GAErB,CAAC;AAAA;AAAA,cAGL,EAAE;AAAA;AAAA;AAAA,KAIZ,CACF,EAriBaE,QAAAA,SACJ,OAAS,CAACyC,EAAAA,kBAAmBC,EAAAA,kBAAmBC,EAAAA,0BAA2BC,2BAA0BC,EAAAA,sBAAuBC,EAAAA,sBAAuBC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GA0GzJ,EAEqDC,EAAA,CAArDC,EAAAA,SAAS,CAAE,KAAM,OAAQ,UAAW,cAAe,CAAA,EA7GzCjD,iBA6G2C,UAAA,cAAA,CAAA,EACGgD,EAAA,CAAxDC,EAAAA,SAAS,CAAE,KAAM,OAAQ,UAAW,iBAAkB,CAAA,EA9G5CjD,iBA8G8C,UAAA,iBAAA,CAAA,EAC7BgD,EAAA,CAA3BC,WAAS,CAAE,KAAM,MAAA,CAAQ,CAAA,EA/GfjD,iBA+GiB,UAAA,QAAA,CAAA,EACwBgD,EAAA,CAAnDC,EAAAA,SAAS,CAAE,KAAM,OAAQ,UAAW,YAAa,CAAA,EAhHvCjD,iBAgHyC,UAAA,YAAA,CAAA,EACDgD,EAAA,CAAlDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,UAAW,CAAA,EAjHtCjD,iBAiHwC,UAAA,UAAA,CAAA,EACAgD,EAAA,CAAlDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,UAAW,CAAA,EAlHtCjD,iBAkHwC,UAAA,UAAA,CAAA,EACDgD,EAAA,CAAjDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,SAAU,CAAA,EAnHrCjD,iBAmHuC,UAAA,SAAA,CAAA,EACKgD,EAAA,CAAtDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,cAAe,CAAA,EApH1CjD,iBAoH4C,UAAA,cAAA,CAAA,EACHgD,EAAA,CAAnDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,WAAY,CAAA,EArHvCjD,iBAqHyC,UAAA,WAAA,CAAA,EACUgD,EAAA,CAA7DC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,qBAAsB,CAAA,EAtHjDjD,iBAsHmD,UAAA,qBAAA,CAAA,EACJgD,EAAA,CAAzDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,iBAAkB,CAAA,EAvH7CjD,iBAuH+C,UAAA,iBAAA,CAAA,EACIgD,EAAA,CAA7DC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,qBAAsB,CAAA,EAxHjDjD,iBAwHmD,UAAA,qBAAA,CAAA,EACFgD,EAAA,CAA3DC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,mBAAoB,CAAA,EAzH/CjD,iBAyHiD,UAAA,mBAAA,CAAA,EAChBgD,EAAA,CAA3CC,EAAAA,SAAS,CAAE,KAAM,QAAS,QAAS,GAAM,CAAA,EA1H/BjD,iBA0HiC,UAAA,UAAA,CAAA,EACagD,EAAA,CAAxDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,gBAAiB,CAAA,EA3H5CjD,iBA2H8C,UAAA,gBAAA,CAAA,EAC7BgD,EAAA,CAA3BC,WAAS,CAAE,KAAM,MAAA,CAAQ,CAAA,EA5HfjD,iBA4HiB,UAAA,WAAA,CAAA,EACgCgD,EAAA,CAA3DC,EAAAA,SAAS,CAAE,KAAM,OAAQ,UAAW,oBAAqB,CAAA,EA7H/CjD,iBA6HiD,UAAA,oBAAA,CAAA,EACQgD,EAAA,CAAnEC,EAAAA,SAAS,CAAE,KAAM,OAAQ,UAAW,4BAA6B,CAAA,EA9HvDjD,iBA8HyD,UAAA,4BAAA,CAAA,EAEpEgD,EAAA,CADCC,EAAAA,SAAS,CAAE,KAAM,OAAQ,UAAW,eAAgB,CAAA,EA/H1CjD,iBAgIX,UAAA,eAAA,CAAA,EAUIgD,EAAA,CADHC,EAAAA,SAAS,CAAE,KAAM,MAAO,UAAW,cAAe,CAAA,EAzIxCjD,iBA0IP,UAAA,cAAA,CAAA,EASAgD,EAAA,CADHC,EAAAA,SAAS,CAAE,KAAM,MAAO,UAAW,sBAAuB,CAAA,EAlJhDjD,iBAmJP,UAAA,sBAAA,CAAA,EAQAgD,EAAA,CADHC,EAAAA,SAAS,CAAE,KAAM,MAAO,UAAW,kBAAmB,CAAA,EA1J5CjD,iBA2JP,UAAA,kBAAA,CAAA,EAOagD,EAAA,CAAhBE,EAAAA,MAAA,CAAM,EAlKIlD,iBAkKM,UAAA,WAAA,CAAA,EACAgD,EAAA,CAAhBE,EAAAA,MAAA,CAAM,EAnKIlD,iBAmKM,UAAA,kBAAA,CAAA,EACAgD,EAAA,CAAhBE,EAAAA,MAAA,CAAM,EApKIlD,iBAoKM,UAAA,YAAA,CAAA,EACAgD,EAAA,CAAhBE,EAAAA,MAAA,CAAM,EArKIlD,iBAqKM,UAAA,SAAA,CAAA,EACAgD,EAAA,CAAhBE,EAAAA,MAAA,CAAM,EAtKIlD,iBAsKM,UAAA,YAAA,CAAA,EACAgD,EAAA,CAAhBE,EAAAA,MAAA,CAAM,EAvKIlD,iBAuKM,UAAA,gBAAA,CAAA,EACAgD,EAAA,CAAhBE,EAAAA,MAAA,CAAM,EAxKIlD,iBAwKM,UAAA,YAAA,CAAA,EAEqCgD,EAAA,CAArDC,EAAAA,SAAS,CAAE,KAAM,OAAQ,UAAW,cAAe,CAAA,EA1KzCjD,iBA0K2C,UAAA,cAAA,CAAA,EACDgD,EAAA,CAApDC,EAAAA,SAAS,CAAE,KAAM,QAAS,UAAW,YAAa,CAAA,EA3KxCjD,iBA2K0C,UAAA,YAAA,CAAA,EA3K1CA,QAAAA,SAANgD,EAAA,CADNG,EAAAA,kBAAkB,WAAW,CAAA,EACjBnD,gBAAA"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const u=require("./title-prefix.cjs");function r(t,e,o){t.dispatchEvent(new CustomEvent(e,{bubbles:!0,composed:!0,detail:o??null}))}function n(t,e){t.dispatchEvent(new CustomEvent("update:modelValue",{bubbles:!0,composed:!0,detail:e}))}function c(t){const e=document.createElement("div");e.textContent=t,Object.assign(e.style,{position:"fixed",top:"20px",left:"50%",transform:"translateX(-50%)",padding:"10px 20px",borderRadius:"4px",fontSize:"13px",color:"#fff",background:"#f56c6c",zIndex:"99999",boxShadow:"0 4px 12px rgba(0,0,0,.15)",transition:"opacity .3s",opacity:"1"}),document.body.appendChild(e),setTimeout(()=>{e.style.opacity="0",setTimeout(()=>e.remove(),300)},2500)}function l(t=[]){return t.filter(e=>e?.resourceType===1).map(e=>e?.resource?.middle||e?.resource?.url).filter(Boolean)}function s(t=[]){return t.find(e=>e?.resourceType===2)?.resource||null}function b(t=[],e){const o=t.find(i=>String(i?.categoryId)===String(e));return o?.title||o?.categoryName||e||"未选择分类"}function a(t,e,o){return u.joinSubjectTitle(u.resolveSubjectPrefix(t,`${e+1}.`),o)}function d(t,e,o){return u.joinSubjectTitle(u.resolveSubjectPrefix(t,`${e+1}. `),o)}exports.buildSubjectPreviewTitle=a;exports.buildSubjectSortingTitle=d;exports.emitSubjectEvent=r;exports.emitSubjectModelValue=n;exports.getSubjectImageResources=l;exports.getSubjectVideoResource=s;exports.resolveSubjectCategoryLabel=b;exports.showSubjectToast=c;
|
|
2
2
|
//# sourceMappingURL=shared-methods.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared-methods.cjs","sources":["../../../../packages/components/src/subject/shared-methods.ts"],"sourcesContent":["import { joinSubjectTitle, resolveSubjectPrefix } from './title-prefix'\n\nexport function emitSubjectEvent(host: EventTarget, name: string, detail?: unknown) {\n host.dispatchEvent(new CustomEvent(name, { bubbles: true, composed: true, detail: detail ?? null }))\n}\n\nexport function emitSubjectModelValue(host: EventTarget, value: string) {\n host.dispatchEvent(new CustomEvent('update:modelValue', {\n bubbles: true,\n composed: true,\n detail: value,\n }))\n}\n\nexport function showSubjectToast(msg: string) {\n const el = document.createElement('div')\n el.textContent = msg\n Object.assign(el.style, {\n position: 'fixed',\n top: '20px',\n left: '50%',\n transform: 'translateX(-50%)',\n padding: '10px 20px',\n borderRadius: '4px',\n fontSize: '13px',\n color: '#fff',\n background: '#f56c6c',\n zIndex: '99999',\n boxShadow: '0 4px 12px rgba(0,0,0,.15)',\n transition: 'opacity .3s',\n opacity: '1',\n })\n document.body.appendChild(el)\n setTimeout(() => {\n el.style.opacity = '0'\n setTimeout(() => el.remove(), 300)\n }, 2500)\n}\n\nexport function getSubjectImageResources(resourceList: any[] = []) {\n return resourceList\n .filter(item => item?.resourceType === 1)\n .map(item => item?.resource?.middle || item?.resource?.url)\n .filter(Boolean) as string[]\n}\n\nexport function getSubjectVideoResource(resourceList: any[] = []) {\n return resourceList.find(item => item?.resourceType === 2)?.resource || null\n}\n\nexport function resolveSubjectCategoryLabel(categoryList: any[] = [], categoryId?: string | number) {\n const matched = categoryList.find((item: any) => String(item?.categoryId) === String(categoryId))\n return matched?.title || matched?.categoryName || categoryId || '未选择分类'\n}\n\nexport function buildSubjectPreviewTitle(subjectPrefix: unknown, orderIndex: number, title: string) {\n return joinSubjectTitle(\n resolveSubjectPrefix(subjectPrefix, `${orderIndex + 1}.`),\n title,\n )\n}\n\nexport function buildSubjectSortingTitle(subjectPrefix: unknown, orderIndex: number, title: string) {\n return joinSubjectTitle(\n resolveSubjectPrefix(subjectPrefix, `${orderIndex + 1}. `),\n title,\n )\n}\n"],"names":["
|
|
1
|
+
{"version":3,"file":"shared-methods.cjs","sources":["../../../../packages/components/src/subject/shared-methods.ts"],"sourcesContent":["import { joinSubjectTitle, resolveSubjectPrefix } from './title-prefix'\n\nexport function emitSubjectEvent(host: EventTarget, name: string, detail?: unknown) {\n host.dispatchEvent(new CustomEvent(name, { bubbles: true, composed: true, detail: detail ?? null }))\n}\n\nexport function emitSubjectModelValue(host: EventTarget, value: string) {\n host.dispatchEvent(new CustomEvent('update:modelValue', {\n bubbles: true,\n composed: true,\n detail: value,\n }))\n}\n\nexport function showSubjectToast(msg: string) {\n const el = document.createElement('div')\n el.textContent = msg\n Object.assign(el.style, {\n position: 'fixed',\n top: '20px',\n left: '50%',\n transform: 'translateX(-50%)',\n padding: '10px 20px',\n borderRadius: '4px',\n fontSize: '13px',\n color: '#fff',\n background: '#f56c6c',\n zIndex: '99999',\n boxShadow: '0 4px 12px rgba(0,0,0,.15)',\n transition: 'opacity .3s',\n opacity: '1',\n })\n document.body.appendChild(el)\n setTimeout(() => {\n el.style.opacity = '0'\n setTimeout(() => el.remove(), 300)\n }, 2500)\n}\n\nexport function getSubjectImageResources(resourceList: any[] = []) {\n return resourceList\n .filter(item => item?.resourceType === 1)\n .map(item => item?.resource?.middle || item?.resource?.url)\n .filter(Boolean) as string[]\n}\n\nexport function getSubjectVideoResource(resourceList: any[] = []) {\n return resourceList.find(item => item?.resourceType === 2)?.resource || null\n}\n\nexport function resolveSubjectCategoryLabel(categoryList: any[] = [], categoryId?: string | number) {\n const matched = categoryList.find((item: any) => String(item?.categoryId) === String(categoryId))\n return matched?.title || matched?.categoryName || categoryId || '未选择分类'\n}\n\nexport function buildSubjectPreviewTitle(subjectPrefix: unknown, orderIndex: number, title: string) {\n return joinSubjectTitle(\n resolveSubjectPrefix(subjectPrefix, `${orderIndex + 1}.`),\n title,\n )\n}\n\nexport function buildSubjectSortingTitle(subjectPrefix: unknown, orderIndex: number, title: string) {\n return joinSubjectTitle(\n resolveSubjectPrefix(subjectPrefix, `${orderIndex + 1}. `),\n title,\n )\n}\n"],"names":["emitSubjectEvent","host","name","detail","emitSubjectModelValue","value","showSubjectToast","msg","el","getSubjectImageResources","resourceList","item","getSubjectVideoResource","resolveSubjectCategoryLabel","categoryList","categoryId","matched","buildSubjectPreviewTitle","subjectPrefix","orderIndex","title","joinSubjectTitle","resolveSubjectPrefix","buildSubjectSortingTitle"],"mappings":"sHAEO,SAASA,EAAiBC,EAAmBC,EAAcC,EAAkB,CAClFF,EAAK,cAAc,IAAI,YAAYC,EAAM,CAAE,QAAS,GAAM,SAAU,GAAM,OAAQC,GAAU,IAAA,CAAM,CAAC,CACrG,CAEO,SAASC,EAAsBH,EAAmBI,EAAe,CACtEJ,EAAK,cAAc,IAAI,YAAY,oBAAqB,CACtD,QAAS,GACT,SAAU,GACV,OAAQI,CAAA,CACT,CAAC,CACJ,CAEO,SAASC,EAAiBC,EAAa,CAC5C,MAAMC,EAAK,SAAS,cAAc,KAAK,EACvCA,EAAG,YAAcD,EACjB,OAAO,OAAOC,EAAG,MAAO,CACtB,SAAU,QACV,IAAK,OACL,KAAM,MACN,UAAW,mBACX,QAAS,YACT,aAAc,MACd,SAAU,OACV,MAAO,OACP,WAAY,UACZ,OAAQ,QACR,UAAW,6BACX,WAAY,cACZ,QAAS,GAAA,CACV,EACD,SAAS,KAAK,YAAYA,CAAE,EAC5B,WAAW,IAAM,CACfA,EAAG,MAAM,QAAU,IACnB,WAAW,IAAMA,EAAG,OAAA,EAAU,GAAG,CACnC,EAAG,IAAI,CACT,CAEO,SAASC,EAAyBC,EAAsB,GAAI,CACjE,OAAOA,EACJ,OAAOC,GAAQA,GAAM,eAAiB,CAAC,EACvC,IAAIA,GAAQA,GAAM,UAAU,QAAUA,GAAM,UAAU,GAAG,EACzD,OAAO,OAAO,CACnB,CAEO,SAASC,EAAwBF,EAAsB,GAAI,CAChE,OAAOA,EAAa,KAAKC,GAAQA,GAAM,eAAiB,CAAC,GAAG,UAAY,IAC1E,CAEO,SAASE,EAA4BC,EAAsB,CAAA,EAAIC,EAA8B,CAClG,MAAMC,EAAUF,EAAa,KAAMH,GAAc,OAAOA,GAAM,UAAU,IAAM,OAAOI,CAAU,CAAC,EAChG,OAAOC,GAAS,OAASA,GAAS,cAAgBD,GAAc,OAClE,CAEO,SAASE,EAAyBC,EAAwBC,EAAoBC,EAAe,CAClG,OAAOC,EAAAA,iBACLC,EAAAA,qBAAqBJ,EAAe,GAAGC,EAAa,CAAC,GAAG,EACxDC,CAAA,CAEJ,CAEO,SAASG,EAAyBL,EAAwBC,EAAoBC,EAAe,CAClG,OAAOC,EAAAA,iBACLC,EAAAA,qBAAqBJ,EAAe,GAAGC,EAAa,CAAC,IAAI,EACzDC,CAAA,CAEJ"}
|