@robot-admin/naive-ui-components 0.3.0

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 (352) hide show
  1. package/README.md +257 -0
  2. package/dist/C_ActionBar-DWN-woTc.css.map +1 -0
  3. package/dist/C_ActionBar.cjs +5 -0
  4. package/dist/C_ActionBar.d.cts +2 -0
  5. package/dist/C_ActionBar.d.ts +2 -0
  6. package/dist/C_ActionBar.js +4 -0
  7. package/dist/C_ActionBar2.js +196 -0
  8. package/dist/C_ActionBar2.js.map +1 -0
  9. package/dist/C_AntV-AFKyK6hH.css.map +1 -0
  10. package/dist/C_AntV.cjs +8 -0
  11. package/dist/C_AntV.d.cts +2 -0
  12. package/dist/C_AntV.d.ts +2 -0
  13. package/dist/C_AntV.js +4 -0
  14. package/dist/C_AntV2.js +3150 -0
  15. package/dist/C_AntV2.js.map +1 -0
  16. package/dist/C_Barcode-P_EFj8dC.css.map +1 -0
  17. package/dist/C_Barcode.cjs +4 -0
  18. package/dist/C_Barcode.d.cts +2 -0
  19. package/dist/C_Barcode.d.ts +2 -0
  20. package/dist/C_Barcode.js +3 -0
  21. package/dist/C_Barcode2.js +68 -0
  22. package/dist/C_Barcode2.js.map +1 -0
  23. package/dist/C_Captcha-C-ef41xw.css.map +1 -0
  24. package/dist/C_Captcha.cjs +4 -0
  25. package/dist/C_Captcha.d.cts +2 -0
  26. package/dist/C_Captcha.d.ts +2 -0
  27. package/dist/C_Captcha.js +3 -0
  28. package/dist/C_Captcha2.js +155 -0
  29. package/dist/C_Captcha2.js.map +1 -0
  30. package/dist/C_Cascade-D9kNsjsV.css.map +1 -0
  31. package/dist/C_Cascade.cjs +4 -0
  32. package/dist/C_Cascade.d.cts +2 -0
  33. package/dist/C_Cascade.d.ts +2 -0
  34. package/dist/C_Cascade.js +3 -0
  35. package/dist/C_Cascade2.js +103 -0
  36. package/dist/C_Cascade2.js.map +1 -0
  37. package/dist/C_City-BCQ4ipiK.css.map +1 -0
  38. package/dist/C_City.cjs +4 -0
  39. package/dist/C_City.d.cts +2 -0
  40. package/dist/C_City.d.ts +2 -0
  41. package/dist/C_City.js +3 -0
  42. package/dist/C_City2.js +841 -0
  43. package/dist/C_City2.js.map +1 -0
  44. package/dist/C_Code-C9kvvEmO.css.map +1 -0
  45. package/dist/C_Code.cjs +5 -0
  46. package/dist/C_Code.d.cts +2 -0
  47. package/dist/C_Code.d.ts +2 -0
  48. package/dist/C_Code.js +4 -0
  49. package/dist/C_Code2.js +346 -0
  50. package/dist/C_Code2.js.map +1 -0
  51. package/dist/C_CollapsePanel-BUJHuYcU.css.map +1 -0
  52. package/dist/C_CollapsePanel.cjs +6 -0
  53. package/dist/C_CollapsePanel.d.cts +2 -0
  54. package/dist/C_CollapsePanel.d.ts +2 -0
  55. package/dist/C_CollapsePanel.js +4 -0
  56. package/dist/C_CollapsePanel2.js +319 -0
  57. package/dist/C_CollapsePanel2.js.map +1 -0
  58. package/dist/C_Cron-yx2Ob4Jl.css.map +1 -0
  59. package/dist/C_Cron.cjs +15 -0
  60. package/dist/C_Cron.d.cts +2 -0
  61. package/dist/C_Cron.d.ts +2 -0
  62. package/dist/C_Cron.js +4 -0
  63. package/dist/C_Cron2.js +1209 -0
  64. package/dist/C_Cron2.js.map +1 -0
  65. package/dist/C_Date.cjs +4 -0
  66. package/dist/C_Date.d.cts +2 -0
  67. package/dist/C_Date.d.ts +2 -0
  68. package/dist/C_Date.js +3 -0
  69. package/dist/C_Date2.js +219 -0
  70. package/dist/C_Date2.js.map +1 -0
  71. package/dist/C_Draggable-C483syRC.css.map +1 -0
  72. package/dist/C_Draggable.cjs +5 -0
  73. package/dist/C_Draggable.d.cts +2 -0
  74. package/dist/C_Draggable.d.ts +2 -0
  75. package/dist/C_Draggable.js +3 -0
  76. package/dist/C_Draggable2.js +295 -0
  77. package/dist/C_Draggable2.js.map +1 -0
  78. package/dist/C_Editor-Bp0SyIEw.css.map +1 -0
  79. package/dist/C_Editor.cjs +4 -0
  80. package/dist/C_Editor.d.cts +2 -0
  81. package/dist/C_Editor.d.ts +2 -0
  82. package/dist/C_Editor.js +3 -0
  83. package/dist/C_Editor2.js +160 -0
  84. package/dist/C_Editor2.js.map +1 -0
  85. package/dist/C_FilePreview-CPqvhoCy.css.map +1 -0
  86. package/dist/C_FilePreview.cjs +6 -0
  87. package/dist/C_FilePreview.d.cts +2 -0
  88. package/dist/C_FilePreview.d.ts +2 -0
  89. package/dist/C_FilePreview.js +3 -0
  90. package/dist/C_FilePreview2.js +1031 -0
  91. package/dist/C_FilePreview2.js.map +1 -0
  92. package/dist/C_Form-Jx7PY3sT.css.map +1 -0
  93. package/dist/C_Form.cjs +15 -0
  94. package/dist/C_Form.d.cts +2 -0
  95. package/dist/C_Form.d.ts +2 -0
  96. package/dist/C_Form.js +4 -0
  97. package/dist/C_Form2.js +2510 -0
  98. package/dist/C_Form2.js.map +1 -0
  99. package/dist/C_FormSearch-DvRgxlRn.css.map +1 -0
  100. package/dist/C_FormSearch.cjs +6 -0
  101. package/dist/C_FormSearch.d.cts +2 -0
  102. package/dist/C_FormSearch.d.ts +2 -0
  103. package/dist/C_FormSearch.js +3 -0
  104. package/dist/C_FormSearch2.js +356 -0
  105. package/dist/C_FormSearch2.js.map +1 -0
  106. package/dist/C_FormulaEditor-DtGkt4T_.css.map +1 -0
  107. package/dist/C_FormulaEditor.cjs +13 -0
  108. package/dist/C_FormulaEditor.d.cts +2 -0
  109. package/dist/C_FormulaEditor.d.ts +2 -0
  110. package/dist/C_FormulaEditor.js +4 -0
  111. package/dist/C_FormulaEditor2.js +1433 -0
  112. package/dist/C_FormulaEditor2.js.map +1 -0
  113. package/dist/C_FullCalendar-BF7H0YIx.css.map +1 -0
  114. package/dist/C_FullCalendar.cjs +9 -0
  115. package/dist/C_FullCalendar.d.cts +2 -0
  116. package/dist/C_FullCalendar.d.ts +2 -0
  117. package/dist/C_FullCalendar.js +3 -0
  118. package/dist/C_FullCalendar2.js +377 -0
  119. package/dist/C_FullCalendar2.js.map +1 -0
  120. package/dist/C_Guide.cjs +4 -0
  121. package/dist/C_Guide.d.cts +2 -0
  122. package/dist/C_Guide.d.ts +2 -0
  123. package/dist/C_Guide.js +3 -0
  124. package/dist/C_Guide2.js +58 -0
  125. package/dist/C_Guide2.js.map +1 -0
  126. package/dist/C_Icon.cjs +4 -0
  127. package/dist/C_Icon.d.cts +2 -0
  128. package/dist/C_Icon.d.ts +2 -0
  129. package/dist/C_Icon.js +3 -0
  130. package/dist/C_Icon2.js +286 -0
  131. package/dist/C_Icon2.js.map +1 -0
  132. package/dist/C_ImageCropper-BVJfUufl.css.map +1 -0
  133. package/dist/C_ImageCropper.cjs +6 -0
  134. package/dist/C_ImageCropper.d.cts +2 -0
  135. package/dist/C_ImageCropper.d.ts +2 -0
  136. package/dist/C_ImageCropper.js +4 -0
  137. package/dist/C_ImageCropper2.js +723 -0
  138. package/dist/C_ImageCropper2.js.map +1 -0
  139. package/dist/C_Language.cjs +4 -0
  140. package/dist/C_Language.d.cts +2 -0
  141. package/dist/C_Language.d.ts +2 -0
  142. package/dist/C_Language.js +3 -0
  143. package/dist/C_Language2.js +72 -0
  144. package/dist/C_Language2.js.map +1 -0
  145. package/dist/C_Map-DpzeuWdX.css.map +1 -0
  146. package/dist/C_Map.cjs +7 -0
  147. package/dist/C_Map.d.cts +2 -0
  148. package/dist/C_Map.d.ts +2 -0
  149. package/dist/C_Map.js +3 -0
  150. package/dist/C_Map2.js +199 -0
  151. package/dist/C_Map2.js.map +1 -0
  152. package/dist/C_Markdown-BEjxknqd.css.map +1 -0
  153. package/dist/C_Markdown.cjs +4 -0
  154. package/dist/C_Markdown.d.cts +2 -0
  155. package/dist/C_Markdown.d.ts +2 -0
  156. package/dist/C_Markdown.js +3 -0
  157. package/dist/C_Markdown2.js +186 -0
  158. package/dist/C_Markdown2.js.map +1 -0
  159. package/dist/C_NotificationCenter-0l3TY2Gn.css.map +1 -0
  160. package/dist/C_NotificationCenter.cjs +20 -0
  161. package/dist/C_NotificationCenter.d.cts +2 -0
  162. package/dist/C_NotificationCenter.d.ts +2 -0
  163. package/dist/C_NotificationCenter.js +4 -0
  164. package/dist/C_NotificationCenter2.js +1383 -0
  165. package/dist/C_NotificationCenter2.js.map +1 -0
  166. package/dist/C_Progress.cjs +4 -0
  167. package/dist/C_Progress.d.cts +2 -0
  168. package/dist/C_Progress.d.ts +2 -0
  169. package/dist/C_Progress.js +3 -0
  170. package/dist/C_Progress2.js +103 -0
  171. package/dist/C_Progress2.js.map +1 -0
  172. package/dist/C_QRCode-DbdiAIPg.css.map +1 -0
  173. package/dist/C_QRCode.cjs +5 -0
  174. package/dist/C_QRCode.d.cts +2 -0
  175. package/dist/C_QRCode.d.ts +2 -0
  176. package/dist/C_QRCode.js +3 -0
  177. package/dist/C_QRCode2.js +218 -0
  178. package/dist/C_QRCode2.js.map +1 -0
  179. package/dist/C_Signature-zhHCbra9.css.map +1 -0
  180. package/dist/C_Signature.cjs +8 -0
  181. package/dist/C_Signature.d.cts +2 -0
  182. package/dist/C_Signature.d.ts +2 -0
  183. package/dist/C_Signature.js +4 -0
  184. package/dist/C_Signature2.js +618 -0
  185. package/dist/C_Signature2.js.map +1 -0
  186. package/dist/C_SplitPane-C6sBsfKY.css.map +1 -0
  187. package/dist/C_SplitPane.cjs +6 -0
  188. package/dist/C_SplitPane.d.cts +2 -0
  189. package/dist/C_SplitPane.d.ts +2 -0
  190. package/dist/C_SplitPane.js +4 -0
  191. package/dist/C_SplitPane2.js +356 -0
  192. package/dist/C_SplitPane2.js.map +1 -0
  193. package/dist/C_Steps-CODHN5Hs.css.map +1 -0
  194. package/dist/C_Steps.cjs +4 -0
  195. package/dist/C_Steps.d.cts +2 -0
  196. package/dist/C_Steps.d.ts +2 -0
  197. package/dist/C_Steps.js +3 -0
  198. package/dist/C_Steps2.js +82 -0
  199. package/dist/C_Steps2.js.map +1 -0
  200. package/dist/C_Table-DSNsntmT.css.map +1 -0
  201. package/dist/C_Table.cjs +19 -0
  202. package/dist/C_Table.d.cts +2 -0
  203. package/dist/C_Table.d.ts +2 -0
  204. package/dist/C_Table.js +5 -0
  205. package/dist/C_Table2.js +3009 -0
  206. package/dist/C_Table2.js.map +1 -0
  207. package/dist/C_Theme.cjs +4 -0
  208. package/dist/C_Theme.d.cts +2 -0
  209. package/dist/C_Theme.d.ts +2 -0
  210. package/dist/C_Theme.js +3 -0
  211. package/dist/C_Theme2.js +60 -0
  212. package/dist/C_Theme2.js.map +1 -0
  213. package/dist/C_Time-BvZLYraL.css.map +1 -0
  214. package/dist/C_Time.cjs +5 -0
  215. package/dist/C_Time.d.cts +2 -0
  216. package/dist/C_Time.d.ts +2 -0
  217. package/dist/C_Time.js +3 -0
  218. package/dist/C_Time2.js +199 -0
  219. package/dist/C_Time2.js.map +1 -0
  220. package/dist/C_Tree-0GDv--jX.css.map +1 -0
  221. package/dist/C_Tree.cjs +7 -0
  222. package/dist/C_Tree.d.cts +2 -0
  223. package/dist/C_Tree.d.ts +2 -0
  224. package/dist/C_Tree.js +4 -0
  225. package/dist/C_Tree2.js +441 -0
  226. package/dist/C_Tree2.js.map +1 -0
  227. package/dist/C_Upload-BXd3YYLx.css.map +1 -0
  228. package/dist/C_Upload.cjs +12 -0
  229. package/dist/C_Upload.d.cts +2 -0
  230. package/dist/C_Upload.d.ts +2 -0
  231. package/dist/C_Upload.js +4 -0
  232. package/dist/C_Upload2.js +1388 -0
  233. package/dist/C_Upload2.js.map +1 -0
  234. package/dist/C_VideoPlayer-DYG3RL0Q.css.map +1 -0
  235. package/dist/C_VideoPlayer.cjs +23 -0
  236. package/dist/C_VideoPlayer.d.cts +2 -0
  237. package/dist/C_VideoPlayer.d.ts +2 -0
  238. package/dist/C_VideoPlayer.js +3 -0
  239. package/dist/C_VideoPlayer2.js +1932 -0
  240. package/dist/C_VideoPlayer2.js.map +1 -0
  241. package/dist/C_VtableGantt-fhItIiHE.css.map +1 -0
  242. package/dist/C_VtableGantt.cjs +6 -0
  243. package/dist/C_VtableGantt.d.cts +2 -0
  244. package/dist/C_VtableGantt.d.ts +2 -0
  245. package/dist/C_VtableGantt.js +4 -0
  246. package/dist/C_VtableGantt2.js +873 -0
  247. package/dist/C_VtableGantt2.js.map +1 -0
  248. package/dist/C_WaterFall-8sQDFXKg.css.map +1 -0
  249. package/dist/C_WaterFall.cjs +13 -0
  250. package/dist/C_WaterFall.d.cts +2 -0
  251. package/dist/C_WaterFall.d.ts +2 -0
  252. package/dist/C_WaterFall.js +3 -0
  253. package/dist/C_WaterFall2.js +365 -0
  254. package/dist/C_WaterFall2.js.map +1 -0
  255. package/dist/C_WorkFlow-J-dyIuh9.css.map +1 -0
  256. package/dist/C_WorkFlow.cjs +8 -0
  257. package/dist/C_WorkFlow.d.cts +2 -0
  258. package/dist/C_WorkFlow.d.ts +2 -0
  259. package/dist/C_WorkFlow.js +4 -0
  260. package/dist/C_WorkFlow2.js +1984 -0
  261. package/dist/C_WorkFlow2.js.map +1 -0
  262. package/dist/chunk.js +22 -0
  263. package/dist/city.js +4817 -0
  264. package/dist/city.js.map +1 -0
  265. package/dist/constants.d.ts +273 -0
  266. package/dist/constants.d.ts.map +1 -0
  267. package/dist/constants2.d.ts +178 -0
  268. package/dist/constants2.d.ts.map +1 -0
  269. package/dist/constants3.d.ts +475 -0
  270. package/dist/constants3.d.ts.map +1 -0
  271. package/dist/constants4.d.ts +430 -0
  272. package/dist/constants4.d.ts.map +1 -0
  273. package/dist/constants5.d.ts +4283 -0
  274. package/dist/constants5.d.ts.map +1 -0
  275. package/dist/data.d.ts +67 -0
  276. package/dist/data.d.ts.map +1 -0
  277. package/dist/export-helper.js +9 -0
  278. package/dist/index.cjs +409 -0
  279. package/dist/index.d.cts +96 -0
  280. package/dist/index.d.cts.map +1 -0
  281. package/dist/index.d.ts +103 -0
  282. package/dist/index.d.ts.map +1 -0
  283. package/dist/index.js +230 -0
  284. package/dist/index.js.map +1 -0
  285. package/dist/index.vue.d.ts +80 -0
  286. package/dist/index.vue.d.ts.map +1 -0
  287. package/dist/index10.vue.d.ts +72 -0
  288. package/dist/index10.vue.d.ts.map +1 -0
  289. package/dist/index11.vue.d.ts +26 -0
  290. package/dist/index11.vue.d.ts.map +1 -0
  291. package/dist/index12.vue.d.ts +81 -0
  292. package/dist/index12.vue.d.ts.map +1 -0
  293. package/dist/index13.vue.d.ts +55 -0
  294. package/dist/index13.vue.d.ts.map +1 -0
  295. package/dist/index14.vue.d.ts +33 -0
  296. package/dist/index14.vue.d.ts.map +1 -0
  297. package/dist/index15.vue.d.ts +18 -0
  298. package/dist/index15.vue.d.ts.map +1 -0
  299. package/dist/index16.vue.d.ts +662 -0
  300. package/dist/index16.vue.d.ts.map +1 -0
  301. package/dist/index2.vue.d.ts +38 -0
  302. package/dist/index2.vue.d.ts.map +1 -0
  303. package/dist/index3.vue.d.ts +45 -0
  304. package/dist/index3.vue.d.ts.map +1 -0
  305. package/dist/index4.vue.d.ts +31 -0
  306. package/dist/index4.vue.d.ts.map +1 -0
  307. package/dist/index5.vue.d.ts +35 -0
  308. package/dist/index5.vue.d.ts.map +1 -0
  309. package/dist/index6.vue.d.ts +48 -0
  310. package/dist/index6.vue.d.ts.map +1 -0
  311. package/dist/index7.vue.d.ts +56 -0
  312. package/dist/index7.vue.d.ts.map +1 -0
  313. package/dist/index8.vue.d.ts +41 -0
  314. package/dist/index8.vue.d.ts.map +1 -0
  315. package/dist/index9.vue.d.ts +30 -0
  316. package/dist/index9.vue.d.ts.map +1 -0
  317. package/dist/storage.js +31 -0
  318. package/dist/storage.js.map +1 -0
  319. package/dist/style.css +7725 -0
  320. package/dist/useCalendarEvents.d.ts +148 -0
  321. package/dist/useCalendarEvents.d.ts.map +1 -0
  322. package/dist/useCollapsePanel.d.ts +132 -0
  323. package/dist/useCollapsePanel.d.ts.map +1 -0
  324. package/dist/useCropperCore.d.ts +102 -0
  325. package/dist/useCropperCore.d.ts.map +1 -0
  326. package/dist/useDraggableLayout.d.ts +194 -0
  327. package/dist/useDraggableLayout.d.ts.map +1 -0
  328. package/dist/useDynamicFormState.d.ts +4248 -0
  329. package/dist/useDynamicFormState.d.ts.map +1 -0
  330. package/dist/useEdgeInteraction.d.ts +7614 -0
  331. package/dist/useEdgeInteraction.d.ts.map +1 -0
  332. package/dist/useFullscreen.d.ts +166 -0
  333. package/dist/useFullscreen.d.ts.map +1 -0
  334. package/dist/useInfiniteScroll.d.ts +169 -0
  335. package/dist/useInfiniteScroll.d.ts.map +1 -0
  336. package/dist/useModalEdit.d.ts +960 -0
  337. package/dist/useModalEdit.d.ts.map +1 -0
  338. package/dist/useQRCode.d.ts +87 -0
  339. package/dist/useQRCode.d.ts.map +1 -0
  340. package/dist/useSearchState.d.ts +180 -0
  341. package/dist/useSearchState.d.ts.map +1 -0
  342. package/dist/useSignatureHistory.d.ts +189 -0
  343. package/dist/useSignatureHistory.d.ts.map +1 -0
  344. package/dist/useSplitResize.d.ts +158 -0
  345. package/dist/useSplitResize.d.ts.map +1 -0
  346. package/dist/useTimeSelection.d.ts +105 -0
  347. package/dist/useTimeSelection.d.ts.map +1 -0
  348. package/dist/useTreeOperations.d.ts +183 -0
  349. package/dist/useTreeOperations.d.ts.map +1 -0
  350. package/dist/useWorkflowValidation.d.ts +1052 -0
  351. package/dist/useWorkflowValidation.d.ts.map +1 -0
  352. package/package.json +342 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"C_Date2.js","names":["mode","placeholder","disabled","valueFormat","$attrs","startPlaceholder","endPlaceholder","startDateProps","endDateProps"],"sources":["../src/components/C_Date/index.vue","../src/components/C_Date/index.vue","../src/components/C_Date/index.vue"],"sourcesContent":["<!--\r\n * @Author: ChenYu ycyplus@gmail.com\r\n * @Date: 2025-05-28\r\n * @Description: 日期选择器组件\r\n * @Migration: naive-ui-components 组件库迁移版本\r\n * Copyright (c) 2025 by CHENY, All Rights Reserved.\r\n-->\r\n<template>\r\n <div class=\"inline-block\">\r\n <NDatePicker\r\n v-if=\"mode === 'date'\"\r\n v-model:value=\"singleDate\"\r\n type=\"date\"\r\n :placeholder=\"placeholder || '请选择日期'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleSingleDateChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'datetime'\"\r\n v-model:value=\"singleDateTime\"\r\n type=\"datetime\"\r\n :placeholder=\"placeholder || '请选择日期时间'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleSingleDateTimeChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'daterange'\"\r\n v-model:value=\"dateRange\"\r\n type=\"daterange\"\r\n :start-placeholder=\"startPlaceholder || '开始日期'\"\r\n :end-placeholder=\"endPlaceholder || '结束日期'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleDateRangeChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'datetimerange'\"\r\n v-model:value=\"dateTimeRange\"\r\n type=\"datetimerange\"\r\n :start-placeholder=\"startPlaceholder || '开始日期时间'\"\r\n :end-placeholder=\"endPlaceholder || '结束日期时间'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleDateTimeRangeChange\"\r\n />\r\n\r\n <div v-else-if=\"mode === 'smart-range'\" class=\"inline-block\">\r\n <div class=\"flex gap-2.5 items-center\">\r\n <NDatePicker\r\n class=\"flex-1\"\r\n v-model:value=\"startDate\"\r\n type=\"date\"\r\n :placeholder=\"startPlaceholder || '请选择开始日期'\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"startDateProps\"\r\n />\r\n <NDatePicker\r\n class=\"flex-1\"\r\n v-model:value=\"endDate\"\r\n type=\"date\"\r\n :placeholder=\"endPlaceholder || '请选择结束日期'\"\r\n :disabled=\"endDateDisabled\"\r\n :is-date-disabled=\"endDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"endDateProps\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script lang=\"ts\" setup>\r\nimport { ref, watch } from \"vue\";\r\nimport { NDatePicker } from \"naive-ui\";\r\n\r\ndefineOptions({ name: \"C_Date\" });\r\n\r\ntype DatePickerMode =\r\n | \"date\"\r\n | \"datetime\"\r\n | \"daterange\"\r\n | \"datetimerange\"\r\n | \"smart-range\";\r\n\r\ntype DateValue = number | null;\r\ntype DateRangeValue = [number, number] | null;\r\n\r\ninterface Props {\r\n mode?: DatePickerMode;\r\n placeholder?: string;\r\n startPlaceholder?: string;\r\n endPlaceholder?: string;\r\n disabled?: boolean;\r\n disabledBeforeToday?: boolean;\r\n disabledAfterToday?: boolean;\r\n valueFormat?: string;\r\n startDateProps?: Record<string, any>;\r\n endDateProps?: Record<string, any>;\r\n}\r\n\r\ninterface Emits {\r\n (e: \"update:singleDate\", value: DateValue): void;\r\n (e: \"update:singleDateTime\", value: DateValue): void;\r\n (e: \"update:dateRange\", value: DateRangeValue): void;\r\n (e: \"update:dateTimeRange\", value: DateRangeValue): void;\r\n (e: \"update:smartRange\", value: DateRangeValue): void;\r\n (e: \"change\", value: DateValue | DateRangeValue): void;\r\n}\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n mode: \"date\",\r\n placeholder: \"\",\r\n startPlaceholder: \"\",\r\n endPlaceholder: \"\",\r\n disabled: false,\r\n disabledBeforeToday: false,\r\n disabledAfterToday: false,\r\n valueFormat: \"yyyy-MM-dd\",\r\n startDateProps: () => ({}),\r\n endDateProps: () => ({}),\r\n});\r\n\r\nconst emits = defineEmits<Emits>();\r\n\r\nconst singleDate = ref<DateValue>(null);\r\nconst singleDateTime = ref<DateValue>(null);\r\nconst dateRange = ref<DateRangeValue>(null);\r\nconst dateTimeRange = ref<DateRangeValue>(null);\r\nconst startDate = ref<DateValue>(null);\r\nconst endDate = ref<DateValue>(null);\r\nconst endDateDisabled = ref(true);\r\n\r\nconst getTodayTimestamp = (): number => {\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n return today.getTime();\r\n};\r\n\r\nconst singleDisabledDate = (timestamp: number): boolean => {\r\n const todayTimestamp = getTodayTimestamp();\r\n if (props.disabledBeforeToday && timestamp < todayTimestamp) return true;\r\n if (props.disabledAfterToday && timestamp > todayTimestamp) return true;\r\n return false;\r\n};\r\n\r\nconst endDisabledDate = (timestamp: number): boolean => {\r\n if (!startDate.value) return true;\r\n if (timestamp < startDate.value) return true;\r\n return singleDisabledDate(timestamp);\r\n};\r\n\r\nconst handleSingleDateChange = (value: DateValue): void => {\r\n emits(\"update:singleDate\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleSingleDateTimeChange = (value: DateValue): void => {\r\n emits(\"update:singleDateTime\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleDateRangeChange = (value: DateRangeValue): void => {\r\n emits(\"update:dateRange\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleDateTimeRangeChange = (value: DateRangeValue): void => {\r\n emits(\"update:dateTimeRange\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nwatch(\r\n () => [startDate.value, endDate.value],\r\n ([startVal, endVal]) => {\r\n if (!startVal) {\r\n endDate.value = null;\r\n endDateDisabled.value = true;\r\n return;\r\n }\r\n if (startVal) {\r\n endDateDisabled.value = false;\r\n }\r\n if (startVal && endVal) {\r\n const rangeValue: DateRangeValue = [startVal, endVal];\r\n emits(\"update:smartRange\", rangeValue);\r\n emits(\"change\", rangeValue);\r\n }\r\n },\r\n { deep: true },\r\n);\r\n\r\ndefineExpose({\r\n singleDate,\r\n singleDateTime,\r\n dateRange,\r\n dateTimeRange,\r\n startDate,\r\n endDate,\r\n clearAll: () => {\r\n singleDate.value = null;\r\n singleDateTime.value = null;\r\n dateRange.value = null;\r\n dateTimeRange.value = null;\r\n startDate.value = null;\r\n endDate.value = null;\r\n endDateDisabled.value = true;\r\n },\r\n});\r\n</script>\r\n","<!--\r\n * @Author: ChenYu ycyplus@gmail.com\r\n * @Date: 2025-05-28\r\n * @Description: 日期选择器组件\r\n * @Migration: naive-ui-components 组件库迁移版本\r\n * Copyright (c) 2025 by CHENY, All Rights Reserved.\r\n-->\r\n<template>\r\n <div class=\"inline-block\">\r\n <NDatePicker\r\n v-if=\"mode === 'date'\"\r\n v-model:value=\"singleDate\"\r\n type=\"date\"\r\n :placeholder=\"placeholder || '请选择日期'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleSingleDateChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'datetime'\"\r\n v-model:value=\"singleDateTime\"\r\n type=\"datetime\"\r\n :placeholder=\"placeholder || '请选择日期时间'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleSingleDateTimeChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'daterange'\"\r\n v-model:value=\"dateRange\"\r\n type=\"daterange\"\r\n :start-placeholder=\"startPlaceholder || '开始日期'\"\r\n :end-placeholder=\"endPlaceholder || '结束日期'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleDateRangeChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'datetimerange'\"\r\n v-model:value=\"dateTimeRange\"\r\n type=\"datetimerange\"\r\n :start-placeholder=\"startPlaceholder || '开始日期时间'\"\r\n :end-placeholder=\"endPlaceholder || '结束日期时间'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleDateTimeRangeChange\"\r\n />\r\n\r\n <div v-else-if=\"mode === 'smart-range'\" class=\"inline-block\">\r\n <div class=\"flex gap-2.5 items-center\">\r\n <NDatePicker\r\n class=\"flex-1\"\r\n v-model:value=\"startDate\"\r\n type=\"date\"\r\n :placeholder=\"startPlaceholder || '请选择开始日期'\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"startDateProps\"\r\n />\r\n <NDatePicker\r\n class=\"flex-1\"\r\n v-model:value=\"endDate\"\r\n type=\"date\"\r\n :placeholder=\"endPlaceholder || '请选择结束日期'\"\r\n :disabled=\"endDateDisabled\"\r\n :is-date-disabled=\"endDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"endDateProps\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script lang=\"ts\" setup>\r\nimport { ref, watch } from \"vue\";\r\nimport { NDatePicker } from \"naive-ui\";\r\n\r\ndefineOptions({ name: \"C_Date\" });\r\n\r\ntype DatePickerMode =\r\n | \"date\"\r\n | \"datetime\"\r\n | \"daterange\"\r\n | \"datetimerange\"\r\n | \"smart-range\";\r\n\r\ntype DateValue = number | null;\r\ntype DateRangeValue = [number, number] | null;\r\n\r\ninterface Props {\r\n mode?: DatePickerMode;\r\n placeholder?: string;\r\n startPlaceholder?: string;\r\n endPlaceholder?: string;\r\n disabled?: boolean;\r\n disabledBeforeToday?: boolean;\r\n disabledAfterToday?: boolean;\r\n valueFormat?: string;\r\n startDateProps?: Record<string, any>;\r\n endDateProps?: Record<string, any>;\r\n}\r\n\r\ninterface Emits {\r\n (e: \"update:singleDate\", value: DateValue): void;\r\n (e: \"update:singleDateTime\", value: DateValue): void;\r\n (e: \"update:dateRange\", value: DateRangeValue): void;\r\n (e: \"update:dateTimeRange\", value: DateRangeValue): void;\r\n (e: \"update:smartRange\", value: DateRangeValue): void;\r\n (e: \"change\", value: DateValue | DateRangeValue): void;\r\n}\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n mode: \"date\",\r\n placeholder: \"\",\r\n startPlaceholder: \"\",\r\n endPlaceholder: \"\",\r\n disabled: false,\r\n disabledBeforeToday: false,\r\n disabledAfterToday: false,\r\n valueFormat: \"yyyy-MM-dd\",\r\n startDateProps: () => ({}),\r\n endDateProps: () => ({}),\r\n});\r\n\r\nconst emits = defineEmits<Emits>();\r\n\r\nconst singleDate = ref<DateValue>(null);\r\nconst singleDateTime = ref<DateValue>(null);\r\nconst dateRange = ref<DateRangeValue>(null);\r\nconst dateTimeRange = ref<DateRangeValue>(null);\r\nconst startDate = ref<DateValue>(null);\r\nconst endDate = ref<DateValue>(null);\r\nconst endDateDisabled = ref(true);\r\n\r\nconst getTodayTimestamp = (): number => {\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n return today.getTime();\r\n};\r\n\r\nconst singleDisabledDate = (timestamp: number): boolean => {\r\n const todayTimestamp = getTodayTimestamp();\r\n if (props.disabledBeforeToday && timestamp < todayTimestamp) return true;\r\n if (props.disabledAfterToday && timestamp > todayTimestamp) return true;\r\n return false;\r\n};\r\n\r\nconst endDisabledDate = (timestamp: number): boolean => {\r\n if (!startDate.value) return true;\r\n if (timestamp < startDate.value) return true;\r\n return singleDisabledDate(timestamp);\r\n};\r\n\r\nconst handleSingleDateChange = (value: DateValue): void => {\r\n emits(\"update:singleDate\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleSingleDateTimeChange = (value: DateValue): void => {\r\n emits(\"update:singleDateTime\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleDateRangeChange = (value: DateRangeValue): void => {\r\n emits(\"update:dateRange\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleDateTimeRangeChange = (value: DateRangeValue): void => {\r\n emits(\"update:dateTimeRange\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nwatch(\r\n () => [startDate.value, endDate.value],\r\n ([startVal, endVal]) => {\r\n if (!startVal) {\r\n endDate.value = null;\r\n endDateDisabled.value = true;\r\n return;\r\n }\r\n if (startVal) {\r\n endDateDisabled.value = false;\r\n }\r\n if (startVal && endVal) {\r\n const rangeValue: DateRangeValue = [startVal, endVal];\r\n emits(\"update:smartRange\", rangeValue);\r\n emits(\"change\", rangeValue);\r\n }\r\n },\r\n { deep: true },\r\n);\r\n\r\ndefineExpose({\r\n singleDate,\r\n singleDateTime,\r\n dateRange,\r\n dateTimeRange,\r\n startDate,\r\n endDate,\r\n clearAll: () => {\r\n singleDate.value = null;\r\n singleDateTime.value = null;\r\n dateRange.value = null;\r\n dateTimeRange.value = null;\r\n startDate.value = null;\r\n endDate.value = null;\r\n endDateDisabled.value = true;\r\n },\r\n});\r\n</script>\r\n","<!--\r\n * @Author: ChenYu ycyplus@gmail.com\r\n * @Date: 2025-05-28\r\n * @Description: 日期选择器组件\r\n * @Migration: naive-ui-components 组件库迁移版本\r\n * Copyright (c) 2025 by CHENY, All Rights Reserved.\r\n-->\r\n<template>\r\n <div class=\"inline-block\">\r\n <NDatePicker\r\n v-if=\"mode === 'date'\"\r\n v-model:value=\"singleDate\"\r\n type=\"date\"\r\n :placeholder=\"placeholder || '请选择日期'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleSingleDateChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'datetime'\"\r\n v-model:value=\"singleDateTime\"\r\n type=\"datetime\"\r\n :placeholder=\"placeholder || '请选择日期时间'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleSingleDateTimeChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'daterange'\"\r\n v-model:value=\"dateRange\"\r\n type=\"daterange\"\r\n :start-placeholder=\"startPlaceholder || '开始日期'\"\r\n :end-placeholder=\"endPlaceholder || '结束日期'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleDateRangeChange\"\r\n />\r\n\r\n <NDatePicker\r\n v-else-if=\"mode === 'datetimerange'\"\r\n v-model:value=\"dateTimeRange\"\r\n type=\"datetimerange\"\r\n :start-placeholder=\"startPlaceholder || '开始日期时间'\"\r\n :end-placeholder=\"endPlaceholder || '结束日期时间'\"\r\n :disabled=\"disabled\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"$attrs\"\r\n @update:value=\"handleDateTimeRangeChange\"\r\n />\r\n\r\n <div v-else-if=\"mode === 'smart-range'\" class=\"inline-block\">\r\n <div class=\"flex gap-2.5 items-center\">\r\n <NDatePicker\r\n class=\"flex-1\"\r\n v-model:value=\"startDate\"\r\n type=\"date\"\r\n :placeholder=\"startPlaceholder || '请选择开始日期'\"\r\n :is-date-disabled=\"singleDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"startDateProps\"\r\n />\r\n <NDatePicker\r\n class=\"flex-1\"\r\n v-model:value=\"endDate\"\r\n type=\"date\"\r\n :placeholder=\"endPlaceholder || '请选择结束日期'\"\r\n :disabled=\"endDateDisabled\"\r\n :is-date-disabled=\"endDisabledDate\"\r\n :value-format=\"valueFormat\"\r\n clearable\r\n v-bind=\"endDateProps\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script lang=\"ts\" setup>\r\nimport { ref, watch } from \"vue\";\r\nimport { NDatePicker } from \"naive-ui\";\r\n\r\ndefineOptions({ name: \"C_Date\" });\r\n\r\ntype DatePickerMode =\r\n | \"date\"\r\n | \"datetime\"\r\n | \"daterange\"\r\n | \"datetimerange\"\r\n | \"smart-range\";\r\n\r\ntype DateValue = number | null;\r\ntype DateRangeValue = [number, number] | null;\r\n\r\ninterface Props {\r\n mode?: DatePickerMode;\r\n placeholder?: string;\r\n startPlaceholder?: string;\r\n endPlaceholder?: string;\r\n disabled?: boolean;\r\n disabledBeforeToday?: boolean;\r\n disabledAfterToday?: boolean;\r\n valueFormat?: string;\r\n startDateProps?: Record<string, any>;\r\n endDateProps?: Record<string, any>;\r\n}\r\n\r\ninterface Emits {\r\n (e: \"update:singleDate\", value: DateValue): void;\r\n (e: \"update:singleDateTime\", value: DateValue): void;\r\n (e: \"update:dateRange\", value: DateRangeValue): void;\r\n (e: \"update:dateTimeRange\", value: DateRangeValue): void;\r\n (e: \"update:smartRange\", value: DateRangeValue): void;\r\n (e: \"change\", value: DateValue | DateRangeValue): void;\r\n}\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n mode: \"date\",\r\n placeholder: \"\",\r\n startPlaceholder: \"\",\r\n endPlaceholder: \"\",\r\n disabled: false,\r\n disabledBeforeToday: false,\r\n disabledAfterToday: false,\r\n valueFormat: \"yyyy-MM-dd\",\r\n startDateProps: () => ({}),\r\n endDateProps: () => ({}),\r\n});\r\n\r\nconst emits = defineEmits<Emits>();\r\n\r\nconst singleDate = ref<DateValue>(null);\r\nconst singleDateTime = ref<DateValue>(null);\r\nconst dateRange = ref<DateRangeValue>(null);\r\nconst dateTimeRange = ref<DateRangeValue>(null);\r\nconst startDate = ref<DateValue>(null);\r\nconst endDate = ref<DateValue>(null);\r\nconst endDateDisabled = ref(true);\r\n\r\nconst getTodayTimestamp = (): number => {\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n return today.getTime();\r\n};\r\n\r\nconst singleDisabledDate = (timestamp: number): boolean => {\r\n const todayTimestamp = getTodayTimestamp();\r\n if (props.disabledBeforeToday && timestamp < todayTimestamp) return true;\r\n if (props.disabledAfterToday && timestamp > todayTimestamp) return true;\r\n return false;\r\n};\r\n\r\nconst endDisabledDate = (timestamp: number): boolean => {\r\n if (!startDate.value) return true;\r\n if (timestamp < startDate.value) return true;\r\n return singleDisabledDate(timestamp);\r\n};\r\n\r\nconst handleSingleDateChange = (value: DateValue): void => {\r\n emits(\"update:singleDate\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleSingleDateTimeChange = (value: DateValue): void => {\r\n emits(\"update:singleDateTime\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleDateRangeChange = (value: DateRangeValue): void => {\r\n emits(\"update:dateRange\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nconst handleDateTimeRangeChange = (value: DateRangeValue): void => {\r\n emits(\"update:dateTimeRange\", value);\r\n emits(\"change\", value);\r\n};\r\n\r\nwatch(\r\n () => [startDate.value, endDate.value],\r\n ([startVal, endVal]) => {\r\n if (!startVal) {\r\n endDate.value = null;\r\n endDateDisabled.value = true;\r\n return;\r\n }\r\n if (startVal) {\r\n endDateDisabled.value = false;\r\n }\r\n if (startVal && endVal) {\r\n const rangeValue: DateRangeValue = [startVal, endVal];\r\n emits(\"update:smartRange\", rangeValue);\r\n emits(\"change\", rangeValue);\r\n }\r\n },\r\n { deep: true },\r\n);\r\n\r\ndefineExpose({\r\n singleDate,\r\n singleDateTime,\r\n dateRange,\r\n dateTimeRange,\r\n startDate,\r\n endDate,\r\n clearAll: () => {\r\n singleDate.value = null;\r\n singleDateTime.value = null;\r\n dateRange.value = null;\r\n dateTimeRange.value = null;\r\n startDate.value = null;\r\n endDate.value = null;\r\n endDateDisabled.value = true;\r\n },\r\n});\r\n</script>\r\n"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"C_Draggable-C483syRC.css","names":[],"sources":["../src/components/C_Draggable/index.vue?vue&type=style&index=0&scoped=68fb07e5&lang.scss"],"sourcesContent":["/* ===== 容器布局样式 ===== */\n.c-draggable-wrapper[data-v-68fb07e5] {\n position: relative;\n width: 100%;\n}\n.c-draggable-list[data-v-68fb07e5] {\n min-height: 50px;\n width: 100%;\n display: flex;\n gap: var(--gap, 8px);\n /* 默认垂直布局 */\n /* 水平布局 */\n /* 弹性换行布局 */\n /* 网格布局 */\n}\n.c-draggable-list.layout-vertical[data-v-68fb07e5] {\n flex-direction: column;\n}\n.c-draggable-list.layout-horizontal[data-v-68fb07e5] {\n flex-direction: row;\n align-items: var(--align-items, stretch);\n justify-content: var(--justify-content, flex-start);\n}\n.c-draggable-list.layout-horizontal.flex-wrap[data-v-68fb07e5] {\n flex-wrap: wrap;\n}\n.c-draggable-list.layout-flex-wrap[data-v-68fb07e5] {\n flex-direction: row;\n flex-wrap: wrap;\n align-items: var(--align-items, stretch);\n justify-content: var(--justify-content, flex-start);\n}\n.c-draggable-list.layout-grid[data-v-68fb07e5] {\n display: grid;\n grid-template-columns: repeat(var(--grid-columns, 4), 1fr);\n grid-template-rows: var(--grid-rows, auto);\n align-items: var(--align-items, stretch);\n justify-content: var(--justify-content, stretch);\n}\n.c-draggable-list.layout-grid > .c-draggable-item[data-v-68fb07e5] {\n width: 100%;\n box-sizing: border-box;\n}\n\n/* ===== 拖拽项目基础样式 ===== */\n.c-draggable-item[data-v-68fb07e5] {\n position: relative;\n}\n.c-draggable-item.is-disabled[data-v-68fb07e5] {\n opacity: 0.6;\n cursor: not-allowed;\n}\n.c-draggable-item.is-disabled[data-v-68fb07e5] * {\n cursor: not-allowed !important;\n}\n\n/* ===== 默认项目样式 ===== */\n.default-item[data-v-68fb07e5] {\n display: flex;\n align-items: center;\n padding: 16px;\n background: var(--n-card-color);\n border: 1px solid var(--n-border-color);\n border-radius: 8px;\n cursor: grab;\n transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n position: relative;\n}\n.default-item[data-v-68fb07e5]:hover {\n border-color: var(--n-primary-color);\n box-shadow: 0 2px 8px var(--n-box-shadow-color);\n transform: translateY(-1px);\n}\n.default-item[data-v-68fb07e5]:active {\n cursor: grabbing;\n}\n.default-item .drag-handle[data-v-68fb07e5] {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n margin-right: 12px;\n color: var(--n-text-color-disabled);\n cursor: grab;\n border-radius: 4px;\n transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n flex-shrink: 0;\n}\n.default-item .drag-handle[data-v-68fb07e5]:hover {\n background: var(--n-action-color);\n color: var(--n-primary-color);\n}\n.default-item .drag-handle[data-v-68fb07e5]:active {\n cursor: grabbing;\n}\n.default-item .drag-handle div[data-v-68fb07e5] {\n font-size: 18px;\n}\n.default-item .item-content[data-v-68fb07e5] {\n flex: 1;\n min-width: 0;\n}\n.default-item .item-content .item-title[data-v-68fb07e5] {\n font-size: 16px;\n font-weight: 600;\n color: var(--n-text-color);\n line-height: 1.5;\n margin-bottom: 4px;\n word-break: break-word;\n}\n.default-item .item-content .item-description[data-v-68fb07e5] {\n font-size: 14px;\n color: var(--n-text-color-disabled);\n line-height: 1.4;\n word-break: break-word;\n}\n\n/* ===== 空状态样式 ===== */\n.empty-state[data-v-68fb07e5] {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n padding: 60px 20px;\n text-align: center;\n border: 2px dashed var(--n-border-color);\n border-radius: 8px;\n}\n.empty-state .default-empty .empty-icon[data-v-68fb07e5] {\n font-size: 48px;\n color: var(--n-text-color-disabled);\n margin-bottom: 16px;\n}\n.empty-state .default-empty .empty-text[data-v-68fb07e5] {\n color: var(--n-text-color-disabled);\n font-size: 16px;\n margin: 0;\n}\n\n/* ===== 拖拽状态样式 ===== */\n.sortable-ghost {\n opacity: 0.5 !important;\n background: var(--n-primary-color-suppl) !important;\n border: 2px dashed var(--n-primary-color) !important;\n transform: scale(0.98) !important;\n}\n.sortable-chosen {\n outline: 2px solid var(--n-primary-color) !important;\n outline-offset: 2px !important;\n transform: scale(1.02) !important;\n z-index: 999 !important;\n}\n.sortable-drag {\n opacity: 0.9 !important;\n transform: rotate(2deg) scale(1.05) !important;\n z-index: 1000 !important;\n box-shadow: 0 8px 25px var(--n-box-shadow-color) !important;\n}\n\n/* ===== 网格布局特殊优化 ===== */\n.c-draggable-list.layout-grid .c-draggable-item[data-v-68fb07e5] {\n display: flex;\n flex-direction: column;\n height: 100%;\n}\n.c-draggable-list.layout-grid .c-draggable-item .default-item[data-v-68fb07e5] {\n flex: 1;\n height: 100%;\n min-height: 80px;\n}\n.c-draggable-list.layout-grid + .empty-state[data-v-68fb07e5] {\n grid-column: 1/-1;\n padding: 40px 20px;\n}\n.c-draggable-list.layout-grid + .empty-state .default-empty .empty-icon[data-v-68fb07e5] {\n font-size: 36px;\n}\n\n/* ===== 弹性布局特殊优化 ===== */\n.c-draggable-list.layout-horizontal .c-draggable-item[data-v-68fb07e5],\n.c-draggable-list.layout-flex-wrap .c-draggable-item[data-v-68fb07e5] {\n flex-shrink: 0;\n}\n.c-draggable-list.layout-horizontal .c-draggable-item[data-v-68fb07e5]:not(:last-child),\n.c-draggable-list.layout-flex-wrap .c-draggable-item[data-v-68fb07e5]:not(:last-child) {\n margin-right: 0;\n}\n.c-draggable-list.layout-horizontal .default-item[data-v-68fb07e5],\n.c-draggable-list.layout-flex-wrap .default-item[data-v-68fb07e5] {\n min-width: 200px;\n width: 100%;\n}\n\n/* ===== 响应式设计 ===== */\n@media (max-width: 768px) {\n.c-draggable-list.layout-grid[data-v-68fb07e5] {\n grid-template-columns: repeat(2, 1fr) !important;\n}\n.c-draggable-list.layout-horizontal[data-v-68fb07e5] {\n flex-wrap: wrap;\n}\n.default-item[data-v-68fb07e5] {\n padding: 12px;\n min-width: 150px !important;\n}\n.default-item .drag-handle[data-v-68fb07e5] {\n width: 20px;\n height: 20px;\n margin-right: 8px;\n}\n.default-item .drag-handle div[data-v-68fb07e5] {\n font-size: 16px;\n}\n.default-item .item-content .item-title[data-v-68fb07e5] {\n font-size: 15px;\n}\n.default-item .item-content .item-description[data-v-68fb07e5] {\n font-size: 13px;\n}\n.empty-state[data-v-68fb07e5] {\n padding: 40px 16px;\n}\n.empty-state .default-empty .empty-icon[data-v-68fb07e5] {\n font-size: 36px;\n}\n}\n@media (max-width: 480px) {\n.c-draggable-list.layout-grid[data-v-68fb07e5] {\n grid-template-columns: 1fr !important;\n}\n.default-item[data-v-68fb07e5] {\n min-width: 100% !important;\n padding: 10px;\n}\n}"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA"}
@@ -0,0 +1,5 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+ const require_C_Draggable = require('./C_Draggable.js');
3
+
4
+ exports.C_Draggable = require_C_Draggable.C_Draggable_default;
5
+ exports.useDraggableLayout = require_C_Draggable.useDraggableLayout;
@@ -0,0 +1,2 @@
1
+ import { a as DraggableEmits, c as GroupOptions, i as DragEvent, l as JustifyContent, n as _default, o as DraggableItem, r as AlignItems, s as DraggableProps, t as useDraggableLayout, u as LayoutMode } from "./useDraggableLayout.js";
2
+ export { type AlignItems, _default as C_Draggable, type DragEvent, type DraggableEmits, type DraggableItem, type DraggableProps, type GroupOptions, type JustifyContent, type LayoutMode, useDraggableLayout };
@@ -0,0 +1,2 @@
1
+ import { a as DraggableEmits, c as GroupOptions, i as DragEvent, l as JustifyContent, n as _default, o as DraggableItem, r as AlignItems, s as DraggableProps, t as useDraggableLayout, u as LayoutMode } from "./useDraggableLayout.js";
2
+ export { type AlignItems, _default as C_Draggable, type DragEvent, type DraggableEmits, type DraggableItem, type DraggableProps, type GroupOptions, type JustifyContent, type LayoutMode, useDraggableLayout };
@@ -0,0 +1,3 @@
1
+ import { n as useDraggableLayout, t as C_Draggable_default } from "./C_Draggable2.js";
2
+
3
+ export { C_Draggable_default as C_Draggable, useDraggableLayout };
@@ -0,0 +1,295 @@
1
+ import { t as export_helper_default } from "./export-helper.js";
2
+ import { Fragment, computed, createCommentVNode, createElementBlock, createElementVNode, createVNode, defineComponent, isRef, mergeProps, nextTick, normalizeClass, openBlock, readonly, ref, renderList, renderSlot, toDisplayString, unref, withCtx } from "vue";
3
+ import { VueDraggable } from "vue-draggable-plus";
4
+
5
+ //#region src/components/C_Draggable/composables/useDraggableLayout.ts
6
+ function useDraggableLayout(props, emit) {
7
+ const isDragging = ref(false);
8
+ const internalList = computed({
9
+ get: () => props.modelValue ?? [],
10
+ set: (value) => {
11
+ emit("update:modelValue", value);
12
+ emit("list-change", value);
13
+ }
14
+ });
15
+ const isEmpty = computed(() => (props.modelValue ?? []).length === 0);
16
+ const listClasses = computed(() => [
17
+ "c-draggable-list",
18
+ props.listClass,
19
+ `layout-${props.layout}`,
20
+ { "flex-wrap": props.flexWrap && (props.layout === "horizontal" || props.layout === "flex-wrap") }
21
+ ]);
22
+ const listStyles = computed(() => {
23
+ const styles = {
24
+ "--gap": typeof props.gap === "number" ? `${props.gap}px` : props.gap ?? "8px",
25
+ "--grid-columns": props.gridColumns ?? 4,
26
+ "--justify-content": props.justifyContent ?? "flex-start",
27
+ "--align-items": props.alignItems ?? "stretch",
28
+ ...props.customStyles
29
+ };
30
+ if (props.gridRows) styles["--grid-rows"] = props.gridRows;
31
+ return styles;
32
+ });
33
+ const draggableOptions = computed(() => {
34
+ const options = {
35
+ disabled: props.disabled,
36
+ group: props.group,
37
+ sort: props.sort,
38
+ animation: props.animation,
39
+ delay: props.delay,
40
+ ghostClass: props.ghostClass,
41
+ chosenClass: props.chosenClass,
42
+ dragClass: props.dragClass,
43
+ swapThreshold: props.swapThreshold,
44
+ invertSwap: props.invertSwap,
45
+ direction: props.direction,
46
+ forceFallback: false
47
+ };
48
+ if (props.handle) options.handle = props.handle;
49
+ else if (props.showHandle) options.handle = ".drag-handle";
50
+ return options;
51
+ });
52
+ const getItemKey = (item, index) => props.itemKey ? props.itemKey(item, index) : item.id ?? index;
53
+ const getItemTitle = (item) => {
54
+ if (props.itemTitle) return props.itemTitle(item);
55
+ return item.title || item.name || item.label || String(item.id) || "未命名项目";
56
+ };
57
+ const getItemDescription = (item) => {
58
+ if (props.itemDescription) return props.itemDescription(item);
59
+ return item.description || "";
60
+ };
61
+ const getItemClass = (_index) => [
62
+ "c-draggable-item",
63
+ props.itemClass,
64
+ { "is-disabled": props.disabled }
65
+ ];
66
+ const handleStart = (event) => {
67
+ isDragging.value = true;
68
+ const item = internalList.value[event.oldIndex];
69
+ if (item) emit("drag-start", {
70
+ oldIndex: event.oldIndex,
71
+ newIndex: event.oldIndex,
72
+ item
73
+ });
74
+ };
75
+ const handleEnd = (event) => {
76
+ const item = internalList.value[event.newIndex];
77
+ if (item) emit("drag-end", {
78
+ oldIndex: event.oldIndex,
79
+ newIndex: event.newIndex,
80
+ item
81
+ });
82
+ nextTick(() => {
83
+ isDragging.value = false;
84
+ });
85
+ };
86
+ const handleAdd = (event) => {
87
+ const item = internalList.value[event.newIndex];
88
+ if (item) emit("item-add", item, event.newIndex);
89
+ };
90
+ const handleRemove = (event) => {
91
+ if (event.item) emit("item-remove", event.item, event.oldIndex);
92
+ };
93
+ const handleUpdate = (_event) => {};
94
+ const addItem = (item, index) => {
95
+ const list = [...internalList.value];
96
+ if (typeof index === "number" && index >= 0 && index <= list.length) list.splice(index, 0, item);
97
+ else list.push(item);
98
+ internalList.value = list;
99
+ };
100
+ const removeItem = (index) => {
101
+ if (index >= 0 && index < internalList.value.length) {
102
+ const list = [...internalList.value];
103
+ const [removed] = list.splice(index, 1);
104
+ internalList.value = list;
105
+ return removed;
106
+ }
107
+ return null;
108
+ };
109
+ const moveItem = (fromIndex, toIndex) => {
110
+ const list = internalList.value;
111
+ if (fromIndex >= 0 && fromIndex < list.length && toIndex >= 0 && toIndex < list.length && fromIndex !== toIndex) {
112
+ const newList = [...list];
113
+ const [item] = newList.splice(fromIndex, 1);
114
+ newList.splice(toIndex, 0, item);
115
+ internalList.value = newList;
116
+ return true;
117
+ }
118
+ return false;
119
+ };
120
+ const updateList = (newList) => {
121
+ internalList.value = [...newList];
122
+ };
123
+ const clear = () => {
124
+ internalList.value = [];
125
+ };
126
+ const getItem = (index) => internalList.value[index];
127
+ const findIndex = (predicate) => internalList.value.findIndex(predicate);
128
+ return {
129
+ isDragging,
130
+ internalList,
131
+ isEmpty,
132
+ listClasses,
133
+ listStyles,
134
+ draggableOptions,
135
+ getItemKey,
136
+ getItemTitle,
137
+ getItemDescription,
138
+ getItemClass,
139
+ handleStart,
140
+ handleEnd,
141
+ handleAdd,
142
+ handleRemove,
143
+ handleUpdate,
144
+ addItem,
145
+ removeItem,
146
+ moveItem,
147
+ updateList,
148
+ clear,
149
+ getItem,
150
+ findIndex
151
+ };
152
+ }
153
+
154
+ //#endregion
155
+ //#region src/components/C_Draggable/index.vue?vue&type=script&setup=true&lang.ts
156
+ const _hoisted_1 = ["data-index"];
157
+ const _hoisted_2 = { class: "default-item" };
158
+ const _hoisted_3 = {
159
+ key: 0,
160
+ class: "drag-handle"
161
+ };
162
+ const _hoisted_4 = { class: "item-content" };
163
+ const _hoisted_5 = { class: "item-title" };
164
+ const _hoisted_6 = {
165
+ key: 0,
166
+ class: "item-description"
167
+ };
168
+ const _hoisted_7 = {
169
+ key: 0,
170
+ class: "empty-state"
171
+ };
172
+ const _hoisted_8 = { class: "default-empty" };
173
+ const _hoisted_9 = { class: "empty-text" };
174
+ var index_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
175
+ name: "C_Draggable",
176
+ __name: "index",
177
+ props: {
178
+ modelValue: { default: () => [] },
179
+ disabled: {
180
+ type: Boolean,
181
+ default: false
182
+ },
183
+ group: { default: "default" },
184
+ sort: {
185
+ type: Boolean,
186
+ default: true
187
+ },
188
+ animation: { default: 200 },
189
+ delay: { default: 0 },
190
+ handle: { default: "" },
191
+ showHandle: {
192
+ type: Boolean,
193
+ default: false
194
+ },
195
+ ghostClass: { default: "sortable-ghost" },
196
+ chosenClass: { default: "sortable-chosen" },
197
+ dragClass: { default: "sortable-drag" },
198
+ wrapperClass: { default: "" },
199
+ listClass: { default: "" },
200
+ itemClass: { default: "" },
201
+ showEmptyState: {
202
+ type: Boolean,
203
+ default: true
204
+ },
205
+ emptyText: { default: "暂无数据" },
206
+ itemKey: {},
207
+ itemTitle: {},
208
+ itemDescription: {},
209
+ swapThreshold: { default: 1 },
210
+ invertSwap: {
211
+ type: Boolean,
212
+ default: false
213
+ },
214
+ direction: { default: "vertical" },
215
+ layout: { default: "vertical" },
216
+ gridColumns: { default: 4 },
217
+ gridRows: { default: void 0 },
218
+ gap: { default: "8px" },
219
+ flexWrap: {
220
+ type: Boolean,
221
+ default: false
222
+ },
223
+ justifyContent: { default: "flex-start" },
224
+ alignItems: { default: "stretch" },
225
+ customStyles: { default: () => ({}) }
226
+ },
227
+ emits: [
228
+ "update:modelValue",
229
+ "drag-start",
230
+ "drag-end",
231
+ "item-add",
232
+ "item-remove",
233
+ "list-change"
234
+ ],
235
+ setup(__props, { expose: __expose, emit: __emit }) {
236
+ const { isDragging, internalList, isEmpty, listClasses, listStyles, draggableOptions, getItemKey, getItemTitle, getItemDescription, getItemClass, handleStart, handleEnd, handleAdd, handleRemove, handleUpdate, addItem, removeItem, moveItem, updateList, clear, getItem, findIndex } = useDraggableLayout(__props, __emit);
237
+ __expose({
238
+ isDragging: readonly(isDragging),
239
+ list: readonly(internalList),
240
+ isEmpty: readonly(isEmpty),
241
+ addItem,
242
+ removeItem,
243
+ moveItem,
244
+ updateList,
245
+ clear,
246
+ getItem,
247
+ findIndex
248
+ });
249
+ return (_ctx, _cache) => {
250
+ return openBlock(), createElementBlock("div", { class: normalizeClass(["c-draggable-wrapper", _ctx.wrapperClass]) }, [createVNode(unref(VueDraggable), mergeProps({
251
+ modelValue: unref(internalList),
252
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(internalList) ? internalList.value = $event : null)
253
+ }, unref(draggableOptions), {
254
+ class: unref(listClasses),
255
+ style: unref(listStyles),
256
+ onStart: unref(handleStart),
257
+ onEnd: unref(handleEnd),
258
+ onAdd: unref(handleAdd),
259
+ onRemove: unref(handleRemove),
260
+ onUpdate: unref(handleUpdate)
261
+ }), {
262
+ default: withCtx(() => [(openBlock(true), createElementBlock(Fragment, null, renderList(unref(internalList), (item, index) => {
263
+ return openBlock(), createElementBlock("div", {
264
+ key: unref(getItemKey)(item, index),
265
+ class: normalizeClass(unref(getItemClass)(index)),
266
+ "data-index": index
267
+ }, [renderSlot(_ctx.$slots, "default", {
268
+ item,
269
+ index,
270
+ isDragging: unref(isDragging),
271
+ isDisabled: _ctx.disabled
272
+ }, () => [createElementVNode("div", _hoisted_2, [_ctx.showHandle ? (openBlock(), createElementBlock("div", _hoisted_3, _cache[1] || (_cache[1] = [createElementVNode("div", { class: "i-mdi:drag-vertical" }, null, -1)]))) : createCommentVNode("v-if", true), createElementVNode("div", _hoisted_4, [createElementVNode("div", _hoisted_5, toDisplayString(unref(getItemTitle)(item)), 1), unref(getItemDescription)(item) ? (openBlock(), createElementBlock("div", _hoisted_6, toDisplayString(unref(getItemDescription)(item)), 1)) : createCommentVNode("v-if", true)])])], true)], 10, _hoisted_1);
273
+ }), 128))]),
274
+ _: 3
275
+ }, 16, [
276
+ "modelValue",
277
+ "class",
278
+ "style",
279
+ "onStart",
280
+ "onEnd",
281
+ "onAdd",
282
+ "onRemove",
283
+ "onUpdate"
284
+ ]), unref(isEmpty) && _ctx.showEmptyState ? (openBlock(), createElementBlock("div", _hoisted_7, [renderSlot(_ctx.$slots, "empty", {}, () => [createElementVNode("div", _hoisted_8, [_cache[2] || (_cache[2] = createElementVNode("div", { class: "empty-icon i-mdi:inbox-outline" }, null, -1)), createElementVNode("p", _hoisted_9, toDisplayString(_ctx.emptyText), 1)])], true)])) : createCommentVNode("v-if", true)], 2);
285
+ };
286
+ }
287
+ });
288
+
289
+ //#endregion
290
+ //#region src/components/C_Draggable/index.vue
291
+ var C_Draggable_default = /* @__PURE__ */ export_helper_default(index_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-68fb07e5"]]);
292
+
293
+ //#endregion
294
+ export { useDraggableLayout as n, C_Draggable_default as t };
295
+ //# sourceMappingURL=C_Draggable2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"C_Draggable2.js","names":["wrapperClass","disabled","showHandle","showEmptyState","emptyText"],"sources":["../src/components/C_Draggable/composables/useDraggableLayout.ts","../src/components/C_Draggable/index.vue","../src/components/C_Draggable/index.vue","../src/components/C_Draggable/index.vue"],"sourcesContent":["import { ref, computed, nextTick } from \"vue\";\r\nimport type { DraggableItem, DragEvent, DraggableProps } from \"../types\";\r\n\r\ntype EmitFn = {\r\n (event: \"update:modelValue\", value: DraggableItem[]): void;\r\n (event: \"drag-start\", dragEvent: DragEvent): void;\r\n (event: \"drag-end\", dragEvent: DragEvent): void;\r\n (event: \"item-add\", item: DraggableItem, index: number): void;\r\n (event: \"item-remove\", item: DraggableItem, index: number): void;\r\n (event: \"list-change\", list: DraggableItem[]): void;\r\n};\r\n\r\nexport function useDraggableLayout(props: DraggableProps, emit: EmitFn) {\r\n const isDragging = ref(false);\r\n\r\n const internalList = computed({\r\n get: () => props.modelValue ?? [],\r\n set: (value: DraggableItem[]) => {\r\n emit(\"update:modelValue\", value);\r\n emit(\"list-change\", value);\r\n },\r\n });\r\n\r\n const isEmpty = computed(() => (props.modelValue ?? []).length === 0);\r\n\r\n const listClasses = computed(() => [\r\n \"c-draggable-list\",\r\n props.listClass,\r\n `layout-${props.layout}`,\r\n {\r\n \"flex-wrap\":\r\n props.flexWrap &&\r\n (props.layout === \"horizontal\" || props.layout === \"flex-wrap\"),\r\n },\r\n ]);\r\n\r\n const listStyles = computed(() => {\r\n const styles: Record<string, string | number> = {\r\n \"--gap\":\r\n typeof props.gap === \"number\" ? `${props.gap}px` : (props.gap ?? \"8px\"),\r\n \"--grid-columns\": props.gridColumns ?? 4,\r\n \"--justify-content\": props.justifyContent ?? \"flex-start\",\r\n \"--align-items\": props.alignItems ?? \"stretch\",\r\n ...props.customStyles,\r\n };\r\n if (props.gridRows) {\r\n styles[\"--grid-rows\"] = props.gridRows;\r\n }\r\n return styles;\r\n });\r\n\r\n const draggableOptions = computed(() => {\r\n const options: Record<string, any> = {\r\n disabled: props.disabled,\r\n group: props.group,\r\n sort: props.sort,\r\n animation: props.animation,\r\n delay: props.delay,\r\n ghostClass: props.ghostClass,\r\n chosenClass: props.chosenClass,\r\n dragClass: props.dragClass,\r\n swapThreshold: props.swapThreshold,\r\n invertSwap: props.invertSwap,\r\n direction: props.direction,\r\n forceFallback: false,\r\n };\r\n if (props.handle) {\r\n options.handle = props.handle;\r\n } else if (props.showHandle) {\r\n options.handle = \".drag-handle\";\r\n }\r\n return options;\r\n });\r\n\r\n const getItemKey = (item: DraggableItem, index: number): string | number =>\r\n props.itemKey ? props.itemKey(item, index) : (item.id ?? index);\r\n\r\n const getItemTitle = (item: DraggableItem): string => {\r\n if (props.itemTitle) return props.itemTitle(item);\r\n return (\r\n item.title || item.name || item.label || String(item.id) || \"未命名项目\"\r\n );\r\n };\r\n\r\n const getItemDescription = (item: DraggableItem): string => {\r\n if (props.itemDescription) return props.itemDescription(item);\r\n return item.description || \"\";\r\n };\r\n\r\n const getItemClass = (_index: number) => [\r\n \"c-draggable-item\",\r\n props.itemClass,\r\n { \"is-disabled\": props.disabled },\r\n ];\r\n\r\n const handleStart = (event: any) => {\r\n isDragging.value = true;\r\n const item = internalList.value[event.oldIndex];\r\n if (item) {\r\n emit(\"drag-start\", {\r\n oldIndex: event.oldIndex,\r\n newIndex: event.oldIndex,\r\n item,\r\n } as DragEvent);\r\n }\r\n };\r\n\r\n const handleEnd = (event: any) => {\r\n const item = internalList.value[event.newIndex];\r\n if (item) {\r\n emit(\"drag-end\", {\r\n oldIndex: event.oldIndex,\r\n newIndex: event.newIndex,\r\n item,\r\n } as DragEvent);\r\n }\r\n nextTick(() => {\r\n isDragging.value = false;\r\n });\r\n };\r\n\r\n const handleAdd = (event: any) => {\r\n const item = internalList.value[event.newIndex];\r\n if (item) emit(\"item-add\", item, event.newIndex);\r\n };\r\n\r\n const handleRemove = (event: any) => {\r\n if (event.item) emit(\"item-remove\", event.item, event.oldIndex);\r\n };\r\n\r\n const handleUpdate = (_event: any) => {};\r\n\r\n const addItem = (item: DraggableItem, index?: number): void => {\r\n const list = [...internalList.value];\r\n if (typeof index === \"number\" && index >= 0 && index <= list.length) {\r\n list.splice(index, 0, item);\r\n } else {\r\n list.push(item);\r\n }\r\n internalList.value = list;\r\n };\r\n\r\n const removeItem = (index: number): DraggableItem | null => {\r\n if (index >= 0 && index < internalList.value.length) {\r\n const list = [...internalList.value];\r\n const [removed] = list.splice(index, 1);\r\n internalList.value = list;\r\n return removed;\r\n }\r\n return null;\r\n };\r\n\r\n const moveItem = (fromIndex: number, toIndex: number): boolean => {\r\n const list = internalList.value;\r\n if (\r\n fromIndex >= 0 &&\r\n fromIndex < list.length &&\r\n toIndex >= 0 &&\r\n toIndex < list.length &&\r\n fromIndex !== toIndex\r\n ) {\r\n const newList = [...list];\r\n const [item] = newList.splice(fromIndex, 1);\r\n newList.splice(toIndex, 0, item);\r\n internalList.value = newList;\r\n return true;\r\n }\r\n return false;\r\n };\r\n\r\n const updateList = (newList: DraggableItem[]): void => {\r\n internalList.value = [...newList];\r\n };\r\n\r\n const clear = (): void => {\r\n internalList.value = [];\r\n };\r\n\r\n const getItem = (index: number): DraggableItem | undefined =>\r\n internalList.value[index];\r\n\r\n const findIndex = (predicate: (item: DraggableItem) => boolean): number =>\r\n internalList.value.findIndex(predicate);\r\n\r\n return {\r\n isDragging,\r\n internalList,\r\n isEmpty,\r\n listClasses,\r\n listStyles,\r\n draggableOptions,\r\n getItemKey,\r\n getItemTitle,\r\n getItemDescription,\r\n getItemClass,\r\n handleStart,\r\n handleEnd,\r\n handleAdd,\r\n handleRemove,\r\n handleUpdate,\r\n addItem,\r\n removeItem,\r\n moveItem,\r\n updateList,\r\n clear,\r\n getItem,\r\n findIndex,\r\n };\r\n}\r\n","<!--\r\n * @Author: ChenYu ycyplus@gmail.com\r\n * @Date: 2025-06-25\r\n * @Description: 拖拽组件 - 基于 vue-draggable-plus 封装(薄 UI 壳 + useDraggableLayout 引擎)\r\n * @Migration: naive-ui-components 组件库迁移版本\r\n * Copyright (c) 2025 by CHENY, All Rights Reserved.\r\n-->\r\n<template>\r\n <div class=\"c-draggable-wrapper\" :class=\"wrapperClass\">\r\n <VueDraggable\r\n v-model=\"internalList\"\r\n v-bind=\"draggableOptions\"\r\n :class=\"listClasses\"\r\n :style=\"listStyles\"\r\n @start=\"handleStart\"\r\n @end=\"handleEnd\"\r\n @add=\"handleAdd\"\r\n @remove=\"handleRemove\"\r\n @update=\"handleUpdate\"\r\n >\r\n <div\r\n v-for=\"(item, index) in internalList\"\r\n :key=\"getItemKey(item, index)\"\r\n :class=\"getItemClass(index)\"\r\n :data-index=\"index\"\r\n >\r\n <slot\r\n :item=\"item\"\r\n :index=\"index\"\r\n :is-dragging=\"isDragging\"\r\n :is-disabled=\"disabled\"\r\n >\r\n <div class=\"default-item\">\r\n <div v-if=\"showHandle\" class=\"drag-handle\">\r\n <div class=\"i-mdi:drag-vertical\"></div>\r\n </div>\r\n <div class=\"item-content\">\r\n <div class=\"item-title\">{{ getItemTitle(item) }}</div>\r\n <div v-if=\"getItemDescription(item)\" class=\"item-description\">\r\n {{ getItemDescription(item) }}\r\n </div>\r\n </div>\r\n </div>\r\n </slot>\r\n </div>\r\n </VueDraggable>\r\n\r\n <div v-if=\"isEmpty && showEmptyState\" class=\"empty-state\">\r\n <slot name=\"empty\">\r\n <div class=\"default-empty\">\r\n <div class=\"empty-icon i-mdi:inbox-outline\"></div>\r\n <p class=\"empty-text\">{{ emptyText }}</p>\r\n </div>\r\n </slot>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { readonly } from \"vue\";\r\nimport { VueDraggable } from \"vue-draggable-plus\";\r\nimport { useDraggableLayout } from \"./composables/useDraggableLayout\";\r\nimport type { DraggableProps, DraggableEmits } from \"./types\";\r\n\r\ndefineOptions({ name: \"C_Draggable\" });\r\n\r\nconst props = withDefaults(defineProps<DraggableProps>(), {\r\n modelValue: () => [],\r\n disabled: false,\r\n group: \"default\",\r\n sort: true,\r\n animation: 200,\r\n delay: 0,\r\n handle: \"\",\r\n showHandle: false,\r\n ghostClass: \"sortable-ghost\",\r\n chosenClass: \"sortable-chosen\",\r\n dragClass: \"sortable-drag\",\r\n wrapperClass: \"\",\r\n listClass: \"\",\r\n itemClass: \"\",\r\n showEmptyState: true,\r\n emptyText: \"暂无数据\",\r\n swapThreshold: 1,\r\n invertSwap: false,\r\n direction: \"vertical\",\r\n layout: \"vertical\",\r\n gridColumns: 4,\r\n gridRows: undefined,\r\n gap: \"8px\",\r\n flexWrap: false,\r\n justifyContent: \"flex-start\",\r\n alignItems: \"stretch\",\r\n customStyles: () => ({}),\r\n});\r\n\r\nconst emit = defineEmits<DraggableEmits>();\r\n\r\nconst {\r\n isDragging,\r\n internalList,\r\n isEmpty,\r\n listClasses,\r\n listStyles,\r\n draggableOptions,\r\n getItemKey,\r\n getItemTitle,\r\n getItemDescription,\r\n getItemClass,\r\n handleStart,\r\n handleEnd,\r\n handleAdd,\r\n handleRemove,\r\n handleUpdate,\r\n addItem,\r\n removeItem,\r\n moveItem,\r\n updateList,\r\n clear,\r\n getItem,\r\n findIndex,\r\n} = useDraggableLayout(props, emit);\r\n\r\ndefineExpose({\r\n isDragging: readonly(isDragging),\r\n list: readonly(internalList),\r\n isEmpty: readonly(isEmpty),\r\n addItem,\r\n removeItem,\r\n moveItem,\r\n updateList,\r\n clear,\r\n getItem,\r\n findIndex,\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n@use \"./index.scss\";\r\n</style>\r\n","<!--\r\n * @Author: ChenYu ycyplus@gmail.com\r\n * @Date: 2025-06-25\r\n * @Description: 拖拽组件 - 基于 vue-draggable-plus 封装(薄 UI 壳 + useDraggableLayout 引擎)\r\n * @Migration: naive-ui-components 组件库迁移版本\r\n * Copyright (c) 2025 by CHENY, All Rights Reserved.\r\n-->\r\n<template>\r\n <div class=\"c-draggable-wrapper\" :class=\"wrapperClass\">\r\n <VueDraggable\r\n v-model=\"internalList\"\r\n v-bind=\"draggableOptions\"\r\n :class=\"listClasses\"\r\n :style=\"listStyles\"\r\n @start=\"handleStart\"\r\n @end=\"handleEnd\"\r\n @add=\"handleAdd\"\r\n @remove=\"handleRemove\"\r\n @update=\"handleUpdate\"\r\n >\r\n <div\r\n v-for=\"(item, index) in internalList\"\r\n :key=\"getItemKey(item, index)\"\r\n :class=\"getItemClass(index)\"\r\n :data-index=\"index\"\r\n >\r\n <slot\r\n :item=\"item\"\r\n :index=\"index\"\r\n :is-dragging=\"isDragging\"\r\n :is-disabled=\"disabled\"\r\n >\r\n <div class=\"default-item\">\r\n <div v-if=\"showHandle\" class=\"drag-handle\">\r\n <div class=\"i-mdi:drag-vertical\"></div>\r\n </div>\r\n <div class=\"item-content\">\r\n <div class=\"item-title\">{{ getItemTitle(item) }}</div>\r\n <div v-if=\"getItemDescription(item)\" class=\"item-description\">\r\n {{ getItemDescription(item) }}\r\n </div>\r\n </div>\r\n </div>\r\n </slot>\r\n </div>\r\n </VueDraggable>\r\n\r\n <div v-if=\"isEmpty && showEmptyState\" class=\"empty-state\">\r\n <slot name=\"empty\">\r\n <div class=\"default-empty\">\r\n <div class=\"empty-icon i-mdi:inbox-outline\"></div>\r\n <p class=\"empty-text\">{{ emptyText }}</p>\r\n </div>\r\n </slot>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { readonly } from \"vue\";\r\nimport { VueDraggable } from \"vue-draggable-plus\";\r\nimport { useDraggableLayout } from \"./composables/useDraggableLayout\";\r\nimport type { DraggableProps, DraggableEmits } from \"./types\";\r\n\r\ndefineOptions({ name: \"C_Draggable\" });\r\n\r\nconst props = withDefaults(defineProps<DraggableProps>(), {\r\n modelValue: () => [],\r\n disabled: false,\r\n group: \"default\",\r\n sort: true,\r\n animation: 200,\r\n delay: 0,\r\n handle: \"\",\r\n showHandle: false,\r\n ghostClass: \"sortable-ghost\",\r\n chosenClass: \"sortable-chosen\",\r\n dragClass: \"sortable-drag\",\r\n wrapperClass: \"\",\r\n listClass: \"\",\r\n itemClass: \"\",\r\n showEmptyState: true,\r\n emptyText: \"暂无数据\",\r\n swapThreshold: 1,\r\n invertSwap: false,\r\n direction: \"vertical\",\r\n layout: \"vertical\",\r\n gridColumns: 4,\r\n gridRows: undefined,\r\n gap: \"8px\",\r\n flexWrap: false,\r\n justifyContent: \"flex-start\",\r\n alignItems: \"stretch\",\r\n customStyles: () => ({}),\r\n});\r\n\r\nconst emit = defineEmits<DraggableEmits>();\r\n\r\nconst {\r\n isDragging,\r\n internalList,\r\n isEmpty,\r\n listClasses,\r\n listStyles,\r\n draggableOptions,\r\n getItemKey,\r\n getItemTitle,\r\n getItemDescription,\r\n getItemClass,\r\n handleStart,\r\n handleEnd,\r\n handleAdd,\r\n handleRemove,\r\n handleUpdate,\r\n addItem,\r\n removeItem,\r\n moveItem,\r\n updateList,\r\n clear,\r\n getItem,\r\n findIndex,\r\n} = useDraggableLayout(props, emit);\r\n\r\ndefineExpose({\r\n isDragging: readonly(isDragging),\r\n list: readonly(internalList),\r\n isEmpty: readonly(isEmpty),\r\n addItem,\r\n removeItem,\r\n moveItem,\r\n updateList,\r\n clear,\r\n getItem,\r\n findIndex,\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n@use \"./index.scss\";\r\n</style>\r\n","<!--\r\n * @Author: ChenYu ycyplus@gmail.com\r\n * @Date: 2025-06-25\r\n * @Description: 拖拽组件 - 基于 vue-draggable-plus 封装(薄 UI 壳 + useDraggableLayout 引擎)\r\n * @Migration: naive-ui-components 组件库迁移版本\r\n * Copyright (c) 2025 by CHENY, All Rights Reserved.\r\n-->\r\n<template>\r\n <div class=\"c-draggable-wrapper\" :class=\"wrapperClass\">\r\n <VueDraggable\r\n v-model=\"internalList\"\r\n v-bind=\"draggableOptions\"\r\n :class=\"listClasses\"\r\n :style=\"listStyles\"\r\n @start=\"handleStart\"\r\n @end=\"handleEnd\"\r\n @add=\"handleAdd\"\r\n @remove=\"handleRemove\"\r\n @update=\"handleUpdate\"\r\n >\r\n <div\r\n v-for=\"(item, index) in internalList\"\r\n :key=\"getItemKey(item, index)\"\r\n :class=\"getItemClass(index)\"\r\n :data-index=\"index\"\r\n >\r\n <slot\r\n :item=\"item\"\r\n :index=\"index\"\r\n :is-dragging=\"isDragging\"\r\n :is-disabled=\"disabled\"\r\n >\r\n <div class=\"default-item\">\r\n <div v-if=\"showHandle\" class=\"drag-handle\">\r\n <div class=\"i-mdi:drag-vertical\"></div>\r\n </div>\r\n <div class=\"item-content\">\r\n <div class=\"item-title\">{{ getItemTitle(item) }}</div>\r\n <div v-if=\"getItemDescription(item)\" class=\"item-description\">\r\n {{ getItemDescription(item) }}\r\n </div>\r\n </div>\r\n </div>\r\n </slot>\r\n </div>\r\n </VueDraggable>\r\n\r\n <div v-if=\"isEmpty && showEmptyState\" class=\"empty-state\">\r\n <slot name=\"empty\">\r\n <div class=\"default-empty\">\r\n <div class=\"empty-icon i-mdi:inbox-outline\"></div>\r\n <p class=\"empty-text\">{{ emptyText }}</p>\r\n </div>\r\n </slot>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { readonly } from \"vue\";\r\nimport { VueDraggable } from \"vue-draggable-plus\";\r\nimport { useDraggableLayout } from \"./composables/useDraggableLayout\";\r\nimport type { DraggableProps, DraggableEmits } from \"./types\";\r\n\r\ndefineOptions({ name: \"C_Draggable\" });\r\n\r\nconst props = withDefaults(defineProps<DraggableProps>(), {\r\n modelValue: () => [],\r\n disabled: false,\r\n group: \"default\",\r\n sort: true,\r\n animation: 200,\r\n delay: 0,\r\n handle: \"\",\r\n showHandle: false,\r\n ghostClass: \"sortable-ghost\",\r\n chosenClass: \"sortable-chosen\",\r\n dragClass: \"sortable-drag\",\r\n wrapperClass: \"\",\r\n listClass: \"\",\r\n itemClass: \"\",\r\n showEmptyState: true,\r\n emptyText: \"暂无数据\",\r\n swapThreshold: 1,\r\n invertSwap: false,\r\n direction: \"vertical\",\r\n layout: \"vertical\",\r\n gridColumns: 4,\r\n gridRows: undefined,\r\n gap: \"8px\",\r\n flexWrap: false,\r\n justifyContent: \"flex-start\",\r\n alignItems: \"stretch\",\r\n customStyles: () => ({}),\r\n});\r\n\r\nconst emit = defineEmits<DraggableEmits>();\r\n\r\nconst {\r\n isDragging,\r\n internalList,\r\n isEmpty,\r\n listClasses,\r\n listStyles,\r\n draggableOptions,\r\n getItemKey,\r\n getItemTitle,\r\n getItemDescription,\r\n getItemClass,\r\n handleStart,\r\n handleEnd,\r\n handleAdd,\r\n handleRemove,\r\n handleUpdate,\r\n addItem,\r\n removeItem,\r\n moveItem,\r\n updateList,\r\n clear,\r\n getItem,\r\n findIndex,\r\n} = useDraggableLayout(props, emit);\r\n\r\ndefineExpose({\r\n isDragging: readonly(isDragging),\r\n list: readonly(internalList),\r\n isEmpty: readonly(isEmpty),\r\n addItem,\r\n removeItem,\r\n moveItem,\r\n updateList,\r\n clear,\r\n getItem,\r\n findIndex,\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n@use \"./index.scss\";\r\n</style>\r\n"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"C_Editor-Bp0SyIEw.css","names":[],"sources":["../src/components/C_Editor/index.vue?vue&type=style&index=0&scoped=9ff5e94d&lang.css"],"sourcesContent":["\r\n/* 暗色主题样式 */\n.editor-dark[data-v-9ff5e94d] .w-e-toolbar {\r\n background-color: #1f2937 !important;\r\n border-color: #374151 !important;\n}\n.editor-dark[data-v-9ff5e94d] .w-e-toolbar .w-e-menu .w-e-menu-item {\r\n color: #e5e7eb !important;\n}\n.editor-dark[data-v-9ff5e94d] .w-e-toolbar .w-e-menu .w-e-menu-item:hover {\r\n background-color: #374151 !important;\r\n color: #ffffff !important;\n}\n.editor-dark[data-v-9ff5e94d] .w-e-toolbar .w-e-menu .w-e-menu-item.w-e-active {\r\n background-color: #2080f0 !important;\r\n color: #ffffff !important;\n}\n.editor-dark[data-v-9ff5e94d] .w-e-text-container {\r\n background-color: #111827 !important;\r\n border-color: #374151 !important;\n}\n.editor-dark[data-v-9ff5e94d] .w-e-text-container .w-e-text {\r\n background-color: #303033 !important;\r\n color: #e5e7eb !important;\n}\n.editor-dark[data-v-9ff5e94d] .w-e-text-container .w-e-text:focus {\r\n background-color: #111827 !important;\r\n color: #e5e7eb !important;\n}\n[data-v-9ff5e94d] .w-e-toolbar,[data-v-9ff5e94d] .w-e-text-container {\r\n max-width: 100% !important;\r\n overflow-x: auto !important;\r\n box-sizing: border-box !important;\n}\n[data-v-9ff5e94d] .w-e-text {\r\n max-width: 100% !important;\r\n word-wrap: break-word !important;\r\n overflow-wrap: break-word !important;\n}\n[data-v-9ff5e94d] .w-e-toolbar,[data-v-9ff5e94d] .w-e-text-container,[data-v-9ff5e94d] .w-e-text {\r\n transition:\r\n background-color 0.3s ease,\r\n border-color 0.3s ease,\r\n color 0.3s ease !important;\n}\n.editor-focused[data-v-9ff5e94d] {\r\n overflow: hidden !important;\r\n max-width: 100% !important;\n}\r\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA"}
@@ -0,0 +1,4 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+ const require_C_Editor = require('./C_Editor.js');
3
+
4
+ exports.C_Editor = require_C_Editor.C_Editor_default;
@@ -0,0 +1,2 @@
1
+ import { t as _default } from "./index8.vue.js";
2
+ export { _default as C_Editor };
@@ -0,0 +1,2 @@
1
+ import { t as _default } from "./index8.vue.js";
2
+ export { _default as C_Editor };
@@ -0,0 +1,3 @@
1
+ import { t as C_Editor_default } from "./C_Editor2.js";
2
+
3
+ export { C_Editor_default as C_Editor };
@@ -0,0 +1,160 @@
1
+ import { t as export_helper_default } from "./export-helper.js";
2
+ import { computed, createElementBlock, defineComponent, nextTick, normalizeClass, onBeforeUnmount, onMounted, openBlock, readonly, ref, vShow, watch, withDirectives } from "vue";
3
+ import E from "wangeditor";
4
+
5
+ //#region src/components/C_Editor/index.vue?vue&type=script&setup=true&lang.ts
6
+ const _hoisted_1 = ["id"];
7
+ var index_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
8
+ name: "C_Editor",
9
+ __name: "index",
10
+ props: {
11
+ editorId: {},
12
+ modelValue: { default: "" },
13
+ placeholder: { default: "" },
14
+ disabled: {
15
+ type: Boolean,
16
+ default: false
17
+ },
18
+ readonly: {
19
+ type: Boolean,
20
+ default: false
21
+ },
22
+ height: { default: 240 },
23
+ theme: { default: "light" }
24
+ },
25
+ emits: [
26
+ "update:modelValue",
27
+ "editor-mounted",
28
+ "editor-change"
29
+ ],
30
+ setup(__props, { expose: __expose, emit: __emit }) {
31
+ const props = __props;
32
+ const emit = __emit;
33
+ const editorContainer = ref(null);
34
+ const editorInstance = ref(null);
35
+ const isInitialized = ref(false);
36
+ const isDark = computed(() => props.theme === "dark");
37
+ const initializeEditor = () => {
38
+ if (!editorContainer.value || isInitialized.value) return;
39
+ try {
40
+ const editor = new E(editorContainer.value);
41
+ const editorConfig = editor.config;
42
+ editorConfig.placeholder = props.placeholder;
43
+ editorConfig.height = props.height - 50;
44
+ editorConfig.onchange = (html) => {
45
+ emit("update:modelValue", html);
46
+ emit("editor-change", html);
47
+ };
48
+ editor.create();
49
+ nextTick(() => {
50
+ if (props.modelValue) editor.txt.html(props.modelValue);
51
+ if (props.readonly) editor.disable();
52
+ editorInstance.value = editor;
53
+ isInitialized.value = true;
54
+ emit("editor-mounted", editor);
55
+ });
56
+ } catch (error) {
57
+ console.error(`[C_Editor] 编辑器初始化失败: ${props.editorId}`, error);
58
+ }
59
+ };
60
+ const destroyEditor = () => {
61
+ if (editorInstance.value && isInitialized.value) try {
62
+ editorInstance.value.destroy();
63
+ editorInstance.value = null;
64
+ isInitialized.value = false;
65
+ } catch (error) {
66
+ console.error(`[C_Editor] 编辑器销毁失败: ${props.editorId}`, error);
67
+ }
68
+ };
69
+ const setContent = (html) => {
70
+ if (editorInstance.value && isInitialized.value) try {
71
+ editorInstance.value.txt.html(html);
72
+ } catch (error) {
73
+ console.warn(`[C_Editor] 设置编辑器内容失败: ${props.editorId}`, error);
74
+ }
75
+ };
76
+ const getContent = () => {
77
+ if (editorInstance.value && isInitialized.value) try {
78
+ return editorInstance.value.txt.html();
79
+ } catch (error) {
80
+ console.warn(`[C_Editor] 获取编辑器内容失败: ${props.editorId}`, error);
81
+ return "";
82
+ }
83
+ return "";
84
+ };
85
+ watch(() => props.modelValue, (newValue) => {
86
+ if (editorInstance.value && isInitialized.value) {
87
+ if (editorInstance.value.txt.html() !== newValue) editorInstance.value.txt.html(newValue || "");
88
+ }
89
+ });
90
+ watch(() => props.disabled, (disabled) => {
91
+ if (editorInstance.value && isInitialized.value) try {
92
+ if (disabled) editorInstance.value.disable();
93
+ else editorInstance.value.enable();
94
+ } catch (error) {
95
+ console.warn(`[C_Editor] 设置编辑器状态失败`, error);
96
+ }
97
+ });
98
+ watch(() => props.readonly, (readonlyVal) => {
99
+ if (editorInstance.value && isInitialized.value) try {
100
+ if (readonlyVal) editorInstance.value.disable();
101
+ else editorInstance.value.enable();
102
+ } catch (error) {
103
+ console.warn(`[C_Editor] 设置编辑器只读状态失败`, error);
104
+ }
105
+ });
106
+ const handleEditorFocus = () => {
107
+ if (!editorContainer.value) return;
108
+ const container = editorContainer.value.closest(".form-demo");
109
+ if (container) {
110
+ container.classList.add("editor-focused");
111
+ const containerWidth = container.scrollWidth;
112
+ container.style.maxWidth = `${containerWidth}px`;
113
+ }
114
+ };
115
+ const handleEditorBlur = () => {
116
+ if (!editorContainer.value) return;
117
+ const container = editorContainer.value.closest(".form-demo");
118
+ if (container) {
119
+ container.classList.remove("editor-focused");
120
+ container.style.maxWidth = "";
121
+ }
122
+ };
123
+ onMounted(() => {
124
+ nextTick(() => {
125
+ initializeEditor();
126
+ });
127
+ });
128
+ onBeforeUnmount(() => {
129
+ destroyEditor();
130
+ });
131
+ __expose({
132
+ initializeEditor,
133
+ destroyEditor,
134
+ setContent,
135
+ getContent,
136
+ handleEditorFocus,
137
+ handleEditorBlur,
138
+ editorInstance: readonly(editorInstance),
139
+ isInitialized: readonly(isInitialized)
140
+ });
141
+ return (_ctx, _cache) => {
142
+ return withDirectives((openBlock(), createElementBlock("div", {
143
+ ref_key: "editorContainer",
144
+ ref: editorContainer,
145
+ id: _ctx.editorId,
146
+ class: normalizeClass(["w-full", { "editor-dark": isDark.value }]),
147
+ onFocusin: handleEditorFocus,
148
+ onFocusout: handleEditorBlur
149
+ }, null, 42, _hoisted_1)), [[vShow, isInitialized.value]]);
150
+ };
151
+ }
152
+ });
153
+
154
+ //#endregion
155
+ //#region src/components/C_Editor/index.vue
156
+ var C_Editor_default = /* @__PURE__ */ export_helper_default(index_vue_vue_type_script_setup_true_lang_default, [["__scopeId", "data-v-9ff5e94d"]]);
157
+
158
+ //#endregion
159
+ export { C_Editor_default as t };
160
+ //# sourceMappingURL=C_Editor2.js.map