@farris/ui-vue 1.7.0-beta.4 → 1.7.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 (563) hide show
  1. package/components/accordion/index.esm.js +61 -312
  2. package/components/accordion/index.umd.cjs +1 -1
  3. package/components/avatar/index.esm.js +56 -1481
  4. package/components/avatar/index.umd.cjs +1 -1
  5. package/components/binding-selector/index.esm.js +8 -752
  6. package/components/binding-selector/index.umd.cjs +1 -1
  7. package/components/button-edit/index.esm.js +358 -351
  8. package/components/button-edit/index.umd.cjs +1 -1
  9. package/components/button-group/index.esm.js +110 -266
  10. package/components/button-group/index.umd.cjs +1 -1
  11. package/components/calendar/index.esm.js +1371 -1284
  12. package/components/calendar/index.umd.cjs +30 -30
  13. package/components/code-editor/index.esm.js +169 -237
  14. package/components/code-editor/index.umd.cjs +3 -3
  15. package/components/collection-property-editor/index.esm.js +382 -351
  16. package/components/collection-property-editor/index.umd.cjs +2 -2
  17. package/components/color-picker/index.esm.js +502 -812
  18. package/components/color-picker/index.umd.cjs +1 -1
  19. package/components/combo-list/index.esm.js +197 -183
  20. package/components/combo-list/index.umd.cjs +1 -1
  21. package/components/combo-tree/index.esm.js +199 -364
  22. package/components/combo-tree/index.umd.cjs +1 -1
  23. package/components/comment/index.esm.js +1501 -1465
  24. package/components/comment/index.umd.cjs +6 -6
  25. package/components/common/index.esm.js +136 -100
  26. package/components/common/index.umd.cjs +1 -1
  27. package/components/component/index.css +1 -1
  28. package/components/component/index.esm.js +2662 -3647
  29. package/components/component/index.umd.cjs +1 -8
  30. package/components/condition/index.esm.js +492 -2449
  31. package/components/condition/index.umd.cjs +1 -8
  32. package/components/content-container/index.esm.js +252 -241
  33. package/components/content-container/index.umd.cjs +1 -1
  34. package/components/data-grid/index.esm.js +505 -409
  35. package/components/data-grid/index.umd.cjs +1 -1
  36. package/components/data-view/index.esm.js +3326 -3258
  37. package/components/data-view/index.umd.cjs +1 -1
  38. package/components/date-picker/index.esm.js +1709 -1634
  39. package/components/date-picker/index.umd.cjs +1 -1
  40. package/components/designer-canvas/index.css +1 -1
  41. package/components/designer-canvas/index.esm.js +2693 -3021
  42. package/components/designer-canvas/index.umd.cjs +1 -1
  43. package/components/designer-outline/index.esm.js +102 -98
  44. package/components/designer-outline/index.umd.cjs +1 -1
  45. package/components/drawer/index.esm.js +409 -358
  46. package/components/drawer/index.umd.cjs +2 -2
  47. package/components/dropdown/index.esm.js +124 -373
  48. package/components/dropdown/index.umd.cjs +2 -2
  49. package/components/dynamic-form/index.esm.js +760 -573
  50. package/components/dynamic-form/index.umd.cjs +1 -1
  51. package/components/dynamic-resolver/index.esm.js +354 -327
  52. package/components/dynamic-resolver/index.umd.cjs +2 -2
  53. package/components/dynamic-view/index.esm.js +413 -359
  54. package/components/dynamic-view/index.umd.cjs +1 -1
  55. package/components/event-parameter/index.esm.js +1 -1
  56. package/components/event-parameter/index.umd.cjs +1 -1
  57. package/components/events-editor/index.css +1 -1
  58. package/components/events-editor/index.esm.js +1535 -1941
  59. package/components/events-editor/index.umd.cjs +3 -3
  60. package/components/expression-editor/index.css +1 -1
  61. package/components/expression-editor/index.esm.js +2 -7317
  62. package/components/expression-editor/index.umd.cjs +1 -427
  63. package/components/field-selector/index.esm.js +13 -13
  64. package/components/field-selector/index.umd.cjs +1 -1
  65. package/components/fieldset/index.esm.js +140 -123
  66. package/components/fieldset/index.umd.cjs +1 -1
  67. package/components/filter-bar/index.esm.js +1021 -1012
  68. package/components/filter-bar/index.umd.cjs +2 -2
  69. package/components/filter-condition-editor/index.css +1 -1
  70. package/components/filter-condition-editor/index.esm.js +448 -9000
  71. package/components/filter-condition-editor/index.umd.cjs +1 -427
  72. package/components/html-template/index.esm.js +167 -147
  73. package/components/html-template/index.umd.cjs +1 -1
  74. package/components/image/index.esm.js +372 -352
  75. package/components/image/index.umd.cjs +2 -2
  76. package/components/image-cropper/index.esm.js +361 -615
  77. package/components/image-cropper/index.umd.cjs +1 -1
  78. package/components/json-editor/index.esm.js +247 -325
  79. package/components/json-editor/index.umd.cjs +1 -1
  80. package/components/language-textbox/index.esm.js +835 -421
  81. package/components/language-textbox/index.umd.cjs +2 -2
  82. package/components/layout/index.esm.js +163 -549
  83. package/components/layout/index.umd.cjs +1 -1
  84. package/components/list-nav/index.esm.js +39 -836
  85. package/components/list-nav/index.umd.cjs +1 -1
  86. package/components/list-view/index.esm.js +690 -474
  87. package/components/list-view/index.umd.cjs +6 -8
  88. package/components/loading/index.esm.js +128 -97
  89. package/components/loading/index.umd.cjs +2 -2
  90. package/components/locale/index.esm.js +361 -340
  91. package/components/locale/index.umd.cjs +5 -5
  92. package/components/lookup/index.css +1 -1
  93. package/components/lookup/index.esm.js +3396 -3368
  94. package/components/lookup/index.umd.cjs +1 -1
  95. package/components/mapping-editor/index.css +1 -1
  96. package/components/mapping-editor/index.esm.js +1684 -1584
  97. package/components/mapping-editor/index.umd.cjs +1 -1
  98. package/components/menu-lookup/index.esm.js +586 -609
  99. package/components/menu-lookup/index.umd.cjs +6 -6
  100. package/components/message-box/index.css +1 -1
  101. package/components/message-box/index.esm.js +357 -353
  102. package/components/message-box/index.umd.cjs +1 -1
  103. package/components/modal/index.esm.js +325 -318
  104. package/components/modal/index.umd.cjs +1 -1
  105. package/components/nav/index.esm.js +31 -311
  106. package/components/nav/index.umd.cjs +1 -1
  107. package/components/number-range/index.esm.js +189 -1633
  108. package/components/number-range/index.umd.cjs +1 -1
  109. package/components/number-spinner/index.esm.js +195 -175
  110. package/components/number-spinner/index.umd.cjs +1 -1
  111. package/components/order/index.esm.js +761 -1057
  112. package/components/order/index.umd.cjs +7 -9
  113. package/components/page-footer/index.esm.js +48 -331
  114. package/components/page-footer/index.umd.cjs +1 -1
  115. package/components/page-header/index.esm.js +92 -73
  116. package/components/page-header/index.umd.cjs +1 -1
  117. package/components/pagination/index.esm.js +195 -472
  118. package/components/pagination/index.umd.cjs +1 -1
  119. package/components/popover/index.esm.js +77 -76
  120. package/components/popover/index.umd.cjs +1 -1
  121. package/components/progress/index.esm.js +148 -353
  122. package/components/progress/index.umd.cjs +3 -3
  123. package/components/property-editor/index.esm.js +74 -68
  124. package/components/property-editor/index.umd.cjs +1 -1
  125. package/components/property-panel/index.esm.js +872 -1800
  126. package/components/property-panel/index.umd.cjs +5 -12
  127. package/components/query-solution/index.css +1 -1
  128. package/components/query-solution/index.esm.js +4223 -6205
  129. package/components/query-solution/index.umd.cjs +6 -13
  130. package/components/response-layout/index.esm.js +206 -170
  131. package/components/response-layout/index.umd.cjs +1 -1
  132. package/components/response-layout-editor/index.esm.js +1 -1
  133. package/components/response-layout-editor/index.umd.cjs +1 -1
  134. package/components/response-toolbar/index.esm.js +378 -359
  135. package/components/response-toolbar/index.umd.cjs +1 -1
  136. package/components/schema-selector/index.esm.js +2491 -2653
  137. package/components/schema-selector/index.umd.cjs +8 -10
  138. package/components/search-box/index.esm.js +79 -240
  139. package/components/search-box/index.umd.cjs +1 -1
  140. package/components/section/index.esm.js +304 -289
  141. package/components/section/index.umd.cjs +2 -2
  142. package/components/smoke-detector/index.esm.js +8 -179
  143. package/components/smoke-detector/index.umd.cjs +1 -1
  144. package/components/sort-condition-editor/index.esm.js +4 -9421
  145. package/components/sort-condition-editor/index.umd.cjs +1 -427
  146. package/components/splitter/index.esm.js +142 -1171
  147. package/components/splitter/index.umd.cjs +1 -1
  148. package/components/step/index.esm.js +48 -47
  149. package/components/step/index.umd.cjs +1 -1
  150. package/components/tabs/index.esm.js +460 -513
  151. package/components/tabs/index.umd.cjs +1 -1
  152. package/components/text/index.esm.js +73 -217
  153. package/components/text/index.umd.cjs +1 -1
  154. package/components/time-picker/index.esm.js +380 -375
  155. package/components/time-picker/index.umd.cjs +1 -1
  156. package/components/tooltip/index.esm.js +40 -40
  157. package/components/tooltip/index.umd.cjs +1 -1
  158. package/components/transfer/index.esm.js +551 -771
  159. package/components/transfer/index.umd.cjs +6 -8
  160. package/components/tree-grid/index.esm.js +250 -235
  161. package/components/tree-grid/index.umd.cjs +1 -1
  162. package/components/tree-view/index.esm.js +157 -314
  163. package/components/tree-view/index.umd.cjs +1 -1
  164. package/components/uploader/index.esm.js +634 -1125
  165. package/components/uploader/index.umd.cjs +2 -2
  166. package/components/verify-detail/index.esm.js +106 -359
  167. package/components/verify-detail/index.umd.cjs +1 -1
  168. package/components/video/index.esm.js +89 -222
  169. package/components/video/index.umd.cjs +1 -1
  170. package/components/weather/index.esm.js +199 -290
  171. package/components/weather/index.umd.cjs +1 -1
  172. package/designer/accordion/index.esm.js +257 -0
  173. package/designer/accordion/index.umd.cjs +1 -0
  174. package/designer/avatar/index.esm.js +227 -0
  175. package/designer/avatar/index.umd.cjs +1 -0
  176. package/designer/binding-selector/index.esm.js +792 -0
  177. package/designer/binding-selector/index.umd.cjs +1 -0
  178. package/designer/button-edit/index.esm.js +210 -203
  179. package/designer/button-edit/index.umd.cjs +1 -1
  180. package/designer/button-group/index.esm.js +282 -0
  181. package/designer/button-group/index.umd.cjs +1 -0
  182. package/designer/checkbox/index.esm.js +51 -45
  183. package/designer/checkbox/index.umd.cjs +1 -1
  184. package/designer/checkbox-group/index.esm.js +89 -83
  185. package/designer/checkbox-group/index.umd.cjs +1 -1
  186. package/designer/code-editor/index.esm.js +75 -0
  187. package/designer/code-editor/index.umd.cjs +1 -0
  188. package/designer/color-picker/index.esm.js +1096 -0
  189. package/designer/color-picker/index.umd.cjs +1 -0
  190. package/designer/combo-list/index.esm.js +1095 -0
  191. package/designer/combo-list/index.umd.cjs +1 -0
  192. package/designer/combo-tree/index.esm.js +186 -0
  193. package/designer/combo-tree/index.umd.cjs +1 -0
  194. package/designer/component/index.css +1 -0
  195. package/designer/component/index.esm.js +5002 -0
  196. package/designer/component/index.umd.cjs +1 -0
  197. package/designer/condition/index.esm.js +1899 -0
  198. package/designer/condition/index.umd.cjs +1 -0
  199. package/designer/data-grid/index.esm.js +5580 -6213
  200. package/designer/data-grid/index.umd.cjs +10 -17
  201. package/designer/data-view/index.esm.js +212 -191
  202. package/designer/data-view/index.umd.cjs +2 -2
  203. package/designer/date-picker/index.esm.js +621 -607
  204. package/designer/date-picker/index.umd.cjs +1 -1
  205. package/designer/drawer/index.css +1 -1
  206. package/designer/drawer/index.esm.js +869 -620
  207. package/designer/drawer/index.umd.cjs +2 -2
  208. package/designer/dropdown/index.esm.js +261 -0
  209. package/designer/dropdown/index.umd.cjs +1 -0
  210. package/designer/dynamic-form/index.esm.js +1166 -1384
  211. package/designer/dynamic-form/index.umd.cjs +1 -8
  212. package/designer/expression-editor/index.css +1 -0
  213. package/designer/expression-editor/index.esm.js +7006 -0
  214. package/designer/expression-editor/index.umd.cjs +427 -0
  215. package/designer/farris-designer.all.esm.js +10309 -10617
  216. package/designer/farris-designer.all.umd.cjs +17 -19
  217. package/designer/filter-condition-editor/index.css +1 -0
  218. package/designer/filter-condition-editor/index.esm.js +4795 -0
  219. package/designer/filter-condition-editor/index.umd.cjs +1 -0
  220. package/designer/html-template/index.esm.js +718 -0
  221. package/designer/html-template/index.umd.cjs +1 -0
  222. package/designer/image-cropper/index.esm.js +765 -0
  223. package/designer/image-cropper/index.umd.cjs +1 -0
  224. package/designer/index.css +1 -1
  225. package/designer/input-group/index.esm.js +72 -66
  226. package/designer/input-group/index.umd.cjs +1 -1
  227. package/designer/json-editor/index.esm.js +83 -0
  228. package/designer/json-editor/index.umd.cjs +1 -0
  229. package/designer/language-textbox/index.esm.js +783 -0
  230. package/designer/language-textbox/index.umd.cjs +8 -0
  231. package/designer/layout/index.esm.js +430 -0
  232. package/designer/layout/index.umd.cjs +1 -0
  233. package/designer/list-nav/index.esm.js +802 -0
  234. package/designer/list-nav/index.umd.cjs +1 -0
  235. package/designer/list-view/index.esm.js +864 -844
  236. package/designer/list-view/index.umd.cjs +7 -9
  237. package/designer/lookup/index.esm.js +2083 -0
  238. package/designer/lookup/index.umd.cjs +1 -0
  239. package/designer/menu-lookup/index.esm.js +46 -0
  240. package/designer/menu-lookup/index.umd.cjs +1 -0
  241. package/designer/modal/index.esm.js +137 -29
  242. package/designer/modal/index.umd.cjs +1 -1
  243. package/designer/nav/index.esm.js +284 -0
  244. package/designer/nav/index.umd.cjs +1 -0
  245. package/designer/number-range/index.esm.js +1616 -0
  246. package/designer/number-range/index.umd.cjs +1 -0
  247. package/designer/number-spinner/index.esm.js +19 -17
  248. package/designer/number-spinner/index.umd.cjs +1 -1
  249. package/designer/order/index.css +1 -0
  250. package/designer/order/index.esm.js +2196 -0
  251. package/designer/order/index.umd.cjs +18 -0
  252. package/designer/page-footer/index.esm.js +290 -0
  253. package/designer/page-footer/index.umd.cjs +1 -0
  254. package/designer/page-header/index.esm.js +1003 -0
  255. package/designer/page-header/index.umd.cjs +1 -0
  256. package/designer/pagination/index.esm.js +591 -0
  257. package/designer/pagination/index.umd.cjs +1 -0
  258. package/designer/progress/index.esm.js +213 -0
  259. package/designer/progress/index.umd.cjs +1 -0
  260. package/designer/radio-group/index.esm.js +978 -949
  261. package/designer/radio-group/index.umd.cjs +1 -1
  262. package/designer/response-layout-editor/index.esm.js +1 -1
  263. package/designer/response-layout-editor/index.umd.cjs +1 -1
  264. package/designer/response-toolbar/index.esm.js +1471 -1416
  265. package/designer/response-toolbar/index.umd.cjs +1 -1
  266. package/designer/search-box/index.esm.js +245 -0
  267. package/designer/search-box/index.umd.cjs +1 -0
  268. package/designer/section/index.esm.js +83 -78
  269. package/designer/section/index.umd.cjs +1 -1
  270. package/designer/smoke-detector/index.css +1 -0
  271. package/designer/smoke-detector/index.esm.js +178 -0
  272. package/designer/smoke-detector/index.umd.cjs +1 -0
  273. package/designer/sort-condition-editor/index.esm.js +138 -0
  274. package/designer/sort-condition-editor/index.umd.cjs +1 -0
  275. package/designer/splitter/index.esm.js +1120 -0
  276. package/designer/splitter/index.umd.cjs +1 -0
  277. package/designer/step/index.esm.js +226 -0
  278. package/designer/step/index.umd.cjs +1 -0
  279. package/designer/switch/index.esm.js +10 -10
  280. package/designer/switch/index.umd.cjs +1 -1
  281. package/designer/tabs/index.css +1 -1
  282. package/designer/tabs/index.esm.js +2447 -2698
  283. package/designer/tabs/index.umd.cjs +2 -2
  284. package/designer/text/index.esm.js +147 -0
  285. package/designer/text/index.umd.cjs +1 -0
  286. package/designer/time-picker/index.esm.js +101 -100
  287. package/designer/time-picker/index.umd.cjs +1 -1
  288. package/designer/transfer/index.esm.js +254 -0
  289. package/designer/transfer/index.umd.cjs +1 -0
  290. package/designer/tree-grid/index.esm.js +473 -810
  291. package/designer/tree-grid/index.umd.cjs +1 -1
  292. package/designer/tree-view/index.esm.js +313 -0
  293. package/designer/tree-view/index.umd.cjs +1 -0
  294. package/designer/uploader/index.esm.js +1190 -0
  295. package/designer/uploader/index.umd.cjs +2 -0
  296. package/designer/verify-detail/index.esm.js +258 -0
  297. package/designer/verify-detail/index.umd.cjs +1 -0
  298. package/designer/video/index.esm.js +136 -0
  299. package/designer/video/index.umd.cjs +1 -0
  300. package/designer/weather/index.css +1 -0
  301. package/designer/weather/index.esm.js +6244 -0
  302. package/designer/weather/index.umd.cjs +14 -0
  303. package/farris.all.esm.js +69941 -70514
  304. package/farris.all.umd.cjs +117 -117
  305. package/index.css +1 -1
  306. package/locales/filter-bar/ui/en.json +2 -1
  307. package/locales/filter-bar/ui/zh-CHS.json +2 -1
  308. package/locales/filter-bar/ui/zh-CHT.json +2 -1
  309. package/locales/query-solution/ui/en.json +1 -1
  310. package/locales/query-solution/ui/zh-CHS.json +1 -1
  311. package/locales/query-solution/ui/zh-CHT.json +1 -1
  312. package/locales/ui/en.json +3 -2
  313. package/locales/ui/zh-CHS.json +3 -2
  314. package/locales/ui/zh-CHT.json +3 -2
  315. package/package.json +1 -1
  316. package/types/accordion/designer.d.ts +44 -0
  317. package/types/accordion/src/accordion.props.d.ts +0 -1
  318. package/types/accordion/src/components/accordion-item.props.d.ts +0 -1
  319. package/types/avatar/designer.d.ts +29 -0
  320. package/types/avatar/src/avatar.props.d.ts +0 -1
  321. package/types/avatar/src/property-config/avatar.property-config.d.ts +1 -1
  322. package/types/{expression-editor/index.d.ts → binding-selector/designer.d.ts} +6 -6
  323. package/types/binding-selector/index.d.ts +0 -54
  324. package/types/binding-selector/src/binding-selector.props.d.ts +0 -1
  325. package/types/button-group/designer.d.ts +29 -0
  326. package/types/button-group/index.d.ts +15 -0
  327. package/types/button-group/src/button-group.props.d.ts +0 -1
  328. package/types/calendar/src/calendar.props.d.ts +1 -0
  329. package/types/calendar/src/components/month/month-view.component.d.ts +6 -6
  330. package/types/calendar/src/composition/use-calendar-events.d.ts +1 -1
  331. package/types/calendar/src/composition/use-locales.d.ts +1 -0
  332. package/types/calendar/src/property-config/calendar.property-config.d.ts +2 -0
  333. package/types/capsule/src/capsule-item.component.d.ts +6 -6
  334. package/types/checkbox/designer.d.ts +2 -0
  335. package/types/checkbox-group/designer.d.ts +2 -0
  336. package/types/code-editor/designer.d.ts +5 -0
  337. package/types/code-editor/index.d.ts +0 -1
  338. package/types/code-editor/src/code-textbox.component.d.ts +6 -6
  339. package/types/code-editor/src/code-textbox.props.d.ts +0 -2
  340. package/types/color-picker/designer.d.ts +29 -0
  341. package/types/color-picker/index.d.ts +0 -15
  342. package/types/color-picker/src/color-picker.props.d.ts +0 -1
  343. package/types/combo-list/designer.d.ts +29 -0
  344. package/types/combo-list/src/combo-list.props.d.ts +1 -0
  345. package/types/combo-list/src/designer/combo-list.design.props.d.ts +6 -0
  346. package/types/combo-tree/designer.d.ts +5 -0
  347. package/types/combo-tree/src/combo-tree.props.d.ts +0 -1
  348. package/types/combo-tree/src/components/tree-container.component.d.ts +7 -7
  349. package/types/comment/src/comment.props.d.ts +4 -0
  350. package/types/comment/src/designer/comment.design.props.d.ts +4 -0
  351. package/types/common/index.d.ts +1 -0
  352. package/types/common/utils/use-mobile.d.ts +1 -0
  353. package/types/component/designer.d.ts +35 -0
  354. package/types/component/index.d.ts +0 -2
  355. package/types/component/src/component.props.d.ts +0 -8
  356. package/types/component/src/composition/field-tree-builder.d.ts +1 -0
  357. package/types/components.d.ts +2 -6
  358. package/types/condition/designer.d.ts +56 -0
  359. package/types/condition/index.d.ts +0 -55
  360. package/types/content-container/index.d.ts +3 -2
  361. package/types/content-container/src/content-container.props.d.ts +1 -0
  362. package/types/data-grid/designer.d.ts +2 -0
  363. package/types/data-grid/index.d.ts +5 -2
  364. package/types/data-grid/src/data-grid.component.d.ts +2 -1
  365. package/types/data-grid/src/designer/grid-field-editor.props.d.ts +1 -0
  366. package/types/data-view/composition/types.d.ts +7 -1
  367. package/types/data-view/composition/use-mobile.d.ts +3 -0
  368. package/types/data-view/designer/property-config/use-command-option.d.ts +11 -0
  369. package/types/data-view/index.d.ts +1 -0
  370. package/types/designer-canvas/src/composition/designer-canvas-changed.d.ts +3 -3
  371. package/types/designer-canvas/src/composition/dg-control.d.ts +8 -0
  372. package/types/designer-outline/src/designer-outline.component.d.ts +3 -3
  373. package/types/designer-outline/src/types.d.ts +5 -1
  374. package/types/drawer/designer.d.ts +12 -0
  375. package/types/drawer/src/designer/drawer-toolbar.design.props.d.ts +12 -0
  376. package/types/drawer/src/designer/drawer.design.component.d.ts +8 -0
  377. package/types/drawer/src/designer/drawer.design.props.d.ts +4 -0
  378. package/types/drawer/src/schema/schema-mapper.d.ts +1 -0
  379. package/types/drawer/src/schema/schema-resolver.d.ts +1 -0
  380. package/types/dropdown/designer.d.ts +6 -0
  381. package/types/dropdown/index.d.ts +27 -6
  382. package/types/dropdown/src/dropdown.item.component.d.ts +2 -2
  383. package/types/dropdown/src/dropdown.props.d.ts +0 -1
  384. package/types/dynamic-form/designer.d.ts +3 -1
  385. package/types/dynamic-form/index.d.ts +4 -3
  386. package/types/dynamic-form/src/component/dynamic-form-label/dynamic-form-label.component.d.ts +6 -6
  387. package/types/dynamic-form/src/composition/use-input-type-resolver.d.ts +11 -0
  388. package/types/dynamic-resolver/index.d.ts +3 -0
  389. package/types/dynamic-resolver/src/props-resolver.d.ts +2 -0
  390. package/types/dynamic-resolver/src/resolver/property-config/property-config-resolver-design.d.ts +1 -1
  391. package/types/dynamic-resolver/src/resolver/property-config/property-config-resolver.d.ts +1 -1
  392. package/types/dynamic-resolver/src/resolver/property-config/use-property-config-resolver.d.ts +2 -2
  393. package/types/dynamic-resolver/src/resolver/schema/schema-resolver-design.d.ts +1 -1
  394. package/types/dynamic-resolver/src/resolver/schema/schema-resolver.d.ts +1 -1
  395. package/types/dynamic-view/src/components/maps.d.ts +883 -1
  396. package/types/dynamic-view/src/dynamic-view.component.d.ts +1 -1
  397. package/types/dynamic-view/src/types.d.ts +4 -0
  398. package/types/expression-editor/designer.d.ts +9 -0
  399. package/types/field-selector/index.d.ts +2 -1
  400. package/types/fieldset/index.d.ts +3 -2
  401. package/types/fieldset/src/fieldset.props.d.ts +1 -0
  402. package/types/filter-bar/src/composition/types.d.ts +1 -1
  403. package/types/filter-bar/src/composition/use-size.d.ts +2 -2
  404. package/types/filter-bar/src/locale/locale.d.ts +1 -0
  405. package/types/filter-condition-editor/designer.d.ts +10 -0
  406. package/types/filter-condition-editor/index.d.ts +0 -9
  407. package/types/filter-condition-editor/src/components/filter-condition-grid.component.d.ts +12 -12
  408. package/types/filter-condition-editor/src/components/sort-editor-grid.component.d.ts +12 -12
  409. package/types/filter-condition-editor/src/filter-condition-editor.props.d.ts +0 -1
  410. package/types/html-template/designer.d.ts +31 -0
  411. package/types/html-template/src/designer/html-template.design.props.d.ts +9 -0
  412. package/types/html-template/src/html-template.props.d.ts +2 -0
  413. package/types/image-cropper/designer.d.ts +4 -0
  414. package/types/image-cropper/src/image-cropper.props.d.ts +0 -1
  415. package/types/index.d.ts +0 -1
  416. package/types/input-group/designer.d.ts +2 -0
  417. package/types/json-editor/designer.d.ts +5 -0
  418. package/types/json-editor/src/components/editable-combo/editable-combo.component.d.ts +3 -3
  419. package/types/json-editor/src/components/editable-combo/popup-container.component.d.ts +3 -3
  420. package/types/json-editor/src/json-editor.props.d.ts +0 -1
  421. package/types/language-textbox/index.d.ts +6 -6
  422. package/types/language-textbox/src/language-textbox.component.d.ts +2 -2
  423. package/types/language-textbox/src/language-textbox.props.d.ts +1 -0
  424. package/types/layout/index.d.ts +1 -0
  425. package/types/layout/src/components/layout-pane.props.d.ts +0 -1
  426. package/types/layout/src/layout.props.d.ts +0 -1
  427. package/types/list-nav/index.d.ts +24 -5
  428. package/types/list-nav/src/list-nav.props.d.ts +0 -1
  429. package/types/list-view/index.d.ts +1 -0
  430. package/types/list-view/src/composition/use-draggable.d.ts +1 -1
  431. package/types/list-view/src/designer/list-view.design.props.d.ts +1 -0
  432. package/types/list-view/src/list-view-table.props.d.ts +1 -0
  433. package/types/loading/index.d.ts +6 -6
  434. package/types/loading/src/loading.component.d.ts +3 -3
  435. package/types/lookup/index.d.ts +1 -1
  436. package/types/lookup/src/components/popup-container.component.d.ts +6 -6
  437. package/types/lookup/src/lookup.props.d.ts +1 -0
  438. package/types/lookup/src/property-config/external-lookup.property-config.d.ts +1 -0
  439. package/types/lookup/src/property-config/lookup.property-config.d.ts +1 -0
  440. package/types/menu-lookup/designer.d.ts +5 -0
  441. package/types/menu-lookup/src/menu-lookup.props.d.ts +0 -1
  442. package/types/message-box/index.d.ts +6 -6
  443. package/types/message-box/src/message-box.component.d.ts +3 -3
  444. package/types/modal/designer.d.ts +2 -0
  445. package/types/modal/index.d.ts +30 -24
  446. package/types/modal/src/modal.component.d.ts +15 -12
  447. package/types/modal/src/modal.props.d.ts +4 -0
  448. package/types/nav/designer.d.ts +6 -0
  449. package/types/nav/index.d.ts +24 -20
  450. package/types/nav/src/nav.props.d.ts +0 -1
  451. package/types/notify/index.d.ts +3 -3
  452. package/types/notify/src/notify.component.d.ts +2 -2
  453. package/types/number-range/designer.d.ts +29 -0
  454. package/types/number-range/src/number-range.props.d.ts +0 -1
  455. package/types/number-spinner/src/composition/types.d.ts +1 -0
  456. package/types/order/designer.d.ts +6 -0
  457. package/types/order/index.d.ts +36 -5
  458. package/types/order/src/designer/order.design.component.d.ts +1 -1
  459. package/types/order/src/order.props.d.ts +0 -1
  460. package/types/page-footer/designer.d.ts +6 -0
  461. package/types/page-footer/index.d.ts +0 -2
  462. package/types/page-footer/src/page-footer.props.d.ts +0 -1
  463. package/types/page-header/index.d.ts +3 -2
  464. package/types/page-header/src/designer/page-header.design.props.d.ts +20 -0
  465. package/types/page-header/src/page-header.props.d.ts +2 -0
  466. package/types/pagination/designer.d.ts +29 -0
  467. package/types/pagination/index.d.ts +15 -0
  468. package/types/pagination/src/pagination.props.d.ts +0 -1
  469. package/types/popover/index.d.ts +3 -3
  470. package/types/popover/src/composition/use-resize.d.ts +1 -1
  471. package/types/popover/src/popover.component.d.ts +2 -2
  472. package/types/progress/designer.d.ts +29 -0
  473. package/types/progress/src/progress.props.d.ts +0 -1
  474. package/types/property-panel/src/property-panel.component.d.ts +3 -3
  475. package/types/query-solution/index.d.ts +4 -4
  476. package/types/query-solution/src/composition/types.d.ts +8 -2
  477. package/types/query-solution/src/composition/use-header.d.ts +2 -2
  478. package/types/query-solution/src/composition/use-solution-utils.d.ts +1 -1
  479. package/types/query-solution/src/designer/query-solution-config/composition/use-util.d.ts +1 -1
  480. package/types/query-solution/src/designer/query-solution-config/query-solution-config.props.d.ts +1 -0
  481. package/types/query-solution/src/designer/solution-preset-config/solution-preset.props.d.ts +1 -0
  482. package/types/query-solution/src/query-solution.props.d.ts +1 -0
  483. package/types/radio-group/designer.d.ts +4 -1
  484. package/types/radio-group/src/designer/item-collection-editor.props.d.ts +1 -0
  485. package/types/response-layout/index.d.ts +3 -2
  486. package/types/response-layout/src/component/response-layout-item.props.d.ts +1 -0
  487. package/types/response-layout/src/property-config/response-layout-splitter/response-layout-splitter.props.d.ts +1 -0
  488. package/types/response-layout/src/response-layout.props.d.ts +1 -0
  489. package/types/response-toolbar/designer.d.ts +2 -1
  490. package/types/response-toolbar/src/designer/response-toolbar.design.props.d.ts +1 -0
  491. package/types/search-box/designer.d.ts +52 -0
  492. package/types/search-box/index.d.ts +1 -17
  493. package/types/search-box/src/components/search-box-container.component.d.ts +3 -3
  494. package/types/search-box/src/search-box.props.d.ts +0 -1
  495. package/types/section/designer.d.ts +1 -0
  496. package/types/smoke-detector/designer.d.ts +6 -0
  497. package/types/smoke-detector/index.d.ts +0 -2
  498. package/types/smoke-detector/src/smoke-detector.props.d.ts +0 -1
  499. package/types/sort-condition-editor/designer.d.ts +9 -0
  500. package/types/sort-condition-editor/index.d.ts +2 -7
  501. package/types/sort-condition-editor/src/sort-condition-editor.props.d.ts +0 -1
  502. package/types/splitter/designer.d.ts +32 -0
  503. package/types/splitter/index.d.ts +1 -0
  504. package/types/splitter/src/components/splitter-pane.props.d.ts +0 -1
  505. package/types/splitter/src/splitter.props.d.ts +0 -1
  506. package/types/step/designer.d.ts +6 -0
  507. package/types/tabs/designer.d.ts +1 -0
  508. package/types/tabs/index.d.ts +0 -1
  509. package/types/tabs/src/composition/types.d.ts +1 -0
  510. package/types/tabs/src/designer/tab-toolbar-item.props.d.ts +1 -0
  511. package/types/tags/index.d.ts +3 -3
  512. package/types/tags/src/tags.component.d.ts +1 -1
  513. package/types/text/designer.d.ts +6 -0
  514. package/types/text/index.d.ts +24 -20
  515. package/types/text/src/text.props.d.ts +0 -1
  516. package/types/time-picker/src/components/time.component.d.ts +3 -3
  517. package/types/transfer/designer.d.ts +35 -0
  518. package/types/transfer/src/transfer.props.d.ts +0 -1
  519. package/types/tree-view/designer.d.ts +29 -0
  520. package/types/tree-view/src/tree-view.props.d.ts +0 -1
  521. package/types/uploader/designer.d.ts +141 -0
  522. package/types/uploader/index.d.ts +6 -6
  523. package/types/uploader/src/components/upload-progress.component.d.ts +3 -3
  524. package/types/uploader/src/uploader.component.d.ts +3 -3
  525. package/types/uploader/src/uploader.props.d.ts +0 -1
  526. package/types/verify-detail/designer.d.ts +6 -0
  527. package/types/verify-detail/index.d.ts +58 -5
  528. package/types/verify-detail/src/designer/verify-detail.design.component.d.ts +8 -8
  529. package/types/verify-detail/src/verify-detail.props.d.ts +0 -1
  530. package/types/video/designer.d.ts +6 -0
  531. package/types/video/index.d.ts +24 -20
  532. package/types/video/src/video.props.d.ts +0 -1
  533. package/components/sort-condition-editor/index.css +0 -1
  534. package/package.zip +0 -0
  535. package/types/designer-toolbox/index.d.ts +0 -3
  536. package/types/designer-toolbox/src/toolbox.component.d.ts +0 -14
  537. package/types/designer-toolbox/src/toolbox.props.d.ts +0 -29
  538. package/types/designer-toolbox/src/types.d.ts +0 -21
  539. package/types/designer.d.ts +0 -13
  540. package/types/flow-canvas/index.d.ts +0 -3
  541. package/types/flow-canvas/src/components/flow-node-item.component.d.ts +0 -8
  542. package/types/flow-canvas/src/components/flow-node-item.props.d.ts +0 -3
  543. package/types/flow-canvas/src/composition/types.d.ts +0 -42
  544. package/types/flow-canvas/src/composition/use-bezier-curve.d.ts +0 -2
  545. package/types/flow-canvas/src/composition/use-connections.d.ts +0 -2
  546. package/types/flow-canvas/src/composition/use-curve.d.ts +0 -4
  547. package/types/flow-canvas/src/composition/use-drawing-bezier.d.ts +0 -2
  548. package/types/flow-canvas/src/composition/use-drawing.d.ts +0 -4
  549. package/types/flow-canvas/src/flow-canvas.component.d.ts +0 -8
  550. package/types/flow-canvas/src/flow-canvas.props.d.ts +0 -3
  551. package/types/layout/src/designer/layout-pane-use-designer-rules.d.ts +0 -2
  552. package/types/layout/src/designer/layout-pane.design.component.d.ts +0 -8
  553. package/types/layout/src/designer/layout-use-designer-rules.d.ts +0 -2
  554. package/types/layout/src/designer/layout.design.component.d.ts +0 -8
  555. package/types/layout/src/schema/schema-mapper.d.ts +0 -2
  556. package/types/layout/src/schema/schema-resolver.d.ts +0 -2
  557. package/types/list-nav/src/designer/use-designer-rules.d.ts +0 -2
  558. package/types/list-nav/src/property-config/list-nav.property-config.d.ts +0 -8
  559. package/types/list-nav/src/schema/schema-mapper.d.ts +0 -2
  560. package/types/list-nav/src/schema/schema-resolver.d.ts +0 -2
  561. /package/{components → designer}/condition/index.css +0 -0
  562. /package/{components → designer}/uploader/index.css +0 -0
  563. /package/types/{list-nav/src/designer/list-nav.design.component.d.ts → dynamic-form/src/component/form-control/form-control.component.d.ts} +0 -0
