@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.
Files changed (415) hide show
  1. package/es/base/define.mjs +1 -1
  2. package/es/base/define.mjs.map +1 -1
  3. package/es/base/uid.mjs +1 -1
  4. package/es/base/uid.mjs.map +1 -1
  5. package/es/data-chart.mjs +15 -14
  6. package/es/data-chart.mjs.map +1 -1
  7. package/es/editor/blocksuite-editor.mjs +62 -51
  8. package/es/editor/blocksuite-editor.mjs.map +1 -1
  9. package/es/editor/content-format.mjs +8 -1
  10. package/es/editor/content-format.mjs.map +1 -1
  11. package/es/editor/index.mjs +1 -1
  12. package/es/editor/index.mjs.map +1 -1
  13. package/es/editor/toolbar.mjs +1 -1
  14. package/es/editor/toolbar.mjs.map +1 -1
  15. package/es/entry-data-chart.mjs +1 -1
  16. package/es/entry-editor.mjs +1 -1
  17. package/es/entry-file-upload.mjs +1 -1
  18. package/es/entry-fixed-action-bar.mjs +1 -1
  19. package/es/entry-icon.mjs +1 -1
  20. package/es/entry-image-upload.mjs +1 -1
  21. package/es/entry-photo-crop-tool.mjs +1 -1
  22. package/es/entry-subject.mjs +1 -1
  23. package/es/file-upload.mjs +25 -18
  24. package/es/file-upload.mjs.map +1 -1
  25. package/es/fixed-action-bar.mjs +5 -5
  26. package/es/fixed-action-bar.mjs.map +1 -1
  27. package/es/icon.mjs +7 -7
  28. package/es/icon.mjs.map +1 -1
  29. package/es/image-upload.mjs +26 -26
  30. package/es/image-upload.mjs.map +1 -1
  31. package/es/index.mjs +1 -1
  32. package/es/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.mjs +59 -1
  33. package/es/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.mjs.map +1 -1
  34. package/es/node_modules/.pnpm/turndown-plugin-gfm@1.0.2/node_modules/turndown-plugin-gfm/lib/turndown-plugin-gfm.es.mjs +16 -1
  35. 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
  36. package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.mjs +62 -0
  37. package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.mjs.map +1 -0
  38. package/es/photo-crop-tool.mjs +12 -12
  39. package/es/photo-crop-tool.mjs.map +1 -1
  40. package/es/subject/action.mjs +58 -58
  41. package/es/subject/action.mjs.map +1 -1
  42. package/es/subject/blank-fill.mjs +80 -80
  43. package/es/subject/blank-fill.mjs.map +1 -1
  44. package/es/subject/draft.mjs +1 -1
  45. package/es/subject/draft.mjs.map +1 -1
  46. package/es/subject/layout.mjs +4 -4
  47. package/es/subject/layout.mjs.map +1 -1
  48. package/es/subject/page-end.mjs +5 -5
  49. package/es/subject/page-end.mjs.map +1 -1
  50. package/es/subject/pagination.mjs +1 -1
  51. package/es/subject/pagination.mjs.map +1 -1
  52. package/es/subject/runtime.mjs +1 -1
  53. package/es/subject/runtime.mjs.map +1 -1
  54. package/es/subject/scale.mjs +53 -50
  55. package/es/subject/scale.mjs.map +1 -1
  56. package/es/subject/shared-methods.mjs +1 -1
  57. package/es/subject/shared-methods.mjs.map +1 -1
  58. package/es/subject/shared-styles.mjs +53 -15
  59. package/es/subject/shared-styles.mjs.map +1 -1
  60. package/es/subject/single-interactions.mjs +2 -0
  61. package/es/subject/single-interactions.mjs.map +1 -0
  62. package/es/subject/single-model.mjs +2 -0
  63. package/es/subject/single-model.mjs.map +1 -0
  64. package/es/subject/single-state.mjs +2 -0
  65. package/es/subject/single-state.mjs.map +1 -0
  66. package/es/subject/single.mjs +177 -177
  67. package/es/subject/single.mjs.map +1 -1
  68. package/es/subject/sort-controller.mjs +1 -1
  69. package/es/subject/sort-controller.mjs.map +1 -1
  70. package/es/subject/sortable.mjs +13 -13
  71. package/es/subject/sortable.mjs.map +1 -1
  72. package/es/subject/sorting-card.mjs +12 -12
  73. package/es/subject/sorting-card.mjs.map +1 -1
  74. package/es/subject/subject-shared.mjs +2 -0
  75. package/es/subject/subject-shared.mjs.map +1 -0
  76. package/es/subject/text-fill.mjs +73 -73
  77. package/es/subject/text-fill.mjs.map +1 -1
  78. package/es/subject/title-prefix.mjs +1 -1
  79. package/es/subject/title-prefix.mjs.map +1 -1
  80. package/es/subject/types.mjs +1 -1
  81. package/es/subject/types.mjs.map +1 -1
  82. package/lib/base/define.cjs +1 -1
  83. package/lib/base/define.cjs.map +1 -1
  84. package/lib/base/uid.cjs +1 -1
  85. package/lib/base/uid.cjs.map +1 -1
  86. package/lib/data-chart.cjs +16 -15
  87. package/lib/data-chart.cjs.map +1 -1
  88. package/lib/editor/blocksuite-editor.cjs +62 -51
  89. package/lib/editor/blocksuite-editor.cjs.map +1 -1
  90. package/lib/editor/content-format.cjs +8 -1
  91. package/lib/editor/content-format.cjs.map +1 -1
  92. package/lib/editor/index.cjs +1 -1
  93. package/lib/editor/index.cjs.map +1 -1
  94. package/lib/editor/toolbar.cjs +1 -1
  95. package/lib/editor/toolbar.cjs.map +1 -1
  96. package/lib/entry-data-chart.cjs +1 -1
  97. package/lib/entry-editor.cjs +1 -1
  98. package/lib/entry-file-upload.cjs +1 -1
  99. package/lib/entry-fixed-action-bar.cjs +1 -1
  100. package/lib/entry-icon.cjs +1 -1
  101. package/lib/entry-image-upload.cjs +1 -1
  102. package/lib/entry-photo-crop-tool.cjs +1 -1
  103. package/lib/entry-subject.cjs +1 -1
  104. package/lib/file-upload.cjs +24 -17
  105. package/lib/file-upload.cjs.map +1 -1
  106. package/lib/fixed-action-bar.cjs +6 -6
  107. package/lib/fixed-action-bar.cjs.map +1 -1
  108. package/lib/icon.cjs +9 -9
  109. package/lib/icon.cjs.map +1 -1
  110. package/lib/image-upload.cjs +26 -26
  111. package/lib/image-upload.cjs.map +1 -1
  112. package/lib/index.cjs +1 -1
  113. package/lib/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.cjs +59 -1
  114. package/lib/node_modules/.pnpm/marked@17.0.6/node_modules/marked/lib/marked.esm.cjs.map +1 -1
  115. package/lib/node_modules/.pnpm/turndown-plugin-gfm@1.0.2/node_modules/turndown-plugin-gfm/lib/turndown-plugin-gfm.es.cjs +16 -1
  116. 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
  117. package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.cjs +62 -0
  118. package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.browser.es.cjs.map +1 -0
  119. package/lib/photo-crop-tool.cjs +11 -11
  120. package/lib/photo-crop-tool.cjs.map +1 -1
  121. package/lib/subject/action.cjs +42 -42
  122. package/lib/subject/action.cjs.map +1 -1
  123. package/lib/subject/blank-fill.cjs +80 -80
  124. package/lib/subject/blank-fill.cjs.map +1 -1
  125. package/lib/subject/draft.cjs +1 -1
  126. package/lib/subject/draft.cjs.map +1 -1
  127. package/lib/subject/layout.cjs +4 -4
  128. package/lib/subject/layout.cjs.map +1 -1
  129. package/lib/subject/page-end.cjs +4 -4
  130. package/lib/subject/page-end.cjs.map +1 -1
  131. package/lib/subject/pagination.cjs +1 -1
  132. package/lib/subject/pagination.cjs.map +1 -1
  133. package/lib/subject/runtime.cjs +1 -1
  134. package/lib/subject/runtime.cjs.map +1 -1
  135. package/lib/subject/scale.cjs +53 -50
  136. package/lib/subject/scale.cjs.map +1 -1
  137. package/lib/subject/shared-methods.cjs +1 -1
  138. package/lib/subject/shared-methods.cjs.map +1 -1
  139. package/lib/subject/shared-styles.cjs +54 -16
  140. package/lib/subject/shared-styles.cjs.map +1 -1
  141. package/lib/subject/single-interactions.cjs +2 -0
  142. package/lib/subject/single-interactions.cjs.map +1 -0
  143. package/lib/subject/single-model.cjs +2 -0
  144. package/lib/subject/single-model.cjs.map +1 -0
  145. package/lib/subject/single-state.cjs +2 -0
  146. package/lib/subject/single-state.cjs.map +1 -0
  147. package/lib/subject/single.cjs +177 -177
  148. package/lib/subject/single.cjs.map +1 -1
  149. package/lib/subject/sort-controller.cjs +1 -1
  150. package/lib/subject/sort-controller.cjs.map +1 -1
  151. package/lib/subject/sortable.cjs +15 -15
  152. package/lib/subject/sortable.cjs.map +1 -1
  153. package/lib/subject/sorting-card.cjs +12 -12
  154. package/lib/subject/sorting-card.cjs.map +1 -1
  155. package/lib/subject/subject-shared.cjs +2 -0
  156. package/lib/subject/subject-shared.cjs.map +1 -0
  157. package/lib/subject/text-fill.cjs +81 -81
  158. package/lib/subject/text-fill.cjs.map +1 -1
  159. package/lib/subject/title-prefix.cjs +1 -1
  160. package/lib/subject/title-prefix.cjs.map +1 -1
  161. package/lib/subject/types.cjs +1 -1
  162. package/lib/subject/types.cjs.map +1 -1
  163. package/package.json +5 -5
  164. package/types/editor/blocksuite-editor.d.ts +2 -0
  165. package/types/editor/toolbar.d.ts +1 -1
  166. package/types/file-upload.d.ts +2 -0
  167. package/types/subject/blank-fill.d.ts +1 -1
  168. package/types/subject/runtime.d.ts +1 -1
  169. package/types/subject/scale.d.ts +1 -1
  170. package/types/subject/single-interactions.d.ts +46 -0
  171. package/types/subject/single-model.d.ts +88 -0
  172. package/types/subject/single-state.d.ts +42 -0
  173. package/types/subject/single.d.ts +7 -85
  174. package/types/subject/sortable.d.ts +1 -1
  175. package/types/subject/subject-shared.d.ts +43 -0
  176. package/types/subject/text-fill.d.ts +1 -1
  177. package/README.md +0 -562
  178. 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
  179. 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
  180. package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.mjs +0 -2
  181. package/es/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.mjs.map +0 -1
  182. package/es/package.json.mjs +0 -2
  183. package/es/package.json.mjs.map +0 -1
  184. package/es/src/alert/index.mjs +0 -2
  185. package/es/src/alert/index.mjs.map +0 -1
  186. package/es/src/alert/src/alert.mjs +0 -2
  187. package/es/src/alert/src/alert.mjs.map +0 -1
  188. package/es/src/components.mjs +0 -2
  189. package/es/src/components.mjs.map +0 -1
  190. package/es/src/data-chart/index.mjs +0 -2
  191. package/es/src/data-chart/index.mjs.map +0 -1
  192. package/es/src/defaults.mjs +0 -2
  193. package/es/src/defaults.mjs.map +0 -1
  194. package/es/src/dialog/src/dialog.mjs +0 -2
  195. package/es/src/dialog/src/dialog.mjs.map +0 -1
  196. package/es/src/feedback-plugin/index.mjs +0 -2
  197. package/es/src/feedback-plugin/index.mjs.map +0 -1
  198. package/es/src/file-upload/index.mjs +0 -2
  199. package/es/src/file-upload/index.mjs.map +0 -1
  200. package/es/src/icon/index.mjs +0 -2
  201. package/es/src/icon/index.mjs.map +0 -1
  202. package/es/src/icon/src/icon.mjs +0 -2
  203. package/es/src/icon/src/icon.mjs.map +0 -1
  204. package/es/src/image-upload/index.mjs +0 -2
  205. package/es/src/image-upload/index.mjs.map +0 -1
  206. package/es/src/make-installer.mjs +0 -2
  207. package/es/src/make-installer.mjs.map +0 -1
  208. package/es/src/message/src/message.mjs +0 -2
  209. package/es/src/message/src/message.mjs.map +0 -1
  210. package/es/src/photo-crop-tool/index.mjs +0 -2
  211. package/es/src/photo-crop-tool/index.mjs.map +0 -1
  212. package/es/src/tiny-mce-editor/index.mjs +0 -2
  213. package/es/src/tiny-mce-editor/index.mjs.map +0 -1
  214. package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue.mjs +0 -2
  215. package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue.mjs.map +0 -1
  216. package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue2.mjs +0 -2
  217. package/es/src/tiny-mce-editor/src/tiny-mce-editor.vue2.mjs.map +0 -1
  218. package/es/src/ui/button/index.mjs +0 -2
  219. package/es/src/ui/button/index.mjs.map +0 -1
  220. package/es/src/ui/checkbox/index.mjs +0 -2
  221. package/es/src/ui/checkbox/index.mjs.map +0 -1
  222. package/es/src/ui/dialog/index.mjs +0 -2
  223. package/es/src/ui/dialog/index.mjs.map +0 -1
  224. package/es/src/ui/input/index.mjs +0 -2
  225. package/es/src/ui/input/index.mjs.map +0 -1
  226. package/es/src/ui/input-number/index.mjs +0 -2
  227. package/es/src/ui/input-number/index.mjs.map +0 -1
  228. package/es/src/ui/layout/index.mjs +0 -2
  229. package/es/src/ui/layout/index.mjs.map +0 -1
  230. package/es/src/ui/link/index.mjs +0 -2
  231. package/es/src/ui/link/index.mjs.map +0 -1
  232. package/es/src/ui/popover/index.mjs +0 -2
  233. package/es/src/ui/popover/index.mjs.map +0 -1
  234. package/es/src/ui/radio/index.mjs +0 -2
  235. package/es/src/ui/radio/index.mjs.map +0 -1
  236. package/es/src/ui/scrollbar/index.mjs +0 -2
  237. package/es/src/ui/scrollbar/index.mjs.map +0 -1
  238. package/es/src/ui/select/index.mjs +0 -2
  239. package/es/src/ui/select/index.mjs.map +0 -1
  240. package/es/src/ui/table/index.mjs +0 -2
  241. package/es/src/ui/table/index.mjs.map +0 -1
  242. package/es/src/ui/tag/index.mjs +0 -2
  243. package/es/src/ui/tag/index.mjs.map +0 -1
  244. package/es/src/wc-bridge.mjs +0 -2
  245. package/es/src/wc-bridge.mjs.map +0 -1
  246. package/es/src/withInstall.mjs +0 -2
  247. package/es/src/withInstall.mjs.map +0 -1
  248. 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
  249. 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
  250. package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.cjs +0 -2
  251. package/lib/node_modules/.pnpm/turndown@7.2.4/node_modules/turndown/lib/turndown.es.cjs.map +0 -1
  252. package/lib/package.json.cjs +0 -2
  253. package/lib/package.json.cjs.map +0 -1
  254. package/lib/src/alert/index.cjs +0 -2
  255. package/lib/src/alert/index.cjs.map +0 -1
  256. package/lib/src/alert/src/alert.cjs +0 -2
  257. package/lib/src/alert/src/alert.cjs.map +0 -1
  258. package/lib/src/components.cjs +0 -2
  259. package/lib/src/components.cjs.map +0 -1
  260. package/lib/src/data-chart/index.cjs +0 -2
  261. package/lib/src/data-chart/index.cjs.map +0 -1
  262. package/lib/src/defaults.cjs +0 -2
  263. package/lib/src/defaults.cjs.map +0 -1
  264. package/lib/src/dialog/src/dialog.cjs +0 -2
  265. package/lib/src/dialog/src/dialog.cjs.map +0 -1
  266. package/lib/src/feedback-plugin/index.cjs +0 -2
  267. package/lib/src/feedback-plugin/index.cjs.map +0 -1
  268. package/lib/src/file-upload/index.cjs +0 -2
  269. package/lib/src/file-upload/index.cjs.map +0 -1
  270. package/lib/src/icon/index.cjs +0 -2
  271. package/lib/src/icon/index.cjs.map +0 -1
  272. package/lib/src/icon/src/icon.cjs +0 -2
  273. package/lib/src/icon/src/icon.cjs.map +0 -1
  274. package/lib/src/image-upload/index.cjs +0 -2
  275. package/lib/src/image-upload/index.cjs.map +0 -1
  276. package/lib/src/make-installer.cjs +0 -2
  277. package/lib/src/make-installer.cjs.map +0 -1
  278. package/lib/src/message/src/message.cjs +0 -2
  279. package/lib/src/message/src/message.cjs.map +0 -1
  280. package/lib/src/photo-crop-tool/index.cjs +0 -2
  281. package/lib/src/photo-crop-tool/index.cjs.map +0 -1
  282. package/lib/src/tiny-mce-editor/index.cjs +0 -2
  283. package/lib/src/tiny-mce-editor/index.cjs.map +0 -1
  284. package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue.cjs +0 -2
  285. package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue.cjs.map +0 -1
  286. package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue2.cjs +0 -2
  287. package/lib/src/tiny-mce-editor/src/tiny-mce-editor.vue2.cjs.map +0 -1
  288. package/lib/src/ui/button/index.cjs +0 -2
  289. package/lib/src/ui/button/index.cjs.map +0 -1
  290. package/lib/src/ui/checkbox/index.cjs +0 -2
  291. package/lib/src/ui/checkbox/index.cjs.map +0 -1
  292. package/lib/src/ui/dialog/index.cjs +0 -2
  293. package/lib/src/ui/dialog/index.cjs.map +0 -1
  294. package/lib/src/ui/input/index.cjs +0 -2
  295. package/lib/src/ui/input/index.cjs.map +0 -1
  296. package/lib/src/ui/input-number/index.cjs +0 -2
  297. package/lib/src/ui/input-number/index.cjs.map +0 -1
  298. package/lib/src/ui/layout/index.cjs +0 -2
  299. package/lib/src/ui/layout/index.cjs.map +0 -1
  300. package/lib/src/ui/link/index.cjs +0 -2
  301. package/lib/src/ui/link/index.cjs.map +0 -1
  302. package/lib/src/ui/popover/index.cjs +0 -2
  303. package/lib/src/ui/popover/index.cjs.map +0 -1
  304. package/lib/src/ui/radio/index.cjs +0 -2
  305. package/lib/src/ui/radio/index.cjs.map +0 -1
  306. package/lib/src/ui/scrollbar/index.cjs +0 -2
  307. package/lib/src/ui/scrollbar/index.cjs.map +0 -1
  308. package/lib/src/ui/select/index.cjs +0 -2
  309. package/lib/src/ui/select/index.cjs.map +0 -1
  310. package/lib/src/ui/table/index.cjs +0 -2
  311. package/lib/src/ui/table/index.cjs.map +0 -1
  312. package/lib/src/ui/tag/index.cjs +0 -2
  313. package/lib/src/ui/tag/index.cjs.map +0 -1
  314. package/lib/src/wc-bridge.cjs +0 -2
  315. package/lib/src/wc-bridge.cjs.map +0 -1
  316. package/lib/src/withInstall.cjs +0 -2
  317. package/lib/src/withInstall.cjs.map +0 -1
  318. package/types/index.d.ts.map +0 -1
  319. package/types/src/alert/index.d.ts +0 -66
  320. package/types/src/alert/index.d.ts.map +0 -1
  321. package/types/src/alert/src/alert.d.ts +0 -73
  322. package/types/src/alert/src/alert.d.ts.map +0 -1
  323. package/types/src/components.d.ts +0 -10
  324. package/types/src/components.d.ts.map +0 -1
  325. package/types/src/data-chart/index.d.ts +0 -13
  326. package/types/src/data-chart/index.d.ts.map +0 -1
  327. package/types/src/defaults.d.ts +0 -6
  328. package/types/src/defaults.d.ts.map +0 -1
  329. package/types/src/dialog/index.d.ts +0 -3
  330. package/types/src/dialog/index.d.ts.map +0 -1
  331. package/types/src/dialog/src/dialog.d.ts +0 -25
  332. package/types/src/dialog/src/dialog.d.ts.map +0 -1
  333. package/types/src/feedback-plugin/index.d.ts +0 -9
  334. package/types/src/feedback-plugin/index.d.ts.map +0 -1
  335. package/types/src/file-upload/index.d.ts +0 -12
  336. package/types/src/file-upload/index.d.ts.map +0 -1
  337. package/types/src/icon/index.d.ts +0 -56
  338. package/types/src/icon/index.d.ts.map +0 -1
  339. package/types/src/icon/src/icon.d.ts +0 -62
  340. package/types/src/icon/src/icon.d.ts.map +0 -1
  341. package/types/src/image-upload/index.d.ts +0 -12
  342. package/types/src/image-upload/index.d.ts.map +0 -1
  343. package/types/src/make-installer.d.ts +0 -6
  344. package/types/src/make-installer.d.ts.map +0 -1
  345. package/types/src/message/index.d.ts +0 -3
  346. package/types/src/message/index.d.ts.map +0 -1
  347. package/types/src/message/src/message.d.ts +0 -21
  348. package/types/src/message/src/message.d.ts.map +0 -1
  349. package/types/src/message/src/toaster.vue.d.ts +0 -3
  350. package/types/src/message/src/toaster.vue.d.ts.map +0 -1
  351. package/types/src/photo-crop-tool/index.d.ts +0 -12
  352. package/types/src/photo-crop-tool/index.d.ts.map +0 -1
  353. package/types/src/subject-action/index.d.ts +0 -93
  354. package/types/src/subject-action/index.d.ts.map +0 -1
  355. package/types/src/subject-action/src/subject-action.vue.d.ts +0 -92
  356. package/types/src/subject-action/src/subject-action.vue.d.ts.map +0 -1
  357. package/types/src/subject-layout/index.d.ts +0 -30
  358. package/types/src/subject-layout/index.d.ts.map +0 -1
  359. package/types/src/subject-layout/src/subject-layout.vue.d.ts +0 -20
  360. package/types/src/subject-layout/src/subject-layout.vue.d.ts.map +0 -1
  361. package/types/src/subject-list/index.d.ts +0 -20
  362. package/types/src/subject-list/index.d.ts.map +0 -1
  363. package/types/src/subject-list/src/components/SubjectPageEnd.vue.d.ts +0 -24
  364. package/types/src/subject-list/src/components/SubjectPageEnd.vue.d.ts.map +0 -1
  365. package/types/src/subject-list/src/components/subject-blank-fill.vue.d.ts +0 -32
  366. package/types/src/subject-list/src/components/subject-blank-fill.vue.d.ts.map +0 -1
  367. package/types/src/subject-list/src/components/subject-scale.vue.d.ts +0 -29
  368. package/types/src/subject-list/src/components/subject-scale.vue.d.ts.map +0 -1
  369. package/types/src/subject-list/src/components/subject-single.vue.d.ts +0 -37
  370. package/types/src/subject-list/src/components/subject-single.vue.d.ts.map +0 -1
  371. package/types/src/subject-list/src/components/subject-text-fill.vue.d.ts +0 -34
  372. package/types/src/subject-list/src/components/subject-text-fill.vue.d.ts.map +0 -1
  373. package/types/src/subject-list/src/subject-list.vue.d.ts +0 -21
  374. package/types/src/subject-list/src/subject-list.vue.d.ts.map +0 -1
  375. package/types/src/subject-type/index.d.ts +0 -8
  376. package/types/src/subject-type/index.d.ts.map +0 -1
  377. package/types/src/subject-type/src/subject-type.vue.d.ts +0 -7
  378. package/types/src/subject-type/src/subject-type.vue.d.ts.map +0 -1
  379. package/types/src/tiny-mce-editor/index.d.ts +0 -20
  380. package/types/src/tiny-mce-editor/index.d.ts.map +0 -1
  381. package/types/src/tiny-mce-editor/src/tiny-mce-editor.vue.d.ts +0 -32
  382. package/types/src/tiny-mce-editor/src/tiny-mce-editor.vue.d.ts.map +0 -1
  383. package/types/src/ui/button/index.d.ts +0 -96
  384. package/types/src/ui/button/index.d.ts.map +0 -1
  385. package/types/src/ui/checkbox/index.d.ts +0 -111
  386. package/types/src/ui/checkbox/index.d.ts.map +0 -1
  387. package/types/src/ui/dialog/index.d.ts +0 -134
  388. package/types/src/ui/dialog/index.d.ts.map +0 -1
  389. package/types/src/ui/index.d.ts +0 -16
  390. package/types/src/ui/index.d.ts.map +0 -1
  391. package/types/src/ui/input/index.d.ts +0 -132
  392. package/types/src/ui/input/index.d.ts.map +0 -1
  393. package/types/src/ui/input-number/index.d.ts +0 -106
  394. package/types/src/ui/input-number/index.d.ts.map +0 -1
  395. package/types/src/ui/layout/index.d.ts +0 -373
  396. package/types/src/ui/layout/index.d.ts.map +0 -1
  397. package/types/src/ui/link/index.d.ts +0 -57
  398. package/types/src/ui/link/index.d.ts.map +0 -1
  399. package/types/src/ui/popover/index.d.ts +0 -89
  400. package/types/src/ui/popover/index.d.ts.map +0 -1
  401. package/types/src/ui/radio/index.d.ts +0 -84
  402. package/types/src/ui/radio/index.d.ts.map +0 -1
  403. package/types/src/ui/scrollbar/index.d.ts +0 -35
  404. package/types/src/ui/scrollbar/index.d.ts.map +0 -1
  405. package/types/src/ui/select/index.d.ts +0 -113
  406. package/types/src/ui/select/index.d.ts.map +0 -1
  407. package/types/src/ui/table/index.d.ts +0 -152
  408. package/types/src/ui/table/index.d.ts.map +0 -1
  409. package/types/src/ui/tag/index.d.ts +0 -69
  410. package/types/src/ui/tag/index.d.ts.map +0 -1
  411. package/types/src/wc-bridge.d.ts +0 -23
  412. package/types/src/wc-bridge.d.ts.map +0 -1
  413. package/types/src/withInstall.d.ts +0 -4
  414. package/types/src/withInstall.d.ts.map +0 -1
  415. package/types/tsconfig.tsbuildinfo +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"single.cjs","sources":["../../../../packages/components/src/subject/single.ts"],"sourcesContent":["import type { AnswerType } from './types'\nimport { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { uid } from '../base/uid'\nimport { SUB_TEXT_EDITOR_TOOLBAR } from '../editor/toolbar'\nimport { buildSubjectPreviewTitle, buildSubjectSortingTitle, emitSubjectEvent, emitSubjectModelValue, getSubjectImageResources, getSubjectVideoResource, resolveSubjectCategoryLabel, showSubjectToast } from './shared-methods'\nimport { subjectControlResetStyles, subjectFormBaseStyles, subjectHostStyles, subjectPreviewBaseStyles, subjectTextareaStyles } from './shared-styles'\nimport { renderSortingCard, sortingCardStyles } from './sorting-card'\nimport { SubjectTypeLabel } from './types'\n\nexport interface SubjectErrorOptions {\n message: string\n code?: string\n field?: string\n row?: any\n}\n\nexport class SubjectError extends Error {\n constructor(\n message: string,\n public code: string = 'VALIDATION_ERROR',\n public field?: string,\n public row?: any,\n ) {\n super(message)\n this.name = 'SubjectError'\n }\n\n static from(options: SubjectErrorOptions): SubjectError {\n return new SubjectError(options.message, options.code, options.field, options.row)\n }\n}\n\ninterface Answer {\n title: string\n isCorrect: boolean\n customAnswerId?: string\n answerId?: string\n resultItem?: string\n orderIndex?: number\n answerRelations?: any[]\n relationType?: number | null\n}\n\ninterface SubjectSnapshot {\n title: string\n answers: Answer[]\n analysis: string\n leastAnswerCount: number | null\n selectedTagList: TagItem[]\n examExpand: string\n showRichText: boolean\n richText: string\n orderList: string[]\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>`\nconst iconArrow = html`<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><polyline points=\"6 9 12 15 18 9\"/></svg>`\n\nfunction normalizeTitle(text: string) {\n return text\n .replace(/^\\d+\\.\\s*/, '')\n .replace(/[\\s,,。.!!??;;::、'\"“”‘’()()[\\]【】\\-_/\\\\]+/g, '')\n .toLowerCase()\n}\n\nexport function trimText(value: unknown) {\n return String(value ?? '').trim()\n}\n\nexport function trimCommaSeparatedText(value: unknown) {\n return String(value ?? '')\n .split(',')\n .map(item => item.trim())\n .filter(Boolean)\n .join(',')\n}\n\n/**\n * 标签项 - 用于关联题目的标签信息\n * @typedef {object} TagItem\n * @property {string|number} tagId - 标签ID\n * @property {string} tagName - 标签名称\n * @property {KnowledgePointInfo[]} [knowledgePointInfos] - 关联的知识点的列表\n */\nexport interface TagItem {\n tagId: string | number\n tagName: string\n knowledgePointInfos?: KnowledgePointInfo[]\n}\n\n/**\n * 知识点信息\n * @typedef {object} KnowledgePointInfo\n * @property {string|number} knowledgePointId - 知识点ID\n * @property {string} knowledgePointName - 知识点名称\n */\nexport interface KnowledgePointInfo {\n knowledgePointId: string | number\n knowledgePointName: string\n}\n\n/**\n * 分类选项\n * @typedef {object} Category\n * @property {string|number} categoryId - 分类ID\n * @property {string} title - 分类标题\n */\nexport interface Category {\n categoryId: string | number\n title: string\n}\n\n/**\n * 题库搜索结果项\n * @typedef {object} SearchResult\n * @property {string|number} id - 题目ID\n * @property {string} title - 题目标题\n * @property {string} value - 用于搜索框显示的值\n * @property {any} [key: string] - 其他扩展字段\n */\nexport interface SearchResult {\n id: string | number\n title: string\n value: string\n [key: string]: any\n}\n\n/**\n * 题目资源(图片或视频)\n * @typedef {object} Resource\n * @property {1|2} resourceType - 资源类型:1-图片, 2-视频\n * @property {object} resource - 资源详情\n * @property {string} [resource.url] - 资源URL\n * @property {string} [resource.middle] - 中等尺寸图片URL\n * @property {string} [resource.videoId] - 视频ID\n */\nexport interface Resource {\n resourceType: 1 | 2\n resource: {\n url?: string\n middle?: string\n videoId?: string\n [key: string]: any\n }\n}\n\n@safeCustomElement('qxs-subject-single')\nexport class QxsSubjectSingle extends LitElement {\n static styles = [sortingCardStyles, subjectHostStyles, subjectControlResetStyles, subjectPreviewBaseStyles, subjectFormBaseStyles, subjectTextareaStyles, css`\n .preview-answer { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }\n .preview-answer .radio { display: grid; grid-template-columns: auto auto minmax(0, 1fr); column-gap: 10px; row-gap: 3px; align-items: center; }\n .preview-answer .order { color: #6b7280; font-size: 13px; font-weight: 600; }\n .preview-answer .answer-main { min-width: 0; display: inline-flex; flex-wrap: wrap; align-items: baseline; gap: 8px; }\n .preview-answer .answer-text { min-width: 0; font-size: 14px; line-height: 1.7; font-weight: 500; color: #303133; }\n .preview-answer .answer-meta { grid-column: 3; display: flex; flex-wrap: wrap; gap: 8px; font-size: 12px; line-height: 1.6; color: #8b95a7; }\n .preview-answer .correct { color: #3D61E3; font-weight: 600; }\n .preview-answer .result-info { color: #8b95a7; }\n\n .flex { display: flex; }\n .flex-items-center { display: flex; align-items: center; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .edit-actions {\n display: flex;\n justify-content: flex-end;\n padding-left: 88px;\n }\n .edit-inline {\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n gap: 8px 14px;\n min-height: 32px;\n }\n .edit-note {\n margin-top: 6px;\n font-size: 12px;\n line-height: 1.6;\n color: #909399;\n }\n\n .answer-list { display: flex; flex-direction: column; gap: 10px; }\n .answer-item {\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n gap: 8px;\n border-radius: 4px;\n }\n .answer-item .label {\n min-width: 28px;\n font-size: 13px;\n font-weight: 600;\n color: #6b7280;\n letter-spacing: 0;\n }\n .answer-item .input { flex: 1; min-width: 240px; max-width: 380px; position: relative; display: block; }\n .answer-item .input input {\n height: 36px; padding: 0 56px 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 .answer-item .input input:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n .answer-item .input .char-counter {\n position: absolute; right: 8px; top: 50%; transform: translateY(-50%);\n font-size: 12px; color: #909399; line-height: 1; pointer-events: none;\n }\n\n .answer-item .correct {\n color: #909399;\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n gap: 6px;\n min-height: 20px;\n white-space: nowrap;\n }\n .answer-item .correct:hover { color: #3D61E3; }\n .answer-item .correct.is-correct { color: #67c23a; }\n .answer-item .correct input {\n width: 14px;\n height: 14px;\n margin: 0;\n flex: 0 0 auto;\n cursor: pointer;\n accent-color: #3D61E3;\n }\n .answer-item .correct .correct-text {\n display: inline-flex;\n align-items: center;\n line-height: 1.2;\n }\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 .answer-item .link {\n color: #3D61E3;\n cursor: pointer;\n font-size: 12px;\n white-space: nowrap;\n }\n .answer-item .link:hover { color: #2D4CB8; }\n\n .el-select {\n width: 150px; height: 34px; border: 1px solid #dcdfe6; border-radius: 6px;\n padding: 0 8px; font-size: 13px; background: #fff; appearance: none;\n background-image: url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23c0c4cc' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E\");\n background-repeat: no-repeat; background-position: right 8px center;\n }\n .el-select:focus { border-color: #3D61E3; outline: none; }\n .el-select:disabled { background: #f5f7fa; color: #c0c4cc; cursor: not-allowed; }\n\n .sort-badge { font-weight: bold; color: #3D61E3; margin-left: 10px; }\n\n .el-link { color: #3D61E3; cursor: pointer; font-size: 12px; background: none; border: none; padding: 0; margin: 0; font-family: inherit; }\n .el-link:hover { color: #2D4CB8; }\n .el-link.danger { color: #f56c6c; }\n\n .value-text { font-size: 13px; color: #606266; white-space: pre-wrap; }\n .muted-text { font-size: 12px; color: #909399; }\n\n .search-wrap { position: relative; }\n .search-dropdown {\n position: absolute; z-index: 120; left: 0; right: 0; top: calc(100% + 4px);\n background: #fff; border: 1px solid #e4e7ed; border-radius: 6px;\n box-shadow: 0 8px 20px rgba(0,0,0,.12); overflow: hidden;\n }\n .search-item {\n padding: 10px 12px; cursor: pointer; transition: background .2s;\n font-size: 13px; color: #606266; line-height: 1.4;\n }\n .search-item:hover { background: #f5f7fa; color: #3D61E3; }\n .search-empty { padding: 10px 12px; font-size: 12px; color: #909399; }\n\n .tag-list { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; min-height: 32px; }\n .tag-item {\n display: inline-flex; align-items: center; gap: 4px;\n padding: 4px 8px; font-size: 12px; line-height: 1;\n color: #3D61E3; background: #ecf5ff; border: 1px solid #d9ecff; border-radius: 4px;\n }\n .tag-item .close { cursor: pointer; color: #909399; }\n .tag-item .close:hover { color: #f56c6c; }\n .tag-hint { font-size: 12px; color: #909399; }\n\n .resource-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 8px; }\n .resource-summary { font-size: 12px; color: #606266; }\n .resource-thumbs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 8px; }\n .resource-thumb {\n width: 72px; height: 72px; object-fit: cover; border-radius: 6px;\n border: 1px solid #e4e7ed; cursor: pointer; background: #f5f7fa;\n }\n .resource-video {\n display: inline-flex; align-items: center; justify-content: center;\n min-width: 88px; height: 30px; padding: 0 10px; border: 1px solid #dcdfe6; border-radius: 4px;\n color: #606266; background: #fff; cursor: pointer; font-size: 12px; transition: all .2s;\n }\n .resource-video:hover { color: #3D61E3; border-color: #3D61E3; background: #ecf5ff; }\n .media-stage { display: flex; align-items: center; justify-content: center; min-height: 240px; }\n .media-stage img, .media-stage video { max-width: 100%; max-height: 60vh; border-radius: 6px; }\n .media-footer { display: flex; justify-content: space-between; align-items: center; gap: 8px; width: 100%; }\n .media-footer .group { display: flex; gap: 8px; }\n\n /* Multi-select with tags (Element Plus style) */\n .multi-select-wrapper { position: relative; }\n .multi-select {\n width: 240px; min-height: 36px; border: 1px solid #dcdfe6; border-radius: 6px;\n padding: 0 30px 0 8px; font-size: 13px; background: #fff; cursor: pointer;\n display: flex; flex-wrap: nowrap; align-items: center; gap: 4px;\n transition: border-color .2s; position: relative; overflow: hidden;\n }\n .multi-select:hover { border-color: #c0c4cc; }\n .multi-select.focused { border-color: #3D61E3; }\n .multi-select.disabled { background: #f5f7fa; cursor: not-allowed; }\n .multi-select .placeholder { color: #c0c4cc; font-size: 13px; padding: 4px 0; }\n .multi-select .arrow {\n position: absolute; right: 8px; top: 50%; transform: translateY(-50%);\n color: #c0c4cc; display: inline-flex; transition: transform .2s;\n }\n .multi-select.focused .arrow { transform: translateY(-50%) rotate(180deg); color: #3D61E3; }\n .multi-select .tag {\n display: inline-flex; align-items: center; gap: 2px;\n background: #f0f2f5; border-radius: 3px; padding: 0 6px; height: 20px;\n font-size: 12px; color: #606266; line-height: 20px;\n }\n .multi-select .tag .tag-close {\n display: inline-flex; cursor: pointer; color: #909399; margin-left: 2px; line-height: 1;\n }\n .multi-select .tag .tag-close:hover { color: #3D61E3; }\n .multi-select-dropdown {\n position: absolute; z-index: 100; background: #fff; left: 0; top: 100%; margin-top: 4px;\n border: 1px solid #e4e7ed; border-radius: 3px;\n box-shadow: 0 4px 12px rgba(0,0,0,.12); min-width: 240px; max-height: 140px; overflow-y: auto;\n }\n .multi-select-option {\n padding: 4px 12px; font-size: 13px; color: #606266; cursor: pointer;\n transition: background .2s;\n }\n .multi-select-option:hover { background: #f5f7fa; }\n .multi-select-option.selected { color: #3D61E3; font-weight: 500; }\n\n @media (max-width: 720px) {\n .edit-row,\n .section-row {\n flex-direction: column;\n gap: 8px;\n }\n\n .edit-row > .label,\n .section-row > .label {\n min-width: 0;\n padding-top: 0;\n }\n\n .edit-actions {\n padding-left: 0;\n justify-content: flex-start;\n }\n\n .answer-item .input {\n min-width: 0;\n max-width: none;\n width: 100%;\n }\n }\n\n .modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 9000; display: flex; align-items: center; justify-content: center; }\n .modal { background: #fff; border-radius: 6px; width: 520px; max-width: 90vw; box-shadow: 0 12px 32px rgba(0,0,0,.12); display: flex; flex-direction: column; }\n .modal-header { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px 12px; border-bottom: 1px solid #e4e7ed; }\n .modal-title { font-size: 14px; font-weight: 600; color: #303133; }\n .modal-close { background: none; border: none; font-size: 18px; cursor: pointer; color: #909399; padding: 0; line-height: 1; }\n .modal-close:hover { color: #3D61E3; }\n .modal-body { padding: 20px; }\n .modal-body textarea { min-height: 120px; }\n .modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 20px; border-top: 1px solid #e4e7ed; }\n .modal-footer button { padding: 6px 16px; font-size: 12px; border-radius: 3px; cursor: pointer; border: 1px solid #dcdfe6; background: #fff; color: #606266; }\n .modal-footer button:hover { color: #3D61E3; border-color: #a0cfff; }\n .modal-footer button.primary { background: #3D61E3; border-color: #3D61E3; color: #fff; }\n .modal-footer button.primary:hover { background: #2D4CB8; border-color: #2D4CB8; }\n .correct-hint-dialog { width: 520px; max-width: min(90vw, 520px); }\n .correct-hint-dialog .modal-header { padding: 18px 20px 14px; }\n .correct-hint-dialog .modal-title { font-size: 16px; font-weight: 700; color: #303133; }\n .correct-hint-dialog .modal-close { display: none; }\n .correct-hint-dialog .modal-body {\n padding: 32px 28px 20px;\n font-size: 14px;\n line-height: 1.8;\n color: #303133;\n text-align: center;\n }\n .correct-hint-copy { max-width: 420px; margin: 0 auto; }\n .correct-hint-highlight { color: #4c6fff; }\n .correct-hint-dialog .modal-footer {\n justify-content: center;\n gap: 12px;\n padding: 0 28px 28px;\n border-top: none;\n }\n .correct-hint-dialog .modal-footer button {\n min-width: 120px;\n height: 36px;\n padding: 0 18px;\n font-size: 14px;\n border-radius: 4px;\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: 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: 'is-set-correct-answer' }) 'is-set-correct-answer' = false\n @property({ type: Boolean, attribute: 'lock-answer-key' }) lockAnswerKey = false\n @property({ type: Boolean, attribute: 'is-key' }) 'is-key' = 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-answer-setting' }) 'show-answer-setting' = false\n @property({ type: Boolean, attribute: 'show-key' }) 'show-key' = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = false\n @property({ attribute: 'question-type', reflect: true }) type: AnswerType = 'single'\n @property({ type: Number, attribute: 'answer-check-type' }) 'answer-check-type' = 1\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'least-answer-count' }) 'least-answer-count': number | null = null\n @property({ type: String, attribute: 'exam-expand' }) 'exam-expand' = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Number, attribute: 'exam-id' }) 'exam-id' = 0\n @property({ type: String, attribute: 'category-id' }) 'category-id' = ''\n @property({ type: Object, attribute: 'upload-image' }) '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'(v: any) {\n // 编辑模式下不接受外部更新,避免覆盖用户正在编辑的内容\n if (this['is-edit']) {\n return\n }\n const arr = Array.isArray(v) ? v : []\n this._answers = arr.length\n ? arr.map((a: any) => this._normalizeAnswerItem(a))\n : [\n { title: '', isCorrect: false }, { title: '', isCorrect: false },\n { title: '', isCorrect: false }, { title: '', isCorrect: false },\n ]\n this.requestUpdate('answer-list')\n }\n\n // ============ 业务接口 Props ============\n /**\n * 标签列表 - 用于关联题目的标签信息\n * @type {TagItem[]}\n * @description 业务系统传入已选择的标签列表\n */\n @property({ type: Array, attribute: 'tag-list' }) 'tag-list': TagItem[] = []\n /**\n * 分类列表 - 可用于题目的分类选项\n * @type {Category[]}\n * @description 业务系统传入可选的分类列表\n */\n @property({ type: Array, attribute: 'category-list' }) 'category-list': Category[] = []\n /**\n * AI 推荐答案 - AI 根据题目内容推荐的答案\n * @type {string}\n * @description AI 返回的推荐答案,格式如 \"1. 选项A\\n2. 选项B\"\n */\n @property({ type: String, attribute: 'ai-answer' }) 'ai-answer' = ''\n /**\n * 图片/视频资源列表 - 题目附带的媒体资源\n * @type {Resource[]}\n * @description 题目附带图片或视频资源\n */\n @property({ type: Array, attribute: 'resource-list' }) 'resource-list': Resource[] = []\n /**\n * 是否显示标签功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示标签选择 UI\n */\n @property({ type: Boolean, attribute: 'show-tag' }) 'show-tag' = false\n /**\n * 是否显示分类功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示分类选择 UI\n */\n @property({ type: Boolean, attribute: 'show-category' }) 'show-category' = false\n /**\n * 是否显示 AI 推荐功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示 AI 推荐答案 UI\n */\n @property({ type: Boolean, attribute: 'show-ai' }) 'show-ai' = false\n /**\n * 是否显示资源功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示图片/视频资源 UI\n */\n @property({ type: Boolean, attribute: 'show-resource' }) 'show-resource' = false\n /**\n * 是否显示跳题功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示跳题逻辑设置入口\n */\n @property({ type: Boolean, attribute: 'show-jump' }) 'show-jump' = false\n /**\n * 跳题状态 - 是否已设置跳题逻辑\n * @type {boolean}\n * @default false\n * @description 标记当前题目是否已设置跳题逻辑\n */\n @property({ type: Boolean, attribute: 'has-jump' }) 'has-jump' = false\n /**\n * 题库搜索接口地址\n * @type {string}\n * @description 题库模糊搜索接口地址,用于题库搜索功能\n */\n @property({ type: String, attribute: 'search-api' }) 'search-api' = ''\n /**\n * 题库搜索回调函数\n * @type {Function}\n * @param {string} query - 搜索关键词\n * @param {number} answerType - 题目类型:0-单选, 1-多选\n * @returns {Promise<SearchResult[]>} 搜索结果列表\n * @description 题库搜索的回调函数,由业务系统实现搜索逻辑\n */\n @property({ type: Object, attribute: 'search-handler' }) 'search-handler'?: (query: string, answerType: number) => Promise<SearchResult[]>\n\n // 双向绑定支持\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n @state() private _answers: Answer[] = [\n { title: '', isCorrect: false }, { title: '', isCorrect: false },\n { title: '', isCorrect: false }, { title: '', isCorrect: false },\n ]\n\n @property({ type: String }) title = ''\n\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _richText = ''\n @state() private _showRichText = false\n @state() private _leastAnswerCount: number | null = null\n @state() private _answerCheckType = 1\n @state() private _isKey = false\n @state() private _orderList: string[] = []\n @state() private _selectedTagList: TagItem[] = []\n @state() private _categoryId = ''\n @state() private _searchResults: SearchResult[] = []\n @state() private _searchOpen = false\n @state() private _searchLoading = false\n @state() private _sortDropdownOpen = false\n @state() private _imageViewerOpen = false\n @state() private _imageViewerIndex = 0\n @state() private _videoViewerOpen = false\n @state() private _correctHintDialogOpen = false\n @state() private _hasShownCorrectHint = false\n @state() private _changeTypeDialogOpen = false\n\n private _searchTimer: number | null = null\n private _searchToken = 0\n\n private readonly TITLE_MAX = 200\n private readonly ANSWER_MAX = 100\n\n connectedCallback() {\n super.connectedCallback()\n document.addEventListener('click', this._handleDocumentClick)\n this._syncExternalProps()\n }\n\n disconnectedCallback() {\n super.disconnectedCallback()\n document.removeEventListener('click', this._handleDocumentClick)\n if (this._searchTimer) {\n window.clearTimeout(this._searchTimer)\n this._searchTimer = null\n }\n }\n\n private _handleDocumentClick = (e: MouseEvent) => {\n const path = e.composedPath()\n const wrapper = this.shadowRoot?.querySelector('.multi-select-wrapper')\n const searchWrap = this.shadowRoot?.querySelector('.search-wrap')\n if (wrapper && !path.includes(wrapper)) {\n this._sortDropdownOpen = false\n }\n if (searchWrap && !path.includes(searchWrap)) {\n this._searchOpen = false\n }\n this.requestUpdate()\n }\n\n willUpdate(changed: Map<string, unknown>) {\n if (changed.has('is-edit') && this['is-edit']) { this._syncProps() }\n if (!this['is-edit'] && (changed.has('title') || changed.has('answer-list') || changed.has('analysis') || changed.has('least-answer-count') || changed.has('answer-check-type') || changed.has('tag-list') || changed.has('category-id') || changed.has('rich-text-content'))) {\n this._syncExternalProps()\n }\n if (changed.has('is-key')) {\n this._isKey = this['is-key']\n }\n if (changed.has('tag-list')) {\n this._selectedTagList = Array.isArray(this['tag-list']) ? this['tag-list'].map(item => ({ ...item })) : []\n }\n if (changed.has('category-id')) {\n this._categoryId = this['category-id'] ? String(this['category-id']) : ''\n }\n if (changed.has('exam-expand') || changed.has('answer-list')) { this._syncExamExpand() }\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value']\n }\n }\n\n private _supportsLeastAnswerCount(answerType: AnswerType = this.type) {\n return answerType === 'multiple' || answerType === 'sort'\n }\n\n private _normalizeLeastAnswerCount(value: unknown, answerType: AnswerType = this.type): number | null {\n if (!this._supportsLeastAnswerCount(answerType) || value === '' || value === null || value === undefined) {\n return null\n }\n const count = Number(value)\n return Number.isFinite(count) && count > 0 ? count : null\n }\n\n private _leastAnswerCountSuffix(value: number | null, answerType: AnswerType = this.type) {\n if (!this._supportsLeastAnswerCount(answerType) || value === null) {\n return ''\n }\n return `,至少选${value}项${answerType === 'sort' ? '并排序' : ''}`\n }\n\n private _normalizeAnswerItem(answer: any): Answer {\n const next: Answer = {\n ...answer,\n title: trimText(answer?.title ?? answer?.answer ?? ''),\n isCorrect: !!answer?.isCorrect,\n }\n const answerId = answer?.answerId ?? answer?.examAnswerId\n if (answerId !== undefined) {\n next.answerId = answerId\n }\n return next\n }\n\n private _syncExternalProps() {\n this._title = this.title || ''\n this._analysis = this.analysis || ''\n this._leastAnswerCount = this._normalizeLeastAnswerCount(this['least-answer-count'])\n this._answerCheckType = this['answer-check-type'] || 1\n this._isKey = this['is-key']\n this._selectedTagList = Array.isArray(this['tag-list']) ? this['tag-list'].map(item => ({ ...item })) : []\n this._categoryId = this['category-id'] ? String(this['category-id']) : ''\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n if (this['answer-list']?.length) {\n this._answers = this['answer-list'].map((a: any) => this._normalizeAnswerItem(a))\n }\n }\n\n private _syncProps() {\n this._title = (this as any).title || ''\n this._analysis = this.analysis || ''\n this._leastAnswerCount = this._normalizeLeastAnswerCount(this['least-answer-count'])\n this._answerCheckType = this['answer-check-type'] || 1\n this._isKey = this['is-key']\n this._selectedTagList = Array.isArray(this['tag-list']) ? this['tag-list'].map(item => ({ ...item })) : []\n this._categoryId = this['category-id'] ? String(this['category-id']) : ''\n this._richText = this['rich-text-content'] || ''\n this._showRichText = !!this['rich-text-content']\n if (this['answer-list']?.length) {\n this._answers = this['answer-list'].map((a: any) => this._normalizeAnswerItem(a))\n }\n this._syncExamExpand()\n }\n\n private _syncExamExpand() {\n if (!this['exam-expand'] || !this['answer-list']?.length) { return }\n const ids = this['exam-expand'].split(',')\n const answers = this['answer-list'] as any[]\n this._orderList = ids.map((id) => {\n const index = answers.findIndex((answer, answerIndex) =>\n String(answer.answerId ?? answer.orderIndex ?? (answerIndex + 1)) === String(id),\n )\n return index >= 0 ? this._label(index) : ''\n }).filter(Boolean)\n }\n\n private _emit(name: string, detail?: unknown) {\n emitSubjectEvent(this, name, detail)\n }\n\n private _searchAnswerType() {\n if (this.type === 'single') { return 0 }\n if (this.type === 'multiple') { return 1 }\n return 5\n }\n\n private _queueSearch(query: string) {\n if (this._searchTimer) {\n window.clearTimeout(this._searchTimer)\n this._searchTimer = null\n }\n const keyword = query.trim()\n if (!keyword || (!this['search-api'] && typeof this['search-handler'] !== 'function')) {\n this._searchResults = []\n this._searchOpen = false\n this._searchLoading = false\n return\n }\n this._searchTimer = window.setTimeout(() => {\n void this._runSearch(keyword)\n }, 300)\n }\n\n private async _runSearch(query: string) {\n const currentToken = ++this._searchToken\n this._searchLoading = true\n this._searchOpen = true\n this.requestUpdate()\n try {\n let result: SearchResult[] = []\n if (typeof this['search-handler'] === 'function') {\n result = await this['search-handler'](query, this._searchAnswerType())\n }\n else if (this['search-api']) {\n const params = new URLSearchParams({\n searchKey: query,\n answerType: String(this._searchAnswerType()),\n })\n const response = await fetch(`${this['search-api']}${this['search-api'].includes('?') ? '&' : '?'}${params.toString()}`)\n if (!response.ok) {\n throw new Error(`HTTP ${response.status}`)\n }\n const payload = await response.json()\n const list = Array.isArray(payload) ? payload : Array.isArray(payload?.data) ? payload.data : []\n result = list.map((item: any) => ({\n ...item,\n value: item?.value || item?.title || '',\n }))\n }\n if (currentToken !== this._searchToken) { return }\n this._searchResults = Array.isArray(result) ? result : []\n }\n catch (error: any) {\n if (currentToken !== this._searchToken) { return }\n this._searchResults = []\n showSubjectToast(error?.message || '题库搜索失败')\n }\n finally {\n if (currentToken === this._searchToken) {\n this._searchLoading = false\n this.requestUpdate()\n }\n }\n }\n\n private _selectSearchResult(item: SearchResult) {\n const selectedTitle = item.value || item.title || ''\n this._title = selectedTitle\n this._searchResults = []\n this._searchOpen = false\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n this._emit('title-select', {\n ...item,\n id: item.id ?? item.examId ?? item.questionId,\n title: item.title || selectedTitle,\n value: selectedTitle,\n customId: this['custom-id'] || '',\n })\n }\n\n private _applyAiAnswer() {\n if (!this['ai-answer']?.trim()) {\n showSubjectToast('暂无 AI 推荐答案')\n return\n }\n const aiTitles = this['ai-answer']\n .split(/\\r?\\n/)\n .map(line => normalizeTitle(line))\n .filter(Boolean)\n let matched = 0\n if (this.type === 'single') {\n let selected = false\n this._answers = this._answers.map((answer) => {\n const shouldSelect = !selected && aiTitles.includes(normalizeTitle(answer.title || ''))\n if (shouldSelect) {\n selected = true\n matched++\n }\n return { ...answer, isCorrect: shouldSelect }\n })\n }\n else {\n this._answers = this._answers.map((answer) => {\n const shouldSelect = aiTitles.includes(normalizeTitle(answer.title || ''))\n if (shouldSelect) { matched++ }\n return { ...answer, isCorrect: shouldSelect }\n })\n }\n if (!matched) {\n showSubjectToast('未找到匹配的选项,请检查选项内容是否一致')\n return\n }\n this.requestUpdate()\n }\n\n private _onCategoryChange(value: string) {\n this._categoryId = value\n this._emit('category-change', {\n value,\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n })\n }\n\n private _setRelation(item: Answer, answerIndex: number) {\n const answer = item.customAnswerId\n ? { ...item }\n : { ...item, customAnswerId: item.answerId || uid() }\n this._answers = this._answers.map((current, index) => index === answerIndex ? answer : current)\n this.requestUpdate()\n this._emit('set-relation', {\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n answerIndex,\n answer,\n })\n }\n\n private _relationLength(relations: any[] = []) {\n return relations.reduce((count, item) => count + (Array.isArray(item?.relationAnswers) ? item.relationAnswers.length : 0), 0)\n }\n\n private _emitEditResultItem(item: Answer, answerIndex: number) {\n this._emit('edit-result-item', {\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n answerIndex,\n answer: { ...item },\n resultItem: item.resultItem || '',\n })\n }\n\n private _resultSlotName(index: number) {\n return `business-result-item-${index}`\n }\n\n private _imageResources() {\n return getSubjectImageResources(this['resource-list'] || [])\n }\n\n private _videoResource() {\n return getSubjectVideoResource(this['resource-list'] || [])\n }\n\n private _openImageViewer(index = 0) {\n if (!this._imageResources().length) { return }\n this._imageViewerIndex = index\n this._imageViewerOpen = true\n }\n\n private _closeImageViewer() {\n this._imageViewerOpen = false\n }\n\n private _moveImage(step: number) {\n const images = this._imageResources()\n if (!images.length) { return }\n this._imageViewerIndex = (this._imageViewerIndex + step + images.length) % images.length\n }\n\n private _openVideoViewer() {\n if (!this._videoResource()?.url) { return }\n this._videoViewerOpen = true\n }\n\n private _closeVideoViewer() {\n this._videoViewerOpen = false\n }\n\n private _label(i: number) { return String.fromCharCode(65 + i) }\n\n private get _titlePlaceholder() {\n return this.type === 'single' ? '单选题' : this.type === 'multiple' ? '多选题' : '排序题'\n }\n\n private _setCorrect(item: Answer, val: boolean) {\n if (this.lockAnswerKey) { return }\n if (this.type === 'single') {\n this._answers = this._answers.map(answer => ({\n ...answer,\n isCorrect: answer === item ? val : (val ? false : !!answer.isCorrect),\n }))\n }\n else {\n this._answers = this._answers.map(answer => answer === item\n ? { ...answer, isCorrect: val }\n : answer)\n }\n this.requestUpdate()\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) { el.value = el.value.slice(0, this.TITLE_MAX) }\n this._title = el.value\n this._queueSearch(this._title)\n // 双向绑定:通知外部更新\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n }\n\n private _onAnswerInput(e: Event, idx: number) {\n const el = e.target as HTMLInputElement\n if (el.value.length > this.ANSWER_MAX) { el.value = el.value.slice(0, this.ANSWER_MAX) }\n this._answers[idx].title = el.value\n this.requestUpdate()\n }\n\n private _addAnswer(index: number) {\n const arr = [...this._answers]\n arr.splice(index + 1, 0, { title: '', isCorrect: false, customAnswerId: uid() })\n this._answers = arr\n }\n\n private _deleteAnswer(index: number) {\n if (this._answers.length < 3) { return }\n this._answers = this._answers.filter((_, i) => i !== index)\n }\n\n private _toggleSortItem(letter: string) {\n const idx = this._orderList.indexOf(letter)\n if (idx >= 0) {\n this._orderList = this._orderList.filter(l => l !== letter)\n }\n else {\n this._orderList = [...this._orderList, letter]\n }\n this.requestUpdate()\n }\n\n private _removeSortItem(letter: string) {\n this._orderList = this._orderList.filter(l => l !== letter)\n this.requestUpdate()\n }\n\n private _getSortOrder(index: number): number | null {\n const pos = this._orderList.indexOf(this._label(index))\n return pos >= 0 ? pos + 1 : null\n }\n\n private _sortAnswerValue(letter: string) {\n const index = letter.charCodeAt(0) - 65\n const answer = this._answers[index] as any\n return answer?.answerId ?? index + 1\n }\n\n private _rowMeta() {\n return {\n customId: this['custom-id'] || undefined,\n answerType: this.type,\n orderIndex: this['order-index'],\n }\n }\n\n private _collectSnapshot(): SubjectSnapshot {\n const answers = (this['is-edit'] ? this._answers : this['answer-list'] || []).map((answer: any) => ({\n ...answer,\n title: trimText(answer?.title ?? answer?.answer ?? ''),\n isCorrect: !!answer?.isCorrect,\n resultItem: trimText(answer?.resultItem ?? ''),\n }))\n const orderList = this['is-edit']\n ? [...this._orderList]\n : (() => {\n const expand = this['exam-expand']\n if (!expand) { return [] }\n return expand.split(',').map((id: string) => {\n const index = (this['answer-list'] as any[])?.findIndex((answer, answerIndex) =>\n String(answer.answerId ?? answer.orderIndex ?? (answerIndex + 1)) === String(id),\n )\n return index >= 0 ? this._label(index) : ''\n }).filter(Boolean)\n })()\n return {\n title: trimText(this['is-edit'] ? this._title : (this as any).title || ''),\n answers,\n analysis: trimText(this['is-edit'] ? this._analysis : this.analysis || ''),\n leastAnswerCount: this['is-edit']\n ? this._leastAnswerCount\n : this._normalizeLeastAnswerCount(this['least-answer-count']),\n selectedTagList: Array.isArray(this._selectedTagList) ? [...this._selectedTagList] : [],\n examExpand: this['is-edit']\n ? orderList.map((letter: string) => this._sortAnswerValue(letter)).join(',')\n : (this['exam-expand'] || ''),\n showRichText: this['is-edit'] ? this._showRichText : !!this['rich-text-content'],\n richText: this['is-edit'] ? this._richText : this['rich-text-content'] || '',\n orderList,\n }\n }\n\n private _validateSnapshot(snapshot: SubjectSnapshot, answerType: AnswerType = this.type) {\n const row = this._rowMeta()\n const errors: SubjectError[] = []\n\n if (!snapshot.title) {\n errors.push(new SubjectError('题目标题不能为空!', 'EMPTY_TITLE', 'title', row))\n }\n let isSetCorrectAnswer = false\n let correctAnswerCount = 0\n\n snapshot.answers.forEach((answer, index) => {\n if (!answer.title?.trim()) {\n errors.push(new SubjectError(`选项${String.fromCharCode(65 + index)}未填写`, 'ANSWER_EMPTY', 'answers', row))\n }\n if (answerType !== 'sort' && answer.isCorrect) {\n isSetCorrectAnswer = true\n correctAnswerCount++\n }\n })\n\n const titleSet = new Set(snapshot.answers.map(answer => answer.title))\n if (titleSet.size !== snapshot.answers.length && snapshot.answers.length > 0) {\n errors.push(new SubjectError('选项不能重复', 'DUPLICATE_ANSWERS', 'answers', row))\n }\n\n if (answerType === 'single' && correctAnswerCount > 1) {\n errors.push(new SubjectError(\n '此题为单选题,设置了多个推荐/正确选项,请保存时确认是否切换为多选题',\n 'SINGLE_MULTI_CORRECT',\n 'answers',\n row,\n ))\n }\n\n if (answerType === 'multiple') {\n if (correctAnswerCount === 1) {\n errors.push(new SubjectError('请设置至少两个推荐/正确选项', 'CORRECT_COUNT_INVALID', 'answers', row))\n }\n if (correctAnswerCount > 0) {\n isSetCorrectAnswer = true\n }\n if (isSetCorrectAnswer && snapshot.leastAnswerCount !== null && correctAnswerCount < snapshot.leastAnswerCount) {\n errors.push(new SubjectError('至少选几项与推荐/正确选项数不符', 'LEAST_ANSWER_COUNT_INVALID', 'answers', row))\n }\n }\n\n if (answerType === 'sort') {\n isSetCorrectAnswer = snapshot.orderList.length > 0\n if (snapshot.leastAnswerCount !== null && snapshot.orderList.length < snapshot.leastAnswerCount) {\n errors.push(new SubjectError('至少选几项与推荐/正确选项数不符', 'LEAST_ANSWER_COUNT_INVALID', 'orderList', row))\n }\n }\n\n return {\n errors,\n isSetCorrectAnswer,\n correctAnswerCount,\n }\n }\n\n private _serialize(answerType: AnswerType = this.type) {\n const snapshot = this._collectSnapshot()\n const { errors, isSetCorrectAnswer } = this._validateSnapshot(snapshot, answerType)\n if (errors.length) {\n throw errors[0]\n }\n const result: any = {\n answerType: String(answerType),\n examTypeEnum: String(answerType),\n title: snapshot.title,\n answers: snapshot.answers.map((answer, index) => {\n const relationType = answer.resultItem\n ? 1\n : (Array.isArray(answer.answerRelations) && answer.answerRelations.length ? 2 : null)\n const next: any = { ...answer, orderIndex: index + 1, answer: answer.title, relationType }\n if (answer.answerId !== undefined) {\n next.examAnswerId = answer.answerId\n }\n if (relationType === null) {\n delete next.relationType\n }\n return next\n }),\n examExpand: snapshot.examExpand,\n analysis: snapshot.analysis,\n isSetCorrectAnswer,\n examRichTextContent: snapshot.showRichText ? snapshot.richText : '',\n }\n if (this['exam-answer-relation-type']) {\n result.examAnswerRelationType = this['exam-answer-relation-type']\n }\n if (this._supportsLeastAnswerCount(answerType)) {\n result.leastAnswerCount = snapshot.leastAnswerCount\n }\n if (this['custom-id']) { result.customId = this['custom-id'] }\n return result\n }\n\n private _shouldShowCorrectHint() {\n if (this.type === 'sort') {\n return !this._orderList.length\n }\n return !this._answers.some(answer => !!answer.isCorrect)\n }\n\n private async _finalizeSave() {\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 async toJSON(): Promise<any> {\n return Promise.resolve(this._serialize())\n }\n\n validate(): SubjectError[] {\n return this._validateSnapshot(this._collectSnapshot()).errors\n }\n\n setResultItem(answerIndex: number, resultItem: string) {\n if (answerIndex < 0 || answerIndex >= this._answers.length) {\n return\n }\n this._answers = this._answers.map((answer, index) => index === answerIndex\n ? { ...answer, resultItem: resultItem || '' }\n : answer)\n this.requestUpdate()\n }\n\n setAnswerRelation(customAnswerId: string, answerRelations: any) {\n if (!customAnswerId) {\n return\n }\n this._answers = this._answers.map((answer) => {\n const currentId = String(answer.customAnswerId ?? answer.answerId ?? '')\n return currentId === String(customAnswerId)\n ? { ...answer, answerRelations }\n : answer\n })\n this.requestUpdate()\n }\n\n private _renderCorrectHintDialog() {\n if (!this._correctHintDialogOpen) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => { this._correctHintDialogOpen = false }}>\n <div class=\"modal correct-hint-dialog\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">温馨提示</span>\n </div>\n <div class=\"modal-body\">\n <div class=\"correct-hint-copy\">\n 为了收集更全面、有价值的数据,建议您为问卷每题设定<span class=\"correct-hint-highlight\">推荐/正确选项</span>。这将助力深入分析,让调研结果更精准、有意义。\n </div>\n </div>\n <div class=\"modal-footer\">\n <button @click=${async () => {\n this._hasShownCorrectHint = true\n this._correctHintDialogOpen = false\n await this._finalizeSave()\n }}>完成编辑</button>\n <button class=\"primary\" @click=${() => { this._correctHintDialogOpen = false }}>去设置</button>\n </div>\n </div>\n </div>\n `\n }\n\n private _renderChangeTypeDialog() {\n if (!this._changeTypeDialogOpen) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => { this._changeTypeDialogOpen = false }}>\n <div class=\"modal\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">提示</span>\n <button class=\"modal-close\" @click=${() => { this._changeTypeDialogOpen = false }}>&#x2715;</button>\n </div>\n <div class=\"modal-body\">\n <div class=\"value-text\">此题为单选题,设置了多个推荐/正确选项,是否切换成多选题?</div>\n </div>\n <div class=\"modal-footer\">\n <button @click=${() => { this._changeTypeDialogOpen = false }}>取消</button>\n <button class=\"primary\" @click=${() => {\n try {\n const data = this._serialize('multiple')\n this._changeTypeDialogOpen = false\n this._emit('save', data)\n }\n catch (error: any) {\n showSubjectToast(error?.message || '保存失败')\n }\n }}>切换</button>\n </div>\n </div>\n </div>\n `\n }\n\n private _renderSearchDropdown() {\n if (!this['is-edit'] || (!this._searchOpen && !this._searchLoading)) { return '' }\n return html`\n <div class=\"search-dropdown\">\n ${this._searchLoading\n ? html`<div class=\"search-empty\">搜索中...</div>`\n : this._searchResults.length\n ? this._searchResults.map(item => html`\n <div class=\"search-item\" @click=${() => this._selectSearchResult(item)}>${item.value || item.title}</div>\n `)\n : html`<div class=\"search-empty\">暂无匹配题目</div>`}\n </div>\n `\n }\n\n private _renderCategorySection() {\n if (!this['show-category']) { return '' }\n return html`\n <div class=\"flex-items-start section-row\">\n <div class=\"label\"><span>分类:</span></div>\n <div style=\"flex:1\">\n ${this['is-edit']\n ? html`\n <select class=\"el-select\" .value=${String(this._categoryId)}\n @change=${(e: Event) => this._onCategoryChange((e.target as HTMLSelectElement).value)}>\n <option value=\"\">选择分类</option>\n ${this['category-list'].map(item => html`\n <option value=${String(item.categoryId)} ?selected=${String(item.categoryId) === String(this._categoryId)}>${item.title}</option>\n `)}\n </select>\n `\n : html`<span class=\"value-text\">${resolveSubjectCategoryLabel(this['category-list'], this._categoryId)}</span>`}\n </div>\n </div>\n `\n }\n\n private _renderAiSection() {\n if (!this['show-ai'] || !['single', 'multiple'].includes(this.type)) { return '' }\n return html`\n <div class=\"flex-items-start section-row\">\n <div class=\"label\"><span>AI推荐:</span></div>\n <div style=\"flex:1\">\n <span class=\"value-text\">${this['ai-answer'] || '暂无'}</span>\n ${this['is-edit']\n ? html`<div style=\"margin-top:8px\"><span class=\"el-link\" @click=${() => this._applyAiAnswer()}>一键勾选</span></div>`\n : ''}\n </div>\n </div>\n `\n }\n\n private _renderResourceSection() {\n if (!this['show-resource']) { return '' }\n const images = this._imageResources()\n const video = this._videoResource()\n return html`\n <div class=\"flex-items-start section-row\">\n <div class=\"label\"><span>资源:</span></div>\n <div style=\"flex:1\">\n <div class=\"resource-summary\">\n 图片 ${images.length} 张${video ? ',含视频资源' : ''}\n </div>\n <div class=\"resource-actions\">\n ${images.length ? html`<span class=\"el-link\" @click=${() => this._openImageViewer(0)}>查看图片</span>` : ''}\n ${video?.url ? html`<span class=\"el-link\" @click=${() => this._openVideoViewer()}>查看视频</span>` : ''}\n ${!images.length && !video?.url ? html`<span class=\"muted-text\">暂无资源</span>` : ''}\n </div>\n ${images.length\n ? html`\n <div class=\"resource-thumbs\">\n ${images.slice(0, 4).map((src, index) => html`\n <img class=\"resource-thumb\" src=${src} alt=\"resource\" @click=${() => this._openImageViewer(index)} />\n `)}\n </div>\n `\n : ''}\n </div>\n </div>\n `\n }\n\n private _renderImageViewer() {\n if (!this._imageViewerOpen) { return '' }\n const images = this._imageResources()\n const current = images[this._imageViewerIndex]\n if (!current) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => this._closeImageViewer()}>\n <div class=\"modal\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">图片预览</span>\n <button class=\"modal-close\" @click=${() => this._closeImageViewer()}>&#x2715;</button>\n </div>\n <div class=\"modal-body\">\n <div class=\"media-stage\"><img src=${current} alt=\"resource-preview\" /></div>\n </div>\n <div class=\"modal-footer\">\n <div class=\"media-footer\">\n <span class=\"muted-text\">${this._imageViewerIndex + 1} / ${images.length}</span>\n <div class=\"group\">\n ${images.length > 1 ? html`<button @click=${() => this._moveImage(-1)}>上一张</button>` : ''}\n ${images.length > 1 ? html`<button @click=${() => this._moveImage(1)}>下一张</button>` : ''}\n <button class=\"primary\" @click=${() => this._closeImageViewer()}>关闭</button>\n </div>\n </div>\n </div>\n </div>\n </div>\n `\n }\n\n private _renderVideoViewer() {\n const video = this._videoResource()\n if (!this._videoViewerOpen || !video?.url) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => this._closeVideoViewer()}>\n <div class=\"modal\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">视频预览</span>\n <button class=\"modal-close\" @click=${() => this._closeVideoViewer()}>&#x2715;</button>\n </div>\n <div class=\"modal-body\">\n <div class=\"media-stage\">\n <video src=${video.url} controls playsinline></video>\n </div>\n </div>\n <div class=\"modal-footer\">\n <button class=\"primary\" @click=${() => this._closeVideoViewer()}>关闭</button>\n </div>\n </div>\n </div>\n `\n }\n\n private async _save(e?: Event) {\n e?.stopImmediatePropagation()\n const errors = this.validate()\n const convertWarning = errors.find(error => error.code === 'SINGLE_MULTI_CORRECT')\n const blockingErrors = errors.filter(error => error.code !== 'SINGLE_MULTI_CORRECT')\n if (blockingErrors.length) {\n showSubjectToast(blockingErrors[0].message)\n return\n }\n if (convertWarning) {\n this._changeTypeDialogOpen = true\n return\n }\n if (!this._hasShownCorrectHint && this._shouldShowCorrectHint()) {\n this._correctHintDialogOpen = true\n return\n }\n await this._finalizeSave()\n }\n\n private _renderPreview() {\n const typeSuffix = this.type === 'single'\n ? '(单选题)'\n : `(${this._titlePlaceholder}${this._leastAnswerCountSuffix(this._normalizeLeastAnswerCount(this['least-answer-count']))})`\n const answers = this['answer-list'] as Answer[]\n const previewTitle = buildSubjectPreviewTitle(this['subject-prefix'], this['order-index'], (this as any).title || '')\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\">${typeSuffix.replace(/[()]/g, '')}</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=\"preview-answer\">\n ${answers.map((a, i) => html`\n <div class=\"radio\">\n <input type=\"${this.type === 'sort' ? 'checkbox' : 'radio'}\" .checked=${!!a.isCorrect} disabled />\n <span class=\"order\">${this._label(i)}.</span>\n <div class=\"answer-main\">\n <span class=\"answer-text\">${a.title}</span>\n ${this.type !== 'sort' && a.isCorrect ? html`<span class=\"correct\">推荐 / 正确选项</span>` : ''}\n </div>\n ${this.type !== 'sort' && (\n this['exam-answer-relation-type'] === 1\n || this['exam-answer-relation-type'] === 2\n )\n ? html`\n <div class=\"answer-meta\">\n ${this['exam-answer-relation-type'] === 1\n ? html`<span class=\"result-info\">${a.resultItem ? '已设置结果项' : '未设置结果项'}</span>`\n : ''}\n ${this['exam-answer-relation-type'] === 2\n ? html`<span class=\"result-info\">${Array.isArray(a.answerRelations) && a.answerRelations.length ? `关联了${this._relationLength(a.answerRelations)}项` : '未设置关联'}</span>`\n : ''}\n </div>\n `\n : ''}\n </div>\n `)}\n </div>\n ${this['show-category'] && this._categoryId\n ? html`<div class=\"section-row\"><span class=\"value-text\">分类:${resolveSubjectCategoryLabel(this['category-list'], this._categoryId)}</span></div>`\n : ''}\n ${this['show-resource'] ? this._renderResourceSection() : ''}\n </div>\n `\n }\n\n private _renderSorting() {\n const title = trimText(this['is-edit'] ? this._title : (this as any).title || '') || '未命名题目'\n const orderText = buildSubjectSortingTitle(this['subject-prefix'], this['order-index'], title)\n return renderSortingCard(orderText, SubjectTypeLabel[this.type] || this.type)\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 search-wrap\">\n <textarea rows=\"2\" .value=${this._title}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【${this._titlePlaceholder}】请输入问题\"></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n ${this._renderSearchDropdown()}\n </div>\n </div>\n </div>\n\n ${['multiple', 'sort'].includes(this.type)\n ? html`\n <div class=\"edit-row section-row\">\n <div class=\"label\"><span>设置:</span></div>\n <div class=\"row-body\">\n <select class=\"el-select\" .value=${this._leastAnswerCount === null ? '' : String(this._leastAnswerCount)} ?disabled=${this.lockAnswerKey}\n @change=${(e: Event) => {\n const value = (e.target as HTMLSelectElement).value\n this._leastAnswerCount = this._normalizeLeastAnswerCount(value)\n }}>\n <option value=\"\">至少选择几项</option>\n ${Array.from({ length: Math.max(0, this._answers.length - 1) }, (_, i) => i + 2).map(n => html`\n <option value=${n} ?selected=${this._leastAnswerCount === n}>至少选择${n}项</option>\n `)}\n </select>\n </div>\n </div>\n `\n : ''}\n\n <div class=\"edit-row section-row edit-row--compact\">\n <div class=\"label\"><span>${this.type === 'sort' ? '排序项:' : '选项:'}</span></div>\n <div class=\"row-body\">\n <div class=\"answer-list\">\n ${this._answers.map((a, i) => html`\n <div class=\"answer-item\">\n <span class=\"label\">${this._label(i)}.</span>\n <div class=\"input\">\n <input type=\"text\" .value=${a.title}\n maxlength=${this.ANSWER_MAX}\n @input=${(e: Event) => this._onAnswerInput(e, i)}\n placeholder=\"选项${this._label(i)}\" />\n <span class=\"char-counter\">${a.title.length}/${this.ANSWER_MAX}</span>\n </div>\n\n ${this.type === 'sort' && this._getSortOrder(i) !== null\n ? html`<span class=\"sort-badge\">第${this._getSortOrder(i)}位</span>`\n : ''}\n\n ${['single', 'multiple'].includes(this.type)\n ? html`\n <label class=\"correct ${a.isCorrect ? 'is-correct' : ''}\">\n <input type=\"checkbox\" .checked=${a.isCorrect} ?disabled=${this.lockAnswerKey}\n @change=${(e: Event) => this._setCorrect(a, (e.target as HTMLInputElement).checked)} />\n <span class=\"correct-text\">推荐/正确选项</span>\n </label>\n `\n : ''}\n\n <span class=\"icon\"\n @click=${() => this._addAnswer(i)}>\n ${iconPlus}\n </span>\n <span class=\"icon ${this._answers.length < 3 ? 'disabled' : ''}\"\n @click=${() => this._deleteAnswer(i)}>\n ${iconRemove}\n </span>\n\n ${this['exam-answer-relation-type'] === 1 && this.type !== 'sort'\n ? html`\n <slot name=${this._resultSlotName(i)}>\n <button class=\"el-link\" @click=${() => this._emitEditResultItem(a, i)}>\n ${a.resultItem ? '编辑结果' : '添加结果'}\n </button>\n </slot>\n `\n : ''}\n\n ${this['exam-answer-relation-type'] === 2 && this.type !== 'sort'\n ? html`\n <button class=\"el-link\" @click=${() => this._setRelation(a, i)}>\n ${Array.isArray(a.answerRelations) && a.answerRelations.length ? `关联了${this._relationLength(a.answerRelations)}项` : '关联检查'}\n </button>\n `\n : ''}\n\n </div>\n `)}\n </div>\n </div>\n </div>\n\n ${this.type === 'sort'\n ? html`\n <div class=\"edit-row section-row\">\n <div class=\"label\"><span>排序答案:</span></div>\n <div class=\"row-body\">\n <div class=\"multi-select-wrapper\">\n <div class=\"multi-select ${this._sortDropdownOpen ? 'focused' : ''} ${this.lockAnswerKey ? 'disabled' : ''}\"\n @click=${() => { if (!this.lockAnswerKey) { this._sortDropdownOpen = !this._sortDropdownOpen; this.requestUpdate() } }}>\n ${this._orderList.length > 0\n ? this._orderList.map(l => html`\n <span class=\"tag\">\n ${l}\n <span class=\"tag-close\" @click=${(e: Event) => {\n if (this.lockAnswerKey) { return }\n e.stopPropagation()\n this._removeSortItem(l)\n }}>&#x2715;</span>\n </span>\n `)\n : html`<span class=\"placeholder\">请按顺序选择排序答案</span>`\n }\n <span class=\"arrow\">${iconArrow}</span>\n </div>\n ${this._sortDropdownOpen\n ? html`\n <div class=\"multi-select-dropdown\">\n ${this._answers.map((_, i) => html`\n <div class=\"multi-select-option ${this._orderList.includes(this._label(i)) ? 'selected' : ''}\"\n @click=${() => {\n if (this.lockAnswerKey) { return }\n this._toggleSortItem(this._label(i))\n this.requestUpdate()\n }}>\n ${this._label(i)}\n </div>\n `)}\n </div>\n `\n : ''}\n </div>\n </div>\n </div>\n `\n : ''}\n\n <slot name=\"business-tag\"></slot>\n\n ${this._renderCategorySection()}\n\n ${this._renderAiSection()}\n\n ${this._renderResourceSection()}\n\n ${this['show-rich-text'] && this._showRichText\n ? html`\n <div class=\"edit-row section-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`<div class=\"flex-justify-end\" style=\"margin-top:8px\"><span class=\"el-link danger\" @click=${() => { this._showRichText = false; this._richText = '' }}>删除富文本</span></div>`\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"edit-row section-row\">\n <div class=\"label\"><span>解析:</span></div>\n <div class=\"row-body\">\n <textarea rows=\"2\" .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"></textarea>\n </div>\n </div>\n `\n : ''}\n </div>\n `\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-jump=${this['show-jump']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @move=${(e: CustomEvent) => this._emit('move', e.detail)}\n @jump=${() => this._emit('jump', {\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n answerType: this.type,\n })}\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 ${this._renderCorrectHintDialog()}\n ${this._renderChangeTypeDialog()}\n ${this._renderImageViewer()}\n ${this._renderVideoViewer()}\n `\n }\n}\n\nexport function register() {}\n"],"names":["SubjectError","Error","constructor","message","code","arguments","length","undefined","field","row","super","this","name","from","options","iconPlus","html","iconRemove","iconArrow","normalizeTitle","text","replace","toLowerCase","trimText","value","String","trim","QxsSubjectSingle","LitElement","lockAnswerKey","sorting","type","analysis","async","Promise","resolve","reject","reader","FileReader","onload","e","target","result","onerror","readAsDataURL","file","_answers","title","isCorrect","_title","_analysis","_richText","_showRichText","_leastAnswerCount","_answerCheckType","_isKey","_orderList","_selectedTagList","_categoryId","_searchResults","_searchOpen","_searchLoading","_sortDropdownOpen","_imageViewerOpen","_imageViewerIndex","_videoViewerOpen","_correctHintDialogOpen","_hasShownCorrectHint","_changeTypeDialogOpen","_searchTimer","_searchToken","TITLE_MAX","ANSWER_MAX","_handleDocumentClick","path","composedPath","wrapper","shadowRoot","querySelector","searchWrap","includes","requestUpdate","v","arr","Array","isArray","map","a","_normalizeAnswerItem","connectedCallback","document","addEventListener","_syncExternalProps","disconnectedCallback","removeEventListener","window","clearTimeout","willUpdate","changed","has","_syncProps","item","_syncExamExpand","_supportsLeastAnswerCount","answerType","_normalizeLeastAnswerCount","count","Number","isFinite","_leastAnswerCountSuffix","answer","next","answerId","examAnswerId","ids","split","answers","id","index","findIndex","answerIndex","orderIndex","_label","filter","Boolean","_emit","detail","emitSubjectEvent","_searchAnswerType","_queueSearch","query","keyword","setTimeout","_runSearch","currentToken","params","URLSearchParams","searchKey","response","fetch","toString","ok","status","payload","json","data","error","showSubjectToast","_selectSearchResult","selectedTitle","emitSubjectModelValue","examId","questionId","customId","_applyAiAnswer","aiTitles","line","matched","selected","shouldSelect","_onCategoryChange","_setRelation","customAnswerId","uid","current","_relationLength","reduce","relationAnswers","_emitEditResultItem","resultItem","_resultSlotName","_imageResources","getSubjectImageResources","_videoResource","getSubjectVideoResource","_openImageViewer","_closeImageViewer","_moveImage","step","images","_openVideoViewer","url","_closeVideoViewer","i","fromCharCode","_titlePlaceholder","_setCorrect","val","_onTitleInput","el","slice","_onAnswerInput","idx","_addAnswer","splice","_deleteAnswer","_","_toggleSortItem","letter","indexOf","l","_removeSortItem","_getSortOrder","pos","_sortAnswerValue","charCodeAt","_rowMeta","_collectSnapshot","orderList","expand","leastAnswerCount","selectedTagList","examExpand","join","showRichText","richText","_validateSnapshot","snapshot","errors","push","isSetCorrectAnswer","correctAnswerCount","forEach","Set","size","_serialize","examTypeEnum","relationType","answerRelations","examRichTextContent","examAnswerRelationType","_shouldShowCorrectHint","some","_finalizeSave","toJSON","err","validate","setResultItem","setAnswerRelation","_renderCorrectHintDialog","stopPropagation","_renderChangeTypeDialog","_renderSearchDropdown","_renderCategorySection","categoryId","resolveSubjectCategoryLabel","_renderAiSection","_renderResourceSection","video","src","_renderImageViewer","_renderVideoViewer","_save","stopImmediatePropagation","convertWarning","find","blockingErrors","_renderPreview","typeSuffix","previewTitle","buildSubjectPreviewTitle","_renderSorting","orderText","buildSubjectSortingTitle","renderSortingCard","SubjectTypeLabel","_renderEdit","Math","max","n","checked","SUB_TEXT_EDITOR_TOOLBAR","getContent","render","content","styles","sortingCardStyles","subjectHostStyles","subjectControlResetStyles","subjectPreviewBaseStyles","subjectFormBaseStyles","subjectTextareaStyles","css","__decorateClass","property","attribute","prototype","reflect","Object","state","safeCustomElement"],"mappings":"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"}
1
+ {"version":3,"file":"single.cjs","sources":["../../../../packages/components/src/subject/single.ts"],"sourcesContent":["import type { AnswerType } from './types'\nimport { css, html, LitElement } from 'lit'\nimport { property, state } from 'lit/decorators.js'\nimport { safeCustomElement } from '../base/define'\nimport { uid } from '../base/uid'\nimport { SUB_TEXT_EDITOR_TOOLBAR } from '../editor/toolbar'\nimport { buildSubjectPreviewTitle, buildSubjectSortingTitle, emitSubjectEvent, emitSubjectModelValue, getSubjectImageResources, getSubjectVideoResource, resolveSubjectCategoryLabel, showSubjectToast } from './shared-methods'\nimport { subjectControlResetStyles, subjectFormBaseStyles, subjectHostStyles, subjectPreviewBaseStyles, subjectTextareaStyles } from './shared-styles'\nimport { acknowledgeSingleCorrectHint, applySingleSaveDecisionToDialogs, buildSingleSearchSelection, dismissSingleChangeTypeDialog, dismissSingleCorrectHintDialog, hasSingleSearchSource, resolveSingleSaveDecision, searchSingleSubjects, type SingleDialogState } from './single-interactions'\nimport { buildSingleEditorState, buildSingleSnapshot, leastAnswerCountSuffix, normalizeLeastAnswerCount, normalizeSingleAnswerList, resolveSingleOrderList, serializeSingleSnapshot, type SingleAnswer, type SingleEditorState, type SingleSnapshot, validateSingleSnapshot } from './single-model'\nimport { applySingleAiAnswer, countSingleRelationAnswers, deleteSingleAnswerAt, getSingleSortOrder, insertSingleAnswerAfter, removeSingleSortLetter, resolveSingleSortAnswerValue, setSingleCorrectState, shouldShowSingleCorrectHint, toggleSingleSortLetter, updateSingleAnswerTitle } from './single-state'\nimport { renderSortingCard, sortingCardStyles } from './sorting-card'\nimport { type Category, type Resource, type SearchResult, SubjectError, type TagItem, trimText } from './subject-shared'\nimport { SubjectTypeLabel } from './types'\n\nexport { SubjectError, trimCommaSeparatedText, trimText } from './subject-shared'\nexport type { Category, KnowledgePointInfo, Resource, SearchResult, TagItem } from './subject-shared'\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>`\nconst iconArrow = html`<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><polyline points=\"6 9 12 15 18 9\"/></svg>`\n\n@safeCustomElement('qxs-subject-single')\nexport class QxsSubjectSingle extends LitElement {\n static styles = [sortingCardStyles, subjectHostStyles, subjectControlResetStyles, subjectPreviewBaseStyles, subjectFormBaseStyles, subjectTextareaStyles, css`\n .preview-answer { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }\n .preview-answer .radio { display: grid; grid-template-columns: auto auto minmax(0, 1fr); column-gap: 10px; row-gap: 3px; align-items: center; }\n .preview-answer .order { color: var(--qxs-subject-text-soft, #6b7280); font-size: 13px; font-weight: 600; }\n .preview-answer .answer-main { min-width: 0; display: inline-flex; flex-wrap: wrap; align-items: baseline; gap: 8px; }\n .preview-answer .answer-text { min-width: 0; font-size: 14px; line-height: 1.7; font-weight: 500; color: var(--qxs-subject-text-primary, #303133); }\n .preview-answer .answer-meta { grid-column: 3; display: flex; flex-wrap: wrap; gap: 8px; font-size: 12px; line-height: 1.6; color: var(--qxs-subject-text-muted, #8b95a7); }\n .preview-answer .correct { color: var(--qxs-subject-color-primary, #3D61E3); font-weight: 600; }\n .preview-answer .result-info { color: var(--qxs-subject-text-muted, #8b95a7); }\n\n .flex { display: flex; }\n .flex-items-center { display: flex; align-items: center; }\n .flex-items-start { display: flex; align-items: flex-start; }\n .flex-justify-end { display: flex; justify-content: flex-end; }\n .edit-actions {\n display: flex;\n justify-content: flex-end;\n padding-left: 88px;\n }\n .edit-inline {\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n gap: 8px 14px;\n min-height: 32px;\n }\n .edit-note {\n margin-top: 6px;\n font-size: 12px;\n line-height: 1.6;\n color: var(--qxs-subject-text-secondary, #909399);\n }\n\n .answer-list { display: flex; flex-direction: column; gap: 10px; }\n .answer-item {\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n gap: 8px;\n border-radius: 4px;\n }\n .answer-item .label {\n min-width: 28px;\n font-size: 13px;\n font-weight: 600;\n color: var(--qxs-subject-text-soft, #6b7280);\n letter-spacing: 0;\n }\n .answer-item .input { flex: 1; min-width: 240px; max-width: 380px; position: relative; display: block; }\n .answer-item .input input {\n height: 36px; padding: 0 56px 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 .answer-item .input input:disabled { background: var(--qxs-subject-fill-light, #f5f7fa); color: var(--qxs-subject-text-disabled, #c0c4cc); cursor: not-allowed; }\n .answer-item .input .char-counter {\n position: absolute; right: 8px; top: 50%; transform: translateY(-50%);\n font-size: 12px; color: var(--qxs-subject-text-secondary, #909399); line-height: 1; pointer-events: none;\n }\n\n .answer-item .correct {\n color: var(--qxs-subject-text-secondary, #909399);\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n gap: 6px;\n min-height: 20px;\n white-space: nowrap;\n }\n .answer-item .correct:hover { color: var(--qxs-subject-color-primary, #3D61E3); }\n .answer-item .correct.is-correct { color: var(--qxs-subject-color-success, #67c23a); }\n .answer-item .correct input {\n width: 14px;\n height: 14px;\n margin: 0;\n flex: 0 0 auto;\n cursor: pointer;\n accent-color: var(--qxs-subject-color-primary, #3D61E3);\n }\n .answer-item .correct .correct-text {\n display: inline-flex;\n align-items: center;\n line-height: 1.2;\n }\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 .answer-item .link {\n color: var(--qxs-subject-color-primary, #3D61E3);\n cursor: pointer;\n font-size: 12px;\n white-space: nowrap;\n }\n .answer-item .link:hover { color: var(--qxs-subject-color-primary-hover, #2D4CB8); }\n\n .el-select {\n width: 150px; height: 34px; border: 1px solid var(--qxs-subject-border, #dcdfe6); border-radius: 6px;\n padding: 0 8px; font-size: 13px; background: var(--qxs-subject-fill-blank, #fff); appearance: none;\n background-image: url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23c0c4cc' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E\");\n background-repeat: no-repeat; background-position: right 8px center;\n }\n .el-select:focus { border-color: var(--qxs-subject-color-primary, #3D61E3); outline: none; }\n .el-select:disabled { background: var(--qxs-subject-fill-light, #f5f7fa); color: var(--qxs-subject-text-disabled, #c0c4cc); cursor: not-allowed; }\n\n .sort-badge { font-weight: bold; color: var(--qxs-subject-color-primary, #3D61E3); margin-left: 10px; }\n\n .el-link { color: var(--qxs-subject-color-primary, #3D61E3); cursor: pointer; font-size: 12px; background: none; border: none; padding: 0; margin: 0; font-family: inherit; }\n .el-link:hover { color: var(--qxs-subject-color-primary-hover, #2D4CB8); }\n .el-link.danger { color: var(--qxs-subject-color-danger, #f56c6c); }\n\n .value-text { font-size: 13px; color: var(--qxs-subject-text-regular, #606266); white-space: pre-wrap; }\n .muted-text { font-size: 12px; color: var(--qxs-subject-text-secondary, #909399); }\n\n .search-wrap { position: relative; }\n .search-dropdown {\n position: absolute; z-index: 120; left: 0; right: 0; top: calc(100% + 4px);\n background: var(--qxs-subject-fill-blank, #fff); border: 1px solid var(--qxs-subject-border-light, #e4e7ed); border-radius: 6px;\n box-shadow: var(--qxs-subject-shadow-soft, 0 8px 20px rgba(0,0,0,.12)); overflow: hidden;\n }\n .search-item {\n padding: 10px 12px; cursor: pointer; transition: background .2s;\n font-size: 13px; color: var(--qxs-subject-text-regular, #606266); line-height: 1.4;\n }\n .search-item:hover { background: var(--qxs-subject-fill-light, #f5f7fa); color: var(--qxs-subject-color-primary, #3D61E3); }\n .search-empty { padding: 10px 12px; font-size: 12px; color: var(--qxs-subject-text-secondary, #909399); }\n\n .tag-list { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; min-height: 32px; }\n .tag-item {\n display: inline-flex; align-items: center; gap: 4px;\n padding: 4px 8px; font-size: 12px; line-height: 1;\n color: var(--qxs-subject-color-primary, #3D61E3); background: var(--qxs-subject-fill-soft-primary, #ecf5ff); border: 1px solid var(--qxs-subject-fill-soft-primary-border, #d9ecff); border-radius: 4px;\n }\n .tag-item .close { cursor: pointer; color: var(--qxs-subject-text-secondary, #909399); }\n .tag-item .close:hover { color: var(--qxs-subject-color-danger, #f56c6c); }\n .tag-hint { font-size: 12px; color: var(--qxs-subject-text-secondary, #909399); }\n\n .resource-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 8px; }\n .resource-summary { font-size: 12px; color: var(--qxs-subject-text-regular, #606266); }\n .resource-thumbs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 8px; }\n .resource-thumb {\n width: 72px; height: 72px; object-fit: cover; border-radius: 6px;\n border: 1px solid var(--qxs-subject-border-light, #e4e7ed); cursor: pointer; background: var(--qxs-subject-fill-light, #f5f7fa);\n }\n .resource-video {\n display: inline-flex; align-items: center; justify-content: center;\n min-width: 88px; height: 30px; padding: 0 10px; border: 1px solid var(--qxs-subject-border, #dcdfe6); border-radius: 4px;\n color: var(--qxs-subject-text-regular, #606266); background: var(--qxs-subject-fill-blank, #fff); cursor: pointer; font-size: 12px; transition: all .2s;\n }\n .resource-video: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 .media-stage { display: flex; align-items: center; justify-content: center; min-height: 240px; }\n .media-stage img, .media-stage video { max-width: 100%; max-height: 60vh; border-radius: 6px; }\n .media-footer { display: flex; justify-content: space-between; align-items: center; gap: 8px; width: 100%; }\n .media-footer .group { display: flex; gap: 8px; }\n\n /* Multi-select with tags (Element Plus style) */\n .multi-select-wrapper { position: relative; }\n .multi-select {\n width: 240px; min-height: 36px; border: 1px solid var(--qxs-subject-border, #dcdfe6); border-radius: 6px;\n padding: 0 30px 0 8px; font-size: 13px; background: var(--qxs-subject-fill-blank, #fff); cursor: pointer;\n display: flex; flex-wrap: nowrap; align-items: center; gap: 4px;\n transition: border-color .2s; position: relative; overflow: hidden;\n }\n .multi-select:hover { border-color: var(--qxs-subject-text-disabled, #c0c4cc); }\n .multi-select.focused { border-color: var(--qxs-subject-color-primary, #3D61E3); }\n .multi-select.disabled { background: var(--qxs-subject-fill-light, #f5f7fa); cursor: not-allowed; }\n .multi-select .placeholder { color: var(--qxs-subject-text-disabled, #c0c4cc); font-size: 13px; padding: 4px 0; }\n .multi-select .arrow {\n position: absolute; right: 8px; top: 50%; transform: translateY(-50%);\n color: var(--qxs-subject-text-disabled, #c0c4cc); display: inline-flex; transition: transform .2s;\n }\n .multi-select.focused .arrow { transform: translateY(-50%) rotate(180deg); color: var(--qxs-subject-color-primary, #3D61E3); }\n .multi-select .tag {\n display: inline-flex; align-items: center; gap: 2px;\n background: var(--qxs-subject-fill-dark, #f0f2f5); border-radius: 3px; padding: 0 6px; height: 20px;\n font-size: 12px; color: var(--qxs-subject-text-regular, #606266); line-height: 20px;\n }\n .multi-select .tag .tag-close {\n display: inline-flex; cursor: pointer; color: var(--qxs-subject-text-secondary, #909399); margin-left: 2px; line-height: 1;\n }\n .multi-select .tag .tag-close:hover { color: var(--qxs-subject-color-primary, #3D61E3); }\n .multi-select-dropdown {\n position: absolute; z-index: 100; background: var(--qxs-subject-fill-blank, #fff); left: 0; top: 100%; margin-top: 4px;\n border: 1px solid var(--qxs-subject-border-light, #e4e7ed); border-radius: 3px;\n box-shadow: var(--qxs-subject-shadow-soft, 0 4px 12px rgba(0,0,0,.12)); min-width: 240px; max-height: 140px; overflow-y: auto;\n }\n .multi-select-option {\n padding: 4px 12px; font-size: 13px; color: var(--qxs-subject-text-regular, #606266); cursor: pointer;\n transition: background .2s;\n }\n .multi-select-option:hover { background: var(--qxs-subject-fill-light, #f5f7fa); }\n .multi-select-option.selected { color: var(--qxs-subject-color-primary, #3D61E3); font-weight: 500; }\n\n @media (max-width: 720px) {\n .edit-row,\n .section-row {\n flex-direction: column;\n gap: 8px;\n }\n\n .edit-row > .label,\n .section-row > .label {\n min-width: 0;\n padding-top: 0;\n }\n\n .edit-actions {\n padding-left: 0;\n justify-content: flex-start;\n }\n\n .answer-item .input {\n min-width: 0;\n max-width: none;\n width: 100%;\n }\n }\n\n .modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 9000; display: flex; align-items: center; justify-content: center; }\n .modal { background: var(--qxs-subject-fill-blank, #fff); border-radius: 6px; width: 520px; max-width: 90vw; box-shadow: var(--qxs-subject-shadow-soft, 0 12px 32px rgba(0,0,0,.12)); display: flex; flex-direction: column; }\n .modal-header { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px 12px; border-bottom: 1px solid var(--qxs-subject-border-light, #e4e7ed); }\n .modal-title { font-size: 14px; font-weight: 600; color: var(--qxs-subject-text-primary, #303133); }\n .modal-close { background: none; border: none; font-size: 18px; cursor: pointer; color: var(--qxs-subject-text-secondary, #909399); padding: 0; line-height: 1; }\n .modal-close:hover { color: var(--qxs-subject-color-primary, #3D61E3); }\n .modal-body { padding: 20px; }\n .modal-body textarea { min-height: 120px; }\n .modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 20px; border-top: 1px solid var(--qxs-subject-border-light, #e4e7ed); }\n .modal-footer button { padding: 6px 16px; font-size: 12px; border-radius: 3px; cursor: pointer; border: 1px solid var(--qxs-subject-border, #dcdfe6); background: var(--qxs-subject-fill-blank, #fff); color: var(--qxs-subject-text-regular, #606266); }\n .modal-footer button:hover { color: var(--qxs-subject-color-primary, #3D61E3); border-color: var(--qxs-subject-fill-soft-primary-border-strong, #a0cfff); }\n .modal-footer button.primary { background: var(--qxs-subject-color-primary, #3D61E3); border-color: var(--qxs-subject-color-primary, #3D61E3); color: var(--qxs-subject-fill-blank, #fff); }\n .modal-footer button.primary:hover { background: var(--qxs-subject-color-primary-hover, #2D4CB8); border-color: var(--qxs-subject-color-primary-hover, #2D4CB8); }\n .correct-hint-dialog { width: 520px; max-width: min(90vw, 520px); }\n .correct-hint-dialog .modal-header { padding: 18px 20px 14px; }\n .correct-hint-dialog .modal-title { font-size: 16px; font-weight: 700; color: var(--qxs-subject-text-primary, #303133); }\n .correct-hint-dialog .modal-close { display: none; }\n .correct-hint-dialog .modal-body {\n padding: 32px 28px 20px;\n font-size: 14px;\n line-height: 1.8;\n color: var(--qxs-subject-text-primary, #303133);\n text-align: center;\n }\n .correct-hint-copy { max-width: 420px; margin: 0 auto; }\n .correct-hint-highlight { color: var(--qxs-subject-color-primary, #4c6fff); }\n .correct-hint-dialog .modal-footer {\n justify-content: center;\n gap: 12px;\n padding: 0 28px 28px;\n border-top: none;\n }\n .correct-hint-dialog .modal-footer button {\n min-width: 120px;\n height: 36px;\n padding: 0 18px;\n font-size: 14px;\n border-radius: 4px;\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: 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: 'is-set-correct-answer' }) 'is-set-correct-answer' = false\n @property({ type: Boolean, attribute: 'lock-answer-key' }) lockAnswerKey = false\n @property({ type: Boolean, attribute: 'is-key' }) 'is-key' = 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-answer-setting' }) 'show-answer-setting' = false\n @property({ type: Boolean, attribute: 'show-key' }) 'show-key' = false\n @property({ type: Boolean, attribute: 'show-analysis' }) 'show-analysis' = false\n @property({ attribute: 'question-type', reflect: true }) type: AnswerType = 'single'\n @property({ type: Number, attribute: 'answer-check-type' }) 'answer-check-type' = 1\n @property({ type: Number, attribute: 'exam-answer-relation-type' }) 'exam-answer-relation-type' = 0\n @property({ type: String, attribute: 'rich-text-content' }) 'rich-text-content' = ''\n @property({ type: String }) analysis = ''\n @property({ type: Number, attribute: 'least-answer-count' }) 'least-answer-count': number | null = null\n @property({ type: String, attribute: 'exam-expand' }) 'exam-expand' = ''\n @property({ type: String, attribute: 'custom-id' }) 'custom-id' = ''\n @property({ type: Number, attribute: 'exam-id' }) 'exam-id' = 0\n @property({ type: String, attribute: 'category-id' }) 'category-id' = ''\n @property({ type: Object, attribute: 'upload-image' }) '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'(v: any) {\n // 编辑模式下不接受外部更新,避免覆盖用户正在编辑的内容\n if (this['is-edit']) {\n return\n }\n this._answers = normalizeSingleAnswerList(v)\n this.requestUpdate('answer-list')\n }\n\n // ============ 业务接口 Props ============\n /**\n * 标签列表 - 用于关联题目的标签信息\n * @type {TagItem[]}\n * @description 业务系统传入已选择的标签列表\n */\n @property({ type: Array, attribute: 'tag-list' }) 'tag-list': TagItem[] = []\n /**\n * 分类列表 - 可用于题目的分类选项\n * @type {Category[]}\n * @description 业务系统传入可选的分类列表\n */\n @property({ type: Array, attribute: 'category-list' }) 'category-list': Category[] = []\n /**\n * AI 推荐答案 - AI 根据题目内容推荐的答案\n * @type {string}\n * @description AI 返回的推荐答案,格式如 \"1. 选项A\\n2. 选项B\"\n */\n @property({ type: String, attribute: 'ai-answer' }) 'ai-answer' = ''\n /**\n * 图片/视频资源列表 - 题目附带的媒体资源\n * @type {Resource[]}\n * @description 题目附带图片或视频资源\n */\n @property({ type: Array, attribute: 'resource-list' }) 'resource-list': Resource[] = []\n /**\n * 是否显示标签功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示标签选择 UI\n */\n @property({ type: Boolean, attribute: 'show-tag' }) 'show-tag' = false\n /**\n * 是否显示分类功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示分类选择 UI\n */\n @property({ type: Boolean, attribute: 'show-category' }) 'show-category' = false\n /**\n * 是否显示 AI 推荐功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示 AI 推荐答案 UI\n */\n @property({ type: Boolean, attribute: 'show-ai' }) 'show-ai' = false\n /**\n * 是否显示资源功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示图片/视频资源 UI\n */\n @property({ type: Boolean, attribute: 'show-resource' }) 'show-resource' = false\n /**\n * 是否显示跳题功能\n * @type {boolean}\n * @default false\n * @description 业务功能开关,控制是否显示跳题逻辑设置入口\n */\n @property({ type: Boolean, attribute: 'show-jump' }) 'show-jump' = false\n /**\n * 跳题状态 - 是否已设置跳题逻辑\n * @type {boolean}\n * @default false\n * @description 标记当前题目是否已设置跳题逻辑\n */\n @property({ type: Boolean, attribute: 'has-jump' }) 'has-jump' = false\n /**\n * 题库搜索接口地址\n * @type {string}\n * @description 题库模糊搜索接口地址,用于题库搜索功能\n */\n @property({ type: String, attribute: 'search-api' }) 'search-api' = ''\n /**\n * 题库搜索回调函数\n * @type {Function}\n * @param {string} query - 搜索关键词\n * @param {number} answerType - 题目类型:0-单选, 1-多选\n * @returns {Promise<SearchResult[]>} 搜索结果列表\n * @description 题库搜索的回调函数,由业务系统实现搜索逻辑\n */\n @property({ type: Object, attribute: 'search-handler' }) 'search-handler'?: (query: string, answerType: number) => Promise<SearchResult[]>\n\n // 双向绑定支持\n @property({ type: String, attribute: 'model-value' }) 'model-value' = ''\n @property({ type: Boolean, attribute: 'use-model' }) 'use-model' = false\n\n @state() private _answers: SingleAnswer[] = [\n { title: '', isCorrect: false }, { title: '', isCorrect: false },\n { title: '', isCorrect: false }, { title: '', isCorrect: false },\n ]\n\n @property({ type: String }) title = ''\n\n @state() private _title = ''\n @state() private _analysis = ''\n @state() private _richText = ''\n @state() private _showRichText = false\n @state() private _leastAnswerCount: number | null = null\n @state() private _answerCheckType = 1\n @state() private _isKey = false\n @state() private _orderList: string[] = []\n @state() private _selectedTagList: TagItem[] = []\n @state() private _categoryId = ''\n @state() private _searchResults: SearchResult[] = []\n @state() private _searchOpen = false\n @state() private _searchLoading = false\n @state() private _sortDropdownOpen = false\n @state() private _imageViewerOpen = false\n @state() private _imageViewerIndex = 0\n @state() private _videoViewerOpen = false\n @state() private _correctHintDialogOpen = false\n @state() private _hasShownCorrectHint = false\n @state() private _changeTypeDialogOpen = false\n\n private _searchTimer: number | null = null\n private _searchToken = 0\n\n private readonly TITLE_MAX = 200\n private readonly ANSWER_MAX = 100\n\n connectedCallback() {\n super.connectedCallback()\n document.addEventListener('click', this._handleDocumentClick)\n this._syncExternalProps()\n }\n\n disconnectedCallback() {\n super.disconnectedCallback()\n document.removeEventListener('click', this._handleDocumentClick)\n if (this._searchTimer) {\n window.clearTimeout(this._searchTimer)\n this._searchTimer = null\n }\n }\n\n private _handleDocumentClick = (e: MouseEvent) => {\n const path = e.composedPath()\n const wrapper = this.shadowRoot?.querySelector('.multi-select-wrapper')\n const searchWrap = this.shadowRoot?.querySelector('.search-wrap')\n if (wrapper && !path.includes(wrapper)) {\n this._sortDropdownOpen = false\n }\n if (searchWrap && !path.includes(searchWrap)) {\n this._searchOpen = false\n }\n this.requestUpdate()\n }\n\n willUpdate(changed: Map<string, unknown>) {\n if (changed.has('is-edit') && this['is-edit']) { this._syncProps() }\n if (!this['is-edit'] && (changed.has('title') || changed.has('answer-list') || changed.has('analysis') || changed.has('least-answer-count') || changed.has('answer-check-type') || changed.has('tag-list') || changed.has('category-id') || changed.has('rich-text-content'))) {\n this._syncExternalProps()\n }\n if (changed.has('is-key')) {\n this._isKey = this['is-key']\n }\n if (changed.has('tag-list')) {\n this._selectedTagList = Array.isArray(this['tag-list']) ? this['tag-list'].map(item => ({ ...item })) : []\n }\n if (changed.has('category-id')) {\n this._categoryId = this['category-id'] ? String(this['category-id']) : ''\n }\n if (changed.has('exam-expand') || changed.has('answer-list')) { this._syncExamExpand() }\n if (changed.has('model-value') && this['use-model']) {\n this._title = this['model-value']\n }\n }\n\n private _applyEditorState(state: SingleEditorState) {\n this._title = state.title\n this._analysis = state.analysis\n this._leastAnswerCount = state.leastAnswerCount\n this._answerCheckType = state.answerCheckType\n this._isKey = state.isKey\n this._selectedTagList = state.selectedTagList\n this._categoryId = state.categoryId\n this._richText = state.richText\n this._showRichText = state.showRichText\n if (state.answers) {\n this._answers = state.answers\n }\n if (state.orderList) {\n this._orderList = state.orderList\n }\n }\n\n private _buildEditorState(includeOrderList = false) {\n return buildSingleEditorState({\n answerType: this.type,\n title: this.title,\n analysis: this.analysis,\n leastAnswerCount: this['least-answer-count'],\n answerCheckType: this['answer-check-type'],\n isKey: this['is-key'],\n tagList: this['tag-list'],\n categoryId: this['category-id'],\n richTextContent: this['rich-text-content'],\n answerList: this['answer-list'],\n examExpand: this['exam-expand'],\n labelForIndex: (index) => this._label(index),\n includeOrderList,\n })\n }\n\n private _syncExternalProps() {\n this._applyEditorState(this._buildEditorState())\n }\n\n private _syncProps() {\n this._applyEditorState(this._buildEditorState(true))\n }\n\n private _syncExamExpand() {\n if (!this['exam-expand'] || !this['answer-list']?.length) { return }\n this._orderList = resolveSingleOrderList({\n examExpand: this['exam-expand'],\n answers: this['answer-list'] as SingleAnswer[],\n labelForIndex: (index) => this._label(index),\n })\n }\n\n private _emit(name: string, detail?: unknown) {\n emitSubjectEvent(this, name, detail)\n }\n\n private _queueSearch(query: string) {\n if (this._searchTimer) {\n window.clearTimeout(this._searchTimer)\n this._searchTimer = null\n }\n const keyword = query.trim()\n if (!keyword || !hasSingleSearchSource(this['search-api'], this['search-handler'])) {\n this._searchResults = []\n this._searchOpen = false\n this._searchLoading = false\n return\n }\n this._searchTimer = window.setTimeout(() => {\n void this._runSearch(keyword)\n }, 300)\n }\n\n private async _runSearch(query: string) {\n const currentToken = ++this._searchToken\n this._searchLoading = true\n this._searchOpen = true\n this.requestUpdate()\n try {\n const result = await searchSingleSubjects({\n answerType: this.type,\n query,\n searchApi: this['search-api'],\n searchHandler: this['search-handler'],\n })\n if (currentToken !== this._searchToken) { return }\n this._searchResults = result\n }\n catch (error: any) {\n if (currentToken !== this._searchToken) { return }\n this._searchResults = []\n showSubjectToast(error?.message || '题库搜索失败')\n }\n finally {\n if (currentToken === this._searchToken) {\n this._searchLoading = false\n this.requestUpdate()\n }\n }\n }\n\n private _selectSearchResult(item: SearchResult) {\n const { selectedTitle, detail } = buildSingleSearchSelection(item, this['custom-id'] || '')\n this._title = selectedTitle\n this._searchResults = []\n this._searchOpen = false\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n this._emit('title-select', detail)\n }\n\n private _applyAiAnswer() {\n if (!this['ai-answer']?.trim()) {\n showSubjectToast('暂无 AI 推荐答案')\n return\n }\n const result = applySingleAiAnswer({\n answers: this._answers,\n aiAnswer: this['ai-answer'],\n answerType: this.type,\n })\n if (!result.matchedCount) {\n showSubjectToast('未找到匹配的选项,请检查选项内容是否一致')\n return\n }\n this._answers = result.answers\n }\n\n private _onCategoryChange(value: string) {\n this._categoryId = value\n this._emit('category-change', {\n value,\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n })\n }\n\n private _setRelation(item: SingleAnswer, answerIndex: number) {\n const answer = item.customAnswerId\n ? { ...item }\n : { ...item, customAnswerId: item.answerId || uid() }\n this._answers = this._answers.map((current, index) => index === answerIndex ? answer : current)\n this.requestUpdate()\n this._emit('set-relation', {\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n answerIndex,\n answer,\n })\n }\n\n private _relationLength(relations: any[] = []) {\n return countSingleRelationAnswers(relations)\n }\n\n private _emitEditResultItem(item: SingleAnswer, answerIndex: number) {\n this._emit('edit-result-item', {\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n answerIndex,\n answer: { ...item },\n resultItem: item.resultItem || '',\n })\n }\n\n private _resultSlotName(index: number) {\n return `business-result-item-${index}`\n }\n\n private _imageResources() {\n return getSubjectImageResources(this['resource-list'] || [])\n }\n\n private _videoResource() {\n return getSubjectVideoResource(this['resource-list'] || [])\n }\n\n private _openImageViewer(index = 0) {\n if (!this._imageResources().length) { return }\n this._imageViewerIndex = index\n this._imageViewerOpen = true\n }\n\n private _closeImageViewer() {\n this._imageViewerOpen = false\n }\n\n private _moveImage(step: number) {\n const images = this._imageResources()\n if (!images.length) { return }\n this._imageViewerIndex = (this._imageViewerIndex + step + images.length) % images.length\n }\n\n private _openVideoViewer() {\n if (!this._videoResource()?.url) { return }\n this._videoViewerOpen = true\n }\n\n private _closeVideoViewer() {\n this._videoViewerOpen = false\n }\n\n private _label(i: number) { return String.fromCharCode(65 + i) }\n\n private get _titlePlaceholder() {\n return this.type === 'single' ? '单选题' : this.type === 'multiple' ? '多选题' : '排序题'\n }\n\n private _setCorrect(answerIndexOrAnswer: number | SingleAnswer, val: boolean) {\n if (this.lockAnswerKey) { return }\n const answerIndex = typeof answerIndexOrAnswer === 'number'\n ? answerIndexOrAnswer\n : this._answers.indexOf(answerIndexOrAnswer)\n if (answerIndex < 0) { return }\n this._answers = setSingleCorrectState(this._answers, this.type, answerIndex, val)\n }\n\n private _onTitleInput(e: Event) {\n const el = e.target as HTMLTextAreaElement\n if (el.value.length > this.TITLE_MAX) { el.value = el.value.slice(0, this.TITLE_MAX) }\n this._title = el.value\n this._queueSearch(this._title)\n // 双向绑定:通知外部更新\n if (this['use-model']) {\n emitSubjectModelValue(this, this._title)\n }\n }\n\n private _onAnswerInput(e: Event, idx: number) {\n const el = e.target as HTMLInputElement\n if (el.value.length > this.ANSWER_MAX) { el.value = el.value.slice(0, this.ANSWER_MAX) }\n this._answers = updateSingleAnswerTitle(this._answers, idx, el.value, this.ANSWER_MAX)\n }\n\n private _addAnswer(index: number) {\n this._answers = insertSingleAnswerAfter(this._answers, index, () => uid())\n }\n\n private _deleteAnswer(index: number) {\n this._answers = deleteSingleAnswerAt(this._answers, index)\n }\n\n private _toggleSortItem(letter: string) {\n this._orderList = toggleSingleSortLetter(this._orderList, letter)\n }\n\n private _removeSortItem(letter: string) {\n this._orderList = removeSingleSortLetter(this._orderList, letter)\n }\n\n private _getSortOrder(index: number): number | null {\n return getSingleSortOrder(this._orderList, this._label(index))\n }\n\n private _sortAnswerValue(letter: string) {\n return resolveSingleSortAnswerValue(letter, this._answers)\n }\n\n private _rowMeta() {\n return {\n customId: this['custom-id'] || undefined,\n answerType: this.type,\n orderIndex: this['order-index'],\n }\n }\n\n private _dialogState(): SingleDialogState {\n return {\n correctHintDialogOpen: this._correctHintDialogOpen,\n changeTypeDialogOpen: this._changeTypeDialogOpen,\n hasShownCorrectHint: this._hasShownCorrectHint,\n }\n }\n\n private _applyDialogState(state: SingleDialogState) {\n this._correctHintDialogOpen = state.correctHintDialogOpen\n this._changeTypeDialogOpen = state.changeTypeDialogOpen\n this._hasShownCorrectHint = state.hasShownCorrectHint\n }\n\n private _collectSnapshot(): SingleSnapshot {\n const orderList = this['is-edit']\n ? [...this._orderList]\n : resolveSingleOrderList({\n examExpand: this['exam-expand'],\n answers: this['answer-list'] as SingleAnswer[],\n labelForIndex: (index) => this._label(index),\n })\n\n return buildSingleSnapshot({\n answerType: this.type,\n title: this['is-edit'] ? this._title : (this as any).title || '',\n answers: this['is-edit'] ? this._answers : this['answer-list'] || [],\n analysis: this['is-edit'] ? this._analysis : this.analysis || '',\n leastAnswerCount: this['is-edit'] ? this._leastAnswerCount : this['least-answer-count'],\n selectedTagList: this._selectedTagList,\n examExpand: this['is-edit'] ? '' : (this['exam-expand'] || ''),\n showRichText: this['is-edit'] ? this._showRichText : !!this['rich-text-content'],\n richText: this['is-edit'] ? this._richText : this['rich-text-content'] || '',\n orderList,\n sortAnswerValue: this['is-edit'] ? (letter: string) => this._sortAnswerValue(letter) : undefined,\n })\n }\n\n private _serialize(answerType: AnswerType = this.type) {\n const snapshot = this._collectSnapshot()\n const { errors, isSetCorrectAnswer } = validateSingleSnapshot(snapshot, answerType, this._rowMeta())\n if (errors.length) {\n throw errors[0]\n }\n return serializeSingleSnapshot(snapshot, {\n answerType,\n isSetCorrectAnswer,\n examAnswerRelationType: this['exam-answer-relation-type'],\n customId: this['custom-id'],\n })\n }\n\n private _shouldShowCorrectHint() {\n return shouldShowSingleCorrectHint({\n answerType: this.type,\n answers: this._answers,\n orderList: this._orderList,\n })\n }\n\n private async _finalizeSave() {\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 async toJSON(): Promise<any> {\n return Promise.resolve(this._serialize())\n }\n\n validate(): SubjectError[] {\n return validateSingleSnapshot(this._collectSnapshot(), this.type, this._rowMeta()).errors\n }\n\n setResultItem(answerIndex: number, resultItem: string) {\n if (answerIndex < 0 || answerIndex >= this._answers.length) {\n return\n }\n this._answers = this._answers.map((answer, index) => index === answerIndex\n ? { ...answer, resultItem: resultItem || '' }\n : answer)\n this.requestUpdate()\n }\n\n setAnswerRelation(customAnswerId: string, answerRelations: any) {\n if (!customAnswerId) {\n return\n }\n this._answers = this._answers.map((answer) => {\n const currentId = String(answer.customAnswerId ?? answer.answerId ?? '')\n return currentId === String(customAnswerId)\n ? { ...answer, answerRelations }\n : answer\n })\n this.requestUpdate()\n }\n\n private _renderCorrectHintDialog() {\n if (!this._correctHintDialogOpen) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => { this._applyDialogState(dismissSingleCorrectHintDialog(this._dialogState())) }}>\n <div class=\"modal correct-hint-dialog\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">温馨提示</span>\n </div>\n <div class=\"modal-body\">\n <div class=\"correct-hint-copy\">\n 为了收集更全面、有价值的数据,建议您为问卷每题设定<span class=\"correct-hint-highlight\">推荐/正确选项</span>。这将助力深入分析,让调研结果更精准、有意义。\n </div>\n </div>\n <div class=\"modal-footer\">\n <button @click=${async () => {\n this._applyDialogState(acknowledgeSingleCorrectHint(this._dialogState()))\n await this._finalizeSave()\n }}>完成编辑</button>\n <button class=\"primary\" @click=${() => { this._applyDialogState(dismissSingleCorrectHintDialog(this._dialogState())) }}>去设置</button>\n </div>\n </div>\n </div>\n `\n }\n\n private _renderChangeTypeDialog() {\n if (!this._changeTypeDialogOpen) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => { this._applyDialogState(dismissSingleChangeTypeDialog(this._dialogState())) }}>\n <div class=\"modal\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">提示</span>\n <button class=\"modal-close\" @click=${() => { this._applyDialogState(dismissSingleChangeTypeDialog(this._dialogState())) }}>&#x2715;</button>\n </div>\n <div class=\"modal-body\">\n <div class=\"value-text\">此题为单选题,设置了多个推荐/正确选项,是否切换成多选题?</div>\n </div>\n <div class=\"modal-footer\">\n <button @click=${() => { this._applyDialogState(dismissSingleChangeTypeDialog(this._dialogState())) }}>取消</button>\n <button class=\"primary\" @click=${() => {\n try {\n const data = this._serialize('multiple')\n this._applyDialogState(dismissSingleChangeTypeDialog(this._dialogState()))\n this._emit('save', data)\n }\n catch (error: any) {\n showSubjectToast(error?.message || '保存失败')\n }\n }}>切换</button>\n </div>\n </div>\n </div>\n `\n }\n\n private _renderSearchDropdown() {\n if (!this['is-edit'] || (!this._searchOpen && !this._searchLoading)) { return '' }\n return html`\n <div class=\"search-dropdown\">\n ${this._searchLoading\n ? html`<div class=\"search-empty\">搜索中...</div>`\n : this._searchResults.length\n ? this._searchResults.map(item => html`\n <div class=\"search-item\" @click=${() => this._selectSearchResult(item)}>${item.value || item.title}</div>\n `)\n : html`<div class=\"search-empty\">暂无匹配题目</div>`}\n </div>\n `\n }\n\n private _renderCategorySection() {\n if (!this['show-category']) { return '' }\n return html`\n <div class=\"flex-items-start section-row\">\n <div class=\"label\"><span>分类:</span></div>\n <div style=\"flex:1\">\n ${this['is-edit']\n ? html`\n <select class=\"el-select\" .value=${String(this._categoryId)}\n @change=${(e: Event) => this._onCategoryChange((e.target as HTMLSelectElement).value)}>\n <option value=\"\">选择分类</option>\n ${this['category-list'].map(item => html`\n <option value=${String(item.categoryId)} ?selected=${String(item.categoryId) === String(this._categoryId)}>${item.title}</option>\n `)}\n </select>\n `\n : html`<span class=\"value-text\">${resolveSubjectCategoryLabel(this['category-list'], this._categoryId)}</span>`}\n </div>\n </div>\n `\n }\n\n private _renderAiSection() {\n if (!this['show-ai'] || !['single', 'multiple'].includes(this.type)) { return '' }\n return html`\n <div class=\"flex-items-start section-row\">\n <div class=\"label\"><span>AI推荐:</span></div>\n <div style=\"flex:1\">\n <span class=\"value-text\">${this['ai-answer'] || '暂无'}</span>\n ${this['is-edit']\n ? html`<div style=\"margin-top:8px\"><span class=\"el-link\" @click=${() => this._applyAiAnswer()}>一键勾选</span></div>`\n : ''}\n </div>\n </div>\n `\n }\n\n private _renderResourceSection() {\n if (!this['show-resource']) { return '' }\n const images = this._imageResources()\n const video = this._videoResource()\n return html`\n <div class=\"flex-items-start section-row\">\n <div class=\"label\"><span>资源:</span></div>\n <div style=\"flex:1\">\n <div class=\"resource-summary\">\n 图片 ${images.length} 张${video ? ',含视频资源' : ''}\n </div>\n <div class=\"resource-actions\">\n ${images.length ? html`<span class=\"el-link\" @click=${() => this._openImageViewer(0)}>查看图片</span>` : ''}\n ${video?.url ? html`<span class=\"el-link\" @click=${() => this._openVideoViewer()}>查看视频</span>` : ''}\n ${!images.length && !video?.url ? html`<span class=\"muted-text\">暂无资源</span>` : ''}\n </div>\n ${images.length\n ? html`\n <div class=\"resource-thumbs\">\n ${images.slice(0, 4).map((src, index) => html`\n <img class=\"resource-thumb\" src=${src} alt=\"resource\" @click=${() => this._openImageViewer(index)} />\n `)}\n </div>\n `\n : ''}\n </div>\n </div>\n `\n }\n\n private _renderImageViewer() {\n if (!this._imageViewerOpen) { return '' }\n const images = this._imageResources()\n const current = images[this._imageViewerIndex]\n if (!current) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => this._closeImageViewer()}>\n <div class=\"modal\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">图片预览</span>\n <button class=\"modal-close\" @click=${() => this._closeImageViewer()}>&#x2715;</button>\n </div>\n <div class=\"modal-body\">\n <div class=\"media-stage\"><img src=${current} alt=\"resource-preview\" /></div>\n </div>\n <div class=\"modal-footer\">\n <div class=\"media-footer\">\n <span class=\"muted-text\">${this._imageViewerIndex + 1} / ${images.length}</span>\n <div class=\"group\">\n ${images.length > 1 ? html`<button @click=${() => this._moveImage(-1)}>上一张</button>` : ''}\n ${images.length > 1 ? html`<button @click=${() => this._moveImage(1)}>下一张</button>` : ''}\n <button class=\"primary\" @click=${() => this._closeImageViewer()}>关闭</button>\n </div>\n </div>\n </div>\n </div>\n </div>\n `\n }\n\n private _renderVideoViewer() {\n const video = this._videoResource()\n if (!this._videoViewerOpen || !video?.url) { return '' }\n return html`\n <div class=\"modal-backdrop\" @click=${() => this._closeVideoViewer()}>\n <div class=\"modal\" @click=${(e: Event) => e.stopPropagation()}>\n <div class=\"modal-header\">\n <span class=\"modal-title\">视频预览</span>\n <button class=\"modal-close\" @click=${() => this._closeVideoViewer()}>&#x2715;</button>\n </div>\n <div class=\"modal-body\">\n <div class=\"media-stage\">\n <video src=${video.url} controls playsinline></video>\n </div>\n </div>\n <div class=\"modal-footer\">\n <button class=\"primary\" @click=${() => this._closeVideoViewer()}>关闭</button>\n </div>\n </div>\n </div>\n `\n }\n\n private async _save(e?: Event) {\n e?.stopImmediatePropagation()\n const decision = resolveSingleSaveDecision({\n errors: this.validate(),\n hasShownCorrectHint: this._hasShownCorrectHint,\n shouldShowCorrectHint: this._shouldShowCorrectHint(),\n })\n\n if (decision.kind === 'error') {\n showSubjectToast(decision.error.message)\n return\n }\n\n const nextDialogState = applySingleSaveDecisionToDialogs(this._dialogState(), decision)\n this._applyDialogState(nextDialogState)\n\n if (decision.kind !== 'save') {\n return\n }\n await this._finalizeSave()\n }\n\n private _renderPreview() {\n const typeSuffix = this.type === 'single'\n ? '(单选题)'\n : `(${this._titlePlaceholder}${leastAnswerCountSuffix(normalizeLeastAnswerCount(this['least-answer-count'], this.type), this.type)})`\n const answers = this['answer-list'] as SingleAnswer[]\n const previewTitle = buildSubjectPreviewTitle(this['subject-prefix'], this['order-index'], (this as any).title || '')\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\">${typeSuffix.replace(/[()]/g, '')}</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=\"preview-answer\">\n ${answers.map((a, i) => html`\n <div class=\"radio\">\n <input type=\"${this.type === 'sort' ? 'checkbox' : 'radio'}\" .checked=${!!a.isCorrect} disabled />\n <span class=\"order\">${this._label(i)}.</span>\n <div class=\"answer-main\">\n <span class=\"answer-text\">${a.title}</span>\n ${this.type !== 'sort' && a.isCorrect ? html`<span class=\"correct\">推荐 / 正确选项</span>` : ''}\n </div>\n ${this.type !== 'sort' && (\n this['exam-answer-relation-type'] === 1\n || this['exam-answer-relation-type'] === 2\n )\n ? html`\n <div class=\"answer-meta\">\n ${this['exam-answer-relation-type'] === 1\n ? html`<span class=\"result-info\">${a.resultItem ? '已设置结果项' : '未设置结果项'}</span>`\n : ''}\n ${this['exam-answer-relation-type'] === 2\n ? html`<span class=\"result-info\">${Array.isArray(a.answerRelations) && a.answerRelations.length ? `关联了${this._relationLength(a.answerRelations)}项` : '未设置关联'}</span>`\n : ''}\n </div>\n `\n : ''}\n </div>\n `)}\n </div>\n ${this['show-category'] && this._categoryId\n ? html`<div class=\"section-row\"><span class=\"value-text\">分类:${resolveSubjectCategoryLabel(this['category-list'], this._categoryId)}</span></div>`\n : ''}\n ${this['show-resource'] ? this._renderResourceSection() : ''}\n </div>\n `\n }\n\n private _renderSorting() {\n const title = trimText(this['is-edit'] ? this._title : (this as any).title || '') || '未命名题目'\n const orderText = buildSubjectSortingTitle(this['subject-prefix'], this['order-index'], title)\n return renderSortingCard(orderText, SubjectTypeLabel[this.type] || this.type)\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 search-wrap\">\n <textarea rows=\"2\" .value=${this._title}\n maxlength=${this.TITLE_MAX}\n @input=${(e: Event) => this._onTitleInput(e)}\n placeholder=\"【${this._titlePlaceholder}】请输入问题\"></textarea>\n <span class=\"char-counter\">${this._title.length}/${this.TITLE_MAX}</span>\n ${this._renderSearchDropdown()}\n </div>\n </div>\n </div>\n\n ${['multiple', 'sort'].includes(this.type)\n ? html`\n <div class=\"edit-row section-row\">\n <div class=\"label\"><span>设置:</span></div>\n <div class=\"row-body\">\n <select class=\"el-select\" .value=${this._leastAnswerCount === null ? '' : String(this._leastAnswerCount)} ?disabled=${this.lockAnswerKey}\n @change=${(e: Event) => {\n const value = (e.target as HTMLSelectElement).value\n this._leastAnswerCount = normalizeLeastAnswerCount(value, this.type)\n }}>\n <option value=\"\">至少选择几项</option>\n ${Array.from({ length: Math.max(0, this._answers.length - 1) }, (_, i) => i + 2).map(n => html`\n <option value=${n} ?selected=${this._leastAnswerCount === n}>至少选择${n}项</option>\n `)}\n </select>\n </div>\n </div>\n `\n : ''}\n\n <div class=\"edit-row section-row edit-row--compact\">\n <div class=\"label\"><span>${this.type === 'sort' ? '排序项:' : '选项:'}</span></div>\n <div class=\"row-body\">\n <div class=\"answer-list\">\n ${this._answers.map((a, i) => html`\n <div class=\"answer-item\">\n <span class=\"label\">${this._label(i)}.</span>\n <div class=\"input\">\n <input type=\"text\" .value=${a.title}\n maxlength=${this.ANSWER_MAX}\n @input=${(e: Event) => this._onAnswerInput(e, i)}\n placeholder=\"选项${this._label(i)}\" />\n <span class=\"char-counter\">${a.title.length}/${this.ANSWER_MAX}</span>\n </div>\n\n ${this.type === 'sort' && this._getSortOrder(i) !== null\n ? html`<span class=\"sort-badge\">第${this._getSortOrder(i)}位</span>`\n : ''}\n\n ${['single', 'multiple'].includes(this.type)\n ? html`\n <label class=\"correct ${a.isCorrect ? 'is-correct' : ''}\">\n <input type=\"checkbox\" .checked=${a.isCorrect} ?disabled=${this.lockAnswerKey}\n @change=${(e: Event) => this._setCorrect(i, (e.target as HTMLInputElement).checked)} />\n <span class=\"correct-text\">推荐/正确选项</span>\n </label>\n `\n : ''}\n\n <span class=\"icon\"\n @click=${() => this._addAnswer(i)}>\n ${iconPlus}\n </span>\n <span class=\"icon ${this._answers.length < 3 ? 'disabled' : ''}\"\n @click=${() => this._deleteAnswer(i)}>\n ${iconRemove}\n </span>\n\n ${this['exam-answer-relation-type'] === 1 && this.type !== 'sort'\n ? html`\n <slot name=${this._resultSlotName(i)}>\n <button class=\"el-link\" @click=${() => this._emitEditResultItem(a, i)}>\n ${a.resultItem ? '编辑结果' : '添加结果'}\n </button>\n </slot>\n `\n : ''}\n\n ${this['exam-answer-relation-type'] === 2 && this.type !== 'sort'\n ? html`\n <button class=\"el-link\" @click=${() => this._setRelation(a, i)}>\n ${Array.isArray(a.answerRelations) && a.answerRelations.length ? `关联了${this._relationLength(a.answerRelations)}项` : '关联检查'}\n </button>\n `\n : ''}\n\n </div>\n `)}\n </div>\n </div>\n </div>\n\n ${this.type === 'sort'\n ? html`\n <div class=\"edit-row section-row\">\n <div class=\"label\"><span>排序答案:</span></div>\n <div class=\"row-body\">\n <div class=\"multi-select-wrapper\">\n <div class=\"multi-select ${this._sortDropdownOpen ? 'focused' : ''} ${this.lockAnswerKey ? 'disabled' : ''}\"\n @click=${() => { if (!this.lockAnswerKey) { this._sortDropdownOpen = !this._sortDropdownOpen; this.requestUpdate() } }}>\n ${this._orderList.length > 0\n ? this._orderList.map(l => html`\n <span class=\"tag\">\n ${l}\n <span class=\"tag-close\" @click=${(e: Event) => {\n if (this.lockAnswerKey) { return }\n e.stopPropagation()\n this._removeSortItem(l)\n }}>&#x2715;</span>\n </span>\n `)\n : html`<span class=\"placeholder\">请按顺序选择排序答案</span>`\n }\n <span class=\"arrow\">${iconArrow}</span>\n </div>\n ${this._sortDropdownOpen\n ? html`\n <div class=\"multi-select-dropdown\">\n ${this._answers.map((_, i) => html`\n <div class=\"multi-select-option ${this._orderList.includes(this._label(i)) ? 'selected' : ''}\"\n @click=${() => {\n if (this.lockAnswerKey) { return }\n this._toggleSortItem(this._label(i))\n this.requestUpdate()\n }}>\n ${this._label(i)}\n </div>\n `)}\n </div>\n `\n : ''}\n </div>\n </div>\n </div>\n `\n : ''}\n\n <slot name=\"business-tag\"></slot>\n\n ${this._renderCategorySection()}\n\n ${this._renderAiSection()}\n\n ${this._renderResourceSection()}\n\n ${this['show-rich-text'] && this._showRichText\n ? html`\n <div class=\"edit-row section-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`<div class=\"flex-justify-end\" style=\"margin-top:8px\"><span class=\"el-link danger\" @click=${() => { this._showRichText = false; this._richText = '' }}>删除富文本</span></div>`\n : ''}\n </div>\n </div>\n `\n : ''}\n\n ${this['show-analysis']\n ? html`\n <div class=\"edit-row section-row\">\n <div class=\"label\"><span>解析:</span></div>\n <div class=\"row-body\">\n <textarea rows=\"2\" .value=${this._analysis}\n @input=${(e: Event) => { this._analysis = (e.target as HTMLTextAreaElement).value }}\n placeholder=\"请输入题目解析\"></textarea>\n </div>\n </div>\n `\n : ''}\n </div>\n `\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-jump=${this['show-jump']}\n @delete=${() => this._emit('delete')}\n @save=${this._save}\n @edit=${() => this._emit('edit')}\n @move=${(e: CustomEvent) => this._emit('move', e.detail)}\n @jump=${() => this._emit('jump', {\n customId: this['custom-id'] || '',\n examId: this['exam-id'] || 0,\n answerType: this.type,\n })}\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 ${this._renderCorrectHintDialog()}\n ${this._renderChangeTypeDialog()}\n ${this._renderImageViewer()}\n ${this._renderVideoViewer()}\n `\n }\n}\n\nexport function register() {}\n"],"names":["iconPlus","html","iconRemove","iconArrow","QxsSubjectSingle","LitElement","file","resolve","reject","reader","e","path","wrapper","searchWrap","v","normalizeSingleAnswerList","changed","item","state","includeOrderList","buildSingleEditorState","index","resolveSingleOrderList","name","detail","emitSubjectEvent","query","keyword","hasSingleSearchSource","currentToken","result","searchSingleSubjects","error","showSubjectToast","selectedTitle","buildSingleSearchSelection","emitSubjectModelValue","applySingleAiAnswer","value","answerIndex","answer","uid","current","relations","countSingleRelationAnswers","getSubjectImageResources","getSubjectVideoResource","step","images","i","answerIndexOrAnswer","val","setSingleCorrectState","el","idx","updateSingleAnswerTitle","insertSingleAnswerAfter","deleteSingleAnswerAt","letter","toggleSingleSortLetter","removeSingleSortLetter","getSingleSortOrder","resolveSingleSortAnswerValue","orderList","buildSingleSnapshot","answerType","snapshot","errors","isSetCorrectAnswer","validateSingleSnapshot","serializeSingleSnapshot","shouldShowSingleCorrectHint","data","err","resultItem","customAnswerId","answerRelations","dismissSingleCorrectHintDialog","acknowledgeSingleCorrectHint","dismissSingleChangeTypeDialog","resolveSubjectCategoryLabel","video","src","decision","resolveSingleSaveDecision","nextDialogState","applySingleSaveDecisionToDialogs","typeSuffix","leastAnswerCountSuffix","normalizeLeastAnswerCount","answers","previewTitle","buildSubjectPreviewTitle","title","trimText","orderText","buildSubjectSortingTitle","renderSortingCard","SubjectTypeLabel","_","n","a","l","SUB_TEXT_EDITOR_TOOLBAR","content","sortingCardStyles","subjectHostStyles","subjectControlResetStyles","subjectPreviewBaseStyles","subjectFormBaseStyles","subjectTextareaStyles","css","__decorateClass","property","safeCustomElement"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";exports.moveSubjectItem=function(t,e,r){if(e===r||e<0||r<0||e>=t.length||r>=t.length)return t.map(t=>({...t}));const n=t.map(t=>({...t})),[s]=n.splice(e,1);return n.splice(r,0,s),n},exports.reorderSubjects=function(t,e){if(!e.length)return t.map(t=>({...t}));const r=new Map,n=[];return t.forEach(t=>{t.customId&&r.set(String(t.customId),{...t})}),e.forEach(t=>{const e=r.get(String(t));e&&(n.push(e),r.delete(String(t)))}),t.forEach(t=>{t.customId&&!r.has(String(t.customId))||(n.push(r.get(String(t.customId))||{...t}),r.delete(String(t.customId)))}),n};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function o(c,r,e){if(r===e||r<0||e<0||r>=c.length||e>=c.length)return c.map(u=>({...u}));const n=c.map(u=>({...u})),[t]=n.splice(r,1);return n.splice(e,0,t),n}function s(c,r){if(!r.length)return c.map(t=>({...t}));const e=new Map,n=[];return c.forEach(t=>{t.customId&&e.set(String(t.customId),{...t})}),r.forEach(t=>{const u=e.get(String(t));u&&(n.push(u),e.delete(String(t)))}),c.forEach(t=>{(!t.customId||e.has(String(t.customId)))&&(n.push(e.get(String(t.customId))||{...t}),e.delete(String(t.customId)))}),n}exports.moveSubjectItem=o;exports.reorderSubjects=s;
2
2
  //# sourceMappingURL=sort-controller.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"sort-controller.cjs","sources":["../../../../packages/components/src/subject/sort-controller.ts"],"sourcesContent":["import type { SubjectLikeItem } from './pagination'\n\nexport function moveSubjectItem(items: SubjectLikeItem[], fromIndex: number, toIndex: number): SubjectLikeItem[] {\n if (fromIndex === toIndex || fromIndex < 0 || toIndex < 0 || fromIndex >= items.length || toIndex >= items.length) {\n return items.map(item => ({ ...item }))\n }\n\n const next = items.map(item => ({ ...item }))\n const [moved] = next.splice(fromIndex, 1)\n next.splice(toIndex, 0, moved)\n return next\n}\n\nexport function reorderSubjects(items: SubjectLikeItem[], orderedIds: string[]): SubjectLikeItem[] {\n if (!orderedIds.length) {\n return items.map(item => ({ ...item }))\n }\n\n const itemMap = new Map<string, SubjectLikeItem>()\n const next: SubjectLikeItem[] = []\n\n items.forEach((item) => {\n if (item.customId) {\n itemMap.set(String(item.customId), { ...item })\n }\n })\n\n orderedIds.forEach((id) => {\n const item = itemMap.get(String(id))\n if (!item) {\n return\n }\n next.push(item)\n itemMap.delete(String(id))\n })\n\n items.forEach((item) => {\n if (!item.customId || itemMap.has(String(item.customId))) {\n next.push(itemMap.get(String(item.customId)) || { ...item })\n itemMap.delete(String(item.customId))\n }\n })\n\n return next\n}\n"],"names":["items","fromIndex","toIndex","length","map","item","next","moved","splice","orderedIds","itemMap","Map","forEach","customId","set","String","id","get","push","delete","has"],"mappings":"qCAEO,SAAyBA,EAA0BC,EAAmBC,GAC3E,GAAID,IAAcC,GAAWD,EAAY,GAAKC,EAAU,GAAKD,GAAaD,EAAMG,QAAUD,GAAWF,EAAMG,OACzG,OAAOH,EAAMI,IAAIC,IAAA,IAAcA,KAGjC,MAAMC,EAAON,EAAMI,YAAkBC,MAC9BE,GAASD,EAAKE,OAAOP,EAAW,GAEvC,OADAK,EAAKE,OAAON,EAAS,EAAGK,GACjBD,CACT,0BAEO,SAAyBN,EAA0BS,GACxD,IAAKA,EAAWN,OACd,OAAOH,EAAMI,IAAIC,IAAA,IAAcA,KAGjC,MAAMK,MAAcC,IACdL,EAA0B,GAwBhC,OAtBAN,EAAMY,QAASP,IACTA,EAAKQ,UACPH,EAAQI,IAAIC,OAAOV,EAAKQ,UAAW,IAAKR,MAI5CI,EAAWG,QAASI,IAClB,MAAMX,EAAOK,EAAQO,IAAIF,OAAOC,IAC3BX,IAGLC,EAAKY,KAAKb,GACVK,EAAQS,OAAOJ,OAAOC,OAGxBhB,EAAMY,QAASP,IACRA,EAAKQ,WAAYH,EAAQU,IAAIL,OAAOV,EAAKQ,aAC5CP,EAAKY,KAAKR,EAAQO,IAAIF,OAAOV,EAAKQ,YAAc,IAAKR,IACrDK,EAAQS,OAAOJ,OAAOV,EAAKQ,cAIxBP,CACT"}
1
+ {"version":3,"file":"sort-controller.cjs","sources":["../../../../packages/components/src/subject/sort-controller.ts"],"sourcesContent":["import type { SubjectLikeItem } from './pagination'\n\nexport function moveSubjectItem(items: SubjectLikeItem[], fromIndex: number, toIndex: number): SubjectLikeItem[] {\n if (fromIndex === toIndex || fromIndex < 0 || toIndex < 0 || fromIndex >= items.length || toIndex >= items.length) {\n return items.map(item => ({ ...item }))\n }\n\n const next = items.map(item => ({ ...item }))\n const [moved] = next.splice(fromIndex, 1)\n next.splice(toIndex, 0, moved)\n return next\n}\n\nexport function reorderSubjects(items: SubjectLikeItem[], orderedIds: string[]): SubjectLikeItem[] {\n if (!orderedIds.length) {\n return items.map(item => ({ ...item }))\n }\n\n const itemMap = new Map<string, SubjectLikeItem>()\n const next: SubjectLikeItem[] = []\n\n items.forEach((item) => {\n if (item.customId) {\n itemMap.set(String(item.customId), { ...item })\n }\n })\n\n orderedIds.forEach((id) => {\n const item = itemMap.get(String(id))\n if (!item) {\n return\n }\n next.push(item)\n itemMap.delete(String(id))\n })\n\n items.forEach((item) => {\n if (!item.customId || itemMap.has(String(item.customId))) {\n next.push(itemMap.get(String(item.customId)) || { ...item })\n itemMap.delete(String(item.customId))\n }\n })\n\n return next\n}\n"],"names":["moveSubjectItem","items","fromIndex","toIndex","item","next","moved","reorderSubjects","orderedIds","itemMap","id"],"mappings":"gFAEO,SAASA,EAAgBC,EAA0BC,EAAmBC,EAAoC,CAC/G,GAAID,IAAcC,GAAWD,EAAY,GAAKC,EAAU,GAAKD,GAAaD,EAAM,QAAUE,GAAWF,EAAM,OACzG,OAAOA,EAAM,IAAIG,IAAS,CAAE,GAAGA,GAAO,EAGxC,MAAMC,EAAOJ,EAAM,QAAa,CAAE,GAAGG,GAAO,EACtC,CAACE,CAAK,EAAID,EAAK,OAAOH,EAAW,CAAC,EACxC,OAAAG,EAAK,OAAOF,EAAS,EAAGG,CAAK,EACtBD,CACT,CAEO,SAASE,EAAgBN,EAA0BO,EAAyC,CACjG,GAAI,CAACA,EAAW,OACd,OAAOP,EAAM,IAAIG,IAAS,CAAE,GAAGA,GAAO,EAGxC,MAAMK,MAAc,IACdJ,EAA0B,CAAA,EAEhC,OAAAJ,EAAM,QAASG,GAAS,CAClBA,EAAK,UACPK,EAAQ,IAAI,OAAOL,EAAK,QAAQ,EAAG,CAAE,GAAGA,EAAM,CAElD,CAAC,EAEDI,EAAW,QAASE,GAAO,CACzB,MAAMN,EAAOK,EAAQ,IAAI,OAAOC,CAAE,CAAC,EAC9BN,IAGLC,EAAK,KAAKD,CAAI,EACdK,EAAQ,OAAO,OAAOC,CAAE,CAAC,EAC3B,CAAC,EAEDT,EAAM,QAASG,GAAS,EAClB,CAACA,EAAK,UAAYK,EAAQ,IAAI,OAAOL,EAAK,QAAQ,CAAC,KACrDC,EAAK,KAAKI,EAAQ,IAAI,OAAOL,EAAK,QAAQ,CAAC,GAAK,CAAE,GAAGA,EAAM,EAC3DK,EAAQ,OAAO,OAAOL,EAAK,QAAQ,CAAC,EAExC,CAAC,EAEMC,CACT"}
@@ -1,30 +1,30 @@
1
- "use strict";var e=require("lit"),t=require("lit/decorators.js"),s=require("sortablejs"),r=require("../base/define.cjs"),o=require("./sort-controller.cjs"),i=require("./types.cjs"),l=Object.defineProperty,a=Object.getOwnPropertyDescriptor,n=(e,t,s,r)=>{for(var o,i=r>1?void 0:r?a(t,s):t,n=e.length-1;n>=0;n--)(o=e[n])&&(i=(r?o(t,s,i):o(i))||i);return r&&i&&l(t,s,i),i};exports.QxsSubjectSortable=class extends e.LitElement{constructor(){super(...arguments),this.items=[],this._items=[],this._sortable=null}willUpdate(e){e.has("items")&&(this._items=Array.isArray(this.items)?this.items.map(e=>({...e})):[])}firstUpdated(){this._initSortable()}updated(e){e.has("_items")&&(this._sortable?.destroy(),this._sortable=null,this.updateComplete.then(()=>this._initSortable()))}disconnectedCallback(){super.disconnectedCallback(),this._sortable?.destroy(),this._sortable=null}reorderByIds(e){this._items=o.reorderSubjects(this._items,e),this._emitSortChange()}_initSortable(){const e=this.renderRoot.querySelector(".sort-list");e&&(this._sortable=s.create(e,{handle:".handle",animation:180,ghostClass:"sort-ghost",chosenClass:"sort-chosen",onEnd:e=>{const{oldIndex:t,newIndex:s}=e;null!=t&&null!=s&&t!==s&&(this._items=o.moveSubjectItem(this._items,t,s),this._emitSortChange(t,s))}}))}_emitSortChange(e,t){this.dispatchEvent(new CustomEvent("sort-change",{bubbles:!0,composed:!0,detail:{items:this._items.map(e=>({...e})),newIndex:t,oldIndex:e,orderedIds:this._items.map(e=>String(e.customId||"")).filter(Boolean)}}))}_label(e,t){return"function"==typeof this["label-renderer"]?this["label-renderer"](e,t):e.title||`未命名${i.SubjectTypeLabel[e.answerType]||"题目"}`}render(){return e.html`
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("lit"),c=require("lit/decorators.js"),p=require("sortablejs"),u=require("../base/define.cjs"),b=require("./sort-controller.cjs"),h=require("./shared-styles.cjs"),d=require("./types.cjs");var m=Object.defineProperty,f=Object.getOwnPropertyDescriptor,i=(a,e,t,s)=>{for(var r=s>1?void 0:s?f(e,t):e,l=a.length-1,n;l>=0;l--)(n=a[l])&&(r=(s?n(e,t,r):n(r))||r);return s&&r&&m(e,t,r),r};exports.QxsSubjectSortable=class extends o.LitElement{constructor(){super(...arguments),this.items=[],this._items=[],this._sortable=null}willUpdate(e){e.has("items")&&(this._items=Array.isArray(this.items)?this.items.map(t=>({...t})):[])}firstUpdated(){this._initSortable()}updated(e){e.has("_items")&&(this._sortable?.destroy(),this._sortable=null,this.updateComplete.then(()=>this._initSortable()))}disconnectedCallback(){super.disconnectedCallback(),this._sortable?.destroy(),this._sortable=null}reorderByIds(e){this._items=b.reorderSubjects(this._items,e),this._emitSortChange()}_initSortable(){const e=this.renderRoot.querySelector(".sort-list");e&&(this._sortable=p.create(e,{handle:".handle",animation:180,ghostClass:"sort-ghost",chosenClass:"sort-chosen",onEnd:t=>{const{oldIndex:s,newIndex:r}=t;s==null||r==null||s===r||(this._items=b.moveSubjectItem(this._items,s,r),this._emitSortChange(s,r))}}))}_emitSortChange(e,t){this.dispatchEvent(new CustomEvent("sort-change",{bubbles:!0,composed:!0,detail:{items:this._items.map(s=>({...s})),newIndex:t,oldIndex:e,orderedIds:this._items.map(s=>String(s.customId||"")).filter(Boolean)}}))}_label(e,t){return typeof this["label-renderer"]=="function"?this["label-renderer"](e,t):e.title||`未命名${d.SubjectTypeLabel[e.answerType]||"题目"}`}render(){return o.html`
2
2
  <div class="sort-list">
3
- ${this._items.map((t,s)=>e.html`
4
- <div class="sort-item" data-id=${t.customId||""}>
3
+ ${this._items.map((e,t)=>o.html`
4
+ <div class="sort-item" data-id=${e.customId||""}>
5
5
  <span class="handle">⋮⋮</span>
6
6
  <div class="content">
7
- <div class="title">${this._label(t,s)}</div>
8
- <div class="meta">${i.SubjectTypeLabel[t.answerType]||t.answerType}</div>
7
+ <div class="title">${this._label(e,t)}</div>
8
+ <div class="meta">${d.SubjectTypeLabel[e.answerType]||e.answerType}</div>
9
9
  </div>
10
10
  </div>
11
11
  `)}
12
12
  </div>
13
- `}},exports.QxsSubjectSortable.styles=e.css`
14
- :host { display: block; font-family: inherit; font-size: 13px; }
13
+ `}};exports.QxsSubjectSortable.styles=[h.subjectHostStyles,o.css`
14
+ :host { font-size: 13px; }
15
15
  *, ::before, ::after { box-sizing: border-box; }
16
16
  .sort-list { display: flex; flex-direction: column; gap: 10px; }
17
17
  .sort-item {
18
18
  display: flex; align-items: center; gap: 12px;
19
- padding: 12px 14px; background: #fff; border: 1px solid #e4e7ed; border-radius: 10px;
19
+ padding: 12px 14px; background: var(--qxs-subject-fill-blank, #fff); border: 1px solid var(--qxs-subject-border-light, #e4e7ed); border-radius: 10px;
20
20
  cursor: grab; transition: all .2s;
21
21
  }
22
- .sort-item:hover { border-color: #bfd1ff; background: #f8fbff; }
23
- .sort-item.sort-ghost { opacity: .5; background: #ecf5ff; }
24
- .sort-item.sort-chosen { border-color: #3D61E3; box-shadow: 0 8px 20px rgba(61,97,227,.12); }
25
- .handle { color: #909399; font-size: 16px; user-select: none; }
22
+ .sort-item:hover { border-color: var(--qxs-subject-fill-soft-primary-border-strong, #bfd1ff); background: var(--qxs-subject-fill-soft-primary-hover, #f8fbff); }
23
+ .sort-item.sort-ghost { opacity: .5; background: var(--qxs-subject-fill-soft-primary, #ecf5ff); }
24
+ .sort-item.sort-chosen { border-color: var(--qxs-subject-color-primary, #3D61E3); box-shadow: var(--qxs-subject-shadow-primary, 0 8px 20px rgba(61,97,227,.12)); }
25
+ .handle { color: var(--qxs-subject-text-secondary, #909399); font-size: 16px; user-select: none; }
26
26
  .content { flex: 1; min-width: 0; }
27
- .title { font-size: 13px; color: #303133; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
28
- .meta { margin-top: 4px; font-size: 12px; color: #909399; }
29
- `,n([t.property({type:Array})],exports.QxsSubjectSortable.prototype,"items",2),n([t.property({type:Object,attribute:"label-renderer"})],exports.QxsSubjectSortable.prototype,"label-renderer",2),n([t.state()],exports.QxsSubjectSortable.prototype,"_items",2),exports.QxsSubjectSortable=n([r.safeCustomElement("qxs-subject-sortable")],exports.QxsSubjectSortable);
27
+ .title { font-size: 13px; color: var(--qxs-subject-text-primary, #303133); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
28
+ .meta { margin-top: 4px; font-size: 12px; color: var(--qxs-subject-text-secondary, #909399); }
29
+ `];i([c.property({type:Array})],exports.QxsSubjectSortable.prototype,"items",2);i([c.property({type:Object,attribute:"label-renderer"})],exports.QxsSubjectSortable.prototype,"label-renderer",2);i([c.state()],exports.QxsSubjectSortable.prototype,"_items",2);exports.QxsSubjectSortable=i([u.safeCustomElement("qxs-subject-sortable")],exports.QxsSubjectSortable);
30
30
  //# sourceMappingURL=sortable.cjs.map