@@ -1,427 +1 @@
1
- (function(H,t){typeof exports=="object"&&typeof module<"u"?t(exports,require("vue"),require("../dynamic-resolver/index.umd.js"),require("../common/index.umd.js"),require("../designer-canvas/index.umd.js"),require("../button-edit/index.umd.js"),require("../locale/index.umd.js"),require("lodash-es"),require("../list-view/index.umd.js"),require("../../designer/button-edit/index.umd.js"),require("../property-panel/index.umd.js"),require("../tree-view/index.umd.js"),require("../tags/index.umd.js"),require("../popover/index.umd.js")):typeof define=="function"&&define.amd?define(["exports","vue","../dynamic-resolver/index.umd.js","../common/index.umd.js","../designer-canvas/index.umd.js","../button-edit/index.umd.js","../locale/index.umd.js","lodash-es","../list-view/index.umd.js","../../designer/button-edit/index.umd.js","../property-panel/index.umd.js","../tree-view/index.umd.js","../tags/index.umd.js","../popover/index.umd.js"],t):(H=typeof globalThis<"u"?globalThis:H||self,t(H["expression-editor"]={},H.Vue,H.dynamicResolver,H.common,H.designerCanvas,H.FButtonEdit$1,H.locale,H.LodashES,H.FListView,H.FButtonEditDesign,H.propertyPanel,H.FTreeView,H.FTags,H.FPopover))})(this,function(H,t,U,ee,se,ye,G,ne,Ze,Qe,et,tt,nt,at){"use strict";var ga=Object.defineProperty;var va=(H,t,U)=>t in H?ga(H,t,{enumerable:!0,configurable:!0,writable:!0,value:U}):H[t]=U;var K=(H,t,U)=>va(H,typeof t!="symbol"?t+"":t,U);const Te={modelValue:{type:String,default:""},singleExpand:{type:Boolean,default:!0},entities:{type:Array,default:[]},variables:{type:Array,default:[]},disabledFunctions:{type:Object,default:null},esprimaPath:{type:String,default:"assets/esprima-config.json"},showMessage:{type:Boolean,default:!1},validateMessage:{type:String,default:""},messageType:{type:String,default:"info"},showMessageType:{type:Boolean,default:!1},showDataPanel:{type:Boolean,default:!0},isServerSide:{type:Boolean,default:!1}},Se=new Map([["appearance",U.resolveAppearance]]);function Ne(e,n,a){return n}const ot={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/layout.schema.json",title:"layout",description:"A Farris Container Component",type:"object",properties:{id:{description:"The unique identifier for layout component",type:"string"},type:{description:"The type string of layout component",type:"string",default:"layout"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},contents:{description:"",type:"array",default:[]},collapsable:{description:"",type:"boolean",default:!1},resizable:{description:"",type:"boolean",default:!0},visible:{description:"",type:"boolean",default:!0}},required:["id","type","contents"]},it={title:"layout",description:"A Farris Component",type:"object",categories:{basic:{description:"Basic Infomation",title:"基本信息",properties:{id:{description:"组件标识",title:"标识",type:"string",readonly:!0},type:{description:"类型",title:"类型",type:"string",readonly:!0}}},behavior:{description:"Basic Infomation",title:"行为",properties:{collapsable:{description:"",title:"可收折",type:"boolean"},resizable:{description:"",title:"可调整尺寸",type:"boolean"}}}}},pe={customStyle:{type:String,defaut:""},customClass:{type:String,defaut:""}},Me=U.createPropsResolver(pe,ot,Se,Ne,it);function Oe(e){const n=t.ref(-1),a=t.ref(-1),o=t.ref(0),i=t.ref(0),l=t.ref(!1),r=t.ref(!1),s=t.computed(()=>({display:l.value?"block":"none",left:`${o.value}px`,cursor:"e-resize"})),u=t.computed(()=>({display:r.value?"block":"none",top:`${i.value}px`,cursor:"n-resize"})),f=t.computed(()=>{const c={display:r.value||l.value?"block":"none"};return i.value>0&&(c.cursor="n-resize"),c});function b(c,y,p,x){const S=e.value;if(S){const{left:d,right:g,width:k}=S.getBoundingClientRect();let N=c.clientX-d;x==="right"&&(N=g-c.clientX),N>y&&(N=y),N<p&&(N=p),x==="right"&&(N=k-N),o.value=N}}function v(c,y,p,x){const S=e.value;if(S){const{top:d,bottom:g,height:k}=S.getBoundingClientRect();let N=c.clientY-d;x==="bottom"&&(N=g-c.clientY),N>y&&(N=y),N<p&&(N=p),x==="bottom"&&(N=k-N),i.value=N}}function h(){const c=e.value;if(c){const{width:y,height:p}=c.getBoundingClientRect();return{width:y,height:p}}return null}function w(){const c=e.value;return c?Array.from(c.querySelectorAll("[data-position]")).reduce((y,p)=>{const x=p.getAttribute("data-position");return y=Object.assign(y,{[x]:p}),y},{}):null}function C(c,y){const p=h(),x=w();if(p&&x){const S=x==null?void 0:x.right,d=x==null?void 0:x.left;if(c==="left"&&d)return S?p.width-S.clientWidth-y:p.width-y;if(c==="right"&&S)return d?p.width-d.clientWidth-y:p.width-y}}function m(c,y){const p=h(),x=w();if(p&&x){const S=x==null?void 0:x.bottom,d=x==null?void 0:x.top;if(c==="top"&&d)return S?p.height-S.clientHeight-y:p.height-y;if(c==="bottom"&&S)return d?p.height-d.clientHeight-y:p.height-y}}return{horizontalResizeHandleStyle:s,verticalResizeHandleStyle:u,resizeOverlayStyle:f,showHorizontalResizeHandle:l,showVerticalResizeHandle:r,horizontalResizeBarPosition:n,verticalResizeBarPosition:a,verticalResizeHandleOffset:i,horizontalResizeHandleOffset:o,draggingHorizontalResizeHandle:b,draggingVerticalResizeHandle:v,getPanelMaxHeight:m,getPanelMaxWidth:C}}const _=t.defineComponent({name:"FLayout",props:pe,emits:[],setup(e,n){const a=t.ref(),o=Oe(a),{horizontalResizeHandleStyle:i,verticalResizeHandleStyle:l,resizeOverlayStyle:r}=o;t.provide("layout",{useResizeHandleComposition:o});const s=t.computed(()=>{const f={"f-layout":!0};return ee.getCustomClass(f,e==null?void 0:e.customClass)}),u=t.computed(()=>{const f={};return ee.getCustomStyle(f,e==null?void 0:e.customStyle)});return()=>t.createVNode("div",{class:s.value,style:u.value,ref:a},[n.slots.default&&n.slots.default(),t.createVNode("div",{class:"f-layout-resize-overlay",style:r.value},null),t.createVNode("div",{class:"f-layout-horizontal-resize-proxy",style:i.value},null),t.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:l.value},null)])}}),lt={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/layout-pane.schema.json",title:"layout-pane",description:"A Farris Container Component",type:"object",properties:{id:{description:"The unique identifier for a layout pane",type:"string"},type:{description:"The type string of layout paney",type:"string",default:"layout-pane"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},collapsable:{description:"",type:"boolean",default:!1},contents:{description:"",type:"array",default:[]},height:{description:"",type:"number"},position:{description:"",type:"string",default:"left",enum:["left","center","right","top","bottom"]},resizeable:{description:"",type:"boolean",default:!0},width:{description:"",type:"number"},visible:{description:"",type:"number",default:!0}},required:["id","type","contents"]},rt={title:"layout-pane",description:"A Farris Container Component",type:"object",categories:{basic:{description:"Basic Infomation",title:"基本信息",properties:{id:{description:"组件标识",title:"标识",type:"string",readonly:!0},type:{description:"组件类型",title:"控件类型",type:"enum"},width:{description:"",type:"number",title:"宽度"},height:{description:"",type:"number",title:"高度"}}},appearance:{title:"样式",description:"Appearance",properties:{class:{title:"class样式",type:"string",description:""},style:{title:"style",type:"string",description:""}}},behavior:{description:"",title:"行为",properties:{collapsable:{description:"",type:"boolean",title:"允许收折"},position:{description:"",type:"enum",title:"位置",editor:{type:"combo-list",data:[{id:"left",name:"左侧"},{id:"center",name:"居中"},{id:"right",name:"右侧"},{id:"top",name:"顶部"},{id:"bottom",name:"底部"}]}},resizeable:{description:"",type:"boolean",title:"允许调整尺寸"},visible:{description:"运行时组件是否可见",type:"boolean",title:"是否可见"}}}}},he={customClass:{type:String,defaut:""},customStyle:{type:String,defaut:""},width:{type:Number,default:-1},height:{type:Number,default:-1},position:{type:String,default:"left"},visible:{type:Boolean,default:!0},resizable:{type:Boolean,default:!0},collapsable:{type:Boolean,default:!1},minWidth:{type:Number,default:100},minHeight:{type:Number,default:100}},Ve=U.createPropsResolver(he,lt,Se,Ne,rt);function Be(e,n,a,o,i){const{horizontalResizeBarPosition:l,horizontalResizeHandleOffset:r,showHorizontalResizeHandle:s,showVerticalResizeHandle:u,verticalResizeBarPosition:f,verticalResizeHandleOffset:b,draggingHorizontalResizeHandle:v,draggingVerticalResizeHandle:h,getPanelMaxHeight:w,getPanelMaxWidth:C}=i;let m="",c,y,p;function x(g){if((m==="left"||m==="right")&&y){const{left:k}=y.getBoundingClientRect(),{width:N}=c.getBoundingClientRect(),I=g.clientX-k;let j=m==="left"?(N||0)+(I-l.value):(N||0)-(I-l.value);j=a.value>0?Math.max(a.value,j):j;const O=C(m,a.value);O!=null&&(j=O>j?j:O),e.value=j}if((m==="top"||m==="bottom")&&y){const{top:k}=y.getBoundingClientRect(),{height:N}=c.getBoundingClientRect(),I=g.clientY-k;let j=m==="top"?(N||0)+(I-f.value):(N||0)-(I-f.value);j=o.value>0?Math.max(o.value,j):j;const O=w(m,o.value);O!=null&&(j=O>j?j:O),n.value=j}r.value=0,b.value=0,l.value=-1,f.value=-1,s.value=!1,u.value=!1,document.removeEventListener("mousemove",p),document.removeEventListener("mouseup",x),document.body.style.userSelect="",m="",c=null,y=null}function S(g,k,N){if(m=k,c=N,s.value=!0,y=g.composedPath().find(j=>(j.className||"").split(" ")[0]==="f-layout"),y){const{left:j}=y.getBoundingClientRect(),O=g.clientX-j;r.value=O,l.value=O;const P=C(m,a.value)||0;p=F=>v(F,P,a.value,m),document.addEventListener("mousemove",p),document.addEventListener("mouseup",x),document.body.style.userSelect="none"}}function d(g,k,N){if(m=k,c=N,u.value=!0,y=g.composedPath().find(j=>(j.className||"").split(" ")[0]==="f-layout"),y){const{top:j}=y.getBoundingClientRect();b.value=g.clientY-j,f.value=g.clientY-j;const O=w(m,o.value)||0;p=P=>h(P,O,o.value,m),document.addEventListener("mousemove",p),document.addEventListener("mouseup",x),document.body.style.userSelect="none"}}return{onClickHorizontalResizeBar:S,onClickVerticalResizeBar:d}}const X=t.defineComponent({name:"FLayoutPane",props:he,emits:[],setup(e,n){const a=t.ref(e.minHeight<=0?100:e.minHeight),o=t.ref(e.minWidth<=0?100:e.minWidth),i=t.ref(e.width<=0?100:e.width),l=t.ref(e.height<=0?100:e.height),r=t.ref(Math.max(a.value,l.value)),s=t.ref(Math.max(o.value,i.value)),u=t.ref(),f=t.ref(e.position),b=t.ref(e.resizable);t.watch(()=>e.resizable,d=>{b.value=d});const v=t.inject("layout"),{useResizeHandleComposition:h}=v,w=Be(s,r,o,a,h),{onClickHorizontalResizeBar:C,onClickVerticalResizeBar:m}=w,c=t.computed(()=>({"f-layout-resize-bar":!0,"f-layout-resize-bar-e":f.value==="left","f-layout-resize-bar-n":f.value==="bottom","f-layout-resize-bar-s":f.value==="top","f-layout-resize-bar-w":f.value==="right"})),y=t.computed(()=>f.value!=="center"&&b.value);function p(d,g){(g==="left"||g==="right")&&C(d,g,u.value),(g==="top"||g==="bottom")&&m(d,g,u.value)}const x=t.computed(()=>{const d={"f-layout-pane":!0,"f-page-content-nav":f.value==="left"||f.value==="right","f-page-content-main":f.value==="center"};return e.customClass&&String(e.customClass).split(" ").reduce((g,k)=>(g[k]=!0,g),d),d}),S=t.computed(()=>{const d={};return(s.value&&f.value==="left"||f.value==="right")&&(d.width=`${s.value}px`),(r.value&&f.value==="bottom"||f.value==="top")&&(d.height=`${r.value}px`),e.visible||(d.display="none"),d});return()=>t.createVNode("div",{ref:u,class:x.value,style:S.value,"data-position":f.value},[n.slots.default&&n.slots.default(),y.value&&t.createVNode("span",{class:c.value,onMousedown:d=>p(d,f.value)},null)])}});function st(e,n){function a(){return!1}return{canAccepts:a}}const ct=t.defineComponent({name:"FLayoutDesign",props:pe,emits:[],setup(e,n){var b;const a=t.ref(),o=t.inject("design-item-context"),i=st(o.schema,(b=o.parent)==null?void 0:b.schema),l=se.useDesignerComponent(a,o,i);l.value.canNested=!1;const r=Oe(a),{horizontalResizeHandleStyle:s,verticalResizeHandleStyle:u,resizeOverlayStyle:f}=r;return t.provide("layout",{useResizeHandleComposition:r}),t.onMounted(()=>{a.value.componentInstance=l}),n.expose(l.value),()=>t.createVNode("div",{class:"f-layout f-page-content",ref:a},[n.slots.default&&n.slots.default(),t.createVNode("div",{class:"f-layout-resize-overlay",style:f.value},null),t.createVNode("div",{class:"f-layout-horizontal-resize-proxy",style:s.value},null),t.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:u.value},null)])}});function ut(e,n){const a=e.schema;function o(l){return!!se.useDragulaCommonRule().basalDragulaRuleForContainer(l)}function i(){const l=["f-layout-pane"];return(a.position==="left"||a.position==="right")&&l.push("f-page-content-nav"),a.position==="center"&&l.push("f-page-content-main"),l.join(" ")}return{canAccepts:o,getDesignerClass:i}}const dt=t.defineComponent({name:"FLayoutPaneDesign",props:he,emits:[],setup(e,n){const a=t.ref(),o=t.ref();t.inject("designer-host-service");const i=t.inject("design-item-context"),l=ut(i),r=se.useDesignerComponent(o,i,l);r.value.canNested=!1,r.value.canMove=!1,r.value.canDelete=!1,t.onMounted(()=>{o.value.componentInstance=r}),n.expose(r.value);const s=t.ref(Math.max(e.minHeight,e.height)),u=t.ref(Math.max(e.minWidth,e.width)),f=t.ref(e.minHeight),b=t.ref(e.minWidth),v=t.ref(e.position),h=t.inject("layout"),{useResizeHandleComposition:w}=h,C=Be(u,s,b,f,w),{onClickHorizontalResizeBar:m,onClickVerticalResizeBar:c}=C,y=t.computed(()=>({"f-layout-resize-bar":!0,"f-layout-resize-bar-e":v.value==="left","f-layout-resize-bar-n":v.value==="bottom","f-layout-resize-bar-s":v.value==="top","f-layout-resize-bar-w":v.value==="right"}));function p(d,g){(g==="left"||g==="right")&&m(d,g,a.value),(g==="top"||g==="bottom")&&c(d,g,a.value)}const x=t.computed(()=>{const d={"f-layout-pane":!0,"f-page-content-nav":v.value==="left"||v.value==="right","f-page-content-main":v.value==="center"};return e.customClass&&String(e.customClass).split(" ").reduce((g,k)=>(g[k]=!0,g),d),d}),S=t.computed(()=>{const d={flex:"1"};return(u.value&&v.value==="left"||v.value==="right")&&(d.width=`${u.value}px`),(s.value&&v.value==="bottom"||v.value==="top")&&(d.height=`${s.value}px`),d});return()=>t.createVNode("div",{ref:a,class:x.value,style:S.value},[t.createVNode("div",{ref:o,class:"drag-container","data-dragref":`${i.schema.id}-container`},[n.slots.default&&n.slots.default()]),t.createVNode("span",{class:y.value,onMousedown:d=>p(d,v.value)},null)])}});_.install=e=>{e.component(_.name,_),e.component(X.name,X)},_.register=(e,n,a,o)=>{e.layout=_,n.layout=Me,e["layout-pane"]=X,n["layout-pane"]=Ve},_.registerDesigner=(e,n,a)=>{e.layout=ct,n.layout=Me,e["layout-pane"]=dt,n["layout-pane"]=Ve};const ft=new Map([["appearance",U.resolveAppearance]]),mt={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/combo-list.schema.json",title:"combo-list",description:"A Farris Input Component",type:"object",properties:{id:{description:"The unique identifier for a combo list",type:"string"},type:{description:"The type string of number combo list component",type:"string",default:"combo-list"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},binding:{description:"",type:"object",default:{}},disabled:{description:"",type:"boolean",default:!1},enableClear:{description:"",type:"boolean",default:!1},editable:{description:"",type:"boolean",default:!1},enableLinkLabel:{description:"",type:"boolean",default:!1},label:{description:"",type:"string",default:""},lableWidth:{description:"",type:"number"},placeholder:{description:"",type:"string",default:"请选择"},idField:{description:"",type:"string",default:"id"},valueField:{description:"",type:"string",default:"id"},titleField:{description:"",type:"string",default:"name"},textField:{description:"",type:"string",default:"name"},dataSourceType:{description:"",type:"string",default:"static"},data:{description:"",type:"array"},remote:{description:"",type:"string"},readonly:{description:"",type:"boolean",default:!1},required:{description:"",type:"boolean",default:!1},tabindex:{description:"",type:"number",default:-1},textAlign:{description:"",type:"string",enum:["left","middle","right"],default:"left"},multiSelect:{description:"",type:"boolean",default:!1},maxLength:{description:"",type:"number",default:null},visible:{description:"",type:"boolean",default:!0},onBlur:{description:"",type:"string",default:""},onClickLinkLabel:{description:"",type:"string",default:""},maxHeight:{description:"",type:"number",default:350},minPanelWidth:{description:"",type:"number",default:160},popupOnClick:{description:"",type:"boolean",default:!0},separator:{description:"",type:"string",default:","},viewType:{description:"",type:"string",default:"tag"},enableSearch:{description:"启用搜索",type:"boolean",default:!0},enableHighlightSearch:{description:"启用高亮搜索",type:"boolean",default:!1},beforeOpen:{description:"打卡面板前回调",type:"string"},onChange:{description:"值变化事件",type:"string",default:""},onInput:{description:"输入事件",type:"string",default:""},onClear:{description:"清空事件",type:"string",default:""}},required:["type"],ignore:["id","appearance","binding","visible"]};function yt(e,n,a){return n}function pt(){function e(n,a,o){const i={};return i.beforeOpen=l=>a.call("beforeOpen",n,[l,n],o),i}return{resolve:e}}const ge={id:{type:String},data:{type:Array,default:[]},disabled:{default:!1,type:Boolean},dropDownIcon:{type:String,default:'<span class="f-icon f-icon-arrow-chevron-down"></span>'},editable:{default:!1,type:Boolean},enableClear:{default:!0,type:Boolean},enableSearch:{type:Boolean,default:!1},enableTitle:{default:!0,type:Boolean},fitEditor:{default:!1,type:Boolean},forcePlaceholder:{default:!1,type:Boolean},hidePanelOnClear:{default:!0,type:Boolean},idField:{default:"id",type:String},mapFields:{type:Object},maxHeight:{default:350,type:Number},maxLength:{type:Number},multiSelect:{type:Boolean,default:!1},modelValue:{},placeholder:{type:String,default:"请选择"},placement:{type:String,default:"auto"},readonly:{default:!1,type:Boolean},remote:{default:null,type:Object},remoteSearch:{default:!1,type:Boolean},separator:{default:",",type:String},tabIndex:{type:Number,default:-1},textField:{default:"name",type:String},titleField:{default:"name",type:String},valueField:{default:"id",type:String},viewType:{default:"tag",type:String},change:{type:Function,default:()=>{}},focusOnCreated:{type:Boolean,default:!1},selectOnCreated:{type:Boolean,default:!1},autoHeight:{type:Boolean,default:!0},beforeOpen:{type:Function,default:null},load:{type:Function},searchOption:{type:[Boolean,Function],default:!1},enableHighlightSearch:{type:Boolean,default:!0},minPanelWidth:{type:Number,default:160},popupOnClick:{type:Boolean,default:!0}},ht=Object.assign({},ge,{readonly:{}}),De=U.createPropsResolver(ge,mt,ft,yt),gt=pt(),vt={dataSource:{type:Array,default:[]},enableSearch:{type:Boolean,default:!1},idField:{type:String,default:"id"},multiSelect:{type:Boolean,default:!1},selectedValues:{type:String,default:""},separator:{type:String,default:","},textField:{type:String,default:"name"},titleField:{type:String,default:"name"},width:{type:Number},maxHeight:{type:Number},valueField:{type:String,default:"id"},onSelectionChange:{type:Function,default:()=>{}},searchOption:{type:[Boolean,Function],default:!1},enableHighlightSearch:{type:Boolean,default:!0}},bt=t.defineComponent({name:"FComboListContainer",props:vt,emits:["selectionChange"],setup(e,n){const a=t.ref(),o=t.ref(e.dataSource),i=t.ref([]),l=t.ref(e.separator),r=t.ref(e.width),s=t.ref(e.maxHeight),u=t.computed(()=>e.multiSelect),f=t.ref(e.multiSelect?String(e.selectedValues).split(l.value):[e.selectedValues]),b=t.computed(()=>({enableSelectRow:!0,multiSelect:e.multiSelect,multiSelectMode:"OnCheckAndClick",showCheckbox:u.value,showSelectAll:!1,showSelection:!0}));t.watch(e.dataSource,()=>{o.value=e.dataSource}),t.computed(()=>e.enableSearch?"SearchBar":"ContentHeader");const v=t.computed(()=>{const c={};return r.value!==void 0&&(c.width=`${r.value}px`),s.value!==void 0&&s.value>0&&(c.maxHeight=`${s.value}px`),c});function h(c){a.value.search(c)}function w(c){i.value=c.map(y=>Object.assign({},y)),f.value=c.map(y=>y[e.idField]),n.emit("selectionChange",i.value)}function C(c){if(e.enableHighlightSearch)return;let y=[];const{searchOption:p}=e;typeof p=="function"?y=o.value.filter(x=>p(c,x)):y=o.value.filter(x=>x[e.valueField].indexOf(c)>-1||x[e.textField].indexOf(c)>-1),a.value.updateDataSource(y)}t.watch([()=>e.selectedValues],([c])=>{e.multiSelect?f.value=c.split(l.value):f.value=[c]});function m(c){a.value.activeRowById(c)}return t.onMounted(()=>{var c,y;if(!e.multiSelect){const p=(c=f.value)==null?void 0:c[0];let x=p;const S=o.value.map(d=>d[e.valueField||e.idField]);if(!ne.isUndefined(p)&&S.includes(p)){const d=typeof p,g=typeof((y=o.value[0])==null?void 0:y[e.valueField||e.idField]);g==="number"&&d!==g&&(x=Number(p)),g==="boolean"&&d!==g&&(x=p==="true"?!0:p==="false"?!1:p),m(x)}}}),n.expose({search:h,activeRowById:m}),()=>t.createVNode("div",{class:"f-combo-list-container",style:v.value},[t.createVNode(Ze,{ref:a,size:"small",itemClass:"f-combo-list-item",itemContentClass:"text-truncate",header:"ContentHeader",headerClass:"f-combo-list-search-box",data:o.value,idField:e.idField,textField:e.textField,titleField:e.titleField,multiSelect:e.multiSelect,selection:b.value,enableHighlightSearch:e.enableHighlightSearch,selectionValues:f.value,onSelectionUpdate:w,onAfterSearch:C},null)])}});function kt(e){const n=t.ref(""),a=t.ref(e.modelValue),o=t.ref(e.data||[]),i=t.ref(e.editable);function l(m){const c=e.multiSelect?String(m).split(e.separator):[String(m)],y=c.map(S=>[S,!0]),p=new Map(y);return o.value.filter(S=>p.has(String(S[e.valueField]))).sort((S,d)=>{const g=c.indexOf(S[e.valueField]),k=c.indexOf(d[e.valueField]);return g-k})}function r(m){const c=l(m).map(y=>y[e.textField]).join(e.separator);n.value=i.value?c||m:c}function s(m){if(e.multiSelect){const c=m.split(e.separator).map(p=>[p,!0]),y=new Map(c);return o.value.filter(p=>y.has(p[e.textField]))}return o.value.filter(c=>""+c[e.textField]===m)}function u(m){const c={};return c[e.idField]=m,c[e.textField]=m,[c]}function f(m){let c=s(m);const y=c&&c.length>0;return i.value&&!y&&(c=u(m)),c}function b(){const{url:m,method:c="GET",headers:y={"Content-Type":"application/json;charset=utf-8;"},body:p=null}=e.remote;if(!m)return;const x=c.toLowerCase()==="get"?{method:c,headers:y}:{method:c,headers:y,body:p};let S=!1;fetch(new Request(m,x)).then(d=>{var k,N;if(d.status===200)return S=!!((N=(k=d.headers)==null?void 0:k.get("content-type"))!=null&&N.includes("application/json")),S?d.text():d.json();throw d.status===405?new Error(G.LocaleService.getLocaleValue("comboList.remoteError")):new Error(d.statusText)}).then(d=>{d.length&&(o.value=S?JSON.parse(d):d)}).catch(d=>{console.warn(d)})}e.remote&&(e.load?e.load().then(m=>{o.value=m}).catch(m=>{console.log(m)}):b()),t.watch(()=>e.data,()=>{o.value=e.data}),t.watch([o],([m])=>{if(e.modelValue!=null){const c=m.find(y=>y[e.valueField]===e.modelValue);c&&(n.value=c[e.textField])}}),t.watch(()=>e.modelValue,m=>{a.value=m,r(m)});function v(m){o.value=m}function h(){return o.value}function w(){return n.value}function C(){const m=typeof e.beforeOpen=="function";return!e.beforeOpen||!m?Promise.resolve(!0):Promise.resolve().then(()=>e.beforeOpen({instance:{updateDataSource:v,getData:h,getDisplayText:w}})).then(c=>typeof(c==null?void 0:c.canOpen)=="boolean"?c==null?void 0:c.canOpen:!0)}return e.beforeOpen?C().then(m=>{m&&r(e.modelValue)}):r(e.modelValue),{dataSource:o,displayText:n,editable:i,modelValue:a,beforeOpenList:C,getItemsByDisplayText:s,getItemsByValue:l,getSelectedItemsByDisplayText:f}}const ae=t.defineComponent({name:"FComboList",props:ge,emits:["clear","update:modelValue","change","input"],setup(e,n){const a=t.ref(),o=t.ref(),i=t.ref(e.disabled||e.readonly),l=t.ref(e.enableClear),r=t.ref(e.enableSearch),s=t.ref(e.readonly),{dataSource:u,displayText:f,editable:b,modelValue:v,getItemsByDisplayText:h,getItemsByValue:w,beforeOpenList:C}=kt(e),m=t.ref(e.dropDownIcon);m.value==='<span class="f-icon f-icon-arrow-chevron-down"></span>'&&(m.value='<span id="'+e.id+'-icon-dropdown" class="f-icon f-icon-arrow-chevron-down"></span>');const c=t.computed(()=>e.multiSelect),y=t.computed(()=>o.value?o.value.elementRef.getBoundingClientRect().width:0);function p(){!c.value&&o.value&&o.value.hidePopup()}function x(B){f.value=B.map(L=>L[e.textField]).join(e.separator);let E="";B.length===1?E=B[0][e.valueField]:E=B.map(L=>L[e.valueField]).join(e.separator),v.value!==E&&(v.value=E,n.emit("update:modelValue",v.value),n.emit("change",B,v.value))}function S(){const B=w(v.value);x(B)}function d(){s.value||f.value}function g(B){var E;v.value="",(E=a.value)==null||E.activeRowById(""),n.emit("update:modelValue",""),n.emit("change",[],""),n.emit("clear")}function k(B){var E,L;e.enableSearch&&e.enableHighlightSearch&&((E=a.value)==null||E.search(B)),(L=a.value)==null||L.activeRowById(B),n.emit("change",[v.value],v.value)}function N(B){if(e.multiSelect){const E=h(B);e.viewType;const M=E.map(D=>D[e.idField||e.valueField]).join(e.separator);v.value!==M&&(v.value=M,n.emit("update:modelValue",v.value),n.emit("change",E,v.value))}}function I(){return f.value}function j(B){const{value:E}=B.target;k(E),n.emit("input",E)}function O(){o.value.hidePopup()}function P(B){u.value=B}function F(){return u.value}const V={getDisplayText:I,hidePopup:O,updateDataSource:P,getData:F};return n.expose(V),t.watch([()=>e.disabled,()=>e.editable,()=>e.enableClear,()=>e.enableSearch,()=>e.readonly],([B,E,L,M,D])=>{i.value=B,b.value=E,l.value=L,r.value=M,s.value=D}),()=>t.createVNode(ye,{ref:o,id:e.id,disable:i.value,readonly:s.value,forcePlaceholder:e.forcePlaceholder,editable:b.value,buttonContent:m.value,placeholder:e.placeholder==="请选择"?G.LocaleService.getLocaleValue("comboList.placeholder"):e.placeholder,enableClear:l.value,maxLength:e.maxLength,tabIndex:e.tabIndex,enableTitle:e.enableTitle,multiSelect:e.multiSelect,inputType:e.multiSelect?e.viewType:"text",modelValue:f.value,"onUpdate:modelValue":B=>f.value=B,focusOnCreated:e.focusOnCreated,selectOnCreated:e.selectOnCreated,onClear:g,onClick:d,onChange:N,onBlur:S,onInput:j,beforeOpen:C,placement:e.placement,popupMinWidth:e.minPanelWidth,popupClass:"f-combo-list-wrapper",popupOnClick:e.popupOnClick,limitContentBySpace:!0},{default:()=>[t.createVNode(bt,{ref:a,idField:e.idField,valueField:e.valueField,textField:e.textField,titleField:e.titleField,dataSource:u.value,selectedValues:v.value,separator:e.separator,multiSelect:e.multiSelect,enableSearch:r.value,maxHeight:e.maxHeight,enableHighlightSearch:e.enableHighlightSearch,width:e.fitEditor?y.value:void 0,onSelectionChange:B=>{x(B),p()}},null)]})}}),Ee={convertFrom:(e,n)=>(e.editor.remote||{})[n],convertTo:(e,n,a)=>{e.editor.remote=e.editor.remote||{},e.editor.remote[n]=a}};class Ct extends et.InputBaseProperty{constructor(n,a){super(n,a)}getCommonEditorProperties(n){var a,o,i;return{viewType:{visible:!!((a=n.editor)!=null&&a.multiSelect),description:"数据展示类型,有标签和文本两种方式",title:"数据展示类型",type:"enum",editor:{data:[{id:"tag",name:"标签"},{id:"text",name:"文本"}]},refreshPanelAfterChanged:!0},separator:{visible:!!((o=n.editor)!=null&&o.multiSelect)&&((i=n.editor)==null?void 0:i.viewType)==="text",description:"下拉列表启用多选且数据展示类型为文本时的分隔符",title:"分隔符",type:"enum",editor:{data:[{id:",",name:"逗号(,)"},{id:"#",name:"井号(#)"},{id:".",name:"句号(.)"},{id:"|",name:"竖线(|)"}]}},editable:{description:"",title:"允许编辑",type:"boolean",refreshPanelAfterChanged:!0,readonly:!0}}}getEditorProperties(n){var l,r;const a=this;let o="";if(((l=n==null?void 0:n.binding)==null?void 0:l.type)==="Form"){const s=this.schemaService.getFieldByIDAndVMID(n.binding.field,this.viewModelId);(r=s==null?void 0:s.schemaField)!=null&&r.type&&(o=s.schemaField.type.$type)}return a.getComponentConfig(n,{type:"combo-list"},{enableClear:{description:"",title:"启用清空",type:"boolean"},dataSourceType:{description:"",title:"数据源类型",type:"enum",editor:{default:"static",data:[{id:"static",name:"静态"},{id:"dynamic",name:"动态"}]},refreshPanelAfterChanged:!0},data:{description:"",title:"数据",type:"array",visible:!n.editor.dataSourceType||n.editor.dataSourceType==="static",...a.getItemCollectionEditor(n,n.editor.valueField,n.editor.textField),refreshPanelAfterChanged:!0},url:{visible:n.editor.dataSourceType==="dynamic",$converter:Ee,description:"",title:"服务端API",type:"string"},body:{visible:!1,$converter:Ee,description:"",title:"服务端API参数",type:"string"},textField:{description:"",title:"数据源显示字段",type:"string",readonly:n.editor.dataSourceType!=="dynamic"},valueField:{description:"",title:"数据源值字段",type:"string",readonly:n.editor.dataSourceType!=="dynamic"},multiSelect:{description:"",title:"启用多选",visible:!o||o==="StringType",type:"boolean",refreshPanelAfterChanged:!0},maxLength:{description:"",title:"最大输入长度",type:"number",editor:{nullable:!0,min:0,useThousands:!1,needValid:!0}},...this.getCommonEditorProperties(n)},(s,u)=>{if(!s||!u.editor)return;const f=this;switch(s.propertyID){case"dataSourceType":{s.propertyValue==="static"?(u.editor.valueField="value",u.editor.textField="name",u.editor.remote=null):s.propertyValue==="dynamic"&&(u.editor.remote={method:"GET"},u.editor.valueField="value",u.editor.textField="name");break}case"data":{!f.checkEnumDataReadonly(u)&&u.formatter&&(u.formatter.data=[...s.propertyValue]);break}case"viewType":s.propertyValue==="tag"&&(u.editor.editable=!1)}})}getGridFieldEdtiorProperties(n,a){var r,s,u,f,b,v;const o=this;let i="";if(((r=n==null?void 0:n.binding)==null?void 0:r.type)==="Form"){const h=this.schemaService.getFieldByIDAndVMID(n.binding.field,this.viewModelId);(s=h==null?void 0:h.schemaField)!=null&&s.type&&(i=h.schemaField.type.$type)}return o.getComponentConfig(n,{type:"combo-list"},{enableClear:{description:"",title:"启用清空",type:"boolean"},data:{description:"",title:"数据",type:"array",visible:!((u=n.editor)!=null&&u.dataSourceType)||((f=n.editor)==null?void 0:f.dataSourceType)==="static",...o.getItemCollectionEditor(n,(b=n.editor)==null?void 0:b.valueField,(v=n.editor)==null?void 0:v.textField),refreshPanelAfterChanged:!0},textField:{description:"",title:"数据源显示字段",type:"string",readonly:!0},valueField:{description:"",title:"数据源值字段",type:"string",readonly:!0},multiSelect:{description:"",title:"启用多选",visible:i==="StringType",type:"boolean",refreshPanelAfterChanged:!0},maxLength:{description:"",title:"最大输入长度",type:"number",editor:{nullable:!0,min:0,useThousands:!1,needValid:!0}},...this.getCommonEditorProperties(n)},(h,w)=>{if(!h||!w.editor)return;const C=this;switch(h.propertyID){case"dataSourceType":{h.propertyValue==="static"?(w.editor.valueField="value",w.editor.textField="name",w.editor.remote=null):h.propertyValue==="dynamic"&&(w.editor.remote={method:"GET"},w.editor.valueField="value",w.editor.textField="name");break}case"data":{!C.checkEnumDataReadonly(w)&&w.formatter&&(w.formatter.data=[...h.propertyValue]);break}}})}setEditorPropertyRelates(n,a,o){if(!n||!a.editor)return;const i=this;switch(n.propertyID){case"dataSourceType":{n.propertyValue==="static"&&(a.editor.valueField="value",a.editor.textField="name",a.editor.remote={});break}case"data":{!i.checkEnumDataReadonly(a)&&a.formatter&&(a.formatter.data=[...n.propertyValue]);break}}}changeBindingField(n,a,o){var l;super.changeBindingField(n,a);const i=o;n.editor&&((l=i==null?void 0:i.type)==null?void 0:l.$type)===ee.FormSchemaEntityFieldType$Type.EnumType&&(n.editor.data=i.type.enumValues||[])}getEventPropertyConfig(n,a="card",o,i){const l=this;let r=[{label:"onChange",name:"值变化事件"},{label:"beforeOpen",name:"下拉面板前事件"}];o&&(r=r.concat(o)),this.appendFieldValueChangeEvents(n,r);const s=l.eventsEditorUtils.formProperties(n,l.viewModelId,r);return{title:"事件",hideTitle:!0,properties:l.createBaseEventProperty(s),tabId:"commands",tabName:"交互",setPropertyRelates(b,v){const h=b.propertyValue;delete n[l.viewModelId],h&&(h.setPropertyRelates=this.setPropertyRelates,l.eventsEditorUtils.saveRelatedParameters(n,l.viewModelId,h.events,h)),i&&i(b,v,h);const w=l.designViewModelUtils.getDgViewModel(l.viewModelId);w&&l.designViewModelField&&w.changeField(l.designViewModelField.id,{valueChanging:n.fieldValueChanging,valueChanged:n.fieldValueChanged}),n.editor.beforeOpen!==n.beforeOpen&&(n.editor.beforeOpen=n.beforeOpen),n.editor.onChange!==n.onChange&&(n.editor.onChange=n.onChange),n.editor.onClear!==n.onClear&&(n.editor.onClear=n.onClear)}}}}function xt(e,n){const a=e.schema;function o(i,l){return new Ct(i,n).getPropertyConfig(a,l)}return{getPropsConfig:o}}const wt=t.defineComponent({name:"FComboListDesign",props:ht,emits:["clear","update:modelValue","change"],setup(e,n){const a=t.ref(),o=t.inject("designer-host-service"),i=t.inject("design-item-context"),l=xt(i,o),r=se.useDesignerComponent(a,i,l);return t.onMounted(()=>{a.value.componentInstance=r}),n.expose(r.value),()=>t.createVNode(Qe,{ref:a,buttonContent:e.dropDownIcon,readonly:!0,editable:!1,forcePlaceholder:!0,placeholder:e.placeholder,enableClear:!0},null)}});ae.register=(e,n,a,o)=>{e["combo-list"]=ae,n["combo-list"]=De,o["combo-list"]={callbackResolver:gt}},ae.registerDesigner=(e,n,a)=>{e["combo-list"]=wt,n["combo-list"]=De},ee.withInstall(ae);const Ft={analytical:{name:"数据",items:[{key:"IsNull",name:"是空值",params:[{key:"obj",name:"检测对象",type:"object"}],description:`【功能】判断检测对象是否为空值(null)。检测对象为null返回true,否则返回false
2
- 【参数】
3
- 【obj】检测对象
4
- 【返回值】true或false
5
- 【示例】
6
- 【场景】提交单据Order,单据包含编号code字段
7
- 【需求】判断提交单据的编号是否为null
8
- 【举例】是空值(Order.code)`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"IsNullOrWhiteSpace",name:"是空串",params:[{key:"obj",name:"检测对象",type:"object"}],description:`【功能】判断检测对象是否为null值或空串""。检测对象为null或""返回true,否则返回false
9
- 【参数】
10
- 【obj】检测对象
11
- 【返回值】true或false
12
- 【示例】
13
- 【场景】提交单据Order,单据包含编号code字段
14
- 【需求】判断提交单据的编号是否为null或空串""
15
- 【举例】是空值(Order.code)`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"IsNaN",name:"非数字",params:[{key:"obj",name:"检测对象",type:"object"}],description:`【功能】判断检测对象是否可以转换成数字(Double)。检测对象不能转为数字返回true,否则返回false
16
- 【参数】
17
- 【obj】检测对象
18
- 【返回值】true或false
19
- 【示例】
20
- 【场景】提交单据Order,单据包含单据总额sum字段
21
- 【需求】判断提交单据的单据总额是否为非数字
22
- 【举例】非数字(Order.sum)`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"IsNumber",name:"是数字",params:[{key:"obj",name:"检测对象",type:"object"}],description:`【功能】判断检测对象是否可以转换成数字(Double)。检测对象能转为数字返回true,否则返回false
23
- 【参数】
24
- 【obj】检测对象
25
- 【返回值】true或false
26
- 【示例】
27
- 【场景】提交单据Order,单据包含单据总额sum字段
28
- 【需求】判断提交单据的单据总额是否是数字
29
- 【举例】是数字(Order.sum)`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"ExistData",name:"子表有无数据",params:[{key:"table",name:"主表.子表",type:"string"}],description:`【功能】判断子表中有没有数据。有数据返回true,无数据返回false(参数用""包起来)
30
- 【参数】
31
- 【table】主表.子表(链式结构)
32
- 【返回值】true或false
33
- 【示例】
34
- 【场景】提交单据Order,单据包含差旅明细子表trips
35
- 【需求】判断差旅明细子表是否有数据
36
- 【举例】子表有无数据("Order.trips")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"CountOfChild",name:"子表数据数量",params:[{key:"table",name:"主表.子表",type:"string"}],description:`【功能】返回子表数据的数量(参数用""包起来)
37
- 【参数】
38
- 【table】主表.子表(链式结构)
39
- 【返回值】数量(数值类型)
40
- 【示例】
41
- 【场景】提交单据Order,单据包含差旅明细子表trips
42
- 【需求】获取差旅明细子表的数量
43
- 【举例】子表数据数量("Order.trips")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"SortChildData",name:"子表数据排序",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表排序字段",type:"string"},{key:"order",name:"排序方式",type:"string"}],description:`【功能】对子表数据进行排序(参数用""包起来)
44
- 【参数】
45
- 【table】主表.子表(链式结构)
46
- 【property】子表字段(字段类型应为数字类型)
47
- 【order】排序方式("ESC"表示正序从小到大,"DESC"表示倒序从大到小)
48
- 【返回值】无
49
- 【示例】
50
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段
51
- 【需求】按照出差费用money字段对差旅明细从小到大排序
52
- 【举例】子表数据排序("Order.trips","money","ESC")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"IncludedInList",name:"是否在列表中",params:[{key:"property",name:"字段",type:"object"},{key:"list",name:"数据列表",type:"list"}],description:`【功能】:判断字段是否在数据列表中存在。字段在列表中存在返回true,不存在返回false。支持判断字符和数字类型
53
- 【参数】
54
- 【property】字段
55
- 【list】数据列表
56
- 【返回值】true或false
57
- 【示例】是否在列表中(Order.name,["Zs","Ls"])
58
- 【示例】是否在列表中(Order.quantity,[100,200])`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"CountByProp",name:"子表列非空数",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"}],description:`【功能】:统计子表某字段不为null的数据数量(参数用""包起来)
59
- 【参数】
60
- 【table】主表.子表(链式结构)
61
- 【property】子表字段
62
- 【返回值】子表字段不为null的数量(数值类型)
63
- 【示例】
64
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差方式way字段
65
- 【需求】统计差旅明细子表trips中出差方式way不为空的数据数量
66
- 【举例】子表列非空数("Order.trips","way")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"SumByProp",name:"子表字段求和",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"}],description:`【功能】求和子表某字段(参数用""包起来)
67
- 【参数】
68
- 【table】主表.子表(链式结构)
69
- 【property】子表字段(数值类型)
70
- 【返回值】子表某字段的和(数值类型)
71
- 【示例】
72
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段
73
- 【需求】对差旅明细子表trips的出差费用money字段求和
74
- 【举例】子表字段求和("Order.trips","money")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"AvgByProp",name:"子表列平均值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"}],description:`【功能】求子表某字段的平均值(参数用""包起来)
75
- 【参数】
76
- 【table】主表.子表(链式结构)
77
- 【property】子表字段(数值类型)
78
- 【返回值】子表某字段的平均值(数值类型)
79
- 【示例】
80
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段
81
- 【需求】获取差旅明细子表trips的出差费用money的平均值
82
- 【举例】子表列平均值("Order.trips","money")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"MaxByProp",name:"子表列最大值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"}],description:`【功能】求子表某字段的最大值(参数用""包起来)
83
- 【参数】
84
- 【table】主表.子表(链式结构)
85
- 【property】子表字段(数值类型)
86
- 【返回值】子表某字段的最大值(数值类型)
87
- 【示例】
88
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段
89
- 【需求】获取差旅明细子表trips的出差费用money的最大值
90
- 【举例】子表列最大值("Order.trips","money")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"MinByProp",name:"子表列最小值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"}],description:`【功能】求子表某字段的最小值(参数用""包起来)
91
- 【参数】
92
- 【table】主表.子表(链式结构)
93
- 【property】子表字段(数值类型)
94
- 【返回值】子表某字段的最小值(数值类型)
95
- 【示例】
96
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段
97
- 【需求】获取差旅明细子表trips的出差费用money的最小值
98
- 【举例】子表列最小值("Order.trips","money")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"IsExistRecord",name:"子表有无等于匹配值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"},{key:"match",name:"匹配值",type:"string"}],description:`【功能】判断子表某字段是否存在等于匹配值的数据(参数用""包起来)
99
- 【参数】
100
- 【table】主表.子表(链式结构)
101
- 【property】子表字段
102
- 【match】匹配值
103
- 【返回值】true或false
104
- 【示例】
105
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差方式way
106
- 【需求】判断差旅明细子表trips是否存在出差方式way等于'火车'的数据
107
- 【举例】子表有无等于匹配值("Order.trips","way","火车")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"IsContainMatch",name:"子表有无包含匹配值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"},{key:"match",name:"匹配值",type:"string"}],description:`【功能】判断子表某字段是否存在包含匹配值的数据(参数用""包起来)
108
- 【参数】
109
- 【table】主表.子表(链式结构)
110
- 【property】子表字段
111
- 【match】匹配值
112
- 【返回值】true或false
113
- 【示例】
114
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差方式way
115
- 【需求】判断差旅明细子表trips是否存在出差方式way包含匹配值'飞机'的数据
116
- 【举例】子表有无包含匹配值("Order.trips","way","飞机")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"ListGreaterThan",name:"子表有无大于匹配值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"},{key:"match",name:"匹配值",type:"double"}],description:`【功能】判断子表某字段是否存在大于匹配值的数据(参数用""包起来)
117
- 【参数】
118
- 【table】主表.子表(链式结构)
119
- 【property】子表字段(数值类型)
120
- 【match】匹配值
121
- 【返回值】true或false
122
- 【示例】
123
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差距离distance
124
- 【需求】判断差旅明细子表trips是否存在出差距离distance大于1000的数据
125
- 【举例】子表有无大于匹配值("Order.trips","distance",1000)`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"ListLessThan",name:"子表有无小于匹配值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"},{key:"match",name:"匹配值",type:"double"}],description:`【功能】判断子表某字段是否存在小于匹配值的数据(参数用""包起来)
126
- 【参数】
127
- 【table】主表.子表(链式结构)
128
- 【property】子表字段(数值类型)
129
- 【match】匹配值
130
- 【返回值】true或false
131
- 【示例】
132
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差距离distance
133
- 【需求】判断差旅明细子表trips是否存在出差距离distance小于10的数据
134
- 【举例】子表有无小于匹配值("Order.trips","distance",10)`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"ListStartWith",name:"子表有无以匹配值开头",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"},{key:"match",name:"匹配值",type:"string"}],description:`【功能】判断子表某字段有无开头是匹配值的数据(参数用""包起来)
135
- 【参数】
136
- 【table】主表.子表(链式结构)
137
- 【property】子表字段
138
- 【match】匹配值
139
- 【返回值】true或false
140
- 【示例】
141
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含编号code字段
142
- 【需求】判断差旅明细子表trips是否存在编号code字段以'0001'开头的数据
143
- 【举例】子表有无以匹配值开头("Order.trips","code","0001")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"ListEndWith",name:"子表有无以匹配值结尾",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"},{key:"match",name:"匹配值",type:"string"}],description:`【功能】判断子表某字段有无结尾是匹配值的数据(参数用""包起来)
144
- 【参数】
145
- 【table】主表.子表(链式结构)
146
- 【property】子表字段
147
- 【match】匹配值
148
- 【返回值】true或false
149
- 【示例】
150
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含编号code字段
151
- 【需求】判断差旅明细子表trips是否存在编号code字段以'0002'结尾的数据
152
- 【举例】子表有无以匹配值结尾("Order.trips","code","0002")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"GetComputeJsonData",name:"子表字段取JSON串",params:[{key:"table",name:"主表.子表",type:"string"},{key:"property",name:"子表字段",type:"string"}],description:`【功能】判断子表某字段有无结尾是匹配值的数据(参数用""包起来)
153
- 【参数】
154
- 【table】主表.子表(链式结构)
155
- 【property】子表字段
156
- 【返回值】子表某字段的JSON格式
157
- 【示例】
158
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含编号code字段
159
- 【需求】将差旅明细子表trips编号code字段用一个列表统计数据,并返回序列化后的值
160
- 【举例】子表字段取JSON串("Order.trips","code")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"MultiplyChildNumber",name:"子表属性乘积求和",params:[{key:"table",name:"主表.子表",type:"string"},{key:"prop1",name:"属性一",type:"string"},{key:"prop2",name:"属性二",type:"string"}],description:`【功能】对子表的两个数字类型属性,先做乘积,然后求和(参数用""包起来)
161
- 【参数】
162
- 【table】主表.子表(链式结构)
163
- 【prop1】属性一(数值类型)
164
- 【prop2】属性二(数值类型)
165
- 【返回值】求和值(数值类型)
166
- 【示例】
167
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差天数days、出差费用money
168
- 【需求】获取差旅明细的总费用,即子表出差天数*出差费用的总和
169
- 【举例】子表属性乘积求和("Order.trips","days","money")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"MinValueOfPeriod",name:"时间范围内取最小值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"timeProp",name:"比较时间字段",type:"string"},{key:"valueProp",name:"取值字段",type:"string"},{key:"startTime",name:"起始时间",type:"string"},{key:"endTime",name:"结束时间",type:"string"}],description:`【功能】在指定时间范围内,取子表某字段的最小值(参数用""包起来)
170
- 【参数】
171
- 【table】主表.子表(链式结构)
172
- 【timeProp】比较时间字段(字段类型应为时间类型)
173
- 【valueProp】取值字段(字段类型应为数字类型)
174
- 【startTime】起始时间(支持'yyyy-MM-dd' 或 'yyyy-MM-dd hh:mm:ss')
175
- 【endTime】结束时间(支持'yyyy-MM-dd' 或 'yyyy-MM-dd hh:mm:ss')
176
- 【返回值】时间范围内,子表某字段的最小值
177
- 【示例】
178
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段,出差日期date字段
179
- 【需求】获取2022-10-01到2022-10-07时间段内,哪一天的出差费用money最小
180
- 【举例】时间范围内取最小值("Order.trips","date","money","2022-10-01","2022-10-07")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"MaxValueOfPeriod",name:"时间范围内取最大值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"timeProp",name:"比较时间字段",type:"string"},{key:"valueProp",name:"取值字段",type:"string"},{key:"startTime",name:"起始时间",type:"string"},{key:"endTime",name:"结束时间",type:"string"}],description:`【功能】在指定时间范围内,取子表某字段的最大值(参数用""包起来)
181
- 【参数】
182
- 【table】主表.子表(链式结构)
183
- 【timeProp】比较时间字段(字段类型应为时间类型)
184
- 【valueProp】取值字段(字段类型应为数字类型)
185
- 【startTime】起始时间(支持'yyyy-MM-dd' 或 'yyyy-MM-dd hh:mm:ss')
186
- 【endTime】结束时间(支持'yyyy-MM-dd' 或 'yyyy-MM-dd hh:mm:ss')
187
- 【返回值】时间范围内,子表某字段的最大值
188
- 【示例】
189
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段,出差日期date字段
190
- 【需求】获取2022-10-01到2022-10-07时间段内,哪一天的出差费用money最大
191
- 【举例】时间范围内取最大值("Order.trips","date","money","2022-10-01","2022-10-07")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"AvgValueOfPeriod",name:"时间范围内取平均值",params:[{key:"table",name:"主表.子表",type:"string"},{key:"timeProp",name:"比较时间字段",type:"string"},{key:"valueProp",name:"取值字段",type:"string"},{key:"startTime",name:"起始时间",type:"string"},{key:"endTime",name:"结束时间",type:"string"}],description:`【功能】在指定时间范围内,取子表某字段的平均值(所有参数用""包起来)
192
- 【参数】
193
- 【table】主表.子表(链式结构)
194
- 【timeProp】比较时间字段(字段类型应为时间类型)
195
- 【valueProp】取值字段(字段类型应为数字类型)
196
- 【startTime】起始时间(支持'yyyy-MM-dd' 或 'yyyy-MM-dd hh:mm:ss')
197
- 【endTime】结束时间(支持'yyyy-MM-dd' 或 'yyyy-MM-dd hh:mm:ss')
198
- 【返回值】时间范围内,子表某字段的平均值
199
- 【示例】
200
- 【场景】提交单据Order,单据包含差旅明细子表trips,子表包含出差费用money字段,出差日期date字段
201
- 【需求】获取2022-10-01到2022-10-07时间段内,平均的出差费用money是多少
202
- 【举例】时间范围内取平均值("Order.trips","date","money","2022-10-01","2022-10-07")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"GetSessionValue",name:"获取会话变量",params:[{key:"name",name:"名称",type:"string"}],description:`【功能】获取用户会话变量的值
203
- 【参数】
204
- 【name】会话变量名
205
- 【返回值】对象(object)
206
- 【示例】
207
- 【举例】获取会话变量("会话变量一")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"GetContextParameter",name:"获取上下文变量",params:[{key:"name",name:"名称",type:"string"}],description:`【功能】获取上下文变量的值
208
- 【参数】
209
- 【name】上下文变量名
210
- 【返回值】对象(object)
211
- 【示例】
212
- 【举例】获取上下文变量("上下文变量一")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"GetInjectedEntity",name:"根据注入名获取注入对象",params:[{key:"name",name:"注入名",type:"string"}],description:`【功能】获取运行时注入对象的实际对象(参数用""包起来),不支持获取属性
213
- 【参数】
214
- 【name】注入名
215
- 【返回值】对象(object)
216
- 【示例】
217
- 【举例】根据注入名获取注入对象("注入名")`,type:"Analytical",keyFront:"DefaultFunction",className:""},{key:"GetChainedPropertyValue",name:"根据属性名获取属性值",params:[{key:"property",name:"属性名",type:"string"}],description:`【功能】:获取运行时注入属性的实际值(参数用""包起来)
218
- 【参数】
219
- 【property】属性名
220
- 【返回值】对象(object)
221
- 【示例】
222
- 【举例】根据属性名获取属性值("属性名")`,type:"Analytical",keyFront:"DefaultFunction",className:""}]},datetime:{name:"时间",items:[{key:"DayDifference",name:"天数差",params:[{key:"date1",name:"时间一",type:"obj"},{key:"date2",name:"时间二",type:"obj"}],description:`【功能】计算两个时间的天数差,计算时以年月日为准,自动忽略时分秒。时间一若早于时间二,返回正数;若晚于时间二,返回负数
223
- 【参数】
224
- 【date1】时间一
225
- 【date2】时间二
226
- 【返回值】两个日期的天数差
227
- 【示例】
228
- 【示例一】天数差("2024-01-01","2024-01-11")
229
- 【返回值】10
230
- 【示例一】天数差("2024-01-11","2024-01-01")
231
- 【返回值】-10`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"DateTimeAddDays",name:"增加天数",params:[{key:"date",name:"日期时间",type:"string"},{key:"value",name:"增加天数",type:"int"}],description:`【功能】:在指定日期时间上增加指定天数
232
- 【返回值类型】:日期时间(DateTime)
233
- 【示例】:增加天数("2019-01-30T10:00:00+08:00",2)【返回值】:2019-02-01T10:00+08:00`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"DateTimeAddYears",name:"增加年数",params:[{key:"date",name:"日期时间",type:"string"},{key:"value",name:"增加年数",type:"int"}],description:`【功能】:在指定日期时间上增加指定年数
234
- 【返回值类型】:日期时间(DateTime)
235
- 【示例】:增加年数("2019-01-30T10:00:00+08:00",2)【返回值】:2021-01-30T10:00+08:00`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"DateTimeAddMonths",name:"增加月数",params:[{key:"date",name:"日期时间",type:"string"},{key:"value",name:"增加月数",type:"int"}],description:`【功能】:在指定日期时间上增加指定的月数
236
- 【返回值类型】:日期时间(DateTime)
237
- 【示例】:增加月数("2019-01-30T10:00:00+08:00",1)【返回值】:2019-02-28T10:00+08:00`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"GetFirstDayOfMonth",name:"日期所在月第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:获取指定日期时间所在月的第一天的日期
238
- 【返回值类型】:日期时间(DateTime)
239
- 【示例】:日期所在月第一天("2019-01-30T10:00:00+08:00")【返回值】:2019-01-01`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"GetLastDayOfMonth",name:"日期所在月最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:获取指定日期时间所在月的最后一天的日期
240
- 【返回值类型】:日期时间(DateTime)
241
- 【示例】:日期所在月最后一天("2019-01-30T10:00:00+08:00")【返回值】:2019-01-31`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"GetDateTimeNow",name:"当前日期时间",params:[],description:`【功能】:获取当前的日期时间
242
- 【返回值类型】:日期时间(DateTime)
243
- 【示例】:当前日期时间()【返回值】:2019-01-30T12:00:00.000+08:00`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"CompareDate",name:"比较两个时间",params:[{key:"date1",name:"日期时间一",type:"string"},{key:"date2",name:"日期时间二",type:"string"}],description:`【功能】:比较两个时间值,并返回一个整数
244
- 【返回值类型】:数值(int32)日期1早于日期2,返回-1;日期1等于日期2,返回0;日期1晚于日期2,返回1
245
- 【示例】:比较两个时间("2019-01-30T10:00:00+08:00","2019-02-01T10:00:00+08:00")【返回值】:-1`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FormatDate",name:"格式化当前日期",params:[{key:"format",name:"格式",type:"string"}],description:`【功能】:使用指定的格式将当前日期时间值转换为其等效的字符串表示形式
246
- 【返回值类型】:字符串(String)
247
- 【示例】:格式化当前日期("yyyy-MM-dd HH:mm:ss")【返回值】:"2019-01-30 01:00:00"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FormatDefineDate",name:"格式化指定日期",params:[{key:"format",name:"格式",type:"string"},{key:"date",name:"日期时间",type:"string"}],description:`【功能】:使用指定的格式将指定的日期时间值转换为其等效的字符串表示形式
248
- 【返回值类型】:字符串(String)
249
- 【示例】:格式化指定日期("yyyy-MM-dd HH:mm:ss","2019-01-30 01:00:00")【返回值】:"2019-01-30 01:00:00"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"Today",name:"今天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的今天,格式为"yyyy-MM-dd"形式,无参数则默认返回当前日期的今天
250
- 【返回值类型】:字符串(String)
251
- 【示例】:今天("2019-01-30T10:00:00+08:00")【返回值】:"2019-01-30"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"Yesterday",name:"昨天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的昨天,格式为"yyyy-MM-dd"形式,无参数则默认返回当前日期的昨天
252
- 【返回值类型】:字符串(String)
253
- 【示例】:昨天("2019-01-30T10:00:00+08:00")【返回值】:"2019-01-29"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"Tomorrow",name:"明天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的明天,格式为"yyyy-MM-dd"形式,无参数则默认返回当前日期的明天
254
- 【返回值类型】:字符串(String)
255
- 【示例】:明天("2019-01-30T10:00:00+08:00")【返回值】:"2019-01-31"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"ThisYear",name:"本年",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本年,格式为"yyyy"形式,无参数则默认返回当前日期的本年
256
- 【返回值类型】:字符串(String)
257
- 【示例】:本年("2019-01-30T10:00:00+08:00")【返回值】:"2019"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastYear",name:"去年",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的去年,格式为"yyyy"形式,无参数则默认返回当前日期的去年
258
- 【返回值类型】:字符串(String)
259
- 【示例】:去年("2019-01-30T10:00:00+08:00")【返回值】:"2018"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"NextYear",name:"明年",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的明年,格式为"yyyy"形式,无参数则默认返回当前日期的明年
260
- 【返回值类型】:字符串(String)
261
- 【示例】:明年("2019-01-30T01:00:00+08:00")【返回值】:"2020"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"ThisMonth",name:"本月",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本月,格式为"MM"形式,无参数则默认返回当前日期的本月
262
- 【返回值类型】:字符串(String)
263
- 【示例】:本月("2019-01-30T01:00:00+08:00")【返回值】:"1"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastMonth",name:"上月",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上月,格式为"MM"形式,无参数则默认返回当前日期的上月
264
- 【返回值类型】:字符串(String)
265
- 【示例】:上月("2019-02-30 01:00:00")【返回值】:"1"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"NextMonth",name:"下月",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下月,格式为"MM"形式,无参数则默认返回当前日期的下月
266
- 【返回值类型】:字符串(String)
267
- 【示例】:下月("2019-01-30T01:00:00+08:00")【返回值】:"2"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"ThisWeek",name:"本周",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期在本年的第几周,格式为"ww"形式,无参数则默认返回当前日期在本年的第几周
268
- 【返回值类型】:字符串(String)
269
- 【示例】:本周("2019-01-30T01:00:00+08:00")【返回值】:"5"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastWeek",name:"上周",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上周,格式为"ww"形式,无参数则默认返回当前日期的上周
270
- 【返回值类型】:字符串(String)
271
- 【示例】:上周("2019-01-30T01:00:00+08:00")【返回值】:"4"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"NextWeek",name:"下周",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下周,格式为"ww"形式,无参数则默认返回当前日期的下周
272
- 【返回值类型】:字符串(String)
273
- 【示例】:下周("2019-01-30T01:00:00+08:00")【返回值】:"6"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"DayOfWeek",name:"星期几",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期是本周的星期几,格式为"n",无参数则默认返回当前日期是本周的星期几
274
- 【返回值类型】:字符串(String)
275
- 【示例】:星期几("2019-01-30T01:00:00+08:00")【返回值】:"3"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfWeek",name:"本周第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本周第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的本周第一天
276
- 【返回值类型】:字符串(String)
277
- 【示例】:本周第一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-01-28"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfWeek",name:"本周最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本周最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的本周第一天
278
- 【返回值类型】:字符串(String)
279
- 【示例】:本周最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-02-03"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfLastWeek",name:"上周第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上周第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的上周第一天
280
- 【返回值类型】:字符串(String)
281
- 【示例】:上周第一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-01-21"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfLastWeek",name:"上周最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上周最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的上周最后一天
282
- 【返回值类型】:字符串(System.String)
283
- 【示例】:上周最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-01-27"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfNextWeek",name:"下周第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下周第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的下周第一天
284
- 【返回值类型】:字符串(String)
285
- 【示例】:下周第一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-02-04"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfNextWeek",name:"下周最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下周最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的下周最后一天
286
- 【返回值类型】:字符串(String)
287
- 【示例】:下周最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-02-10"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfMonth",name:"本月第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本月第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的本月第一天
288
- 【返回值类型】:字符串(String)
289
- 【示例】:本月第一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-01-01"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfMonth",name:"本月最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本月最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的本月最后一天
290
- 【返回值类型】:字符串(String)
291
- 【示例】:本月最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-01-31"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfLastMonth",name:"上月第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上月第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的上月第一天
292
- 【返回值类型】:字符串(String)
293
- 【示例】:上月第一天("2019-01-30T01:00:00+08:00")【返回值】:"2018-12-01"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfLastMonth",name:"上月最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上月最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的上月最后一天
294
- 【返回值类型】:字符串(String)
295
- 【示例】:上月最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2018-12-31"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfNextMonth",name:"下月第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下月第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的下月第一天
296
- 【返回值类型】:字符串(String)
297
- 【示例】:下月第一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-02-01"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfNextMonth",name:"下月最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下月最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的下月最后一天
298
- 【返回值类型】:字符串(String)
299
- 【示例】:下月最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-02-28"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfYear",name:"本年第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本年第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的本年第一天
300
- 【返回值类型】:字符串(String)
301
- 【示例】:本年第一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-01-01"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfYear",name:"本年最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的本年最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的本年最后一天
302
- 【返回值类型】:字符串(String)
303
- 【示例】:本年最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2019-12-31"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfLastYear",name:"上年第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上年第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的上年第一天
304
- 【返回值类型】:字符串(String)
305
- 【示例】:上年第一天("2019-01-30T01:00:00+08:00")【返回值】:"2018-01-01"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfLastYear",name:"上年最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的上年最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的上年最后一天
306
- 【返回值类型】:字符串(String)
307
- 【示例】:上年最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2018-12-31"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"FirstDayOfNextYear",name:"下年第一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下年第一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的下年第一天
308
- 【返回值类型】:字符串(String)
309
- 【示例】:下年第一天("2019-01-30T01:00:00+08:00")【返回值】:"2020-01-01"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"LastDayOfNextYear",name:"下年最后一天",params:[{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定日期的下年最后一天,格式为"yyyy-MM-dd",无参数则默认返回当前日期的下年最后一天
310
- 【返回值类型】:字符串(String)
311
- 【示例】:下年最后一天("2019-01-30T01:00:00+08:00")【返回值】:"2020-12-31"`,type:"DateTime",keyFront:"DefaultFunction",className:""},{key:"GetDate",name:"返回指定格式的日期",params:[{key:"format",name:"格式",type:"string"},{key:"date",name:"日期时间",type:"string"}],description:`【功能】:返回指定形式的日期,无参数则默认返回当前日期的指定格式日期
312
- 【返回值类型】:字符串(String)
313
- DD:今天 LD:昨天 ND:明天 YY:本年 LY:上年 NY:下年 MM:本月 LM:上月 NM:下月
314
- WD:星期几 WW:本周 LW:上周 NW:下周 FDW:本周首日 LDW:本周尾日
315
- FDLW:上周首日 LDLW:上周尾日 FDNW:下周首日 LDNW:下周尾日
316
- FDM:本月首日 LDM:本月尾日 FDLM:上月首日 LDLM:上月尾日 FDNM:下月首日 LDNM:下月尾日
317
- FDY:本年首日 LDY:本年尾日 FDLY:上年首日 LDLY:上年尾日 FDNY:下年首日 LDNY:下年尾日
318
- 【示例】:返回指定格式的日期("LD","2019-01-30T01:00:00+08:00")【返回值】:"2019-01-29"`,type:"DateTime",keyFront:"DefaultFunction",className:""}]},string:{name:"字符",items:[{key:"SubString",name:"取子字符串",params:[{key:"data",name:"字符串",type:"str"},{key:"start",name:"起始位置",type:"int"},{key:"length",name:"长度",type:"int"}],description:`【功能】:从字符串中指定位置开始,截取指定长度的字符串并返回
319
- 【返回值类型】:字符串(String)
320
- 【示例】:取子字符串("ABCDEFG",2,3)【返回值】:"CDE"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"Length",name:"取字符串长度",params:[{key:"data",name:"字符串",type:"str"}],description:`【功能】:获取字符串的长度
321
- 【返回值类型】:数值(Int32)
322
- 【示例】:取字符串长度("ABCDEF")【返回值】:6`,type:"String",keyFront:"DefaultFunction",className:""},{key:"Contains",name:"是否包含",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:判断字符串中是否包含目标字符串
323
- 【返回值类型】:布尔(Boolean)
324
- 【示例】:是否包含(salesorder.code,"表达式")【返回值】:false`,type:"String",keyFront:"DefaultFunction",className:""},{key:"NotContains",name:"是否不包含",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:判断字符串中是否不包含目标字符串
325
- 【返回值类型】:布尔(Boolean)
326
- 【示例】:是否不包含(salesorder.code,"表达式")【返回值】:true`,type:"String",keyFront:"DefaultFunction",className:""},{key:"StartsWith",name:"开头是",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:判断字符串是否以目标字符串开头
327
- 【返回值类型】:布尔(Boolean)
328
- 【示例】:开头是(salesorder.code,"表达式")【返回值】:false`,type:"String",keyFront:"DefaultFunction",className:""},{key:"NotStartsWith",name:"开头不是",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:判断字符串是否不以目标字符串开头
329
- 【返回值类型】:布尔(Boolean)
330
- 【示例】:开头不是(salesorder.code,"表达式")【返回值】:true`,type:"String",keyFront:"DefaultFunction",className:""},{key:"EndsWith",name:"结尾是",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:判断字符串是否以目标字符串结尾
331
- 【返回值类型】:布尔(Boolean)
332
- 【示例】:结尾是(salesorder.code,"表达式")【返回值】:false`,type:"String",keyFront:"DefaultFunction",className:""},{key:"NotEndsWith",name:"结尾不是",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:判断字符串是否不以目标字符串结尾
333
- 【返回值类型】:布尔(Boolean)
334
- 【示例】:结尾不是(salesorder.code,"表达式")【返回值】:false`,type:"String",keyFront:"DefaultFunction",className:""},{key:"Replace",name:"字符串替换",params:[{key:"data",name:"字符串",type:"str"},{key:"oldVal",name:"被替换值",type:"str"},{key:"newVal",name:"替换值",type:"str"}],description:`【功能】:将字符串中的"被替换值"替换为"替换值"
335
- 【返回值类型】:字符串(String)
336
- 【示例】:字符串替换("123412","12","00")【返回值】:"003400"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"ToUpper",name:"转大写",params:[{key:"data",name:"字符串",type:"str"}],description:`【功能】:将字符串转换为大写
337
- 【返回值类型】:字符串(String)
338
- 【示例】:转大写("abc")【返回值】:"ABC"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"ToLower",name:"转小写",params:[{key:"data",name:"字符串",type:"str"}],description:`【功能】:将字符串转换为小写
339
- 【返回值类型】:字符串(String)
340
- 【示例】:转小写("ABC")【返回值】:"abc"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"IndexOf",name:"首个匹配字符索引",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:在字符串中检索目标字符串,找到首个匹配的字符串并返回索引位置(从0开始)。如果未找到则返回-1,如果目标字符串为空则返回0,如果原字符串为null则返回-1
341
- 【返回值类型】:数值(Int32)
342
- 【示例】:首个匹配字符索引("12001234012","01")【返回值】:3
343
- 【示例】:首个匹配字符索引("12002323","34")【返回值】:-1
344
- 【示例】:首个匹配字符索引("120011","")【返回值】:0`,type:"String",keyFront:"DefaultFunction",className:""},{key:"LastIndexOf",name:"最后匹配字符索引",params:[{key:"data",name:"字符串",type:"str"},{key:"target",name:"目标字符串",type:"str"}],description:`【功能】:在字符串中检索目标字符串,找到最后一个匹配的字符串后返回索引位置(从0开始)。如果未找到则返回-1,如果目标字符串为空串则返回原字符串长度,如果原字符串为null则返回-1
345
- 【返回值类型】:数值(Int32)
346
- 【示例】:最后匹配字符索引("12001234012","01")【返回值】:8
347
- 【示例】:最后匹配字符索引("12002323","34")【返回值】:-1
348
- 【示例】:最后匹配字符索引("120011","")【返回值】:6`,type:"String",keyFront:"DefaultFunction",className:""},{key:"TrimStart",name:"删除头部空格",params:[{key:"data",name:"字符串",type:"str"}],description:`【功能】:删除字符串的头部空格并返回
349
- 【返回值类型】:字符串(String)
350
- 【示例】:删除头部空格(" ABC")【返回值】:"ABC"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"TrimEnd",name:"删除尾部空格",params:[{key:"data",name:"字符串",type:"str"}],description:`【功能】:删除字符串的尾部空格并返回
351
- 【返回值类型】:字符串(String)
352
- 【示例】:删除尾部空格("ABC ")【返回值】:"ABC"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"Trim",name:"删除头尾部空格",params:[{key:"data",name:"字符串",type:"str"}],description:`【功能】:删除字符串的头尾部空格并返回
353
- 【返回值类型】:字符串(String)
354
- 【示例】:删除头尾部空格(" ABC ")【返回值】:"ABC"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"CreateGuid",name:"唯一标识符",params:[],description:`【功能】:获取唯一标识符Guid
355
- 【返回值类型】:字符串(String)
356
- 【示例】:唯一标识符()【返回值】:"7722A793-14DF-49CD-B7E7-DF4987YYD2"`,type:"String",keyFront:"DefaultFunction",className:""},{key:"Add",name:"字符串相加",params:[{key:"str1",name:"第一个字符串",type:"str"},{key:"str2",name:"第二个字符串",type:"str"}],description:`【功能】:将若干字符串拼接成一个新字符串,最多支持10个字符串拼接,最少2个;编辑器中默认插入两个,多个字符串可手动添加
357
- 【返回值类型】:字符串(String)
358
- 【示例】:字符串相加("Hello","World")【返回值】:"HelloWord"`,type:"String",keyFront:"DefaultFunction",className:""}]},math:{name:"数字",items:[{key:"NumberThousandSeparator",name:"数字千位分隔",params:[{key:"property",name:"数字类型字段",type:"int32"}],description:`【功能】对数字添加千位分割符,以逗号作为千位分隔符
359
- 【参数】
360
- 【property】字段(链式结构)
361
- 【返回值】字符型
362
- 【示例】
363
- 【场景】提交单据Order,单据包含总费用totalCost
364
- 【需求】优化总费用展示,对总费用添加千位分隔符
365
- 【举例】数字千位分隔(Order.totalCost)
366
- 【返回值】1,234,567.89`,type:"Math",keyFront:"DefaultFunction",className:""},{key:"abs",name:"绝对值",params:[{key:"value",name:"数值",type:"double"}],description:`【功能】:返回一个数值的绝对值
367
- 【返回值类型】:数值(Double)
368
- 【示例】:绝对值(-1.5)【返回值】:1.5`,type:"Math",keyFront:"Math",className:""},{key:"round",name:"四舍五入",params:[{key:"value1",name:"数值",type:"double"},{key:"value2",name:"小数位数",type:"int32"}],description:`【功能】:根据小数位数精度,对数值四舍五入
369
- 【value1】:数值
370
- 【value2】:四舍五入小数位数
371
- 【返回值类型】:数值(Double)
372
- 【示例】:四舍五入(1.52,1)【返回值】:1.5`,type:"Math",keyFront:"DefaultFunction",className:""},{key:"random",name:"随机数",params:[],description:`【功能】:随机生成大于等于 0.0 且小于 1.0 的伪随机值
373
- 【返回值类型】:数值(Double)
374
- 【示例】:随机数()【返回值】:0.624508349393`,type:"Math",keyFront:"Math",className:""},{key:"sin",name:"正弦",params:[{key:"value",name:"数值",type:"double"}],description:`【功能】:返回一个数字的正弦值
375
- 【返回值类型】:数值(Double)一个以弧度表示的角
376
- 【示例】:正弦(1)【返回值】:0.84187098`,type:"Math",keyFront:"Math",className:""},{key:"cos",name:"余弦",params:[{key:"value",name:"数值",type:"double"}],description:`【功能】:返回一个数字的余弦值
377
- 【返回值类型】:数值(Double)一个以弧度表示的角
378
- 【示例】:余弦(3)【返回值】:-0.9899924`,type:"Math",keyFront:"Math",className:""},{key:"ceil",name:"向上舍入",params:[{key:"value",name:"数值",type:"double"}],description:`【功能】:返回大于或等于函数参数,并且与之最接近的整数
379
- 【返回值类型】:数值(Int32)
380
- 【示例】:向上舍入(3.2)【返回值】:4`,type:"Math",keyFront:"Math",className:""},{key:"floor",name:"向下舍入",params:[{key:"value",name:"数值",type:"double"}],description:`【功能】:返回小于或等于函数参数,并且与之最接近的整数
381
- 【返回值类型】:数值(Int32)
382
- 【示例】:向下舍入(3.2)【返回值】:3`,type:"Math",keyFront:"Math",className:""},{key:"bankerRound",name:"银行家舍入",params:[{key:"value1",name:"数值",type:"double"},{key:"value2",name:"小数位数",type:"int32"}],description:`【功能】:使用银行家舍入标准,把指定数字舍入为最接近的数字
383
- 【value1】:舍入数值
384
- 【value2】:舍入小数位数
385
- 【返回值类型】:数值(Double)
386
- 【示例】:银行家舍入(36.124,2)【返回值】:36.12`,type:"Math",keyFront:"DefaultFunction",className:""}]},translate:{name:"转换",items:[{key:"ToStringX",name:"转字符串",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换为字符串
387
- 【返回值类型】:字符串(String)
388
- 【示例】:转字符串(123)【返回值】:"123"`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToDateTime",name:"转日期时间",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成日期时间
389
- 【返回值类型】:日期时间(OffsetDateTime)
390
- 【示例】:转日期时间("2019-01-30T10:00:00+08:00")【返回值】: 2019-01-30T10:00+08:00`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToBoolean",name:"转布尔值",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成等效的布尔值
391
- 【返回值类型】:布尔值(Boolean)
392
- 【示例】:转布尔值("True")【返回值】:true`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToBigDecimal",name:"转数值",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成十进制数值
393
- 【返回值类型】:十进制数值(BigDecimal)
394
- 【示例】:转数值("40.23")【返回值】:40.23`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToCustomBigDecimal",name:"转自定义精度数值",params:[{key:"obj",name:"转换值",type:"object"},{key:"number",name:"小数位数",type:"int"}],description:`【功能】:将转换值转换成指定精度的十进制数值
395
- 【返回值类型】:十进制数值(BigDecimal)
396
- 【示例】:转自定义精度数值("40.2,2")【返回值】:40.20`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToDouble",name:"转双精度浮点数",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成双精度浮点数
397
- 【返回值类型】:双精度浮点数(Double)
398
- 【示例】:转双精度浮点数("40.23")【返回值】:40.23`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToFloat",name:"转单精度浮点数",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成单精度浮点数
399
- 【返回值类型】:单精度浮点数(Float)
400
- 【示例】:转单精度浮点数("40.23")【返回值】:40.23`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToByte",name:"转8位无符号整数",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成8位无符号整数
401
- 【返回值类型】:8位无符号整数(Byte)
402
- 【示例】:转8位无符号整数("10")【返回值】:10`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToInt16",name:"转16位有符号整数",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成16位有符号整数
403
- 【返回值类型】:16位有符号整数(Int16)
404
- 【示例】:转16位有符号整数("10")【返回值】:10`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToInt32",name:"转32位有符号整数",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成32位有符号整数
405
- 【返回值类型】:32位有符号整数(Int32)
406
- 【示例】:转32位有符号整数("10")【返回值】:10`,type:"Translate",keyFront:"DefaultFunction",className:""},{key:"ToChineseMoney",name:"转中文大写金额",params:[{key:"obj",name:"转换值",type:"object"}],description:`【功能】:将转换值转换成中文大写金额
407
- 【返回值类型】:字符串(String)
408
- 【示例】:转中文大写金额(40.23)【返回值】:"肆拾元零贰角叁分"`,type:"Translate",keyFront:"DefaultFunction",className:""}]},advanced:{name:"高级",items:[{key:"if",name:`if() {
409
-
410
- }`,params:[],description:"if条件成立,执行括号中内容",type:"Advanced",keyFront:"",className:""},{key:"if else",name:`if() {
411
-
412
- } else {
413
-
414
- }`,params:[],description:"if条件成立,执行括号中内容;否则执行else中内容",type:"Advanced",keyFront:"",className:""},{key:"for",name:`for(;;)
415
- {
416
-
417
- }`,params:[],description:"for循环:示例:for(var i=0;i<5;i++){}",type:"Advanced",keyFront:"",className:""},{key:"return",name:"return ;",params:[],description:"返回值",type:"Advanced",keyFront:"",className:""},{key:"var",name:"var ",params:[],description:"变量定义",type:"Advanced",keyFront:"",className:""},{key:"true",name:"true ",params:[],description:"正确",type:"Advanced",keyFront:"",className:""},{key:"false",name:"false ",params:[],description:"错误",type:"Advanced",keyFront:"",className:""}]}};function Tt(e,n,a){return n in e?Object.defineProperty(e,n,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[n]=a,e}function Pe(e,n){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);n&&(o=o.filter(function(i){return Object.getOwnPropertyDescriptor(e,i).enumerable})),a.push.apply(a,o)}return a}function je(e){for(var n=1;n<arguments.length;n++){var a=arguments[n]!=null?arguments[n]:{};n%2?Pe(Object(a),!0).forEach(function(o){Tt(e,o,a[o])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(a)):Pe(Object(a)).forEach(function(o){Object.defineProperty(e,o,Object.getOwnPropertyDescriptor(a,o))})}return e}function St(e,n){if(e==null)return{};var a={},o=Object.keys(e),i,l;for(l=0;l<o.length;l++)i=o[l],!(n.indexOf(i)>=0)&&(a[i]=e[i]);return a}function Nt(e,n){if(e==null)return{};var a=St(e,n),o,i;if(Object.getOwnPropertySymbols){var l=Object.getOwnPropertySymbols(e);for(i=0;i<l.length;i++)o=l[i],!(n.indexOf(o)>=0)&&Object.prototype.propertyIsEnumerable.call(e,o)&&(a[o]=e[o])}return a}function Mt(e,n){return Ot(e)||Vt(e,n)||Bt(e,n)||Dt()}function Ot(e){if(Array.isArray(e))return e}function Vt(e,n){if(!(typeof Symbol>"u"||!(Symbol.iterator in Object(e)))){var a=[],o=!0,i=!1,l=void 0;try{for(var r=e[Symbol.iterator](),s;!(o=(s=r.next()).done)&&(a.push(s.value),!(n&&a.length===n));o=!0);}catch(u){i=!0,l=u}finally{try{!o&&r.return!=null&&r.return()}finally{if(i)throw l}}return a}}function Bt(e,n){if(e){if(typeof e=="string")return Ie(e,n);var a=Object.prototype.toString.call(e).slice(8,-1);if(a==="Object"&&e.constructor&&(a=e.constructor.name),a==="Map"||a==="Set")return Array.from(e);if(a==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return Ie(e,n)}}function Ie(e,n){(n==null||n>e.length)&&(n=e.length);for(var a=0,o=new Array(n);a<n;a++)o[a]=e[a];return o}function Dt(){throw new TypeError(`Invalid attempt to destructure non-iterable instance.
418
- In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function Et(e,n,a){return n in e?Object.defineProperty(e,n,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[n]=a,e}function Re(e,n){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);n&&(o=o.filter(function(i){return Object.getOwnPropertyDescriptor(e,i).enumerable})),a.push.apply(a,o)}return a}function Le(e){for(var n=1;n<arguments.length;n++){var a=arguments[n]!=null?arguments[n]:{};n%2?Re(Object(a),!0).forEach(function(o){Et(e,o,a[o])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(a)):Re(Object(a)).forEach(function(o){Object.defineProperty(e,o,Object.getOwnPropertyDescriptor(a,o))})}return e}function Pt(){for(var e=arguments.length,n=new Array(e),a=0;a<e;a++)n[a]=arguments[a];return function(o){return n.reduceRight(function(i,l){return l(i)},o)}}function oe(e){return function n(){for(var a=this,o=arguments.length,i=new Array(o),l=0;l<o;l++)i[l]=arguments[l];return i.length>=e.length?e.apply(this,i):function(){for(var r=arguments.length,s=new Array(r),u=0;u<r;u++)s[u]=arguments[u];return n.apply(a,[].concat(i,s))}}}function ce(e){return{}.toString.call(e).includes("Object")}function jt(e){return!Object.keys(e).length}function ie(e){return typeof e=="function"}function It(e,n){return Object.prototype.hasOwnProperty.call(e,n)}function Rt(e,n){return ce(n)||J("changeType"),Object.keys(n).some(function(a){return!It(e,a)})&&J("changeField"),n}function Lt(e){ie(e)||J("selectorType")}function zt(e){ie(e)||ce(e)||J("handlerType"),ce(e)&&Object.values(e).some(function(n){return!ie(n)})&&J("handlersType")}function Ht(e){e||J("initialIsRequired"),ce(e)||J("initialType"),jt(e)&&J("initialContent")}function $t(e,n){throw new Error(e[n]||e.default)}var At={initialIsRequired:"initial state is required",initialType:"initial state should be an object",initialContent:"initial state shouldn't be an empty object",handlerType:"handler should be an object or a function",handlersType:"all handlers should be a functions",selectorType:"selector should be a function",changeType:"provided value of changes should be an object",changeField:'it seams you want to change a field in the state which is not specified in the "initial" state',default:"an unknown error accured in `state-local` package"},J=oe($t)(At),ue={changes:Rt,selector:Lt,handler:zt,initial:Ht};function Wt(e){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};ue.initial(e),ue.handler(n);var a={current:e},o=oe(Ut)(a,n),i=oe(Yt)(a),l=oe(ue.changes)(e),r=oe(qt)(a);function s(){var f=arguments.length>0&&arguments[0]!==void 0?arguments[0]:function(b){return b};return ue.selector(f),f(a.current)}function u(f){Pt(o,i,l,r)(f)}return[s,u]}function qt(e,n){return ie(n)?n(e.current):n}function Yt(e,n){return e.current=Le(Le({},e.current),n),n}function Ut(e,n,a){return ie(n)?n(e.current):Object.keys(a).forEach(function(o){var i;return(i=n[o])===null||i===void 0?void 0:i.call(n,e.current[o])}),a}var Gt={create:Wt},Xt={paths:{vs:"https://cdn.jsdelivr.net/npm/monaco-editor@0.43.0/min/vs"}};function Kt(e){return function n(){for(var a=this,o=arguments.length,i=new Array(o),l=0;l<o;l++)i[l]=arguments[l];return i.length>=e.length?e.apply(this,i):function(){for(var r=arguments.length,s=new Array(r),u=0;u<r;u++)s[u]=arguments[u];return n.apply(a,[].concat(i,s))}}}function _t(e){return{}.toString.call(e).includes("Object")}function Jt(e){return e||He("configIsRequired"),_t(e)||He("configType"),e.urls?(Zt(),{paths:{vs:e.urls.monacoBase}}):e}function Zt(){console.warn(ze.deprecation)}function Qt(e,n){throw new Error(e[n]||e.default)}var ze={configIsRequired:"the configuration object is required",configType:"the configuration object should be an object",default:"an unknown error accured in `@monaco-editor/loader` package",deprecation:`Deprecation warning!
419
- You are using deprecated way of configuration.
420
-
421
- Instead of using
422
- monaco.config({ urls: { monacoBase: '...' } })
423
- use
424
- monaco.config({ paths: { vs: '...' } })
425
-
426
- For more please check the link https://github.com/suren-atoyan/monaco-loader#config
427
- `},He=Kt(Qt)(ze),en={config:Jt},tn=function(){for(var n=arguments.length,a=new Array(n),o=0;o<n;o++)a[o]=arguments[o];return function(i){return a.reduceRight(function(l,r){return r(l)},i)}};function $e(e,n){return Object.keys(n).forEach(function(a){n[a]instanceof Object&&e[a]&&Object.assign(n[a],$e(e[a],n[a]))}),je(je({},e),n)}var nn={type:"cancelation",msg:"operation is manually canceled"};function ve(e){var n=!1,a=new Promise(function(o,i){e.then(function(l){return n?i(nn):o(l)}),e.catch(i)});return a.cancel=function(){return n=!0},a}var an=Gt.create({config:Xt,isInitialized:!1,resolve:null,reject:null,monaco:null}),Ae=Mt(an,2),le=Ae[0],de=Ae[1];function on(e){var n=en.config(e),a=n.monaco,o=Nt(n,["monaco"]);de(function(i){return{config:$e(i.config,o),monaco:a}})}function ln(){var e=le(function(n){var a=n.monaco,o=n.isInitialized,i=n.resolve;return{monaco:a,isInitialized:o,resolve:i}});if(!e.isInitialized){if(de({isInitialized:!0}),e.monaco)return e.resolve(e.monaco),ve(be);if(window.monaco&&window.monaco.editor)return We(window.monaco),e.resolve(window.monaco),ve(be);tn(rn,cn)(un)}return ve(be)}function rn(e){return document.body.appendChild(e)}function sn(e){var n=document.createElement("script");return e&&(n.src=e),n}function cn(e){var n=le(function(o){var i=o.config,l=o.reject;return{config:i,reject:l}}),a=sn("".concat(n.config.paths.vs,"/loader.js"));return a.onload=function(){return e()},a.onerror=n.reject,a}function un(){var e=le(function(a){var o=a.config,i=a.resolve,l=a.reject;return{config:o,resolve:i,reject:l}}),n=window.require;n.config(e.config),n(["vs/editor/editor.main"],function(a){We(a),e.resolve(a)},function(a){e.reject(a)})}function We(e){le().monaco||de({monaco:e})}function dn(){return le(function(e){var n=e.monaco;return n})}var be=new Promise(function(e,n){return de({resolve:e,reject:n})}),ke={config:on,init:ln,__getMonacoInstance:dn};const fn=t.defineComponent({name:"expression-code",props:{modelValue:{type:String,default:""},language:{type:String,default:"javascript"},theme:{type:String,default:"vs"},readOnly:{type:Boolean,default:!1},configPath:{type:String,default:"assets/monaco-editor.config.json"}},emits:[],setup(e,n){const a=t.ref(),o=t.ref();let i=null;const l=t.ref(e.modelValue);async function r(){return fetch(e.configPath).then(C=>C.json())}async function s(){if(a.value&&!i){const C=await r(),{vsPath:m}=C;ke.config({paths:{vs:window.location.origin+m}}),ke.config({"vs/nls":{availableLanguages:{"*":"zh-cn"}}}),ke.init().then(c=>{o.value=c,i=c.editor.create(a.value,{value:l.value,automaticLayout:!0,language:e.language,theme:e.theme,folding:!0,readOnly:e.readOnly,minimap:{enabled:!1},lineNumbers:"on",lineNumbersMinChars:3,overviewRulerLanes:0,fixedOverflowWidgets:!1,scrollBeyondLastLine:!1,scrollbar:{verticalScrollbarSize:8,horizontalScrollbarSize:8}})})}}t.watch(()=>e.modelValue,C=>{l.value=C,i==null||i.setValue(C)});const u=t.ref(),f=new ResizeObserver(C=>{i==null||i.layout();const{width:m,height:c}=C[0].contentRect;u.value={width:`${m-1}px`,height:`${c}px`}});function b(){return i==null?void 0:i.getValue()}function v(C){const m=i.getSelection(),c=new o.value.Range(m.startLineNumber,m.startColumn,m.endLineNumber,m.endColumn);i.executeEdits("insert-text",[{range:c,text:C,forceMoveMarkers:!0}])}t.onMounted(()=>{s(),a.value&&f.observe(a.value.parentElement)}),t.onBeforeUnmount(()=>{i&&i.dispose(),f&&a.value&&(f.unobserve(a.value),f.disconnect())});function h(C){i.setValue(C)}function w(){h("")}return n.expose({getContent:b,insertText:v,clearText:w,setContent:h}),()=>t.createVNode("div",{class:"expression-code-editor",style:u.value,ref:a},null)}}),mn={dataSource:{type:Object,default:{}}},yn={data:{type:Array,default:[]},idField:{type:String,default:"id"},textField:{type:String,default:"name"},formatter:{type:Function},customRowStatus:{type:Object,default:null}},pn=t.defineComponent({name:"FEntitiesTree",props:yn,emits:["dblclickNode"],setup(e,n){const a=t.ref(e.data),o=t.ref(),i=t.ref();function l(){let v=0;return document.querySelectorAll(".entity-variable .fv-grid-hierarchy-cell").forEach(w=>{w.style.width="auto";const C=w.scrollWidth;C>v&&(v=C)}),v}t.watch(()=>e.data,v=>{var h;a.value=v,(h=o.value)==null||h.updateDataSource(v)});const r={customRowStatus:e.customRowStatus},s=t.computed(()=>[{field:e.textField,title:"",dataType:"string",formatter:e.formatter}]);function u({$event:v,node:h}){n.emit("dblclickNode",{$event:v,node:h})}function f(){const v=l();i.value={minWidth:`${v+10}px`}}function b({row:v}){t.nextTick(f)}return t.onMounted(()=>{t.nextTick(f)}),()=>t.createVNode("div",{class:"h-100 f-utils-fill",style:"overflow:auto",id:"entity-tree-view"},[t.createVNode(tt,{ref:o,fit:!1,rowNumber:{enable:!1},data:a.value,idField:e.idField,columns:s.value,rowOption:r,columnOption:{fitColumns:!0,fitMode:"percentage"},onDblclickNode:u,style:i.value,autoHeight:!0,onExpandNode:b},null)])}}),hn=t.defineComponent({name:"entity-variable",props:mn,emits:["variableItemDblClick","entityItemDblClick","fieldClick"],setup(e,n){const a=t.ref("dataEntity"),o=t.ref(e.dataSource),{entities:i,variables:l}=o.value,r=t.ref(""),s=t.ref((i==null?void 0:i.fields)||[]),u=(F,V)=>{F.stopPropagation(),n.emit("fieldClick",{$event:F,item:V.raw})},f=(F,V)=>{const B=`${V.raw.name} [${V.raw.bindingPath}]`;return t.createVNode("div",{class:"d-flex align-items-center w-100 entity-field",style:"justify-content: space-between;"},[t.createVNode("span",{title:B,class:"f-utils-fill text-truncate"},[B]),t.createVNode("button",{title:"插入属性名称",class:"btn btn-link d-none",style:"width:24px;height:24px",onClick:E=>u(E,V),onDblclick:E=>E.stopPropagation()},[t.createVNode("span",{class:"f-icon f-icon-new-edit",style:"font-size: 12px;"},null)])])},b=t.ref({}),v=t.ref(),h=t.computed(()=>F=>({"list-group d-flex flex-column":!0,"f-utils-fill":a.value===F,expand:a.value===F,collapse:a.value!==F})),w=t.computed(()=>F=>({"f-icon f-icon-arrow-chevron-up":a.value!==F,"f-icon f-icon-arrow-chevron-down":a.value===F})),C=t.computed(()=>F=>({"functions-type d-flex flex-column":!0,open:b.value[F],closed:!b.value[F]})),m=t.computed(()=>F=>({"f-icon f-icon-arrow-chevron-down":b.value[F],"f-icon f-icon-arrow-chevron-right":!b.value[F]})),c=t.computed(()=>F=>{var V;return{"functions-item pl-2":!0,selected:((V=v.value)==null?void 0:V.key)===F.key}});function y(F,V){F.stopPropagation(),b.value=b.value||{},b.value[V]=!b.value[V]}function p(F,V){F.stopPropagation(),v.value=V}function x(F,V){n.emit("variableItemDblClick",{$event:F,item:V})}function S({$event:F,node:V}){n.emit("entityItemDblClick",{$event:F,item:V.data,entityCode:i==null?void 0:i.entityCode,parentCodes:V.data.parents.join(".")})}function d(){return t.createVNode(pn,{data:s.value,formatter:f,onDblclickNode:S},null)}function g(){if(l)return t.createVNode("ul",{class:"w-100 functions-list"},[Object.keys(l).map(F=>l[F].visible&&t.createVNode("li",{"variable-type":F,class:C.value(F)},[t.createVNode("div",{class:"functions-type-name pl-2 d-flex align-items-center",onClick:V=>{y(V,F)}},[t.createVNode("span",{class:m.value(F)},null),l[F].name]),t.createVNode("ul",{class:"pl-3 mr-2"},[l[F].items.map(V=>t.createVNode("li",{class:c.value(V),onClick:B=>p(B,V),onDblclick:B=>x(B,V),title:`${V.name} [${V.key}]`},[V.name]))])]))])}function k(F,V){if(F.stopPropagation(),a.value===V){a.value="";return}a.value=V}t.onMounted(()=>{if(l){const F=Object.keys(l)[0];b.value[F]=!0}});function N(F,V){const B=F.children.map(L=>N(L,V)).filter(L=>L!==null);return F.data.name.toLowerCase().includes(V.toLowerCase())||F.data.bindingPath.toLowerCase().includes(V.toLowerCase())?{data:{...F.data},children:F.children}:B.length>0?{data:{...F.data},children:B}:null}function I(F,V){return F.map(B=>N(B,V)).filter(B=>B!==null)}function j(){const F=I((i==null?void 0:i.fields)||[],r.value);s.value=F}function O(){s.value=(i==null?void 0:i.fields)||[]}function P(F){F.key==="Enter"&&j()}return()=>t.createVNode("div",{class:"f-utils-fill entity-variable"},[t.createVNode("ul",{class:"d-flex flex-column h-100"},[t.createVNode("li",{class:h.value("dataEntity")},[t.createVNode("div",{class:"title px-2 d-flex align-items-center",onClick:F=>k(F,"dataEntity")},[t.createTextVNode("数据实体"),t.createVNode("span",{class:w.value("dataEntity")},null)]),t.createVNode("div",{class:"data-area f-utils-fill d-flex flex-column"},[t.createVNode("div",{class:"w-100"},[t.createVNode(ye.FButtonEdit,{class:"m-2",buttonContent:'<i class="f-icon f-icon-search"></i>',enableClear:!0,popupOnClick:!0,placeholder:"请输入名称或编号,按回车查询",modelValue:r.value,"onUpdate:modelValue":F=>r.value=F,onClickButton:j,onClear:O,onKeyup:P},null)]),d()])]),t.createVNode("li",{class:h.value("variables")},[t.createVNode("div",{class:"title px-2 d-flex align-items-center",onClick:F=>k(F,"variables")},[t.createTextVNode("变量"),t.createVNode("span",{class:w.value("variables")},null)]),t.createVNode("div",{class:"data-area f-utils-fill"},[g()])])])])}}),gn={functionItems:{type:Array,default:[]},singleExpand:{type:Boolean,default:!0}},vn=t.defineComponent({name:"FExpressionEditor",props:gn,emits:["insertFunction","search"],setup(e,n){const a=t.ref(),o=t.ref(""),i=t.ref(),l=t.ref({}),r=t.ref(""),s="没有与搜索条件匹配的项",u=t.ref(e.functionItems),f=t.computed(()=>d=>e.singleExpand?{"functions-type d-flex flex-column":!0,open:o.value===d,closed:o.value!==d}:{"functions-type d-flex flex-column":!0,open:l.value[d],closed:!l.value[d]}),b=t.computed(()=>d=>e.singleExpand?{"f-icon f-icon-arrow-chevron-down":o.value===d,"f-icon f-icon-arrow-chevron-right":o.value!==d}:{"f-icon f-icon-arrow-chevron-down":l.value[d],"f-icon f-icon-arrow-chevron-right":!l.value[d]}),v=t.computed(()=>d=>{var g;return{"functions-item pl-2":!0,selected:((g=i.value)==null?void 0:g.key)===d.key}}),h=t.ref(Object.keys(u.value));t.watch(()=>e.functionItems,d=>{u.value=d,h.value=Object.keys(u.value),r.value&&(l.value=h.value.reduce((g,k)=>(g[k]=!0,g),{}))});function w(d){d||(d=o.value);const g=a.value.querySelector('li[function-type="'+d+'"] > div.functions-type-name');g&&(a.value.querySelector(".expression-left").scrollTop=0,g.scrollIntoViewIfNeeded?g.scrollIntoViewIfNeeded(!0):g.scrollIntoView({behavior:"smooth",block:"nearest"}))}function C(d){if(e.singleExpand){if(o.value===d){o.value="";return}o.value=d}else l.value=l.value||{},l.value[d]=!l.value[d]}function m(d,g){d.stopPropagation(),i.value=g}function c(d,g){d.stopPropagation(),n.emit("insertFunction",{$event:d,item:g})}t.watch(()=>o.value,(d,g,k)=>{if(d){const N=setTimeout(()=>{w(d)},200);k(()=>clearTimeout(N))}});function y(){n.emit("search",r.value)}function p(){n.emit("search","")}function x(d){d.key==="Enter"&&y()}function S(){return h.value.length?h.value.map(d=>t.createVNode("li",{"function-type":d,class:f.value(d)},[t.createVNode("div",{class:"functions-type-name pl-2 d-flex align-items-center",onClick:()=>{C(d)}},[t.createVNode("span",{class:b.value(d)},null),u.value[d].name]),t.createVNode("ul",{class:"pl-3 mr-2"},[u.value[d].items.map(g=>{if(g.visible!==!1)return t.createVNode("li",{class:v.value(g),onClick:k=>m(k,g),onDblclick:k=>c(k,g)},[d==="advanced"?g.key:g.name])})])])):t.createVNode("li",{class:"empty-message"},[s])}return t.onMounted(()=>{o.value=h.value[0],l.value=h.value.reduce((d,g)=>(d[g]=o.value===g,d),{})}),()=>t.createVNode("div",{class:"d-flex f-utils-fill flex-column",ref:a},[t.createVNode(_,{class:"flex-column expression-left"},{default:()=>[t.createVNode(X,{position:"top",minHeight:50,height:50,"custom-class":"position-relative d-flex align-items-center search-bar",resizable:!1},{default:()=>[t.createVNode(ye.FButtonEdit,{class:"w-100 mx-2",buttonContent:'<i class="f-icon f-icon-search"></i>',enableClear:!0,popupOnClick:!0,placeholder:"请输入函数名称,按回车查询",modelValue:r.value,"onUpdate:modelValue":d=>r.value=d,onClickButton:y,onClear:p,onKeyup:x},null)]}),t.createVNode(X,{position:"center","custom-class":"layout-border"},{default:()=>[t.createVNode("ul",{class:"w-100 functions-list",style:"user-select: none"},[S()])]}),t.createVNode(X,{"custom-class":"position-relative",position:"bottom",minHeight:80},{default:()=>{var d;return[t.createVNode("textarea",{title:"函数说明",class:"h-100 w-100 function-remark p-1",disabled:!0},[(d=i.value)==null?void 0:d.description])]}})]})])}});function bn(e){async function n(){return fetch(e.esprimaPath).then(r=>r.json())}async function a(){if(window.esprima==null){const r=await n(),{path:s}=r;return new Promise((u,f)=>{const b=document.createElement("script");b.type="text/javascript",b.src=s+"?v="+Date.now(),b.onload=u,b.onerror=f,document.head.appendChild(b)})}}function o(r){const s=[],u=window.esprima.tokenize(r);for(let h=0;h<u.length;h++)s.push(u[h].value);const f=[];for(let h=0;h<s.length;h++){const w=r.indexOf(s[h]);w!==-1?f.push(r.substring(0,w)):f.push(""),r=r.slice(w+s[h].length),h===s.length-1&&f.push(r)}const b=[],v=s.length;for(let h=0;h<v;h++)f[h]!==""&&b.push(f[h]),s[h]!==""&&b.push(s[h]),h===v-1&&f[h+1]!==""&&b.push(f[h+1]);return b}function i(r,s="key2name"){const u=new Map;if(!r)return u;let b=Object.values(r).map(v=>v.items).flat();for(;b.length>0;){const v=b.filter(h=>h.name===b[0].name);v.length>1?b.filter(h=>h.name===b[0].name).forEach(h=>{s==="key2name"?u.set(h.key,h.key+"_"+h.name):s==="name2key"&&u.set(h.key+"_"+h.name,h.key)}):s==="key2name"?u.set(v[0].key,v[0].name):s==="name2key"&&u.set(v[0].name,v[0].key),b=b.filter(h=>h.name!==b[0].name)}return u}a();async function l(r){return window.esprima?r():await a().then(()=>r())}return{loadEsprima:a,getTokens:o,getVariableMaps:i,runWithEsprima:l}}function kn(e,n,a){const o=t.ref(e.disabledFunctions),{getTokens:i,getVariableMaps:l,runWithEsprima:r}=bn(e);function s(){const c=ne.cloneDeep(n);if(o.value){let y=Object.keys(c);const{types:p,functions:x}=o.value;return p&&p.length&&(y=y.filter(S=>p.includes(S))),x&&x.length&&Object.values(c).forEach(S=>{S.items.forEach(d=>{x.includes(d.name)&&(d.visible=!1)})}),c}return c}function u(c){const y=n.analytical.items.find(p=>p.key==="GetContextParameter");if(y)return y.name+'("'+c.name+'")'}function f(c){if(!c||c.length===0)return"";const y=p=>{switch(p.type){case"string":return`"${p.name}"`;case"list":return`[${p.name}]`;default:return p.name}};return c.map(y).join(",")}function b(c){let y=c.name;return c.type.toLowerCase()!=="advanced"&&(y+="("+f(c.params)+")"),y}function v(c){return c==null?void 0:c.bindingPath}function h(c){if(!c)return"";const y=i(c),p=l(a,"name2key");for(let S=0;S<y.length;S++){let d=0;if(d===0&&p&&y[S].length>2&&y[S][0]==='"'&&y[S][y[S].length-1]==='"'){const g=y[S].substring(1,y[S].length-1);if(p.has(g)&&y[S-1]==="("&&y[S+1]===")"){const k=p.get(g);k!==void 0&&(y[S]=`"${k}"`,d=1)}}if(d===0){const g=Object.values(n).map(k=>k.items).flat();for(let k=0;k<g.length;k++)if(y[S]===g[k].name){y[S]=g[k].keyFront+"."+g[k].key,d=1;break}}}const x=y.join("");return JSON.stringify({expr:x,sexpr:""})}function w(c,y,p,x){let S="";const d=[];for(const g of y)g.keyFront==="Math"&&d.push(g.key);for(let g=0;g<c.length;g++){if(c[g]==="Math"&&c[g+1]==="."&&!d.includes(c[g+2])){S=S+c[g]+c[g+1]+c[g+2],g=g+2;continue}if(x.includes(c[g])&&c[g+1]==="."){g=g+1;continue}else{let k=0;if(k===0&&c[g].length>2&&c[g][0]==='"'&&c[g][c[g].length-1]==='"'){const N=c[g].substring(1,c[g].length-1);if(p.has(N)&&c[g-1]==="("&&c[g+1]===")"){const I=p.get(N);I!==void 0&&(S=S+`"${I}"`,k=1)}}if(k===0){for(let N=0;N<y.length;N++)if(c[g]===y[N].key&&y[N].type.toLowerCase()!=="advanced"){S=S+y[N].name,k=1;break}}k===0&&(S=S+c[g])}}return S}function C(c){if(!c)return"";const y=i(c),p=l(a,"key2name"),x=Object.values(n).map(d=>d.items).flat();return w(y,x,p,["DefaultFunction","Math","DefaultExtendFunctionProxy"])}async function m(c){return await r(()=>C(c))}return{resetFunctionItems:s,getFieldExpression:v,getFunctionExpression:b,getContextVariableExpression:u,getExpressionCodeValue:h,getExpressionTextValue:m}}function Cn(e,n){const a=t.ref([]),o=ne.cloneDeep(n.value),i=Object.values(o).map(s=>s.items).flat();function l(s){const u=ne.cloneDeep(o);return Object.keys(u).forEach(f=>{const b=u[f].items.filter(v=>s.includes(v.key));b.length>0?u[f].items=b:delete u[f]}),u}function r(s){if(!s){n.value=o;return}const u=i.filter(f=>f.name.toLowerCase().includes(s.toLowerCase())).map(f=>f.key);n.value=l(u)}return{searchResultList:a,filterFunctions:l,onFunctionSearch:r}}const qe=t.defineComponent({name:"FExpressionEditor",props:Te,emits:[],setup(e,n){var O;const a=t.ref(),o=t.ref(e.validateMessage),i=t.ref(e.messageType),l=t.ref(e.modelValue),r=t.ref(),s=[{label:"提示",value:"info"},{label:"警告",value:"warning"},{label:"错误",value:"error"}],{getFunctionExpression:u,getContextVariableExpression:f,resetFunctionItems:b,getFieldExpression:v,getExpressionCodeValue:h,getExpressionTextValue:w}=kn(e,Ft,e.variables),C=t.ref(b()),{onFunctionSearch:m}=Cn(e,C);function c({$event:P,item:F}){var B;const V=u(F);(B=r.value)==null||B.insertText(V)}function y({$event:P,item:F}){var B;const V=f(F);(B=r.value)==null||B.insertText(V)}function p(P){return P.reduce((F,V)=>{var B;return F.push(V.data),(B=V.children)!=null&&B.length&&F.push(...p(V.children)),F},[])}const x=p(((O=e==null?void 0:e.entities)==null?void 0:O.fields)||[]);function S(P){return P.map(F=>{const V=x.find(B=>B.bindingPath===F);return V&&V.type==="entity"?`${F}[0]`:F}).join(".")}function d({$event:P,item:F,parentCodes:V,entityCode:B}){var M;const E=v(F);V=e.isServerSide?S(F.parents):V;let L=`${V}.${E}`;B===E&&(L=E),(M=r.value)==null||M.insertText(`${L}`)}function g({$event:P,item:F}){var B;const V=v(F);(B=r.value)==null||B.insertText(`${V}`)}function k(){var P;return(P=r.value)==null?void 0:P.getContent()}function N(){var F;const P=(F=r.value)==null?void 0:F.getContent();return{value:h(P),message:o.value,messageType:i.value}}const I=t.ref("");function j(){var P;(P=r.value)==null||P.clearText()}return t.onMounted(async()=>{if(l.value){const P=JSON.parse(l.value),{expr:F}=P;F&&(I.value=await w(F)||"")}}),n.expose({getExpressionContext:k,getExpressionValue:N,resetExpression:j}),()=>t.createVNode("div",{ref:a,class:"h-100 d-flex flex-column f-utils-fill mx-3 expression-editor"},[t.createVNode(_,null,{default:()=>[t.createVNode(X,{position:"left",width:248,minWidth:130},{default:()=>[t.createVNode(vn,{functionItems:C.value,singleExpand:e.singleExpand,onInsertFunction:c,onSearch:m},null)]}),t.createVNode(X,{position:"center","custom-class":"layout-border flex-column",style:"overflow:hidden"},{default:()=>[t.createVNode("div",{class:"f-utils-fill my-2 ml-1"},[t.createVNode(fn,{modelValue:I.value,"onUpdate:modelValue":P=>I.value=P,ref:r},null)]),e.showMessage&&t.createVNode("div",{class:"d-flex flex-column p-1",style:"background: #fafafa"},[t.createVNode("div",{class:"d-flex align-items-center py-1"},[t.createVNode("b",null,[t.createTextVNode("提示信息:")]),e.showMessageType&&t.createVNode(ae,{style:"width: 75px",data:s,modelValue:i.value,"onUpdate:modelValue":P=>i.value=P,textField:"label",valueField:"value",idField:"value",enableClear:!1,minPanelWidth:130,placement:"auto"},null)]),t.withDirectives(t.createVNode("textarea",{"onUpdate:modelValue":P=>o.value=P,class:"form-control",style:"resize:none;border:none;outline:1px solid var(--f-neutral-04);"},null),[[t.vModelText,o.value]])])]}),e.showDataPanel&&t.createVNode(X,{position:"right",width:258,minWidth:130},{default:()=>[t.createVNode(hn,{dataSource:{entities:e.entities,variables:e.variables},onVariableItemDblClick:y,onEntityItemDblClick:d,onFieldClick:g},null)]})]})])}}),xn={id:{type:String,default:""},buttonContent:{type:String,default:'<i class="f-icon f-icon-lookup"></i>'},buttonBehavior:{type:String,default:"Popup"},autoComplete:{type:Boolean,default:!1},customClass:{type:String,default:""},disable:{type:Boolean,default:!1},editable:{type:Boolean,default:!0},enableClear:{type:Boolean,default:!1},modelValue:{type:String,default:""},readonly:{type:Boolean,default:!1},showButtonWhenDisabled:{type:Boolean,default:!1},enableTitle:{type:Boolean,default:!1},inputType:{type:String,default:"text"},forcePlaceholder:{type:Boolean,default:!1},placeholder:{type:String,default:""},minLength:Number,maxLength:{type:Number},tabIndex:Number,popupHost:{type:Object},popupRightBoundary:{type:Object},popupOffsetX:{type:Object},popupOnInput:{type:Boolean,default:!1},popupOnFocus:{type:Boolean,default:!1},popupOnClick:{type:Boolean,default:!1},popupClass:{type:String,default:""},popupMinWidth:{type:Number,default:160},modalOptions:{type:Object,default:{}},wrapText:{type:Boolean,default:!1},multiSelect:{type:Boolean,default:!1},separator:{type:String,default:","},textAlign:{type:String,default:"left"},beforeClickButton:{type:Function,default:null},focusOnCreated:{type:Boolean,default:!1},selectOnCreated:{type:Boolean,default:!1},beforeOpen:{type:Function,default:null},updateOn:{type:String,default:"change"},keepWidthWithReference:{type:Boolean,default:!0},placement:{type:String,default:"bottom-left"},limitContentBySpace:{type:Boolean,default:!1},beforeClosePopup:{type:Function,default:null}},wn={popupContentPosition:{type:Object,default:{left:0,top:0}},host:{type:Object},backgroundColor:{type:String,default:""}},Fn=t.defineComponent({name:"FOverlay",props:wn,emits:["click"],setup(e,n){const a=t.ref(e.popupContentPosition),o=t.ref(e.host),i=t.computed(()=>({backgroundColor:e.backgroundColor||"",pointerEvents:"auto"}));function l(s){n.emit("click"),s.preventDefault(),s.stopPropagation()}t.computed(()=>{const s=o.value;if(s){const u=s.getBoundingClientRect(),{left:f,top:b,height:v}=u;return{left:f,top:b+v}}return a.value});const r=t.computed(()=>({}));return()=>t.createVNode(t.Teleport,{to:"body"},{default:()=>{var s,u;return[t.createVNode("div",{class:"overlay-container",onClick:f=>l(f),style:i.value},[t.createVNode("div",{style:r.value},[(u=(s=n.slots).default)==null?void 0:u.call(s)])])]}})}});function Tn(e){if(e.content&&e.content.render)return e.content.render;if(e.render&&typeof e.render=="function")return e.render}function Sn(e){const n=document.createElement("div");n.style.display="contents";let a;const o=e.onClickCallback||(()=>{}),i=()=>{o(),a&&a.unmount()};return a=t.createApp({setup(){t.onUnmounted(()=>{document.body.removeChild(n)});const l=Tn(e);return()=>t.createVNode(Fn,{"popup-content-position":e.popupPosition,host:e.host,onClick:i,backgroundColor:e.backgroundColor},{default:()=>[l&&l()]})}}),document.body.appendChild(n),a.mount(n),a}class Nn{static show(n){return Sn(n)}}const Mn={allowClickMaskToClose:{type:Boolean,default:!1},beforeClose:{type:Function,default:()=>!0},class:{type:String,default:""},maskClass:{type:String,default:""},title:{type:String,default:""},width:{type:Number,default:500},height:{type:Number,default:320},buttons:{type:Array,default:[]},modelValue:{type:Boolean,default:!1},mask:{type:Boolean,default:!0},showHeader:{type:Boolean,default:!0},showButtons:{type:Boolean,default:!0},fitContent:{type:Boolean,default:!0},showCloseButton:{type:Boolean,default:!0},showMaxButton:{type:Boolean,default:!1},minHeight:{type:Number},maxHeight:{type:Number},minWidth:{type:Number},maxWidth:{type:Number},containment:{type:Object,default:null},resizeable:{type:Boolean,default:!1},draggable:{type:Boolean,default:!1},dragHandle:{type:Object,default:null},closedCallback:{type:Function,default:null},resizeHandle:{type:Function,default:null},render:{type:Function,default:null},acceptCallback:{type:Function,default:null},rejectCallback:{type:Function,default:null},enableEsc:{type:Boolean,default:!0},enableEnter:{type:Boolean,default:!1},dialogType:{type:String,default:""},src:{type:String,default:""},footerHeight:{type:Number,default:60},host:{type:Object,default:"body"}};class A{constructor(n,a){this.x=n,this.y=a}static getTransformInfo(n){const o=window.getComputedStyle(n).getPropertyValue("transform").replace(/[^-\d,]/g,"").split(",");if(o.length>=6){const i=parseInt(o[4],10),l=parseInt(o[5],10);return{x:i,y:l}}return{x:0,y:0}}static fromEvent(n,a=null){if(this.isMouseEvent(n))return new A(n.clientX,n.clientY);if(a===null||n.changedTouches.length===1)return new A(n.changedTouches[0].clientX,n.changedTouches[0].clientY);for(let o=0;o<n.changedTouches.length;o++)if(n.changedTouches[o].target===a)return new A(n.changedTouches[o].clientX,n.changedTouches[o].clientY)}static isMouseEvent(n){return Object.prototype.toString.apply(n).indexOf("MouseEvent")===8}static isIPosition(n){return!!n&&"x"in n&&"y"in n}static getCurrent(n){const a=new A(0,0);if(window){const o=window.getComputedStyle(n);if(o){const i=parseInt(o.getPropertyValue("left"),10),l=parseInt(o.getPropertyValue("top"),10);a.x=isNaN(i)?0:i,a.y=isNaN(l)?0:l}return a}return null}static copy(n){return new A(0,0).set(n)}get value(){return{x:this.x,y:this.y}}add(n){return this.x+=n.x,this.y+=n.y,this}subtract(n){return this.x-=n.x,this.y-=n.y,this}multiply(n){this.x*=n,this.y*=n}divide(n){this.x/=n,this.y/=n}reset(){return this.x=0,this.y=0,this}set(n){return this.x=n.x,this.y=n.y,this}}class Z{constructor(n,a){this.width=n,this.height=a}static getCurrent(n){const a=new Z(0,0);if(window){const o=window.getComputedStyle(n);return o&&(a.width=parseInt(o.getPropertyValue("width"),10),a.height=parseInt(o.getPropertyValue("height"),10)),a}return null}static copy(n){return new Z(0,0).set(n)}set(n){return this.width=n.width,this.height=n.height,this}}function On(e,n){const a=t.ref(),o=t.ref(),i=t.ref(),l=t.ref(),r=t.ref(),s=t.ref(),u=t.ref(),f=t.ref(),b=t.ref(),v=t.ref(),h=t.ref(),w=t.ref(e.resizeable),C=t.ref(),m=t.ref(e.draggable),c=t.ref(!1);function y(){const M=o.value||document.body,D=window.getComputedStyle(M);if(!D||!a.value)return;const $=A.getTransformInfo(a.value),z={};u.value&&(z.deltaL=a.value.offsetLeft-u.value.x,z.deltaT=a.value.offsetTop-u.value.y);const W=D.getPropertyValue("position");z.width=M.clientWidth,z.height=M.clientHeight,z.pr=parseInt(D.getPropertyValue("padding-right"),10),z.pb=parseInt(D.getPropertyValue("padding-bottom"),10),z.position=D.getPropertyValue("position"),W==="static"&&(M.style.position="relative"),z.translateX=$.x,z.translateY=$.y,v.value=z}function p(M){if(a.value){l.value=Z.getCurrent(a.value),r.value=A.getCurrent(a.value),s.value=l.value?Z.copy(l.value):null,u.value=r.value?A.copy(r.value):null,y();const D=M.target.getAttribute("type")||"";f.value={n:!!D.match(/n/),s:!!D.match(/s/),w:!!D.match(/w/),e:!!D.match(/e/)}}}function x(){var M,D,$,z;if(a.value){const W=a.value;f.value&&((f.value.n||f.value.s)&&((M=s.value)!=null&&M.height)&&(W.style.height=s.value.height+"px"),(f.value.w||f.value.e)&&((D=s.value)!=null&&D.width)&&(W.style.width=s.value.width+"px"),u.value&&(($=u.value)!=null&&$.x&&(W.style.left=u.value.x+"px"),(z=u.value)!=null&&z.y&&(W.style.top=u.value.y+"px")))}}function S(){const M=e.minHeight?e.minHeight:1,D=e.minWidth?e.minWidth:1;s.value&&u.value&&f.value&&l.value&&(s.value.height<M&&(s.value.height=M,f.value.n&&r.value&&(u.value.y=r.value.y+(l.value.height-M))),s.value.width<D&&(s.value.width=D,f.value.w&&r.value&&(u.value.x=r.value.x+(l.value.width-D))),e.maxHeight&&s.value.height>e.maxHeight&&(s.value.height=e.maxHeight,r.value&&f.value.n&&(u.value.y=r.value.y+(l.value.height-e.maxHeight))),e.maxWidth&&s.value.width>e.maxWidth&&(s.value.width=e.maxWidth,f.value.w&&r.value&&(u.value.x=r.value.x+(l.value.width-e.maxWidth))))}function d(){if(o.value){const M=v.value;if(u.value&&s.value&&f.value&&l.value){const D=M.width-M.pr-M.deltaL-M.translateX-u.value.x,$=M.height-M.pb-M.deltaT-M.translateY-u.value.y;f.value.n&&u.value.y+M.translateY<0&&r.value&&(u.value.y=-M.translateY,s.value.height=l.value.height+r.value.y+M.translateY),f.value.w&&u.value.x+M.translateX<0&&r.value&&(u.value.x=-M.translateX,s.value.width=l.value.width+r.value.x+M.translateX),s.value.width>D&&(s.value.width=D),s.value.height>$&&(s.value.height=$)}}}function g(M){if(!i.value||!l.value||!r.value||!f.value)return;M.subtract(i.value);const D=M.x,$=M.y;f.value.n?(u.value.y=r.value.y+$,s.value.height=l.value.height-$):f.value.s&&(s.value.height=l.value.height+$),f.value.e?s.value.width=l.value.width+D:f.value.w&&(s.value.width=l.value.width-D,u.value.x=r.value.x+D),d(),S(),x()}function k(M){if(!b.value)return;const D=A.fromEvent(M);D&&g(D)}function N(){if(a.value){const{width:M,height:D,x:$,y:z}=a.value.getBoundingClientRect(),W=A.getTransformInfo(a.value);return{size:{width:M,height:D},position:{x:$-W.x,y:z-W.y}}}return null}function I(M){if(a.value){const D=N();h.value=D}i.value=void 0,l.value=null,r.value=null,s.value=null,u.value=null,f.value=null,b.value=null,document.removeEventListener("mousemove",k),document.removeEventListener("mouseup",I)}function j(){document.addEventListener("mousemove",k),document.addEventListener("mouseup",I)}function O(M){M instanceof MouseEvent&&M.button===2||m.value&&(document.body.click(),M.stopPropagation(),M.preventDefault(),i.value=A.fromEvent(M),b.value=M.target,p(M),j())}function P(M){return a.value=M,w.value&&t.createVNode(t.Fragment,null,[t.createVNode("div",{class:"fv-resizable-handle fv-resizable-n",type:"n",onMousedown:D=>O(D)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-e",type:"e",onMousedown:D=>O(D)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-s",type:"s",onMousedown:D=>O(D)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-w",type:"w",onMousedown:D=>O(D)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-ne",type:"ne",onMousedown:D=>O(D)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-se fv-resizable-diagonal",type:"se",onMousedown:D=>O(D)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-sw",type:"sw",onMousedown:D=>O(D)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-nw",type:"nw",onMousedown:D=>O(D)},null)])}function F(M=!0){document.body.click();const D=o.value||document.body,$=Z.getCurrent(D),z=a.value;M&&z&&(C.value=N(),C.value.transform=z.style.transform),$&&z&&(s.value=$,s.value.height-=14,s.value.width-=14,z.style.height=s.value.height+"px",z.style.width=s.value.width+"px",z.style.left="7px",z.style.top="7px",z.style.transform="",h.value={size:s.value,position:{x:0,y:0}},m.value=!1,c.value=!0)}function V(){var M,D;if(document.body.click(),C.value){const $={width:C.value.size.width||0,height:C.value.size.height||0},z={x:(window.innerWidth-$.width)/2,y:(window.innerHeight-$.height)/2};(M=s.value)==null||M.set($),(D=u.value)==null||D.set(z);const W=a.value;W.style.height=$.height+"px",W.style.width=$.width+"px",W.style.left=`${z.x}px`,W.style.top=`${z.y}px`,W.style.transform="",h.value={size:$,position:z},m.value=e.draggable,c.value=!1}}function B(){if(a.value){const M=Z.getCurrent(a.value);if(M){const{width:D,height:$}=M;a.value.style.left=`${(window.innerWidth-D)/2}px`,a.value.style.top=`${(window.innerHeight-$)/2}px`,a.value.style.transform=""}}}function E(){const M=()=>{c.value?F(!1):B(),document.body.click()};return window.addEventListener("resize",M),()=>{window.removeEventListener("resize",M)}}const L=E();return{renderResizeBar:P,boundingElement:o,resizedEventParam:h,maximize:F,restore:V,allowDrag:m,isMaximized:c,unWindowResizeHandle:L,moveToCenter:B}}function Vn(e,n,a){const o=t.ref(),i=t.ref(e.draggable),l=t.ref(e.lockAxis),r=t.ref(),s=t.ref(),u=t.ref(!1),f=t.ref(new A(0,0)),b=t.ref(new A(0,0)),v=t.ref(new A(0,0)),h=t.ref(new A(0,0));t.watch(()=>a.value,k=>{r.value.style.cursor=k?"move":"default"});function w(k,N){if(N.tagName==="BUTTON")return!1;if(N===k)return!0;for(const I in N.children)if(Object.prototype.hasOwnProperty.call(N.children,I)&&w(k,N.children[I]))return!0;return!1}function C(){var j,O;let k=v.value.x+b.value.x,N=v.value.y+b.value.y;l.value==="x"?(k=((j=f.value)==null?void 0:j.x)||0,v.value.x=0):l.value==="y"&&(N=((O=f.value)==null?void 0:O.y)||0,v.value.y=0);const I=`translate3d(${Math.round(k)}px, ${Math.round(N)}px, 0px)`;o.value&&(o.value.style.transform=I),h.value.x=k,h.value.y=N}function m(){if(!s.value||!o.value)return null;const k=s.value.getBoundingClientRect(),N=o.value.getBoundingClientRect(),I={top:k.top<N.top,right:k.right>N.right,bottom:k.bottom>N.bottom,left:k.left<N.left};return I.top||(v.value.y-=N.top-k.top),I.bottom||(v.value.y-=N.bottom-k.bottom),I.right||(v.value.x-=N.right-k.right),I.left||(v.value.x-=N.left-k.left),C(),I}function c(k){k&&(f.value&&k.subtract(f.value),v.value.set(k),C(),m())}function y(k){u.value&&i.value&&(k.stopPropagation(),k.preventDefault(),c(A.fromEvent(k,r.value)))}function p(){var k;u.value&&(u.value=!1,b.value.add(v.value),v.value.reset(),(k=o.value)==null||k.classList.remove("ng-dragging"),n.emit("stopMove"),document.removeEventListener("mousemove",y),document.removeEventListener("mouseup",p))}function x(){!u.value&&r.value&&(u.value=!0,r.value.classList.add("ng-dragging"),document.addEventListener("mousemove",y),document.addEventListener("mouseup",p))}function S(){if(o.value){const k=A.getTransformInfo(o.value);b.value.set(k);return}b.value.reset()}function d(k){if(!a.value||k instanceof MouseEvent&&k.button===2)return;const N=k.target||k.srcElement;r.value!==void 0&&N&&!w(N,r.value)||i.value!==!1&&(document.body.click(),k.stopPropagation(),k.preventDefault(),f.value=A.fromEvent(k,o.value),S(),x())}function g(k,N,I){if(i.value&&N){if(k)r.value=k;else if(e.dragHandle){if(e.dragHandle instanceof HTMLElement)r.value=e.dragHandle;else if(typeof e.dragHandle=="string"){const j=N.querySelector(e.dragHandle);j&&(r.value=j)}}o.value=N,s.value=I,r.value?(r.value.classList.add("ng-draggable"),r.value.addEventListener("mousedown",d)):i.value=!1}}return{registerDraggle:g,resetTranslate:S}}function Ye(e,n){if(e){const a=o=>{o.key.toLowerCase()===e.toLowerCase()&&n({event:o,key:e})};return document.addEventListener("keydown",a),()=>{document.removeEventListener("keydown",a)}}}function Bn(e,n){const a=t.ref(e.enableEsc);let o=null;return a.value?(o=Ye("Escape",i=>{n.emit("esc",{event:i.event,type:"esc"})}),{remove:o}):null}function Dn(e,n){const a=t.ref(e.enableEnter);let o=null;return a.value?(o=Ye("Enter",i=>{n.emit("enter",{event:i.event,type:"enter"})}),{remove:o}):null}const re=t.defineComponent({name:"FModal",props:Mn,emits:["update:modelValue","accept","cancel","closed","resize","esc","enter","stopMove"],setup(e,n){const a=t.ref(e.width||300),o=t.ref(e.height||200),i=t.ref(e.modelValue),l=t.ref(""),r=t.ref(e.class),s=t.ref(e.fitContent),u=t.ref(e.showHeader),f=t.ref(""),b=t.ref(e.showCloseButton),v=t.ref(e.showMaxButton),h=t.ref(!1),w=t.ref(e.dialogType),C=t.ref(e.src),m=t.ref(""),c=t.ref(e.showButtons),y=t.ref(e.title),p=t.ref(e.containment||null),x=t.ref();y.value==="错误提示"&&(y.value=G.LocaleService.getLocaleValue("messageBox.errorTitle"));const S=t.ref(!1);function d(T,R){const Y=R?"accept":"cancel";Promise.resolve().then(()=>{var q;return(q=e.beforeClose)==null?void 0:q.call(e,{closeType:Y})}).then(q=>{q&&(i.value=!1,n.emit("update:modelValue",!1),R!=null&&n.emit(R?"accept":"cancel"),n.emit("closed",T))})}const g=[{name:"cancel",text:G.LocaleService.getLocaleValue("messageBox.cancel")||"取消",class:"btn btn-secondary",handle:T=>{d(T,!1)}},{name:"accept",text:G.LocaleService.getLocaleValue("messageBox.ok")||"确定",class:"btn btn-primary",handle:T=>{d(T,!0)}}],k=t.ref(e.buttons&&e.buttons.length?e.buttons:g),N=t.computed(()=>!!f.value),I=t.computed(()=>!!c.value&&!!k.value),j=t.ref(),O=t.ref(),P=t.ref(!1),{renderResizeBar:F,maximize:V,restore:B,boundingElement:E,resizedEventParam:L,allowDrag:M,unWindowResizeHandle:D,moveToCenter:$}=On(e),{registerDraggle:z}=Vn(e,n,M);function W(){return!!document.querySelectorAll(".farris-modal").length&&document.body.classList.contains("modal-open")}function _n(){const T=document.querySelectorAll(".farris-modal").length;(!T||T-1<=0)&&document.body.classList.remove("modal-open"),x.value&&x.value.classList.remove("show")}t.watch(()=>e.title,(T,R)=>{T!==R&&(y.value=T)}),t.watch(()=>e.modelValue,(T,R)=>{T!==R&&(i.value=T,i.value&&e.draggable&&t.nextTick(()=>{O.value&&!p.value&&(p.value=O.value.parentElement,E.value=p.value,z(j.value,O.value,E.value),$())}),T||(p.value&&(p.value=null),_n())),i.value?S.value=W():(P.value=!1,M.value=e.draggable)}),t.watch(()=>e.showHeader,(T,R)=>{T!==R&&(u.value=T)}),t.watch(()=>e.showButtons,(T,R)=>{T!==R&&(c.value=T)}),t.watch(()=>L.value,(T,R)=>{const Y=T||{},q=R||{};JSON.stringify(Y)!==JSON.stringify(q)&&n.emit("resize",{newSize:T,oldSize:R,isMaximized:P.value})}),t.watch([()=>e.width,()=>e.height],(T,R)=>{(T[0]!==R[0]||T[1]!==R[1])&&(a.value=T[0]||500,o.value=T[1]||600)});const xe=t.computed(()=>(i.value&&document.body.classList.add("modal-open"),i.value)),Jn=t.computed(()=>{var Y;const T={modal:!0,"farris-modal":!0,fade:!0};T["f-modal-fitContent"]=!!s.value,T.show=!!xe.value;const R=(Y=e.maskClass)==null?void 0:Y.split(" ");return R==null||R.reduce((q,te)=>(q[te]=!0,q),T),T}),Zn=t.computed(()=>{var Y;const T={"modal-dialog":!0},R=(Y=r.value)==null?void 0:Y.split(" ");return R==null||R.reduce((q,te)=>(q[te]=!0,q),T),T}),Qn=t.computed(()=>{const T=document.documentElement.clientWidth,R=document.documentElement.clientHeight,Y=Math.min(a.value,T),q=s.value?"auto":`${Math.min(o.value,R-10)}px`,te={position:"absolute",top:`${(window.innerHeight-parseInt(q==="auto"?"0":q))/2}px`,left:`${(window.innerWidth-Y)/2}px`,width:`${Y}px`,height:q};return e.mask||(te.pointerEvents="auto"),te}),ea=()=>ee.getMaxZIndex()||1040,ta=t.computed(()=>{const T={display:"block",zIndex:ea()};return e.mask||(T.pointerEvents="none",T.backgroundColor="transparent"),S.value&&(T.backgroundColor="transparent"),T}),na=t.computed(()=>({"modal-content":!0,"modal-content-has-header":u.value})),aa=t.computed(()=>{const T={display:u.value?"":"none"};return T["pointer-events"]=M.value?"auto":"none",T}),oa=t.computed(()=>({"f-icon":!0,modal_maximize:!0,modalrevert:P.value})),ia=t.computed(()=>({"modal-body":!0,"f-utils-flex-column":w.value==="iframe","f-utils-fill":!0}));function la(){return{height:`${e.footerHeight||60}px`}}const ra=t.computed(()=>{const T={textAlgin:m.value},R=la();return Object.assign(T,R)});function Je(T){if(T==null||T.stopPropagation(),P.value){P.value=!1,B();return}V(),P.value=!0}async function sa(T,R){T.handle&&await T.handle(R,T)&&n.emit("closed",R)}function ca(T){T.width&&(a.value=T.width),T.height&&(o.value=T.height),T.buttons&&(k.value=T.buttons),T.title&&(y.value=T.title)}let we=null,Fe=null;t.onBeforeMount(()=>{S.value=W()}),t.onMounted(()=>{O.value&&!p.value&&(p.value=O.value.parentElement,E.value=p.value,z(j.value,O.value,E.value)),xe.value&&document.body.classList.add("modal-open"),we=Bn(e,n),Fe=Dn(e,n)}),t.onUnmounted(()=>{D&&D(),we&&we.remove(),Fe&&Fe.remove()}),n.expose({modalElementRef:O,updateModalOptions:ca,close:d,maxDialog:Je,isMaximized:P});function ua(){return t.createVNode("ul",null,[h.value&&t.createVNode("li",{class:"f-btn-icon f-bare"},[t.createVNode("span",{class:"f-icon modal_minimize"},null)]),v.value&&t.createVNode("li",{onClick:Je,class:"f-btn-icon f-bare",style:"pointer-events: auto;"},[t.createVNode("span",{class:oa.value},null)]),b.value&&t.createVNode("li",{class:"f-btn-icon f-bare",onClick:T=>d(T,!1),style:"pointer-events: auto;"},[t.createVNode("span",{class:"f-icon modal_close"},null)])])}function da(){return t.createVNode("div",{class:"modal-footer",style:ra.value},[k.value&&k.value.map(T=>{const R=t.ref(T.disabled);return t.createVNode("button",{name:T.name,type:"button",disabled:R.value,class:T.class+(T.iconClass?" btn-icontext":""),onClick:Y=>{sa(T,Y)}},[!!T.iconClass&&t.createVNode("i",{class:T.iconClass},null),T.text])})])}function fa(){return t.createVNode("div",{ref:j,class:"modal-header",style:aa.value},[n.slots.headerTemplate?n.slots.headerTemplate():t.createVNode("div",{class:"modal-title"},[N.value&&t.createVNode("span",{class:f.value,style:"margin-right: 8px"},null),t.createVNode("span",{class:"modal-title-label"},[y.value])]),t.createVNode("div",{class:"actions"},[ua()])])}function ma(){return n.slots.footerTemplate?n.slots.footerTemplate():I.value&&da()}function ya(T){if(T.stopPropagation(),e.allowClickMaskToClose){if(T.target!==x.value)return;d(T,!1)}}function pa(){var T,R;return t.createVNode("div",{id:l.value,class:Zn.value,style:Qn.value,ref:O},[t.createVNode("div",{class:na.value},[u.value&&fa(),t.createVNode("div",{class:ia.value},[(R=(T=n.slots).default)==null?void 0:R.call(T),w.value==="iframe"&&t.createVNode("iframe",{title:l.value,class:"f-utils-fill",width:"100%",frameborder:"0",src:C.value},null)]),ma()]),!s.value&&O.value&&!P.value&&F(O.value)])}function ha(T){return T||"body"}return()=>t.createVNode(t.Teleport,{to:ha(e.host)},{default:()=>[xe.value&&t.createVNode(t.Transition,{name:"fade",appear:!0},{default:()=>[t.createVNode("div",{ref:x,class:Jn.value,style:ta.value,onClick:ya},[pa()])]})]})}});function Ue(e){if(e.content&&e.content.render)return e.content.render;if(e.render&&typeof e.render=="function")return e.render}function En(e){const n=document.createElement("div");n.style.display="contents";const a=t.createApp({setup(o,i){t.onUnmounted(()=>{document.body.removeChild(n)});const l=t.ref(),r=t.ref(e.class||""),s=t.ref(!!e.showButtons),u=t.ref(!!e.showHeader),f=t.ref(e.showCloseButton==null?!0:e.showCloseButton),b=t.ref(!0),v=t.ref(e.title||""),h=e.acceptCallback||(()=>{}),w=e.rejectCallback||(()=>{}),C=e.closedCallback||(x=>{}),m=e.resizeHandle||(x=>{}),c=e.stopMoveHandle||(x=>{}),y=Ue(e),p=x=>{b.value=!1,a.unmount(),C(x)};return t.onMounted(()=>{}),i.expose({modalRef:l}),()=>t.createVNode(re,{ref:l,class:r.value,modelValue:b.value,"onUpdate:modelValue":x=>b.value=x,title:v.value,width:e.width,height:e.height,buttons:e.buttons,"show-header":u.value,"show-buttons":s.value,"show-close-button":f.value,"show-max-button":!1,onAccept:h,onCancel:w,fitContent:e.fitContent==null?!0:e.fitContent,onClosed:p,onResize:m,onStopMove:c},{default:()=>[y&&y(a)]})}});return document.body.appendChild(n),a.use(G.LocaleService.i18n),a.mount(n),a}class Pn{constructor(n){K(this,"appContext",null);K(this,"modalRef",t.ref());K(this,"activeModalIndex",t.ref(0));K(this,"modalRefs",{});K(this,"isUseEscCloseModal",t.ref(!1));K(this,"activeModalInstance",t.computed(()=>this.modalRefs[this.activeModalIndex.value]));this.app=n,this.appContext=n?n._context:null}getCurrentModal(){return this.activeModalInstance.value}adaptToWindow(n,a){const{width:o,height:i}={width:window.innerWidth,height:window.innerHeight};return o<n&&(n=o-14),i<a&&(a=i-14),{width:n,height:a}}static show(n){const a=Object.assign({title:"",showButtons:!0,showHeader:!0},n);return En(a)}close(n){var a,o;n?(o=n.value)==null||o.close():(a=this.getCurrentModal())==null||a.close()}open(n){const a=document.createDocumentFragment();n.showMaxButton&&n.fitContent&&(n.showMaxButton=!1);const o=t.shallowRef(Object.assign({title:"",showButtons:!0,showHeader:!0},n)),i=t.ref(!0),l=o.value.acceptCallback||(()=>{}),r=o.value.rejectCallback||(()=>{}),s=o.value.closedCallback||((d,g)=>{}),u=o.value.resizeHandle||(d=>{}),f=n.stopMoveHandle||(d=>{});let b;const v=Ue(o.value),h=d=>{var k;i.value=!1;const g=(k=d==null?void 0:d.target)==null?void 0:k.classList.contains("modal_close");s(d,this.isUseEscCloseModal.value?"esc":g?"icon":"button")},w=d=>{h(d),b&&t.nextTick(()=>{if(this.modalRefs[this.activeModalIndex.value]&&delete this.modalRefs[this.activeModalIndex.value],t.render(null,a),b=null,this.modalRef.value=null,this.modalRefs){const g=Object.keys(this.modalRefs).map(k=>Number(k));g.length>0?this.activeModalIndex.value=Math.max(...g):this.activeModalIndex.value=0}this.isUseEscCloseModal.value=!1})},C=d=>{var g;this.isUseEscCloseModal.value=!0,this.activeModalInstance&&((g=this.activeModalInstance.value)==null||g.close(d==null?void 0:d.event))},{width:m,height:c}=o.value,y=this.adaptToWindow(m||500,c||320);Object.assign(o.value,y);const p=()=>t.createVNode(re,t.mergeProps({ref:this.modalRef,modelValue:i.value,"onUpdate:modelValue":d=>i.value=d},o.value,{onAccept:l,onCancel:r,onClosed:w,onResize:u,onEsc:C,onStopMove:f}),{default:()=>[v&&v(this.app)]});return b=(d=>{const g=t.h(p,d);return g.appContext=this.appContext,t.render(g,a),g})({...o.value}),this.activeModalIndex.value++,this.modalRefs[this.activeModalIndex.value]=this.modalRef.value,{update:d=>{o.value={...o.value,...d},b&&t.render(t.cloneVNode(b,{...o}),a)},destroy:w,modalRef:this.activeModalInstance,close:()=>this.close()}}}const Ge=Symbol("FModalService");re.install=e=>{e.component(re.name,re);const n=new Pn(e);e.provide(Ge,n),e.provide("FModalService",n)};function Xe(e,n){function a(){const o=e.beforeOpen||e.beforeClickButton||null;let i=Promise.resolve(!0);if(o){const l=o(n.value);if(typeof l>"u")return i;typeof l=="boolean"?i=Promise.resolve(l):i=l}return i}return{judgeCanOpen:a}}function jn(e,n,a,o,i){const l=t.ref(e.buttonBehavior),r=t.ref(e.popupOnInput),s=t.computed(()=>({"input-group-append":!0,"append-force-show":e.showButtonWhenDisabled&&(e.readonly||e.disable)})),{judgeCanOpen:u}=Xe(e,i),f=t.computed(()=>e.showButtonWhenDisabled||(!e.editable||!e.readonly)&&!e.disable),b=t.inject(Ge,null),v=t.ref();async function h(m){if(await u()&&f.value){const c=!!n.slots.default;if(l.value==="Modal"){const y=e.modalOptions,p=b==null?void 0:b.open({...y,render:()=>n.slots.default&&n.slots.default()});v.value=p==null?void 0:p.modalRef}l.value==="Overlay"&&Nn.show({host:document.body,backgroundColor:"rgba(0,0,0,.15)",render:()=>n.slots.default&&n.slots.default()}),c&&l.value==="Popup"&&o.togglePopup(!0),c&&r.value&&o.hidePopup(),n.emit("clickButton",{origin:m,value:e.modelValue})}}function w(m){n.emit("mouseEnterIcon",m)}function C(m){n.emit("mouseLeaveIcon",m)}return{buttonGroupClass:s,onClickButton:h,onMouseEnterButton:w,onMouseLeaveButton:C,modalRef:v}}function In(e,n,a,o,i,l){const r=t.ref(!1),s=t.computed(()=>e.enableClear&&!e.readonly&&!e.disable),{changeTextBoxValue:u,hasClearClass:f}=l;function b(C){r.value=C,f.value=C}t.watch(i,()=>{b(!!i.value)});function v(C){const m=!e.readonly&&!e.disable&&e.editable,c=!e.editable;C.stopPropagation(),(m||c)&&(u(""),i.value="",b(!r.value),n.emit("clear"))}function h(C){if(s.value){if(!a.value){b(!1);return}!e.disable&&!e.readonly&&b(!0)}}function w(C){s.value&&b(!1)}return{enableClearButton:s,showClearButton:r,onClearValue:v,onMouseEnterTextBox:h,onMouseLeaveTextBox:w}}function Rn(e,n,a,o,i){const l=t.computed(()=>e.popupOnInput),r=t.computed(()=>e.popupOnFocus),{shouldPopupContent:s,closeAllPopover:u}=i,f=t.ref(!1),b=t.computed(()=>e.enableTitle?a.value:""),v=t.computed(()=>(e.disable||e.readonly)&&!e.forcePlaceholder?"":e.placeholder),h=t.computed(()=>e.readonly||!e.editable),w=t.ref(!1),C=t.computed(()=>!e.disable&&w.value),m=t.computed(()=>({"text-left":e.textAlign==="left","text-center":e.textAlign==="center","text-right":e.textAlign==="right","form-control":!0,"f-utils-fill":!0})),c=t.computed(()=>({"input-group":!0,"f-state-disabled":e.disable,"f-state-editable":e.editable&&!e.disable&&!e.readonly,"f-state-readonly":e.readonly,"f-state-focus":C.value,"input-group--has-clear":e.enableClear&&f.value}));function y(O,P=!0){a.value=O,P&&(n.emit("change",O),n.emit("update:modelValue",O))}function p(O){s.value=!1,y(O,!0)}t.watch(()=>e.modelValue,O=>{a.value=O});function x(O){w.value=!1,n.emit("blur",O),O.stopPropagation()}function S(O){n.emit("click",O),u(),n.slots.default&&!e.disable&&!e.readonly&&e.popupOnClick&&i.togglePopup()}function d(O){!e.disable&&!e.readonly&&(w.value=!0,h.value||(n.emit("focus",O),r.value&&!s.value&&i.popup()))}function g(O){n.emit("input",O);const P=O.target.value;o.value=P,a.value!==P&&y(P,e.updateOn==="change"),l.value&&!s.value&&i.popup()}function k(O){O.target.tagName!=="INPUT"&&O.preventDefault(),O.stopPropagation()}function N(O){n.emit("keydown",O)}function I(O){O.key==="Enter"&&(l.value||r.value)&&i.hidePopup(),n.emit("keyup",O)}function j(O){const P=O.target.value;O.stopPropagation(),y(P)}return{hasFocusedTextBox:C,isTextBoxReadonly:h,textBoxClass:m,textBoxPlaceholder:v,textBoxTitle:b,inputGroupClass:c,hasClearClass:f,changeTextBoxValue:y,commitValue:p,onBlurTextBox:x,onClickTextBox:S,onFocusTextBox:d,onInput:g,onKeyDownTextBox:N,onKeyUpTextBox:I,onMouseDownTextBox:k,onTextBoxValueChange:j}}const Q="FarrisVue_PopoverInstancesKey";function Ln(e,n,a,o){const i=t.ref(),l=t.ref(!1),{judgeCanOpen:r}=Xe(e,o);t.watch(()=>i.value,(w,C)=>{window[Q]=window[Q]||new WeakMap,w?window[Q].set(a.value,w):window[Q].delete(a.value)});function s(){if(window[Q]){const w=window[Q];document.querySelectorAll(".f-button-edit,.v-popover").forEach(C=>{const m=w.get(C);m&&C!==a.value&&!a.value.closest(".popover-fitcontent")&&m.hide()})}}function u(){const w=i.value;w&&w.show(a.value)}async function f(w=!1){if(!!n.slots.default){if(!w&&!l.value&&!await r())return;l.value=!l.value,l.value&&(await t.nextTick(),u())}}async function b(w=!1){if(!!n.slots.default){if(!w&&!await r())return;l.value=!0,await t.nextTick(),u()}}function v(){l.value=!1}function h(){l.value=!0,t.nextTick(()=>{u()})}return{hidePopup:v,showPopup:h,popup:b,shouldPopupContent:l,togglePopup:f,popoverRef:i,closeAllPopover:s}}function zn(e,n,a){const o=t.ref(),{isTextBoxReadonly:i,textBoxClass:l,textBoxPlaceholder:r,textBoxTitle:s,onBlurTextBox:u,onClickTextBox:f,onFocusTextBox:b,onInput:v,onKeyDownTextBox:h,onKeyUpTextBox:w,onMouseDownTextBox:C,onTextBoxValueChange:m}=a,c=t.ref(e.id),{uuid:y}=ee.useGuid(),p=t.computed(()=>({}));t.onMounted(()=>{var k,N;e.selectOnCreated&&((k=o.value)==null||k.select()),e.focusOnCreated&&((N=o.value)==null||N.focus({preventScroll:!0})),c.value||(c.value="button-edit_"+y(8)),c.value=c.value+"-textbox"});const x=t.ref(!1),S=k=>{k.preventDefault(),x.value=!0},d=k=>{k.preventDefault(),x.value=!1,v(k)};function g(k){x.value||v(k)}return()=>t.createVNode("input",{id:e.id?e.id+"-textbox":void 0,ref:o,name:"input-group-value",autocomplete:e.autoComplete?"on":"off",class:l.value,style:p.value,disabled:e.disable,maxlength:e.maxLength,minlength:e.minLength,placeholder:r.value,readonly:i.value,tabindex:e.tabIndex,title:s.value,type:e.inputType,value:n.value,onBlur:u,onChange:m,onClick:f,onFocus:b,onInput:g,onKeydown:h,onKeyup:w,onMousedown:C,onCompositionend:d,onCompositionstart:S},null)}function Hn(e,n,a){const o=t.ref(e.separator),i=t.computed(()=>e.readonly||e.disable),{changeTextBoxValue:l,onFocusTextBox:r,onBlurTextBox:s,onClickTextBox:u,textBoxPlaceholder:f}=a,b=t.computed(()=>n.value?n.value.split(o.value).map(C=>({name:C,selectable:!0})):[]);function v(C){l(C.map(m=>m.name).join(o.value),!0)}t.watch(()=>e.separator,C=>{o.value=C});const h=t.ref(!e.disable&&!e.readonly);t.watch([()=>e.disable,()=>e.readonly],([C,m],[c,y])=>{h.value=!C&&!m});function w(C){u(C)}return()=>t.createVNode(nt,{tabindex:e.tabIndex,onFocus:r,onBlur:s,id:`${e.id}-tag-editor`,class:"form-control",placeholder:f.value,data:b.value,showClose:!i.value,showInput:!0,disable:i.value,onChange:v,onClick:w},null)}function $n(e,n,a,o){const{buttonGroupClass:i,onClickButton:l,onMouseEnterButton:r,onMouseLeaveButton:s}=a,{enableClearButton:u,showClearButton:f,onClearValue:b}=o,v=t.ref(),h=ne.debounce(C=>{l(C)},e.buttonBehavior==="Modal"?0:200),w=()=>{n.emit("beforeClearValue")};return{renderButtonGroup:()=>t.createVNode("div",{id:e.id?`${e.id}-button-group`:void 0,class:i.value},[u.value&&t.withDirectives(t.createVNode("span",{class:"input-group-text input-group-clear",onClick:b,onMousedown:w},[t.createVNode("i",{class:"f-icon modal_close"},null)]),[[t.vShow,f.value]]),n.slots.buttonContent?t.createVNode("span",{class:"input-group-text input-group-append-button",onClick:h,onMouseenter:r,onMouseleave:s},[n.slots.buttonContent()]):e.buttonContent?t.createVNode("span",{class:"input-group-text input-group-append-button",innerHTML:e.buttonContent,ref:v,onClick:C=>h(C),onMouseenter:r,onMouseleave:s},null):null]),buttonHandleElement:v}}function An(e,n,a){const o=t.ref(e.popupMinWidth),{hidePopup:i,popoverRef:l}=a,r=()=>{n.emit("shown")};return()=>t.createVNode(at,{id:`${e.id}-popover`,ref:l,placement:e.placement,host:e.popupHost,"keep-width-with-reference":e.keepWidthWithReference,fitContent:!0,"right-boundary":e.popupRightBoundary,minWidth:o.value,class:e.popupClass,offsetX:e.popupOffsetX,onHidden:i,onShown:r,beforeClose:e.beforeClosePopup,limitContentBySpace:e.limitContentBySpace},{default:()=>{var s,u;return[(u=(s=n.slots).default)==null?void 0:u.call(s)]}})}const Wn=t.defineComponent({name:"FButtonEdit",props:xn,emits:["updateExtendInfo","clear","change","click","clickButton","blur","focus","mouseEnterIcon","mouseLeaveIcon","keyup","keydown","inputClick","input","update:modelValue","beforeClearValue"],setup(e,n){const a=t.ref(),o=t.ref(e.customClass),i=t.ref(e.modelValue),l=Ln(e,n,a,i),{shouldPopupContent:r,hidePopup:s,showPopup:u,togglePopup:f}=l,b=jn(e,n,a,l,i),v=t.ref(""),h=Rn(e,n,i,v,l),{hasFocusedTextBox:w,commitValue:C,inputGroupClass:m}=h,c=In(e,n,i,w,v,h),{onMouseEnterTextBox:y,onMouseLeaveTextBox:p}=c,x=t.ref(!1),S=t.computed(()=>{const E={"f-button-edit":!0,"f-cmp-inputgroup":!0,"f-button-edit-nowrap":!e.wrapText};return o.value&&o.value.split(" ").reduce((L,M)=>(L[M]=!0,L),E),E}),d=t.computed(()=>({overflow:e.wrapText?"hidden":""})),g=t.computed(()=>({}));function k(){if(!e.multiSelect||e.inputType!=="tag"||!a.value)return 0;let E=0;const L=Array.from(a.value.querySelectorAll(".farris-tag-item"));return L&&L.length&&(E=L.map(M=>M.offsetTop).filter(M=>M>20).length),E}const N=t.ref(k());t.onUpdated(()=>{N.value=k()});function I(){return e.multiSelect&&e.inputType==="tag"?()=>t.createVNode(t.Fragment,null,[Hn(e,i,h)(),!!N.value&&t.createVNode("div",{class:"d-flex flex-row mr-2 more-tags","more-tags":!0},[t.createVNode("span",{class:"multi--more-text"},[t.createTextVNode("+"),N.value])])]):zn(e,i,h)}let j=I();t.watch([()=>e.multiSelect,()=>e.inputType],()=>{j=I()});const{renderButtonGroup:O,buttonHandleElement:P}=$n(e,n,b,c),F=An(e,n,l),V=t.ref(r.value),B={displayText:v,commitValue:C,elementRef:a,hidePopup:s,showPopup:u,popoverRef:l.popoverRef,shouldPopupContent:r,togglePopup:f,openDialog:()=>{P.value&&e.buttonBehavior==="Modal"&&P.value.click()},getModal:()=>{var E;return e.buttonBehavior==="Modal"?(E=b.modalRef.value)==null?void 0:E.value:null},getTextbox:()=>{var E;return(E=a.value)==null?void 0:E.querySelector("input")},forceClosePopup:()=>{V.value=!1,x.value=!0,r.value=!1}};return t.onMounted(()=>{a.value.componentInstance=B,window.onresize=()=>{document.body.click()}}),t.onBeforeUnmount(()=>{var E;window.onresize=null,(E=window[Q])==null||E.delete(a.value)}),n.expose(B),t.watch(()=>r.value,async(E,L)=>{if(x.value){V.value=E,x.value=!1;return}if(!E&&e.beforeClosePopup&&typeof e.beforeClosePopup=="function"){try{const M=await e.beforeClosePopup();V.value=!M,(!M||e.readonly)&&(r.value=!0)}catch(M){console.error("Error in beforeClosePopup:",M),V.value=L,r.value=L}return}V.value=E}),()=>{var E,L;return t.createVNode(t.Fragment,null,[t.createVNode("div",t.mergeProps(n.attrs,{ref:a,class:S.value,id:e.id?e.id:void 0,style:d.value}),[t.createVNode("div",{id:e.id?`${e.id}-input-group`:void 0,class:m.value,style:g.value,onMouseenter:y,onMouseleave:p},[(L=(E=n.slots).precontent)==null?void 0:L.call(E),j(),O()])]),V.value&&F()])}}}),qn={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/expression-editor.schema.json",title:"expression-editor",description:"A Farris Expression Editor Component",type:"object",properties:{id:{description:"The unique identifier for a Expression Editor",type:"string"},type:{description:"The type string of Expression Editor component",type:"string",default:"expression-editor"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},beforeOpen:{type:"object",default:null},modelValue:{description:"The value of Expression Editor",type:"string",default:""},variables:{description:"The variables of Expression Editor",type:"array",default:[]},entities:{description:"The entities of Expression Editor",type:"array",default:[]},onSubmitModal:{description:"The event of Expression Editor",type:"function",default:null},onExpressionChanged:{description:"The event of Expression Editor",type:"function",default:null},esprimaPath:{description:"The path of esprima",type:"string",default:"assets/esprima-config.json"},singleExpand:{description:"The singleExpand of Expression Editor",type:"boolean",default:!0},showMessage:{description:"The showMessage of Expression Editor",type:"boolean",default:!1},dialogTitle:{description:"The dialogTitle of Expression Editor",type:"string",default:"表达式编辑器"},dialogWidth:{description:"The dialogWidth of Expression Editor",type:"string",default:975},dialogHeight:{description:"The dialogHeight of Expression Editor",type:"string",default:600},beforeSubmit:{description:"The beforeSubmit of Expression Editor",type:"function",default:null},showMessageType:{description:"The showMessageType of Expression Editor",type:"boolean",default:!1},showDataPanel:{description:"Show right panel",type:"boolean",default:!0}},required:["id","type"]},Ke={disabled:{type:Boolean,default:!1},readonly:{type:Boolean,default:!1},enableClear:{type:Boolean,default:!0},modelValue:{type:String,default:""},displayText:{type:String,default:""},repositoryToken:{type:Object,default:null},editorParams:{},singleExpand:{type:Boolean,default:!0},beforeOpen:{type:Function,default:()=>{}},onSubmitModal:{type:Function,default:()=>{}},entities:{type:Array,default:[]},variables:{type:Array,default:[]},disabledFunctions:{type:Object,default:null},onExpressionChanged:{type:Function,default:()=>{}},esprimaPath:{type:String,default:"assets/esprima-config.json"},showMessage:{type:Boolean,default:!1},showMessageType:{type:Boolean,default:!1},dialogTitle:{type:String,default:"表达式编辑器"},dialogWidth:{type:Number,default:975},dialogHeight:{type:Number,default:600},validateMessage:{type:String,default:""},beforeSubmit:{type:Function,default:null},showDataPanel:{type:Boolean,default:!0},isServerSide:{type:Boolean,default:!1}},Yn=U.createPropsResolver(Ke,qn),Un={showCloseButton:{type:Boolean,default:!0},position:{type:String,default:"top-center"},timeout:{type:Number,default:3e3},theme:{type:String,default:"bootstrap"},left:{type:Number},right:{type:Number},top:{type:Number},bottom:{type:Number},id:{type:String},animate:{type:String,default:"fadeIn"},options:{type:Object},safeHtml:{type:Boolean,default:!0}},Gn={showCloseButton:{type:Boolean,default:!0},animate:{type:String,default:"fadeIn"},options:{type:Object}},Ce=t.defineComponent({name:"Toast",props:Gn,emits:["close","click"],setup:(e,n)=>{const a=t.ref(e.animate),o="fadeOut",i=t.computed(()=>e.options),l=t.ref(!1),r=t.computed(()=>i.value.title&&i.value.message),s=t.computed(()=>!i.value.title&&i.value.message),u=t.computed(()=>{const p={animated:l.value,toast:!0,"toast--only-content":!r.value};return p[e.animate]=!1,p[o]=l.value,p["toasty-type-"+i.value.type]=!0,i.value.theme&&(p[i.value.theme]=!0),p}),f=t.computed(()=>{const S=`f-icon-${i.value&&i.value.type?i.value.type.replace("toasty-type-",""):"default"}`,d={"f-icon":!0};return d[S]=!0,d}),b=t.computed(()=>i.value.title||i.value.message),v=t.computed(()=>e.showCloseButton),h=t.computed(()=>!!i.value.buttons||!!n.slots.default),w=t.computed(()=>G.LocaleService.getLocale()==="en"?{wordBreak:"keep-all",overflowWrap:"break-word"}:{});function C(p){p.stopPropagation(),p.preventDefault(),l.value=!1,setTimeout(()=>{n.emit("close",i.value)},200)}function m(p,x){}function c(p){return`f-preten-link ${p.customClass?p.customClass:""}`}t.watch(a,()=>{a.value});const y=()=>{var p;return t.createVNode(t.Fragment,null,[t.createVNode("div",{class:"after-toast-msg text-right"},[!n.slots.default&&((p=i.value.buttons)==null?void 0:p.map(x=>t.createVNode("span",{class:c(x),onClick:S=>void 0},[x.text]))),n.slots.default&&n.slots.default()])])};return()=>t.createVNode("div",{class:u.value,style:"min-height:44px"},[v.value&&t.createVNode("button",{title:G.LocaleService.getLocaleValue("messageBox.close"),class:"toast-close f-btn-icon f-bare",onClick:C},[t.createVNode("span",{class:"f-icon modal_close"},null)]),b.value&&t.createVNode("section",{class:"modal-tips"},[!r.value&&t.createVNode("div",{class:"float-left modal-tips-iconwrap"},[t.createVNode("span",{class:f.value},null)]),t.createVNode("div",{class:"modal-tips-content"},[r.value&&t.createVNode(t.Fragment,null,[t.createVNode("h5",{class:"toast-title modal-tips-title",innerHTML:i.value.title},null),t.createVNode("p",{class:"toast-msg",innerHTML:i.value.message,style:w.value},null),h.value&&y()]),s.value&&(i.value.buttons?t.createVNode("div",{class:"toast-title-btns-wrapper d-flex"},[t.createVNode("h5",{class:"toast-title modal-tips-title only-toast-msg",style:w.value,innerHTML:i.value.message},null),t.createVNode("div",{class:"after-toast-title text-right ml-auto"},[y()])]):t.createVNode("h5",{class:"toast-title modal-tips-title only-toast-msg",style:w.value,innerHTML:i.value.message},null))])])])}}),fe=t.defineComponent({name:"Notify",props:Un,emits:["close","empty"],setup(e,n){const a=t.computed(()=>({"farris-notify":!0})),o={left:12,right:12,top:20,bottom:12},i=t.ref(),l=t.ref(e.options),r=t.ref(e.showCloseButton),s=t.computed(()=>e.position||"bottom-right"),u=t.computed(()=>e.timeout!=null?e.timeout:3e3),f=t.computed(()=>{const h=e.bottom?e.bottom:o.bottom,w=e.top?e.top:o.top,C={transition:"all 0.2s ease",left:s.value.indexOf("left")>-1?`${e.left?e.left:o.left}px`:"",right:s.value.indexOf("right")>-1?`${e.right?e.right:o.right}px`:"",top:s.value.indexOf("top")>-1?`${w}px`:"",bottom:s.value.indexOf("bottom")>-1?`${h}px`:""};return s.value.indexOf("center")>-1&&(C.left="50%",C.marginLeft="calc(-24rem / 2)",s.value==="center-center"&&(C.top="50%",C.transform="translate(-50%, -50%)")),C});function b(h){n.emit("close")}u.value&&setTimeout(()=>{b()},u.value),n.expose({closeToast:b,container:i,notifyPosition:s});function v(h,w){b()}return()=>t.createVNode("div",{class:a.value,style:f.value,ref:i},[t.createVNode(Ce,{options:l.value,showCloseButton:r.value,animate:e.animate,onClose:h=>v(h,l.value)},null)])}});class Xn{constructor(){K(this,"notifyRefs",[]);K(this,"globalConfig",t.reactive({}))}escapeAllHtml(n){if(typeof n!="string"||!n)return"";const a=document.createElement("div");return a.textContent=n||"",a.innerHTML.replace(/\\n/g,"<br>").replace(/\\t/g,"&nbsp;&nbsp;&nbsp;&nbsp;").replace(/\\r/g,"")}createNotifyInstance(n){const a=this,i=Object.assign({timeout:3e3,position:"bottom-right",showCloseButton:!0,safeHtml:!0},this.globalConfig,{...n}),l=document.createElement("div");l.style.display="contents";const r=t.createApp({setup(){var f;const s=t.ref();function u(){s.value.container.style.transform="scale(0)",setTimeout(()=>{a.updateNotifyPositionForClose(i,s),r.unmount()},220)}if(i.position.indexOf("top")>-1){const b=a.getNotifyInstances(i.position),v=b[b.length-1];if(v){const h=v.value.container.getBoundingClientRect();i.top=h.bottom}}return i.safeHtml&&((f=i.options)!=null&&f.message)&&(i.options.message=a.escapeAllHtml(i.options.message)),t.onUnmounted(()=>{document.body.removeChild(l)}),t.onMounted(()=>{a.updateNotifyPositionForCreate(i,s)}),()=>t.createVNode(t.Transition,{mode:"out-in",name:"fade",appear:!0},{default:()=>[t.createVNode(fe,t.mergeProps({ref:s},i,{onClose:u}),null)]})}});return r.provide("NotifyService",this),document.body.appendChild(l),r.use(G.LocaleService.i18n),r.mount(l),r}getNotifyInstances(n){return this.notifyRefs.filter(a=>a.value.notifyPosition===n)}updateNotifyPositionForCreate(n,a){if(this.notifyRefs&&this.notifyRefs.length){const o=window.innerHeight;n.position.indexOf("bottom")>-1&&this.getNotifyInstances(n.position).forEach(i=>{const l=i.value.container.getBoundingClientRect();i.value.container.style.bottom=l.height+o-l.bottom+"px"})}this.notifyRefs=[...this.notifyRefs,a]}updateNotifyPositionForClose(n,a){const o=this.notifyRefs.indexOf(a);if(n.position.indexOf("top")>-1){const i=this.getNotifyInstances(n.position),l=i.indexOf(a);i.slice(l+1).forEach(r=>{r.value.container.style.top=r.value.container.offsetTop-r.value.container.offsetHeight+"px"})}o>-1&&this.notifyRefs.splice(o,1)}show(n){return this.createNotifyInstance(n)}buildNotifyProps(n,a){let o="",i="",l,r,s;typeof a=="string"?o=a:a&&(o=a.message||"",i=a.title||"",r=a.position||null,s=a.showCloseButton!=null?a.showCloseButton:null,l=a.timeout!=null?a.timeout:null);const f={options:{type:n,message:o,title:i}};return r!=null&&(f.position=r),s!=null&&(f.showCloseButton=s),l!=null&&(f.timeout=l),f}info(n){const a=this.buildNotifyProps("info",n);return this.show(a)}success(n){const a=this.buildNotifyProps("success",n);return this.show(a)}warning(n){const a=this.buildNotifyProps("warning",n);return this.show(a)}error(n){const a=this.buildNotifyProps("error",n);return this.show(a)}close(n){n&&n.unmount()}closeAll(){this.notifyRefs.forEach(n=>{n==null||n.value.closeToast()}),this.notifyRefs.length=0}}const _e=Symbol("NOTIFY_SERVICE_TOKEN");fe.install=e=>{e.component(fe.name,fe),e.component(Ce.name,Ce);const n=new Xn;e.provide(_e,n),e.provide("FNotifyService",n)};const me=t.defineComponent({name:"f-expression-textbox",props:Ke,setup(e,n){const a=t.inject(_e),o=t.inject("FLoadingService"),i='<i class="f-icon f-icon-lookup"></i>',l=t.ref(e.modelValue),r=t.ref(e.entities),s=t.ref(e.variables),u=t.ref(),f=t.ref(e.validateMessage||""),b=t.ref("info");async function v(){const{value:m,message:c,messageType:y}=u.value.getExpressionValue();if(f.value=c,b.value=y,e.beforeSubmit&&typeof e.beforeSubmit=="function"){const p=await e.beforeSubmit({notifyService:a,expressionValue:m});if(typeof p=="boolean"&&!p)return!1;if(typeof p=="object"){const{canClose:x,message:S}=p;if(!x)return S&&(a==null||a.error({message:S})),!1}}if(n.emit("update:modelValue",m),l.value=m,e.onSubmitModal){const p={expression:m,message:c};e.showMessageType&&(p.messageType=b.value);const x=e.onSubmitModal(p);e.onExpressionChanged&&e.onExpressionChanged(x)}return!0}const h={title:e.dialogTitle||"表达式编辑器",width:e.dialogWidth||975,height:e.dialogHeight||600,fitContent:!1,minWidth:300,minHeight:200,showMaxButton:!0,resizeable:!0,draggable:!0,buttons:[{name:"reset",text:"清空",class:"btn btn-secondary mr-2",handle:m=>{var c;return(c=u.value)==null||c.resetExpression(),!1}},{name:"cancel",text:"取消",class:"btn btn-secondary",handle:m=>!0},{name:"accept",text:"确定",class:"btn btn-primary",handle:async m=>await v()}]};async function w(){if(e.beforeOpen)try{o==null||o.show();const m=await e.beforeOpen({notifyService:a});if(m)return r.value=m.entities||{},s.value=m.variables||{},f.value=m.message||"",b.value=m.messageType||"info",o==null||o.clearAll(),!0}catch{return a==null||a.error({message:"获取数据失败!"}),!1}finally{o==null||o.clearAll()}return!0}function C(){if(n.emit("update:modelValue",""),l.value="",e.onSubmitModal){const m=e.onSubmitModal({expression:"",message:""});e.onExpressionChanged&&e.onExpressionChanged(m)}}return t.watch(()=>e.modelValue,m=>{l.value=m}),()=>t.createVNode(Wn,{editable:!1,enableTitle:!0,modelValue:l.value,"onUpdate:modelValue":m=>l.value=m,disabled:e.disabled,readonly:e.readonly,inputType:"text",enableClear:e.enableClear,buttonContent:i,buttonBehavior:"Modal",modalOptions:h,beforeOpen:w,onClear:C},{default:()=>[t.createVNode("div",{class:"h-100 d-flex flex-column"},[t.createVNode(qe,{ref:u,validateMessage:f.value,showMessageType:e.showMessageType,messageType:b.value,modelValue:l.value,"onUpdate:modelValue":m=>l.value=m,esprimaPath:e.esprimaPath,showMessage:e.showMessage,entities:r.value,variables:s.value,disabledFunctions:e.disabledFunctions,showDataPanel:e.showDataPanel,singleExpand:e.singleExpand,isServerSide:e.isServerSide},null)])]})}}),Kn={install(e){e.component(me.name,me)},register(e,n,a,o){e["expression-editor"]=me,n["expression-editor"]=Yn}};H.ExpressionEditor=qe,H.FExpressionTextbox=me,H.default=Kn,H.expressionEditorProps=Te,Object.defineProperties(H,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
1
+ (function(e,t){typeof exports=="object"&&typeof module<"u"?t(exports):typeof define=="function"&&define.amd?define(["exports"],t):(e=typeof globalThis<"u"?globalThis:e||self,t(e["expression-editor"]={}))})(this,function(e){"use strict";const t={modelValue:{type:String,default:""},singleExpand:{type:Boolean,default:!0},entities:{type:Array,default:[]},variables:{type:Array,default:[]},disabledFunctions:{type:Object,default:null},esprimaPath:{type:String,default:"assets/esprima-config.json"},showMessage:{type:Boolean,default:!1},validateMessage:{type:String,default:""},messageType:{type:String,default:"info"},showMessageType:{type:Boolean,default:!1},showDataPanel:{type:Boolean,default:!0},isServerSide:{type:Boolean,default:!1}};e.expressionEditorProps=t,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});