@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(R,t){typeof exports=="object"&&typeof module<"u"?t(exports,require("vue"),require("../locale/index.umd.js"),require("../common/index.umd.js"),require("../property-panel/index.umd.js"),require("../tags/index.umd.js"),require("lodash-es"),require("../popover/index.umd.js"),require("../dynamic-resolver/index.umd.js"),require("../button-edit/index.umd.js"),require("../list-view/index.umd.js"),require("../../designer/button-edit/index.umd.js"),require("../designer-canvas/index.umd.js"),require("../tree-view/index.umd.js"),require("../event-parameter/index.umd.js"),require("../input-group/index.umd.js")):typeof define=="function"&&define.amd?define(["exports","vue","../locale/index.umd.js","../common/index.umd.js","../property-panel/index.umd.js","../tags/index.umd.js","lodash-es","../popover/index.umd.js","../dynamic-resolver/index.umd.js","../button-edit/index.umd.js","../list-view/index.umd.js","../../designer/button-edit/index.umd.js","../designer-canvas/index.umd.js","../tree-view/index.umd.js","../event-parameter/index.umd.js","../input-group/index.umd.js"],t):(R=typeof globalThis<"u"?globalThis:R||self,t(R["filter-condition-editor"]={},R.Vue,R.locale,R.common,R.propertyPanel,R.FTags,R.LodashES,R.FPopover,R.dynamicResolver,R.FButtonEdit$1,R.FListView,R.FButtonEditDesign,R.designerCanvas,R.FTreeView,R.FEventParameter,R.inputGroup))})(this,function(R,t,q,Q,xt,Ct,J,wt,_,me,kt,Ft,ye,Ae,Tt,St){"use strict";var uo=Object.defineProperty;var fo=(R,t,q)=>t in R?uo(R,t,{enumerable:!0,configurable:!0,writable:!0,value:q}):R[t]=q;var K=(R,t,q)=>fo(R,typeof t!="symbol"?t+"":t,q);const Nt={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}},Vt={popupContentPosition:{type:Object,default:{left:0,top:0}},host:{type:Object},backgroundColor:{type:String,default:""}},Mt=t.defineComponent({name:"FOverlay",props:Vt,emits:["click"],setup(e,n){const a=t.ref(e.popupContentPosition),o=t.ref(e.host),l=t.computed(()=>({backgroundColor:e.backgroundColor||"",pointerEvents:"auto"}));function i(c){n.emit("click"),c.preventDefault(),c.stopPropagation()}t.computed(()=>{const c=o.value;if(c){const u=c.getBoundingClientRect(),{left:f,top:x,height:m}=u;return{left:f,top:x+m}}return a.value});const s=t.computed(()=>({}));return()=>t.createVNode(t.Teleport,{to:"body"},{default:()=>{var c,u;return[t.createVNode("div",{class:"overlay-container",onClick:f=>i(f),style:l.value},[t.createVNode("div",{style:s.value},[(u=(c=n.slots).default)==null?void 0:u.call(c)])])]}})}});function Bt(e){if(e.content&&e.content.render)return e.content.render;if(e.render&&typeof e.render=="function")return e.render}function Ot(e){const n=document.createElement("div");n.style.display="contents";let a;const o=e.onClickCallback||(()=>{}),l=()=>{o(),a&&a.unmount()};return a=t.createApp({setup(){t.onUnmounted(()=>{document.body.removeChild(n)});const i=Bt(e);return()=>t.createVNode(Mt,{"popup-content-position":e.popupPosition,host:e.host,onClick:l,backgroundColor:e.backgroundColor},{default:()=>[i&&i()]})}}),document.body.appendChild(n),a.mount(n),a}class Et{static show(n){return Ot(n)}}const Dt={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 W{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 l=parseInt(o[4],10),i=parseInt(o[5],10);return{x:l,y:i}}return{x:0,y:0}}static fromEvent(n,a=null){if(this.isMouseEvent(n))return new W(n.clientX,n.clientY);if(a===null||n.changedTouches.length===1)return new W(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 W(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 W(0,0);if(window){const o=window.getComputedStyle(n);if(o){const l=parseInt(o.getPropertyValue("left"),10),i=parseInt(o.getPropertyValue("top"),10);a.x=isNaN(l)?0:l,a.y=isNaN(i)?0:i}return a}return null}static copy(n){return new W(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 ne{constructor(n,a){this.width=n,this.height=a}static getCurrent(n){const a=new ne(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 ne(0,0).set(n)}set(n){return this.width=n.width,this.height=n.height,this}}function Pt(e,n){const a=t.ref(),o=t.ref(),l=t.ref(),i=t.ref(),s=t.ref(),c=t.ref(),u=t.ref(),f=t.ref(),x=t.ref(),m=t.ref(),d=t.ref(),C=t.ref(e.resizeable),b=t.ref(),y=t.ref(e.draggable),r=t.ref(!1);function h(){const B=o.value||document.body,M=window.getComputedStyle(B);if(!M||!a.value)return;const $=W.getTransformInfo(a.value),A={};u.value&&(A.deltaL=a.value.offsetLeft-u.value.x,A.deltaT=a.value.offsetTop-u.value.y);const H=M.getPropertyValue("position");A.width=B.clientWidth,A.height=B.clientHeight,A.pr=parseInt(M.getPropertyValue("padding-right"),10),A.pb=parseInt(M.getPropertyValue("padding-bottom"),10),A.position=M.getPropertyValue("position"),H==="static"&&(B.style.position="relative"),A.translateX=$.x,A.translateY=$.y,m.value=A}function v(B){if(a.value){i.value=ne.getCurrent(a.value),s.value=W.getCurrent(a.value),c.value=i.value?ne.copy(i.value):null,u.value=s.value?W.copy(s.value):null,h();const M=B.target.getAttribute("type")||"";f.value={n:!!M.match(/n/),s:!!M.match(/s/),w:!!M.match(/w/),e:!!M.match(/e/)}}}function k(){var B,M,$,A;if(a.value){const H=a.value;f.value&&((f.value.n||f.value.s)&&((B=c.value)!=null&&B.height)&&(H.style.height=c.value.height+"px"),(f.value.w||f.value.e)&&((M=c.value)!=null&&M.width)&&(H.style.width=c.value.width+"px"),u.value&&(($=u.value)!=null&&$.x&&(H.style.left=u.value.x+"px"),(A=u.value)!=null&&A.y&&(H.style.top=u.value.y+"px")))}}function F(){const B=e.minHeight?e.minHeight:1,M=e.minWidth?e.minWidth:1;c.value&&u.value&&f.value&&i.value&&(c.value.height<B&&(c.value.height=B,f.value.n&&s.value&&(u.value.y=s.value.y+(i.value.height-B))),c.value.width<M&&(c.value.width=M,f.value.w&&s.value&&(u.value.x=s.value.x+(i.value.width-M))),e.maxHeight&&c.value.height>e.maxHeight&&(c.value.height=e.maxHeight,s.value&&f.value.n&&(u.value.y=s.value.y+(i.value.height-e.maxHeight))),e.maxWidth&&c.value.width>e.maxWidth&&(c.value.width=e.maxWidth,f.value.w&&s.value&&(u.value.x=s.value.x+(i.value.width-e.maxWidth))))}function p(){if(o.value){const B=m.value;if(u.value&&c.value&&f.value&&i.value){const M=B.width-B.pr-B.deltaL-B.translateX-u.value.x,$=B.height-B.pb-B.deltaT-B.translateY-u.value.y;f.value.n&&u.value.y+B.translateY<0&&s.value&&(u.value.y=-B.translateY,c.value.height=i.value.height+s.value.y+B.translateY),f.value.w&&u.value.x+B.translateX<0&&s.value&&(u.value.x=-B.translateX,c.value.width=i.value.width+s.value.x+B.translateX),c.value.width>M&&(c.value.width=M),c.value.height>$&&(c.value.height=$)}}}function g(B){if(!l.value||!i.value||!s.value||!f.value)return;B.subtract(l.value);const M=B.x,$=B.y;f.value.n?(u.value.y=s.value.y+$,c.value.height=i.value.height-$):f.value.s&&(c.value.height=i.value.height+$),f.value.e?c.value.width=i.value.width+M:f.value.w&&(c.value.width=i.value.width-M,u.value.x=s.value.x+M),p(),F(),k()}function w(B){if(!x.value)return;const M=W.fromEvent(B);M&&g(M)}function N(){if(a.value){const{width:B,height:M,x:$,y:A}=a.value.getBoundingClientRect(),H=W.getTransformInfo(a.value);return{size:{width:B,height:M},position:{x:$-H.x,y:A-H.y}}}return null}function j(B){if(a.value){const M=N();d.value=M}l.value=void 0,i.value=null,s.value=null,c.value=null,u.value=null,f.value=null,x.value=null,document.removeEventListener("mousemove",w),document.removeEventListener("mouseup",j)}function I(){document.addEventListener("mousemove",w),document.addEventListener("mouseup",j)}function T(B){B instanceof MouseEvent&&B.button===2||y.value&&(document.body.click(),B.stopPropagation(),B.preventDefault(),l.value=W.fromEvent(B),x.value=B.target,v(B),I())}function O(B){return a.value=B,C.value&&t.createVNode(t.Fragment,null,[t.createVNode("div",{class:"fv-resizable-handle fv-resizable-n",type:"n",onMousedown:M=>T(M)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-e",type:"e",onMousedown:M=>T(M)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-s",type:"s",onMousedown:M=>T(M)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-w",type:"w",onMousedown:M=>T(M)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-ne",type:"ne",onMousedown:M=>T(M)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-se fv-resizable-diagonal",type:"se",onMousedown:M=>T(M)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-sw",type:"sw",onMousedown:M=>T(M)},null),t.createVNode("div",{class:"fv-resizable-handle fv-resizable-nw",type:"nw",onMousedown:M=>T(M)},null)])}function S(B=!0){document.body.click();const M=o.value||document.body,$=ne.getCurrent(M),A=a.value;B&&A&&(b.value=N(),b.value.transform=A.style.transform),$&&A&&(c.value=$,c.value.height-=14,c.value.width-=14,A.style.height=c.value.height+"px",A.style.width=c.value.width+"px",A.style.left="7px",A.style.top="7px",A.style.transform="",d.value={size:c.value,position:{x:0,y:0}},y.value=!1,r.value=!0)}function E(){var B,M;if(document.body.click(),b.value){const $={width:b.value.size.width||0,height:b.value.size.height||0},A={x:(window.innerWidth-$.width)/2,y:(window.innerHeight-$.height)/2};(B=c.value)==null||B.set($),(M=u.value)==null||M.set(A);const H=a.value;H.style.height=$.height+"px",H.style.width=$.width+"px",H.style.left=`${A.x}px`,H.style.top=`${A.y}px`,H.style.transform="",d.value={size:$,position:A},y.value=e.draggable,r.value=!1}}function D(){if(a.value){const B=ne.getCurrent(a.value);if(B){const{width:M,height:$}=B;a.value.style.left=`${(window.innerWidth-M)/2}px`,a.value.style.top=`${(window.innerHeight-$)/2}px`,a.value.style.transform=""}}}function P(){const B=()=>{r.value?S(!1):D(),document.body.click()};return window.addEventListener("resize",B),()=>{window.removeEventListener("resize",B)}}const z=P();return{renderResizeBar:O,boundingElement:o,resizedEventParam:d,maximize:S,restore:E,allowDrag:y,isMaximized:r,unWindowResizeHandle:z,moveToCenter:D}}function It(e,n,a){const o=t.ref(),l=t.ref(e.draggable),i=t.ref(e.lockAxis),s=t.ref(),c=t.ref(),u=t.ref(!1),f=t.ref(new W(0,0)),x=t.ref(new W(0,0)),m=t.ref(new W(0,0)),d=t.ref(new W(0,0));t.watch(()=>a.value,w=>{s.value.style.cursor=w?"move":"default"});function C(w,N){if(N.tagName==="BUTTON")return!1;if(N===w)return!0;for(const j in N.children)if(Object.prototype.hasOwnProperty.call(N.children,j)&&C(w,N.children[j]))return!0;return!1}function b(){var I,T;let w=m.value.x+x.value.x,N=m.value.y+x.value.y;i.value==="x"?(w=((I=f.value)==null?void 0:I.x)||0,m.value.x=0):i.value==="y"&&(N=((T=f.value)==null?void 0:T.y)||0,m.value.y=0);const j=`translate3d(${Math.round(w)}px, ${Math.round(N)}px, 0px)`;o.value&&(o.value.style.transform=j),d.value.x=w,d.value.y=N}function y(){if(!c.value||!o.value)return null;const w=c.value.getBoundingClientRect(),N=o.value.getBoundingClientRect(),j={top:w.top<N.top,right:w.right>N.right,bottom:w.bottom>N.bottom,left:w.left<N.left};return j.top||(m.value.y-=N.top-w.top),j.bottom||(m.value.y-=N.bottom-w.bottom),j.right||(m.value.x-=N.right-w.right),j.left||(m.value.x-=N.left-w.left),b(),j}function r(w){w&&(f.value&&w.subtract(f.value),m.value.set(w),b(),y())}function h(w){u.value&&l.value&&(w.stopPropagation(),w.preventDefault(),r(W.fromEvent(w,s.value)))}function v(){var w;u.value&&(u.value=!1,x.value.add(m.value),m.value.reset(),(w=o.value)==null||w.classList.remove("ng-dragging"),n.emit("stopMove"),document.removeEventListener("mousemove",h),document.removeEventListener("mouseup",v))}function k(){!u.value&&s.value&&(u.value=!0,s.value.classList.add("ng-dragging"),document.addEventListener("mousemove",h),document.addEventListener("mouseup",v))}function F(){if(o.value){const w=W.getTransformInfo(o.value);x.value.set(w);return}x.value.reset()}function p(w){if(!a.value||w instanceof MouseEvent&&w.button===2)return;const N=w.target||w.srcElement;s.value!==void 0&&N&&!C(N,s.value)||l.value!==!1&&(document.body.click(),w.stopPropagation(),w.preventDefault(),f.value=W.fromEvent(w,o.value),F(),k())}function g(w,N,j){if(l.value&&N){if(w)s.value=w;else if(e.dragHandle){if(e.dragHandle instanceof HTMLElement)s.value=e.dragHandle;else if(typeof e.dragHandle=="string"){const I=N.querySelector(e.dragHandle);I&&(s.value=I)}}o.value=N,c.value=j,s.value?(s.value.classList.add("ng-draggable"),s.value.addEventListener("mousedown",p)):l.value=!1}}return{registerDraggle:g,resetTranslate:F}}function He(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 jt(e,n){const a=t.ref(e.enableEsc);let o=null;return a.value?(o=He("Escape",l=>{n.emit("esc",{event:l.event,type:"esc"})}),{remove:o}):null}function Rt(e,n){const a=t.ref(e.enableEnter);let o=null;return a.value?(o=He("Enter",l=>{n.emit("enter",{event:l.event,type:"enter"})}),{remove:o}):null}const se=t.defineComponent({name:"FModal",props:Dt,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),l=t.ref(e.modelValue),i=t.ref(""),s=t.ref(e.class),c=t.ref(e.fitContent),u=t.ref(e.showHeader),f=t.ref(""),x=t.ref(e.showCloseButton),m=t.ref(e.showMaxButton),d=t.ref(!1),C=t.ref(e.dialogType),b=t.ref(e.src),y=t.ref(""),r=t.ref(e.showButtons),h=t.ref(e.title),v=t.ref(e.containment||null),k=t.ref();h.value==="错误提示"&&(h.value=q.LocaleService.getLocaleValue("messageBox.errorTitle"));const F=t.ref(!1);function p(V,L){const Y=L?"accept":"cancel";Promise.resolve().then(()=>{var U;return(U=e.beforeClose)==null?void 0:U.call(e,{closeType:Y})}).then(U=>{U&&(l.value=!1,n.emit("update:modelValue",!1),L!=null&&n.emit(L?"accept":"cancel"),n.emit("closed",V))})}const g=[{name:"cancel",text:q.LocaleService.getLocaleValue("messageBox.cancel")||"取消",class:"btn btn-secondary",handle:V=>{p(V,!1)}},{name:"accept",text:q.LocaleService.getLocaleValue("messageBox.ok")||"确定",class:"btn btn-primary",handle:V=>{p(V,!0)}}],w=t.ref(e.buttons&&e.buttons.length?e.buttons:g),N=t.computed(()=>!!f.value),j=t.computed(()=>!!r.value&&!!w.value),I=t.ref(),T=t.ref(),O=t.ref(!1),{renderResizeBar:S,maximize:E,restore:D,boundingElement:P,resizedEventParam:z,allowDrag:B,unWindowResizeHandle:M,moveToCenter:$}=Pt(e),{registerDraggle:A}=It(e,n,B);function H(){return!!document.querySelectorAll(".farris-modal").length&&document.body.classList.contains("modal-open")}function Re(){const V=document.querySelectorAll(".farris-modal").length;(!V||V-1<=0)&&document.body.classList.remove("modal-open"),k.value&&k.value.classList.remove("show")}t.watch(()=>e.title,(V,L)=>{V!==L&&(h.value=V)}),t.watch(()=>e.modelValue,(V,L)=>{V!==L&&(l.value=V,l.value&&e.draggable&&t.nextTick(()=>{T.value&&!v.value&&(v.value=T.value.parentElement,P.value=v.value,A(I.value,T.value,P.value),$())}),V||(v.value&&(v.value=null),Re())),l.value?F.value=H():(O.value=!1,B.value=e.draggable)}),t.watch(()=>e.showHeader,(V,L)=>{V!==L&&(u.value=V)}),t.watch(()=>e.showButtons,(V,L)=>{V!==L&&(r.value=V)}),t.watch(()=>z.value,(V,L)=>{const Y=V||{},U=L||{};JSON.stringify(Y)!==JSON.stringify(U)&&n.emit("resize",{newSize:V,oldSize:L,isMaximized:O.value})}),t.watch([()=>e.width,()=>e.height],(V,L)=>{(V[0]!==L[0]||V[1]!==L[1])&&(a.value=V[0]||500,o.value=V[1]||600)});const fe=t.computed(()=>(l.value&&document.body.classList.add("modal-open"),l.value)),Le=t.computed(()=>{var Y;const V={modal:!0,"farris-modal":!0,fade:!0};V["f-modal-fitContent"]=!!c.value,V.show=!!fe.value;const L=(Y=e.maskClass)==null?void 0:Y.split(" ");return L==null||L.reduce((U,re)=>(U[re]=!0,U),V),V}),Ua=t.computed(()=>{var Y;const V={"modal-dialog":!0},L=(Y=s.value)==null?void 0:Y.split(" ");return L==null||L.reduce((U,re)=>(U[re]=!0,U),V),V}),Ya=t.computed(()=>{const V=document.documentElement.clientWidth,L=document.documentElement.clientHeight,Y=Math.min(a.value,V),U=c.value?"auto":`${Math.min(o.value,L-10)}px`,re={position:"absolute",top:`${(window.innerHeight-parseInt(U==="auto"?"0":U))/2}px`,left:`${(window.innerWidth-Y)/2}px`,width:`${Y}px`,height:U};return e.mask||(re.pointerEvents="auto"),re}),Ga=()=>Q.getMaxZIndex()||1040,Xa=t.computed(()=>{const V={display:"block",zIndex:Ga()};return e.mask||(V.pointerEvents="none",V.backgroundColor="transparent"),F.value&&(V.backgroundColor="transparent"),V}),Ka=t.computed(()=>({"modal-content":!0,"modal-content-has-header":u.value})),Ja=t.computed(()=>{const V={display:u.value?"":"none"};return V["pointer-events"]=B.value?"auto":"none",V}),_a=t.computed(()=>({"f-icon":!0,modal_maximize:!0,modalrevert:O.value})),Za=t.computed(()=>({"modal-body":!0,"f-utils-flex-column":C.value==="iframe","f-utils-fill":!0}));function Qa(){return{height:`${e.footerHeight||60}px`}}const eo=t.computed(()=>{const V={textAlgin:y.value},L=Qa();return Object.assign(V,L)});function vt(V){if(V==null||V.stopPropagation(),O.value){O.value=!1,D();return}E(),O.value=!0}async function to(V,L){V.handle&&await V.handle(L,V)&&n.emit("closed",L)}function no(V){V.width&&(a.value=V.width),V.height&&(o.value=V.height),V.buttons&&(w.value=V.buttons),V.title&&(h.value=V.title)}let $e=null,ze=null;t.onBeforeMount(()=>{F.value=H()}),t.onMounted(()=>{T.value&&!v.value&&(v.value=T.value.parentElement,P.value=v.value,A(I.value,T.value,P.value)),fe.value&&document.body.classList.add("modal-open"),$e=jt(e,n),ze=Rt(e,n)}),t.onUnmounted(()=>{M&&M(),$e&&$e.remove(),ze&&ze.remove()}),n.expose({modalElementRef:T,updateModalOptions:no,close:p,maxDialog:vt,isMaximized:O});function ao(){return t.createVNode("ul",null,[d.value&&t.createVNode("li",{class:"f-btn-icon f-bare"},[t.createVNode("span",{class:"f-icon modal_minimize"},null)]),m.value&&t.createVNode("li",{onClick:vt,class:"f-btn-icon f-bare",style:"pointer-events: auto;"},[t.createVNode("span",{class:_a.value},null)]),x.value&&t.createVNode("li",{class:"f-btn-icon f-bare",onClick:V=>p(V,!1),style:"pointer-events: auto;"},[t.createVNode("span",{class:"f-icon modal_close"},null)])])}function oo(){return t.createVNode("div",{class:"modal-footer",style:eo.value},[w.value&&w.value.map(V=>{const L=t.ref(V.disabled);return t.createVNode("button",{name:V.name,type:"button",disabled:L.value,class:V.class+(V.iconClass?" btn-icontext":""),onClick:Y=>{to(V,Y)}},[!!V.iconClass&&t.createVNode("i",{class:V.iconClass},null),V.text])})])}function lo(){return t.createVNode("div",{ref:I,class:"modal-header",style:Ja.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"},[h.value])]),t.createVNode("div",{class:"actions"},[ao()])])}function io(){return n.slots.footerTemplate?n.slots.footerTemplate():j.value&&oo()}function ro(V){if(V.stopPropagation(),e.allowClickMaskToClose){if(V.target!==k.value)return;p(V,!1)}}function so(){var V,L;return t.createVNode("div",{id:i.value,class:Ua.value,style:Ya.value,ref:T},[t.createVNode("div",{class:Ka.value},[u.value&&lo(),t.createVNode("div",{class:Za.value},[(L=(V=n.slots).default)==null?void 0:L.call(V),C.value==="iframe"&&t.createVNode("iframe",{title:i.value,class:"f-utils-fill",width:"100%",frameborder:"0",src:b.value},null)]),io()]),!c.value&&T.value&&!O.value&&S(T.value)])}function co(V){return V||"body"}return()=>t.createVNode(t.Teleport,{to:co(e.host)},{default:()=>[fe.value&&t.createVNode(t.Transition,{name:"fade",appear:!0},{default:()=>[t.createVNode("div",{ref:k,class:Le.value,style:Xa.value,onClick:ro},[so()])]})]})}});function We(e){if(e.content&&e.content.render)return e.content.render;if(e.render&&typeof e.render=="function")return e.render}function Lt(e){const n=document.createElement("div");n.style.display="contents";const a=t.createApp({setup(o,l){t.onUnmounted(()=>{document.body.removeChild(n)});const i=t.ref(),s=t.ref(e.class||""),c=t.ref(!!e.showButtons),u=t.ref(!!e.showHeader),f=t.ref(e.showCloseButton==null?!0:e.showCloseButton),x=t.ref(!0),m=t.ref(e.title||""),d=e.acceptCallback||(()=>{}),C=e.rejectCallback||(()=>{}),b=e.closedCallback||(k=>{}),y=e.resizeHandle||(k=>{}),r=e.stopMoveHandle||(k=>{}),h=We(e),v=k=>{x.value=!1,a.unmount(),b(k)};return t.onMounted(()=>{}),l.expose({modalRef:i}),()=>t.createVNode(se,{ref:i,class:s.value,modelValue:x.value,"onUpdate:modelValue":k=>x.value=k,title:m.value,width:e.width,height:e.height,buttons:e.buttons,"show-header":u.value,"show-buttons":c.value,"show-close-button":f.value,"show-max-button":!1,onAccept:d,onCancel:C,fitContent:e.fitContent==null?!0:e.fitContent,onClosed:v,onResize:y,onStopMove:r},{default:()=>[h&&h(a)]})}});return document.body.appendChild(n),a.use(q.LocaleService.i18n),a.mount(n),a}class qe{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:l}={width:window.innerWidth,height:window.innerHeight};return o<n&&(n=o-14),l<a&&(a=l-14),{width:n,height:a}}static show(n){const a=Object.assign({title:"",showButtons:!0,showHeader:!0},n);return Lt(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)),l=t.ref(!0),i=o.value.acceptCallback||(()=>{}),s=o.value.rejectCallback||(()=>{}),c=o.value.closedCallback||((p,g)=>{}),u=o.value.resizeHandle||(p=>{}),f=n.stopMoveHandle||(p=>{});let x;const m=We(o.value),d=p=>{var w;l.value=!1;const g=(w=p==null?void 0:p.target)==null?void 0:w.classList.contains("modal_close");c(p,this.isUseEscCloseModal.value?"esc":g?"icon":"button")},C=p=>{d(p),x&&t.nextTick(()=>{if(this.modalRefs[this.activeModalIndex.value]&&delete this.modalRefs[this.activeModalIndex.value],t.render(null,a),x=null,this.modalRef.value=null,this.modalRefs){const g=Object.keys(this.modalRefs).map(w=>Number(w));g.length>0?this.activeModalIndex.value=Math.max(...g):this.activeModalIndex.value=0}this.isUseEscCloseModal.value=!1})},b=p=>{var g;this.isUseEscCloseModal.value=!0,this.activeModalInstance&&((g=this.activeModalInstance.value)==null||g.close(p==null?void 0:p.event))},{width:y,height:r}=o.value,h=this.adaptToWindow(y||500,r||320);Object.assign(o.value,h);const v=()=>t.createVNode(se,t.mergeProps({ref:this.modalRef,modelValue:l.value,"onUpdate:modelValue":p=>l.value=p},o.value,{onAccept:i,onCancel:s,onClosed:C,onResize:u,onEsc:b,onStopMove:f}),{default:()=>[m&&m(this.app)]});return x=(p=>{const g=t.h(v,p);return g.appContext=this.appContext,t.render(g,a),g})({...o.value}),this.activeModalIndex.value++,this.modalRefs[this.activeModalIndex.value]=this.modalRef.value,{update:p=>{o.value={...o.value,...p},x&&t.render(t.cloneVNode(x,{...o}),a)},destroy:C,modalRef:this.activeModalInstance,close:()=>this.close()}}}const Ue=Symbol("FModalService");se.install=e=>{e.component(se.name,se);const n=new qe(e);e.provide(Ue,n),e.provide("FModalService",n)};function Ye(e,n){function a(){const o=e.beforeOpen||e.beforeClickButton||null;let l=Promise.resolve(!0);if(o){const i=o(n.value);if(typeof i>"u")return l;typeof i=="boolean"?l=Promise.resolve(i):l=i}return l}return{judgeCanOpen:a}}function $t(e,n,a,o,l){const i=t.ref(e.buttonBehavior),s=t.ref(e.popupOnInput),c=t.computed(()=>({"input-group-append":!0,"append-force-show":e.showButtonWhenDisabled&&(e.readonly||e.disable)})),{judgeCanOpen:u}=Ye(e,l),f=t.computed(()=>e.showButtonWhenDisabled||(!e.editable||!e.readonly)&&!e.disable),x=t.inject(Ue,null),m=t.ref();async function d(y){if(await u()&&f.value){const r=!!n.slots.default;if(i.value==="Modal"){const h=e.modalOptions,v=x==null?void 0:x.open({...h,render:()=>n.slots.default&&n.slots.default()});m.value=v==null?void 0:v.modalRef}i.value==="Overlay"&&Et.show({host:document.body,backgroundColor:"rgba(0,0,0,.15)",render:()=>n.slots.default&&n.slots.default()}),r&&i.value==="Popup"&&o.togglePopup(!0),r&&s.value&&o.hidePopup(),n.emit("clickButton",{origin:y,value:e.modelValue})}}function C(y){n.emit("mouseEnterIcon",y)}function b(y){n.emit("mouseLeaveIcon",y)}return{buttonGroupClass:c,onClickButton:d,onMouseEnterButton:C,onMouseLeaveButton:b,modalRef:m}}function zt(e,n,a,o,l,i){const s=t.ref(!1),c=t.computed(()=>e.enableClear&&!e.readonly&&!e.disable),{changeTextBoxValue:u,hasClearClass:f}=i;function x(b){s.value=b,f.value=b}t.watch(l,()=>{x(!!l.value)});function m(b){const y=!e.readonly&&!e.disable&&e.editable,r=!e.editable;b.stopPropagation(),(y||r)&&(u(""),l.value="",x(!s.value),n.emit("clear"))}function d(b){if(c.value){if(!a.value){x(!1);return}!e.disable&&!e.readonly&&x(!0)}}function C(b){c.value&&x(!1)}return{enableClearButton:c,showClearButton:s,onClearValue:m,onMouseEnterTextBox:d,onMouseLeaveTextBox:C}}function At(e,n,a,o,l){const i=t.computed(()=>e.popupOnInput),s=t.computed(()=>e.popupOnFocus),{shouldPopupContent:c,closeAllPopover:u}=l,f=t.ref(!1),x=t.computed(()=>e.enableTitle?a.value:""),m=t.computed(()=>(e.disable||e.readonly)&&!e.forcePlaceholder?"":e.placeholder),d=t.computed(()=>e.readonly||!e.editable),C=t.ref(!1),b=t.computed(()=>!e.disable&&C.value),y=t.computed(()=>({"text-left":e.textAlign==="left","text-center":e.textAlign==="center","text-right":e.textAlign==="right","form-control":!0,"f-utils-fill":!0})),r=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":b.value,"input-group--has-clear":e.enableClear&&f.value}));function h(T,O=!0){a.value=T,O&&(n.emit("change",T),n.emit("update:modelValue",T))}function v(T){c.value=!1,h(T,!0)}t.watch(()=>e.modelValue,T=>{a.value=T});function k(T){C.value=!1,n.emit("blur",T),T.stopPropagation()}function F(T){n.emit("click",T),u(),n.slots.default&&!e.disable&&!e.readonly&&e.popupOnClick&&l.togglePopup()}function p(T){!e.disable&&!e.readonly&&(C.value=!0,d.value||(n.emit("focus",T),s.value&&!c.value&&l.popup()))}function g(T){n.emit("input",T);const O=T.target.value;o.value=O,a.value!==O&&h(O,e.updateOn==="change"),i.value&&!c.value&&l.popup()}function w(T){T.target.tagName!=="INPUT"&&T.preventDefault(),T.stopPropagation()}function N(T){n.emit("keydown",T)}function j(T){T.key==="Enter"&&(i.value||s.value)&&l.hidePopup(),n.emit("keyup",T)}function I(T){const O=T.target.value;T.stopPropagation(),h(O)}return{hasFocusedTextBox:b,isTextBoxReadonly:d,textBoxClass:y,textBoxPlaceholder:m,textBoxTitle:x,inputGroupClass:r,hasClearClass:f,changeTextBoxValue:h,commitValue:v,onBlurTextBox:k,onClickTextBox:F,onFocusTextBox:p,onInput:g,onKeyDownTextBox:N,onKeyUpTextBox:j,onMouseDownTextBox:w,onTextBoxValueChange:I}}const ae="FarrisVue_PopoverInstancesKey";function Ht(e,n,a,o){const l=t.ref(),i=t.ref(!1),{judgeCanOpen:s}=Ye(e,o);t.watch(()=>l.value,(C,b)=>{window[ae]=window[ae]||new WeakMap,C?window[ae].set(a.value,C):window[ae].delete(a.value)});function c(){if(window[ae]){const C=window[ae];document.querySelectorAll(".f-button-edit,.v-popover").forEach(b=>{const y=C.get(b);y&&b!==a.value&&!a.value.closest(".popover-fitcontent")&&y.hide()})}}function u(){const C=l.value;C&&C.show(a.value)}async function f(C=!1){if(!!n.slots.default){if(!C&&!i.value&&!await s())return;i.value=!i.value,i.value&&(await t.nextTick(),u())}}async function x(C=!1){if(!!n.slots.default){if(!C&&!await s())return;i.value=!0,await t.nextTick(),u()}}function m(){i.value=!1}function d(){i.value=!0,t.nextTick(()=>{u()})}return{hidePopup:m,showPopup:d,popup:x,shouldPopupContent:i,togglePopup:f,popoverRef:l,closeAllPopover:c}}function Wt(e,n,a){const o=t.ref(),{isTextBoxReadonly:l,textBoxClass:i,textBoxPlaceholder:s,textBoxTitle:c,onBlurTextBox:u,onClickTextBox:f,onFocusTextBox:x,onInput:m,onKeyDownTextBox:d,onKeyUpTextBox:C,onMouseDownTextBox:b,onTextBoxValueChange:y}=a,r=t.ref(e.id),{uuid:h}=Q.useGuid(),v=t.computed(()=>({}));t.onMounted(()=>{var w,N;e.selectOnCreated&&((w=o.value)==null||w.select()),e.focusOnCreated&&((N=o.value)==null||N.focus({preventScroll:!0})),r.value||(r.value="button-edit_"+h(8)),r.value=r.value+"-textbox"});const k=t.ref(!1),F=w=>{w.preventDefault(),k.value=!0},p=w=>{w.preventDefault(),k.value=!1,m(w)};function g(w){k.value||m(w)}return()=>t.createVNode("input",{id:e.id?e.id+"-textbox":void 0,ref:o,name:"input-group-value",autocomplete:e.autoComplete?"on":"off",class:i.value,style:v.value,disabled:e.disable,maxlength:e.maxLength,minlength:e.minLength,placeholder:s.value,readonly:l.value,tabindex:e.tabIndex,title:c.value,type:e.inputType,value:n.value,onBlur:u,onChange:y,onClick:f,onFocus:x,onInput:g,onKeydown:d,onKeyup:C,onMousedown:b,onCompositionend:p,onCompositionstart:F},null)}function qt(e,n,a){const o=t.ref(e.separator),l=t.computed(()=>e.readonly||e.disable),{changeTextBoxValue:i,onFocusTextBox:s,onBlurTextBox:c,onClickTextBox:u,textBoxPlaceholder:f}=a,x=t.computed(()=>n.value?n.value.split(o.value).map(b=>({name:b,selectable:!0})):[]);function m(b){i(b.map(y=>y.name).join(o.value),!0)}t.watch(()=>e.separator,b=>{o.value=b});const d=t.ref(!e.disable&&!e.readonly);t.watch([()=>e.disable,()=>e.readonly],([b,y],[r,h])=>{d.value=!b&&!y});function C(b){u(b)}return()=>t.createVNode(Ct,{tabindex:e.tabIndex,onFocus:s,onBlur:c,id:`${e.id}-tag-editor`,class:"form-control",placeholder:f.value,data:x.value,showClose:!l.value,showInput:!0,disable:l.value,onChange:m,onClick:C},null)}function Ut(e,n,a,o){const{buttonGroupClass:l,onClickButton:i,onMouseEnterButton:s,onMouseLeaveButton:c}=a,{enableClearButton:u,showClearButton:f,onClearValue:x}=o,m=t.ref(),d=J.debounce(b=>{i(b)},e.buttonBehavior==="Modal"?0:200),C=()=>{n.emit("beforeClearValue")};return{renderButtonGroup:()=>t.createVNode("div",{id:e.id?`${e.id}-button-group`:void 0,class:l.value},[u.value&&t.withDirectives(t.createVNode("span",{class:"input-group-text input-group-clear",onClick:x,onMousedown:C},[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:d,onMouseenter:s,onMouseleave:c},[n.slots.buttonContent()]):e.buttonContent?t.createVNode("span",{class:"input-group-text input-group-append-button",innerHTML:e.buttonContent,ref:m,onClick:b=>d(b),onMouseenter:s,onMouseleave:c},null):null]),buttonHandleElement:m}}function Yt(e,n,a){const o=t.ref(e.popupMinWidth),{hidePopup:l,popoverRef:i}=a,s=()=>{n.emit("shown")};return()=>t.createVNode(wt,{id:`${e.id}-popover`,ref:i,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:l,onShown:s,beforeClose:e.beforeClosePopup,limitContentBySpace:e.limitContentBySpace},{default:()=>{var c,u;return[(u=(c=n.slots).default)==null?void 0:u.call(c)]}})}const pe=t.defineComponent({name:"FButtonEdit",props:Nt,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),l=t.ref(e.modelValue),i=Ht(e,n,a,l),{shouldPopupContent:s,hidePopup:c,showPopup:u,togglePopup:f}=i,x=$t(e,n,a,i,l),m=t.ref(""),d=At(e,n,l,m,i),{hasFocusedTextBox:C,commitValue:b,inputGroupClass:y}=d,r=zt(e,n,l,C,m,d),{onMouseEnterTextBox:h,onMouseLeaveTextBox:v}=r,k=t.ref(!1),F=t.computed(()=>{const P={"f-button-edit":!0,"f-cmp-inputgroup":!0,"f-button-edit-nowrap":!e.wrapText};return o.value&&o.value.split(" ").reduce((z,B)=>(z[B]=!0,z),P),P}),p=t.computed(()=>({overflow:e.wrapText?"hidden":""})),g=t.computed(()=>({}));function w(){if(!e.multiSelect||e.inputType!=="tag"||!a.value)return 0;let P=0;const z=Array.from(a.value.querySelectorAll(".farris-tag-item"));return z&&z.length&&(P=z.map(B=>B.offsetTop).filter(B=>B>20).length),P}const N=t.ref(w());t.onUpdated(()=>{N.value=w()});function j(){return e.multiSelect&&e.inputType==="tag"?()=>t.createVNode(t.Fragment,null,[qt(e,l,d)(),!!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])])]):Wt(e,l,d)}let I=j();t.watch([()=>e.multiSelect,()=>e.inputType],()=>{I=j()});const{renderButtonGroup:T,buttonHandleElement:O}=Ut(e,n,x,r),S=Yt(e,n,i),E=t.ref(s.value),D={displayText:m,commitValue:b,elementRef:a,hidePopup:c,showPopup:u,popoverRef:i.popoverRef,shouldPopupContent:s,togglePopup:f,openDialog:()=>{O.value&&e.buttonBehavior==="Modal"&&O.value.click()},getModal:()=>{var P;return e.buttonBehavior==="Modal"?(P=x.modalRef.value)==null?void 0:P.value:null},getTextbox:()=>{var P;return(P=a.value)==null?void 0:P.querySelector("input")},forceClosePopup:()=>{E.value=!1,k.value=!0,s.value=!1}};return t.onMounted(()=>{a.value.componentInstance=D,window.onresize=()=>{document.body.click()}}),t.onBeforeUnmount(()=>{var P;window.onresize=null,(P=window[ae])==null||P.delete(a.value)}),n.expose(D),t.watch(()=>s.value,async(P,z)=>{if(k.value){E.value=P,k.value=!1;return}if(!P&&e.beforeClosePopup&&typeof e.beforeClosePopup=="function"){try{const B=await e.beforeClosePopup();E.value=!B,(!B||e.readonly)&&(s.value=!0)}catch(B){console.error("Error in beforeClosePopup:",B),E.value=z,s.value=z}return}E.value=P}),()=>{var P,z;return t.createVNode(t.Fragment,null,[t.createVNode("div",t.mergeProps(n.attrs,{ref:a,class:F.value,id:e.id?e.id:void 0,style:p.value}),[t.createVNode("div",{id:e.id?`${e.id}-input-group`:void 0,class:y.value,style:g.value,onMouseenter:h,onMouseleave:v},[(z=(P=n.slots).precontent)==null?void 0:z.call(P),I(),T()])]),E.value&&S()])}}}),Gt={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/field-selector.schema.json",title:"field-selector",description:"A Farris Input Component",type:"object",properties:{disabled:{description:"",type:"boolean",default:!1},readonly:{description:"",type:"boolean",default:!1},modelValue:{description:"",type:"string",default:""},repositoryToken:{description:"",type:"object",default:null},fields:{description:"",type:"array",default:null},editorParams:{type:"object",default:null},displayText:{description:"",type:"string",default:""},enableClear:{description:"",type:"boolean",default:!0},beforeOpen:{description:"",type:"function",default:null},onSubmitModal:{description:"",type:"function",default:null},editorType:{description:"",type:"string",default:"filter"},enableExpression:{description:"",type:"boolean",default:!1},expressionOptions:{description:"",type:"object",default:null},formContextData:{description:"",type:"object",default:{}},singleValue:{description:"",type:"boolean",default:!0},idField:{description:"",type:"string",default:"id"},textField:{type:"string",default:""},valueField:{type:"string",default:""},editable:{type:"boolean",default:!0},enableTitle:{type:"boolean",default:!0}}},ke={disabled:{type:Boolean,default:!1},readonly:{type:Boolean,default:!1},enableClear:{type:Boolean,default:!0},displayText:{type:String,default:""},enableExpression:{type:Boolean,default:!1},modelValue:{type:String,default:""},insertType:{type:String,default:"below"},fields:{type:Array,default:[]},repositoryToken:{type:Object,default:null},editorParams:{type:Object,default:null},onSubmitModal:{type:Function,default:null},beforeOpen:{type:Function,default:null},editorType:{type:String,default:"filter"},expressionOptions:{type:Object,default:null},formContextData:{type:Object,default:{}},singleValue:{type:Boolean,default:!0},idField:{type:String,default:"id"},textField:{type:String,default:""},valueField:{type:String,default:""},editable:{type:Boolean,default:!0},enableTitle:{type:Boolean,default:!0},disableConfirmWhenUnchanged:{type:Boolean,default:!1}},Ge=_.createPropsResolver(ke,Gt),Xe={conditions:{type:Array,default:[]},fields:{type:Array,default:[]},activeIndex:{type:Number,default:-1},formatter:{type:Function,default:(e,n)=>`${n.raw.name} [${n.raw.path}]`},enableExpression:{type:Boolean,default:!1},expressionOptions:{type:Object,default:null},formContextData:{type:Object,default:{}},singleValue:{type:Boolean,default:!0},idField:{type:String,default:"id"},textField:{type:String,default:""},valueField:{type:String,default:""}},Xt=new Map([["appearance",_.resolveAppearance]]),Kt={$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 Jt(e,n,a){return n}function _t(){function e(n,a,o){const l={};return l.beforeOpen=i=>a.call("beforeOpen",n,[i,n],o),l}return{resolve:e}}const Fe={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}},Zt=Object.assign({},Fe,{readonly:{}}),Ke=_.createPropsResolver(Fe,Kt,Xt,Jt),Qt=_t(),en={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}},tn=t.defineComponent({name:"FComboListContainer",props:en,emits:["selectionChange"],setup(e,n){const a=t.ref(),o=t.ref(e.dataSource),l=t.ref([]),i=t.ref(e.separator),s=t.ref(e.width),c=t.ref(e.maxHeight),u=t.computed(()=>e.multiSelect),f=t.ref(e.multiSelect?String(e.selectedValues).split(i.value):[e.selectedValues]),x=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 m=t.computed(()=>{const r={};return s.value!==void 0&&(r.width=`${s.value}px`),c.value!==void 0&&c.value>0&&(r.maxHeight=`${c.value}px`),r});function d(r){a.value.search(r)}function C(r){l.value=r.map(h=>Object.assign({},h)),f.value=r.map(h=>h[e.idField]),n.emit("selectionChange",l.value)}function b(r){if(e.enableHighlightSearch)return;let h=[];const{searchOption:v}=e;typeof v=="function"?h=o.value.filter(k=>v(r,k)):h=o.value.filter(k=>k[e.valueField].indexOf(r)>-1||k[e.textField].indexOf(r)>-1),a.value.updateDataSource(h)}t.watch([()=>e.selectedValues],([r])=>{e.multiSelect?f.value=r.split(i.value):f.value=[r]});function y(r){a.value.activeRowById(r)}return t.onMounted(()=>{var r,h;if(!e.multiSelect){const v=(r=f.value)==null?void 0:r[0];let k=v;const F=o.value.map(p=>p[e.valueField||e.idField]);if(!J.isUndefined(v)&&F.includes(v)){const p=typeof v,g=typeof((h=o.value[0])==null?void 0:h[e.valueField||e.idField]);g==="number"&&p!==g&&(k=Number(v)),g==="boolean"&&p!==g&&(k=v==="true"?!0:v==="false"?!1:v),y(k)}}}),n.expose({search:d,activeRowById:y}),()=>t.createVNode("div",{class:"f-combo-list-container",style:m.value},[t.createVNode(kt,{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:x.value,enableHighlightSearch:e.enableHighlightSearch,selectionValues:f.value,onSelectionUpdate:C,onAfterSearch:b},null)])}});function nn(e){const n=t.ref(""),a=t.ref(e.modelValue),o=t.ref(e.data||[]),l=t.ref(e.editable);function i(y){const r=e.multiSelect?String(y).split(e.separator):[String(y)],h=r.map(F=>[F,!0]),v=new Map(h);return o.value.filter(F=>v.has(String(F[e.valueField]))).sort((F,p)=>{const g=r.indexOf(F[e.valueField]),w=r.indexOf(p[e.valueField]);return g-w})}function s(y){const r=i(y).map(h=>h[e.textField]).join(e.separator);n.value=l.value?r||y:r}function c(y){if(e.multiSelect){const r=y.split(e.separator).map(v=>[v,!0]),h=new Map(r);return o.value.filter(v=>h.has(v[e.textField]))}return o.value.filter(r=>""+r[e.textField]===y)}function u(y){const r={};return r[e.idField]=y,r[e.textField]=y,[r]}function f(y){let r=c(y);const h=r&&r.length>0;return l.value&&!h&&(r=u(y)),r}function x(){const{url:y,method:r="GET",headers:h={"Content-Type":"application/json;charset=utf-8;"},body:v=null}=e.remote;if(!y)return;const k=r.toLowerCase()==="get"?{method:r,headers:h}:{method:r,headers:h,body:v};let F=!1;fetch(new Request(y,k)).then(p=>{var w,N;if(p.status===200)return F=!!((N=(w=p.headers)==null?void 0:w.get("content-type"))!=null&&N.includes("application/json")),F?p.text():p.json();throw p.status===405?new Error(q.LocaleService.getLocaleValue("comboList.remoteError")):new Error(p.statusText)}).then(p=>{p.length&&(o.value=F?JSON.parse(p):p)}).catch(p=>{console.warn(p)})}e.remote&&(e.load?e.load().then(y=>{o.value=y}).catch(y=>{console.log(y)}):x()),t.watch(()=>e.data,()=>{o.value=e.data}),t.watch([o],([y])=>{if(e.modelValue!=null){const r=y.find(h=>h[e.valueField]===e.modelValue);r&&(n.value=r[e.textField])}}),t.watch(()=>e.modelValue,y=>{a.value=y,s(y)});function m(y){o.value=y}function d(){return o.value}function C(){return n.value}function b(){const y=typeof e.beforeOpen=="function";return!e.beforeOpen||!y?Promise.resolve(!0):Promise.resolve().then(()=>e.beforeOpen({instance:{updateDataSource:m,getData:d,getDisplayText:C}})).then(r=>typeof(r==null?void 0:r.canOpen)=="boolean"?r==null?void 0:r.canOpen:!0)}return e.beforeOpen?b().then(y=>{y&&s(e.modelValue)}):s(e.modelValue),{dataSource:o,displayText:n,editable:l,modelValue:a,beforeOpenList:b,getItemsByDisplayText:c,getItemsByValue:i,getSelectedItemsByDisplayText:f}}const oe=t.defineComponent({name:"FComboList",props:Fe,emits:["clear","update:modelValue","change","input"],setup(e,n){const a=t.ref(),o=t.ref(),l=t.ref(e.disabled||e.readonly),i=t.ref(e.enableClear),s=t.ref(e.enableSearch),c=t.ref(e.readonly),{dataSource:u,displayText:f,editable:x,modelValue:m,getItemsByDisplayText:d,getItemsByValue:C,beforeOpenList:b}=nn(e),y=t.ref(e.dropDownIcon);y.value==='<span class="f-icon f-icon-arrow-chevron-down"></span>'&&(y.value='<span id="'+e.id+'-icon-dropdown" class="f-icon f-icon-arrow-chevron-down"></span>');const r=t.computed(()=>e.multiSelect),h=t.computed(()=>o.value?o.value.elementRef.getBoundingClientRect().width:0);function v(){!r.value&&o.value&&o.value.hidePopup()}function k(D){f.value=D.map(z=>z[e.textField]).join(e.separator);let P="";D.length===1?P=D[0][e.valueField]:P=D.map(z=>z[e.valueField]).join(e.separator),m.value!==P&&(m.value=P,n.emit("update:modelValue",m.value),n.emit("change",D,m.value))}function F(){const D=C(m.value);k(D)}function p(){c.value||f.value}function g(D){var P;m.value="",(P=a.value)==null||P.activeRowById(""),n.emit("update:modelValue",""),n.emit("change",[],""),n.emit("clear")}function w(D){var P,z;e.enableSearch&&e.enableHighlightSearch&&((P=a.value)==null||P.search(D)),(z=a.value)==null||z.activeRowById(D),n.emit("change",[m.value],m.value)}function N(D){if(e.multiSelect){const P=d(D);e.viewType;const B=P.map(M=>M[e.idField||e.valueField]).join(e.separator);m.value!==B&&(m.value=B,n.emit("update:modelValue",m.value),n.emit("change",P,m.value))}}function j(){return f.value}function I(D){const{value:P}=D.target;w(P),n.emit("input",P)}function T(){o.value.hidePopup()}function O(D){u.value=D}function S(){return u.value}const E={getDisplayText:j,hidePopup:T,updateDataSource:O,getData:S};return n.expose(E),t.watch([()=>e.disabled,()=>e.editable,()=>e.enableClear,()=>e.enableSearch,()=>e.readonly],([D,P,z,B,M])=>{l.value=D,x.value=P,i.value=z,s.value=B,c.value=M}),()=>t.createVNode(me,{ref:o,id:e.id,disable:l.value,readonly:c.value,forcePlaceholder:e.forcePlaceholder,editable:x.value,buttonContent:y.value,placeholder:e.placeholder==="请选择"?q.LocaleService.getLocaleValue("comboList.placeholder"):e.placeholder,enableClear:i.value,maxLength:e.maxLength,tabIndex:e.tabIndex,enableTitle:e.enableTitle,multiSelect:e.multiSelect,inputType:e.multiSelect?e.viewType:"text",modelValue:f.value,"onUpdate:modelValue":D=>f.value=D,focusOnCreated:e.focusOnCreated,selectOnCreated:e.selectOnCreated,onClear:g,onClick:p,onChange:N,onBlur:F,onInput:I,beforeOpen:b,placement:e.placement,popupMinWidth:e.minPanelWidth,popupClass:"f-combo-list-wrapper",popupOnClick:e.popupOnClick,limitContentBySpace:!0},{default:()=>[t.createVNode(tn,{ref:a,idField:e.idField,valueField:e.valueField,textField:e.textField,titleField:e.titleField,dataSource:u.value,selectedValues:m.value,separator:e.separator,multiSelect:e.multiSelect,enableSearch:s.value,maxHeight:e.maxHeight,enableHighlightSearch:e.enableHighlightSearch,width:e.fitEditor?h.value:void 0,onSelectionChange:D=>{k(D),v()}},null)]})}}),Je={convertFrom:(e,n)=>(e.editor.remote||{})[n],convertTo:(e,n,a)=>{e.editor.remote=e.editor.remote||{},e.editor.remote[n]=a}};class an extends xt.InputBaseProperty{constructor(n,a){super(n,a)}getCommonEditorProperties(n){var a,o,l;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)&&((l=n.editor)==null?void 0:l.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 i,s;const a=this;let o="";if(((i=n==null?void 0:n.binding)==null?void 0:i.type)==="Form"){const c=this.schemaService.getFieldByIDAndVMID(n.binding.field,this.viewModelId);(s=c==null?void 0:c.schemaField)!=null&&s.type&&(o=c.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:Je,description:"",title:"服务端API",type:"string"},body:{visible:!1,$converter:Je,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)},(c,u)=>{if(!c||!u.editor)return;const f=this;switch(c.propertyID){case"dataSourceType":{c.propertyValue==="static"?(u.editor.valueField="value",u.editor.textField="name",u.editor.remote=null):c.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=[...c.propertyValue]);break}case"viewType":c.propertyValue==="tag"&&(u.editor.editable=!1)}})}getGridFieldEdtiorProperties(n,a){var s,c,u,f,x,m;const o=this;let l="";if(((s=n==null?void 0:n.binding)==null?void 0:s.type)==="Form"){const d=this.schemaService.getFieldByIDAndVMID(n.binding.field,this.viewModelId);(c=d==null?void 0:d.schemaField)!=null&&c.type&&(l=d.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,(x=n.editor)==null?void 0:x.valueField,(m=n.editor)==null?void 0:m.textField),refreshPanelAfterChanged:!0},textField:{description:"",title:"数据源显示字段",type:"string",readonly:!0},valueField:{description:"",title:"数据源值字段",type:"string",readonly:!0},multiSelect:{description:"",title:"启用多选",visible:l==="StringType",type:"boolean",refreshPanelAfterChanged:!0},maxLength:{description:"",title:"最大输入长度",type:"number",editor:{nullable:!0,min:0,useThousands:!1,needValid:!0}},...this.getCommonEditorProperties(n)},(d,C)=>{if(!d||!C.editor)return;const b=this;switch(d.propertyID){case"dataSourceType":{d.propertyValue==="static"?(C.editor.valueField="value",C.editor.textField="name",C.editor.remote=null):d.propertyValue==="dynamic"&&(C.editor.remote={method:"GET"},C.editor.valueField="value",C.editor.textField="name");break}case"data":{!b.checkEnumDataReadonly(C)&&C.formatter&&(C.formatter.data=[...d.propertyValue]);break}}})}setEditorPropertyRelates(n,a,o){if(!n||!a.editor)return;const l=this;switch(n.propertyID){case"dataSourceType":{n.propertyValue==="static"&&(a.editor.valueField="value",a.editor.textField="name",a.editor.remote={});break}case"data":{!l.checkEnumDataReadonly(a)&&a.formatter&&(a.formatter.data=[...n.propertyValue]);break}}}changeBindingField(n,a,o){var i;super.changeBindingField(n,a);const l=o;n.editor&&((i=l==null?void 0:l.type)==null?void 0:i.$type)===Q.FormSchemaEntityFieldType$Type.EnumType&&(n.editor.data=l.type.enumValues||[])}getEventPropertyConfig(n,a="card",o,l){const i=this;let s=[{label:"onChange",name:"值变化事件"},{label:"beforeOpen",name:"下拉面板前事件"}];o&&(s=s.concat(o)),this.appendFieldValueChangeEvents(n,s);const c=i.eventsEditorUtils.formProperties(n,i.viewModelId,s);return{title:"事件",hideTitle:!0,properties:i.createBaseEventProperty(c),tabId:"commands",tabName:"交互",setPropertyRelates(x,m){const d=x.propertyValue;delete n[i.viewModelId],d&&(d.setPropertyRelates=this.setPropertyRelates,i.eventsEditorUtils.saveRelatedParameters(n,i.viewModelId,d.events,d)),l&&l(x,m,d);const C=i.designViewModelUtils.getDgViewModel(i.viewModelId);C&&i.designViewModelField&&C.changeField(i.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 on(e,n){const a=e.schema;function o(l,i){return new an(l,n).getPropertyConfig(a,i)}return{getPropsConfig:o}}const ln=t.defineComponent({name:"FComboListDesign",props:Zt,emits:["clear","update:modelValue","change"],setup(e,n){const a=t.ref(),o=t.inject("designer-host-service"),l=t.inject("design-item-context"),i=on(l,o),s=ye.useDesignerComponent(a,l,i);return t.onMounted(()=>{a.value.componentInstance=s}),n.expose(s.value),()=>t.createVNode(Ft,{ref:a,buttonContent:e.dropDownIcon,readonly:!0,editable:!1,forcePlaceholder:!0,placeholder:e.placeholder,enableClear:!0},null)}});oe.register=(e,n,a,o)=>{e["combo-list"]=oe,n["combo-list"]=Ke,o["combo-list"]={callbackResolver:Qt}},oe.registerDesigner=(e,n,a)=>{e["combo-list"]=ln,n["combo-list"]=Ke},Q.withInstall(oe),Q.withInstall(pe);const rn={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=new Map([["appearance",_.resolveAppearance]]);function Ze(e,n,a){return n}const sn={$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"]},cn={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"}}}}},Te={customStyle:{type:String,defaut:""},customClass:{type:String,defaut:""}},Qe=_.createPropsResolver(Te,sn,_e,Ze,cn);function et(e){const n=t.ref(-1),a=t.ref(-1),o=t.ref(0),l=t.ref(0),i=t.ref(!1),s=t.ref(!1),c=t.computed(()=>({display:i.value?"block":"none",left:`${o.value}px`,cursor:"e-resize"})),u=t.computed(()=>({display:s.value?"block":"none",top:`${l.value}px`,cursor:"n-resize"})),f=t.computed(()=>{const r={display:s.value||i.value?"block":"none"};return l.value>0&&(r.cursor="n-resize"),r});function x(r,h,v,k){const F=e.value;if(F){const{left:p,right:g,width:w}=F.getBoundingClientRect();let N=r.clientX-p;k==="right"&&(N=g-r.clientX),N>h&&(N=h),N<v&&(N=v),k==="right"&&(N=w-N),o.value=N}}function m(r,h,v,k){const F=e.value;if(F){const{top:p,bottom:g,height:w}=F.getBoundingClientRect();let N=r.clientY-p;k==="bottom"&&(N=g-r.clientY),N>h&&(N=h),N<v&&(N=v),k==="bottom"&&(N=w-N),l.value=N}}function d(){const r=e.value;if(r){const{width:h,height:v}=r.getBoundingClientRect();return{width:h,height:v}}return null}function C(){const r=e.value;return r?Array.from(r.querySelectorAll("[data-position]")).reduce((h,v)=>{const k=v.getAttribute("data-position");return h=Object.assign(h,{[k]:v}),h},{}):null}function b(r,h){const v=d(),k=C();if(v&&k){const F=k==null?void 0:k.right,p=k==null?void 0:k.left;if(r==="left"&&p)return F?v.width-F.clientWidth-h:v.width-h;if(r==="right"&&F)return p?v.width-p.clientWidth-h:v.width-h}}function y(r,h){const v=d(),k=C();if(v&&k){const F=k==null?void 0:k.bottom,p=k==null?void 0:k.top;if(r==="top"&&p)return F?v.height-F.clientHeight-h:v.height-h;if(r==="bottom"&&F)return p?v.height-p.clientHeight-h:v.height-h}}return{horizontalResizeHandleStyle:c,verticalResizeHandleStyle:u,resizeOverlayStyle:f,showHorizontalResizeHandle:i,showVerticalResizeHandle:s,horizontalResizeBarPosition:n,verticalResizeBarPosition:a,verticalResizeHandleOffset:l,horizontalResizeHandleOffset:o,draggingHorizontalResizeHandle:x,draggingVerticalResizeHandle:m,getPanelMaxHeight:y,getPanelMaxWidth:b}}const ee=t.defineComponent({name:"FLayout",props:Te,emits:[],setup(e,n){const a=t.ref(),o=et(a),{horizontalResizeHandleStyle:l,verticalResizeHandleStyle:i,resizeOverlayStyle:s}=o;t.provide("layout",{useResizeHandleComposition:o});const c=t.computed(()=>{const f={"f-layout":!0};return Q.getCustomClass(f,e==null?void 0:e.customClass)}),u=t.computed(()=>{const f={};return Q.getCustomStyle(f,e==null?void 0:e.customStyle)});return()=>t.createVNode("div",{class:c.value,style:u.value,ref:a},[n.slots.default&&n.slots.default(),t.createVNode("div",{class:"f-layout-resize-overlay",style:s.value},null),t.createVNode("div",{class:"f-layout-horizontal-resize-proxy",style:l.value},null),t.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:i.value},null)])}}),un={$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"]},dn={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:"是否可见"}}}}},Se={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}},tt=_.createPropsResolver(Se,un,_e,Ze,dn);function nt(e,n,a,o,l){const{horizontalResizeBarPosition:i,horizontalResizeHandleOffset:s,showHorizontalResizeHandle:c,showVerticalResizeHandle:u,verticalResizeBarPosition:f,verticalResizeHandleOffset:x,draggingHorizontalResizeHandle:m,draggingVerticalResizeHandle:d,getPanelMaxHeight:C,getPanelMaxWidth:b}=l;let y="",r,h,v;function k(g){if((y==="left"||y==="right")&&h){const{left:w}=h.getBoundingClientRect(),{width:N}=r.getBoundingClientRect(),j=g.clientX-w;let I=y==="left"?(N||0)+(j-i.value):(N||0)-(j-i.value);I=a.value>0?Math.max(a.value,I):I;const T=b(y,a.value);T!=null&&(I=T>I?I:T),e.value=I}if((y==="top"||y==="bottom")&&h){const{top:w}=h.getBoundingClientRect(),{height:N}=r.getBoundingClientRect(),j=g.clientY-w;let I=y==="top"?(N||0)+(j-f.value):(N||0)-(j-f.value);I=o.value>0?Math.max(o.value,I):I;const T=C(y,o.value);T!=null&&(I=T>I?I:T),n.value=I}s.value=0,x.value=0,i.value=-1,f.value=-1,c.value=!1,u.value=!1,document.removeEventListener("mousemove",v),document.removeEventListener("mouseup",k),document.body.style.userSelect="",y="",r=null,h=null}function F(g,w,N){if(y=w,r=N,c.value=!0,h=g.composedPath().find(I=>(I.className||"").split(" ")[0]==="f-layout"),h){const{left:I}=h.getBoundingClientRect(),T=g.clientX-I;s.value=T,i.value=T;const O=b(y,a.value)||0;v=S=>m(S,O,a.value,y),document.addEventListener("mousemove",v),document.addEventListener("mouseup",k),document.body.style.userSelect="none"}}function p(g,w,N){if(y=w,r=N,u.value=!0,h=g.composedPath().find(I=>(I.className||"").split(" ")[0]==="f-layout"),h){const{top:I}=h.getBoundingClientRect();x.value=g.clientY-I,f.value=g.clientY-I;const T=C(y,o.value)||0;v=O=>d(O,T,o.value,y),document.addEventListener("mousemove",v),document.addEventListener("mouseup",k),document.body.style.userSelect="none"}}return{onClickHorizontalResizeBar:F,onClickVerticalResizeBar:p}}const Z=t.defineComponent({name:"FLayoutPane",props:Se,emits:[],setup(e,n){const a=t.ref(e.minHeight<=0?100:e.minHeight),o=t.ref(e.minWidth<=0?100:e.minWidth),l=t.ref(e.width<=0?100:e.width),i=t.ref(e.height<=0?100:e.height),s=t.ref(Math.max(a.value,i.value)),c=t.ref(Math.max(o.value,l.value)),u=t.ref(),f=t.ref(e.position),x=t.ref(e.resizable);t.watch(()=>e.resizable,p=>{x.value=p});const m=t.inject("layout"),{useResizeHandleComposition:d}=m,C=nt(c,s,o,a,d),{onClickHorizontalResizeBar:b,onClickVerticalResizeBar:y}=C,r=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"})),h=t.computed(()=>f.value!=="center"&&x.value);function v(p,g){(g==="left"||g==="right")&&b(p,g,u.value),(g==="top"||g==="bottom")&&y(p,g,u.value)}const k=t.computed(()=>{const p={"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,w)=>(g[w]=!0,g),p),p}),F=t.computed(()=>{const p={};return(c.value&&f.value==="left"||f.value==="right")&&(p.width=`${c.value}px`),(s.value&&f.value==="bottom"||f.value==="top")&&(p.height=`${s.value}px`),e.visible||(p.display="none"),p});return()=>t.createVNode("div",{ref:u,class:k.value,style:F.value,"data-position":f.value},[n.slots.default&&n.slots.default(),h.value&&t.createVNode("span",{class:r.value,onMousedown:p=>v(p,f.value)},null)])}});function fn(e,n){function a(){return!1}return{canAccepts:a}}const mn=t.defineComponent({name:"FLayoutDesign",props:Te,emits:[],setup(e,n){var x;const a=t.ref(),o=t.inject("design-item-context"),l=fn(o.schema,(x=o.parent)==null?void 0:x.schema),i=ye.useDesignerComponent(a,o,l);i.value.canNested=!1;const s=et(a),{horizontalResizeHandleStyle:c,verticalResizeHandleStyle:u,resizeOverlayStyle:f}=s;return t.provide("layout",{useResizeHandleComposition:s}),t.onMounted(()=>{a.value.componentInstance=i}),n.expose(i.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:c.value},null),t.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:u.value},null)])}});function yn(e,n){const a=e.schema;function o(i){return!!ye.useDragulaCommonRule().basalDragulaRuleForContainer(i)}function l(){const i=["f-layout-pane"];return(a.position==="left"||a.position==="right")&&i.push("f-page-content-nav"),a.position==="center"&&i.push("f-page-content-main"),i.join(" ")}return{canAccepts:o,getDesignerClass:l}}const pn=t.defineComponent({name:"FLayoutPaneDesign",props:Se,emits:[],setup(e,n){const a=t.ref(),o=t.ref();t.inject("designer-host-service");const l=t.inject("design-item-context"),i=yn(l),s=ye.useDesignerComponent(o,l,i);s.value.canNested=!1,s.value.canMove=!1,s.value.canDelete=!1,t.onMounted(()=>{o.value.componentInstance=s}),n.expose(s.value);const c=t.ref(Math.max(e.minHeight,e.height)),u=t.ref(Math.max(e.minWidth,e.width)),f=t.ref(e.minHeight),x=t.ref(e.minWidth),m=t.ref(e.position),d=t.inject("layout"),{useResizeHandleComposition:C}=d,b=nt(u,c,x,f,C),{onClickHorizontalResizeBar:y,onClickVerticalResizeBar:r}=b,h=t.computed(()=>({"f-layout-resize-bar":!0,"f-layout-resize-bar-e":m.value==="left","f-layout-resize-bar-n":m.value==="bottom","f-layout-resize-bar-s":m.value==="top","f-layout-resize-bar-w":m.value==="right"}));function v(p,g){(g==="left"||g==="right")&&y(p,g,a.value),(g==="top"||g==="bottom")&&r(p,g,a.value)}const k=t.computed(()=>{const p={"f-layout-pane":!0,"f-page-content-nav":m.value==="left"||m.value==="right","f-page-content-main":m.value==="center"};return e.customClass&&String(e.customClass).split(" ").reduce((g,w)=>(g[w]=!0,g),p),p}),F=t.computed(()=>{const p={flex:"1"};return(u.value&&m.value==="left"||m.value==="right")&&(p.width=`${u.value}px`),(c.value&&m.value==="bottom"||m.value==="top")&&(p.height=`${c.value}px`),p});return()=>t.createVNode("div",{ref:a,class:k.value,style:F.value},[t.createVNode("div",{ref:o,class:"drag-container","data-dragref":`${l.schema.id}-container`},[n.slots.default&&n.slots.default()]),t.createVNode("span",{class:h.value,onMousedown:p=>v(p,m.value)},null)])}});ee.install=e=>{e.component(ee.name,ee),e.component(Z.name,Z)},ee.register=(e,n,a,o)=>{e.layout=ee,n.layout=Qe,e["layout-pane"]=Z,n["layout-pane"]=tt},ee.registerDesigner=(e,n,a)=>{e.layout=mn,n.layout=Qe,e["layout-pane"]=pn,n["layout-pane"]=tt};const hn={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 gn(e,n,a){return n in e?Object.defineProperty(e,n,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[n]=a,e}function at(e,n){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);n&&(o=o.filter(function(l){return Object.getOwnPropertyDescriptor(e,l).enumerable})),a.push.apply(a,o)}return a}function ot(e){for(var n=1;n<arguments.length;n++){var a=arguments[n]!=null?arguments[n]:{};n%2?at(Object(a),!0).forEach(function(o){gn(e,o,a[o])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(a)):at(Object(a)).forEach(function(o){Object.defineProperty(e,o,Object.getOwnPropertyDescriptor(a,o))})}return e}function bn(e,n){if(e==null)return{};var a={},o=Object.keys(e),l,i;for(i=0;i<o.length;i++)l=o[i],!(n.indexOf(l)>=0)&&(a[l]=e[l]);return a}function vn(e,n){if(e==null)return{};var a=bn(e,n),o,l;if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(l=0;l<i.length;l++)o=i[l],!(n.indexOf(o)>=0)&&Object.prototype.propertyIsEnumerable.call(e,o)&&(a[o]=e[o])}return a}function xn(e,n){return Cn(e)||wn(e,n)||kn(e,n)||Fn()}function Cn(e){if(Array.isArray(e))return e}function wn(e,n){if(!(typeof Symbol>"u"||!(Symbol.iterator in Object(e)))){var a=[],o=!0,l=!1,i=void 0;try{for(var s=e[Symbol.iterator](),c;!(o=(c=s.next()).done)&&(a.push(c.value),!(n&&a.length===n));o=!0);}catch(u){l=!0,i=u}finally{try{!o&&s.return!=null&&s.return()}finally{if(l)throw i}}return a}}function kn(e,n){if(e){if(typeof e=="string")return lt(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 lt(e,n)}}function lt(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 Fn(){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 Tn(e,n,a){return n in e?Object.defineProperty(e,n,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[n]=a,e}function it(e,n){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);n&&(o=o.filter(function(l){return Object.getOwnPropertyDescriptor(e,l).enumerable})),a.push.apply(a,o)}return a}function rt(e){for(var n=1;n<arguments.length;n++){var a=arguments[n]!=null?arguments[n]:{};n%2?it(Object(a),!0).forEach(function(o){Tn(e,o,a[o])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(a)):it(Object(a)).forEach(function(o){Object.defineProperty(e,o,Object.getOwnPropertyDescriptor(a,o))})}return e}function Sn(){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(l,i){return i(l)},o)}}function ce(e){return function n(){for(var a=this,o=arguments.length,l=new Array(o),i=0;i<o;i++)l[i]=arguments[i];return l.length>=e.length?e.apply(this,l):function(){for(var s=arguments.length,c=new Array(s),u=0;u<s;u++)c[u]=arguments[u];return n.apply(a,[].concat(l,c))}}}function he(e){return{}.toString.call(e).includes("Object")}function Nn(e){return!Object.keys(e).length}function ue(e){return typeof e=="function"}function Vn(e,n){return Object.prototype.hasOwnProperty.call(e,n)}function Mn(e,n){return he(n)||te("changeType"),Object.keys(n).some(function(a){return!Vn(e,a)})&&te("changeField"),n}function Bn(e){ue(e)||te("selectorType")}function On(e){ue(e)||he(e)||te("handlerType"),he(e)&&Object.values(e).some(function(n){return!ue(n)})&&te("handlersType")}function En(e){e||te("initialIsRequired"),he(e)||te("initialType"),Nn(e)&&te("initialContent")}function Dn(e,n){throw new Error(e[n]||e.default)}var Pn={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"},te=ce(Dn)(Pn),ge={changes:Mn,selector:Bn,handler:On,initial:En};function In(e){var n=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};ge.initial(e),ge.handler(n);var a={current:e},o=ce(Ln)(a,n),l=ce(Rn)(a),i=ce(ge.changes)(e),s=ce(jn)(a);function c(){var f=arguments.length>0&&arguments[0]!==void 0?arguments[0]:function(x){return x};return ge.selector(f),f(a.current)}function u(f){Sn(o,l,i,s)(f)}return[c,u]}function jn(e,n){return ue(n)?n(e.current):n}function Rn(e,n){return e.current=rt(rt({},e.current),n),n}function Ln(e,n,a){return ue(n)?n(e.current):Object.keys(a).forEach(function(o){var l;return(l=n[o])===null||l===void 0?void 0:l.call(n,e.current[o])}),a}var $n={create:In},zn={paths:{vs:"https://cdn.jsdelivr.net/npm/monaco-editor@0.43.0/min/vs"}};function An(e){return function n(){for(var a=this,o=arguments.length,l=new Array(o),i=0;i<o;i++)l[i]=arguments[i];return l.length>=e.length?e.apply(this,l):function(){for(var s=arguments.length,c=new Array(s),u=0;u<s;u++)c[u]=arguments[u];return n.apply(a,[].concat(l,c))}}}function Hn(e){return{}.toString.call(e).includes("Object")}function Wn(e){return e||ct("configIsRequired"),Hn(e)||ct("configType"),e.urls?(qn(),{paths:{vs:e.urls.monacoBase}}):e}function qn(){console.warn(st.deprecation)}function Un(e,n){throw new Error(e[n]||e.default)}var st={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
- `},ct=An(Un)(st),Yn={config:Wn},Gn=function(){for(var n=arguments.length,a=new Array(n),o=0;o<n;o++)a[o]=arguments[o];return function(l){return a.reduceRight(function(i,s){return s(i)},l)}};function ut(e,n){return Object.keys(n).forEach(function(a){n[a]instanceof Object&&e[a]&&Object.assign(n[a],ut(e[a],n[a]))}),ot(ot({},e),n)}var Xn={type:"cancelation",msg:"operation is manually canceled"};function Ne(e){var n=!1,a=new Promise(function(o,l){e.then(function(i){return n?l(Xn):o(i)}),e.catch(l)});return a.cancel=function(){return n=!0},a}var Kn=$n.create({config:zn,isInitialized:!1,resolve:null,reject:null,monaco:null}),dt=xn(Kn,2),de=dt[0],be=dt[1];function Jn(e){var n=Yn.config(e),a=n.monaco,o=vn(n,["monaco"]);be(function(l){return{config:ut(l.config,o),monaco:a}})}function _n(){var e=de(function(n){var a=n.monaco,o=n.isInitialized,l=n.resolve;return{monaco:a,isInitialized:o,resolve:l}});if(!e.isInitialized){if(be({isInitialized:!0}),e.monaco)return e.resolve(e.monaco),Ne(Ve);if(window.monaco&&window.monaco.editor)return ft(window.monaco),e.resolve(window.monaco),Ne(Ve);Gn(Zn,ea)(ta)}return Ne(Ve)}function Zn(e){return document.body.appendChild(e)}function Qn(e){var n=document.createElement("script");return e&&(n.src=e),n}function ea(e){var n=de(function(o){var l=o.config,i=o.reject;return{config:l,reject:i}}),a=Qn("".concat(n.config.paths.vs,"/loader.js"));return a.onload=function(){return e()},a.onerror=n.reject,a}function ta(){var e=de(function(a){var o=a.config,l=a.resolve,i=a.reject;return{config:o,resolve:l,reject:i}}),n=window.require;n.config(e.config),n(["vs/editor/editor.main"],function(a){ft(a),e.resolve(a)},function(a){e.reject(a)})}function ft(e){de().monaco||be({monaco:e})}function na(){return de(function(e){var n=e.monaco;return n})}var Ve=new Promise(function(e,n){return be({resolve:e,reject:n})}),Me={config:Jn,init:_n,__getMonacoInstance:na};const aa=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 l=null;const i=t.ref(e.modelValue);async function s(){return fetch(e.configPath).then(b=>b.json())}async function c(){if(a.value&&!l){const b=await s(),{vsPath:y}=b;Me.config({paths:{vs:window.location.origin+y}}),Me.config({"vs/nls":{availableLanguages:{"*":"zh-cn"}}}),Me.init().then(r=>{o.value=r,l=r.editor.create(a.value,{value:i.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,b=>{i.value=b,l==null||l.setValue(b)});const u=t.ref(),f=new ResizeObserver(b=>{l==null||l.layout();const{width:y,height:r}=b[0].contentRect;u.value={width:`${y-1}px`,height:`${r}px`}});function x(){return l==null?void 0:l.getValue()}function m(b){const y=l.getSelection(),r=new o.value.Range(y.startLineNumber,y.startColumn,y.endLineNumber,y.endColumn);l.executeEdits("insert-text",[{range:r,text:b,forceMoveMarkers:!0}])}t.onMounted(()=>{c(),a.value&&f.observe(a.value.parentElement)}),t.onBeforeUnmount(()=>{l&&l.dispose(),f&&a.value&&(f.unobserve(a.value),f.disconnect())});function d(b){l.setValue(b)}function C(){d("")}return n.expose({getContent:x,insertText:m,clearText:C,setContent:d}),()=>t.createVNode("div",{class:"expression-code-editor",style:u.value,ref:a},null)}}),oa={dataSource:{type:Object,default:{}}},la={data:{type:Array,default:[]},idField:{type:String,default:"id"},textField:{type:String,default:"name"},formatter:{type:Function},customRowStatus:{type:Object,default:null}},ia=t.defineComponent({name:"FEntitiesTree",props:la,emits:["dblclickNode"],setup(e,n){const a=t.ref(e.data),o=t.ref(),l=t.ref();function i(){let m=0;return document.querySelectorAll(".entity-variable .fv-grid-hierarchy-cell").forEach(C=>{C.style.width="auto";const b=C.scrollWidth;b>m&&(m=b)}),m}t.watch(()=>e.data,m=>{var d;a.value=m,(d=o.value)==null||d.updateDataSource(m)});const s={customRowStatus:e.customRowStatus},c=t.computed(()=>[{field:e.textField,title:"",dataType:"string",formatter:e.formatter}]);function u({$event:m,node:d}){n.emit("dblclickNode",{$event:m,node:d})}function f(){const m=i();l.value={minWidth:`${m+10}px`}}function x({row:m}){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(Ae,{ref:o,fit:!1,rowNumber:{enable:!1},data:a.value,idField:e.idField,columns:c.value,rowOption:s,columnOption:{fitColumns:!0,fitMode:"percentage"},onDblclickNode:u,style:l.value,autoHeight:!0,onExpandNode:x},null)])}}),ra=t.defineComponent({name:"entity-variable",props:oa,emits:["variableItemDblClick","entityItemDblClick","fieldClick"],setup(e,n){const a=t.ref("dataEntity"),o=t.ref(e.dataSource),{entities:l,variables:i}=o.value,s=t.ref(""),c=t.ref((l==null?void 0:l.fields)||[]),u=(S,E)=>{S.stopPropagation(),n.emit("fieldClick",{$event:S,item:E.raw})},f=(S,E)=>{const D=`${E.raw.name} [${E.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:D,class:"f-utils-fill text-truncate"},[D]),t.createVNode("button",{title:"插入属性名称",class:"btn btn-link d-none",style:"width:24px;height:24px",onClick:P=>u(P,E),onDblclick:P=>P.stopPropagation()},[t.createVNode("span",{class:"f-icon f-icon-new-edit",style:"font-size: 12px;"},null)])])},x=t.ref({}),m=t.ref(),d=t.computed(()=>S=>({"list-group d-flex flex-column":!0,"f-utils-fill":a.value===S,expand:a.value===S,collapse:a.value!==S})),C=t.computed(()=>S=>({"f-icon f-icon-arrow-chevron-up":a.value!==S,"f-icon f-icon-arrow-chevron-down":a.value===S})),b=t.computed(()=>S=>({"functions-type d-flex flex-column":!0,open:x.value[S],closed:!x.value[S]})),y=t.computed(()=>S=>({"f-icon f-icon-arrow-chevron-down":x.value[S],"f-icon f-icon-arrow-chevron-right":!x.value[S]})),r=t.computed(()=>S=>{var E;return{"functions-item pl-2":!0,selected:((E=m.value)==null?void 0:E.key)===S.key}});function h(S,E){S.stopPropagation(),x.value=x.value||{},x.value[E]=!x.value[E]}function v(S,E){S.stopPropagation(),m.value=E}function k(S,E){n.emit("variableItemDblClick",{$event:S,item:E})}function F({$event:S,node:E}){n.emit("entityItemDblClick",{$event:S,item:E.data,entityCode:l==null?void 0:l.entityCode,parentCodes:E.data.parents.join(".")})}function p(){return t.createVNode(ia,{data:c.value,formatter:f,onDblclickNode:F},null)}function g(){if(i)return t.createVNode("ul",{class:"w-100 functions-list"},[Object.keys(i).map(S=>i[S].visible&&t.createVNode("li",{"variable-type":S,class:b.value(S)},[t.createVNode("div",{class:"functions-type-name pl-2 d-flex align-items-center",onClick:E=>{h(E,S)}},[t.createVNode("span",{class:y.value(S)},null),i[S].name]),t.createVNode("ul",{class:"pl-3 mr-2"},[i[S].items.map(E=>t.createVNode("li",{class:r.value(E),onClick:D=>v(D,E),onDblclick:D=>k(D,E),title:`${E.name} [${E.key}]`},[E.name]))])]))])}function w(S,E){if(S.stopPropagation(),a.value===E){a.value="";return}a.value=E}t.onMounted(()=>{if(i){const S=Object.keys(i)[0];x.value[S]=!0}});function N(S,E){const D=S.children.map(z=>N(z,E)).filter(z=>z!==null);return S.data.name.toLowerCase().includes(E.toLowerCase())||S.data.bindingPath.toLowerCase().includes(E.toLowerCase())?{data:{...S.data},children:S.children}:D.length>0?{data:{...S.data},children:D}:null}function j(S,E){return S.map(D=>N(D,E)).filter(D=>D!==null)}function I(){const S=j((l==null?void 0:l.fields)||[],s.value);c.value=S}function T(){c.value=(l==null?void 0:l.fields)||[]}function O(S){S.key==="Enter"&&I()}return()=>t.createVNode("div",{class:"f-utils-fill entity-variable"},[t.createVNode("ul",{class:"d-flex flex-column h-100"},[t.createVNode("li",{class:d.value("dataEntity")},[t.createVNode("div",{class:"title px-2 d-flex align-items-center",onClick:S=>w(S,"dataEntity")},[t.createTextVNode("数据实体"),t.createVNode("span",{class:C.value("dataEntity")},null)]),t.createVNode("div",{class:"data-area f-utils-fill d-flex flex-column"},[t.createVNode("div",{class:"w-100"},[t.createVNode(me.FButtonEdit,{class:"m-2",buttonContent:'<i class="f-icon f-icon-search"></i>',enableClear:!0,popupOnClick:!0,placeholder:"请输入名称或编号,按回车查询",modelValue:s.value,"onUpdate:modelValue":S=>s.value=S,onClickButton:I,onClear:T,onKeyup:O},null)]),p()])]),t.createVNode("li",{class:d.value("variables")},[t.createVNode("div",{class:"title px-2 d-flex align-items-center",onClick:S=>w(S,"variables")},[t.createTextVNode("变量"),t.createVNode("span",{class:C.value("variables")},null)]),t.createVNode("div",{class:"data-area f-utils-fill"},[g()])])])])}}),sa={functionItems:{type:Array,default:[]},singleExpand:{type:Boolean,default:!0}},ca=t.defineComponent({name:"FExpressionEditor",props:sa,emits:["insertFunction","search"],setup(e,n){const a=t.ref(),o=t.ref(""),l=t.ref(),i=t.ref({}),s=t.ref(""),c="没有与搜索条件匹配的项",u=t.ref(e.functionItems),f=t.computed(()=>p=>e.singleExpand?{"functions-type d-flex flex-column":!0,open:o.value===p,closed:o.value!==p}:{"functions-type d-flex flex-column":!0,open:i.value[p],closed:!i.value[p]}),x=t.computed(()=>p=>e.singleExpand?{"f-icon f-icon-arrow-chevron-down":o.value===p,"f-icon f-icon-arrow-chevron-right":o.value!==p}:{"f-icon f-icon-arrow-chevron-down":i.value[p],"f-icon f-icon-arrow-chevron-right":!i.value[p]}),m=t.computed(()=>p=>{var g;return{"functions-item pl-2":!0,selected:((g=l.value)==null?void 0:g.key)===p.key}}),d=t.ref(Object.keys(u.value));t.watch(()=>e.functionItems,p=>{u.value=p,d.value=Object.keys(u.value),s.value&&(i.value=d.value.reduce((g,w)=>(g[w]=!0,g),{}))});function C(p){p||(p=o.value);const g=a.value.querySelector('li[function-type="'+p+'"] > div.functions-type-name');g&&(a.value.querySelector(".expression-left").scrollTop=0,g.scrollIntoViewIfNeeded?g.scrollIntoViewIfNeeded(!0):g.scrollIntoView({behavior:"smooth",block:"nearest"}))}function b(p){if(e.singleExpand){if(o.value===p){o.value="";return}o.value=p}else i.value=i.value||{},i.value[p]=!i.value[p]}function y(p,g){p.stopPropagation(),l.value=g}function r(p,g){p.stopPropagation(),n.emit("insertFunction",{$event:p,item:g})}t.watch(()=>o.value,(p,g,w)=>{if(p){const N=setTimeout(()=>{C(p)},200);w(()=>clearTimeout(N))}});function h(){n.emit("search",s.value)}function v(){n.emit("search","")}function k(p){p.key==="Enter"&&h()}function F(){return d.value.length?d.value.map(p=>t.createVNode("li",{"function-type":p,class:f.value(p)},[t.createVNode("div",{class:"functions-type-name pl-2 d-flex align-items-center",onClick:()=>{b(p)}},[t.createVNode("span",{class:x.value(p)},null),u.value[p].name]),t.createVNode("ul",{class:"pl-3 mr-2"},[u.value[p].items.map(g=>{if(g.visible!==!1)return t.createVNode("li",{class:m.value(g),onClick:w=>y(w,g),onDblclick:w=>r(w,g)},[p==="advanced"?g.key:g.name])})])])):t.createVNode("li",{class:"empty-message"},[c])}return t.onMounted(()=>{o.value=d.value[0],i.value=d.value.reduce((p,g)=>(p[g]=o.value===g,p),{})}),()=>t.createVNode("div",{class:"d-flex f-utils-fill flex-column",ref:a},[t.createVNode(ee,{class:"flex-column expression-left"},{default:()=>[t.createVNode(Z,{position:"top",minHeight:50,height:50,"custom-class":"position-relative d-flex align-items-center search-bar",resizable:!1},{default:()=>[t.createVNode(me.FButtonEdit,{class:"w-100 mx-2",buttonContent:'<i class="f-icon f-icon-search"></i>',enableClear:!0,popupOnClick:!0,placeholder:"请输入函数名称,按回车查询",modelValue:s.value,"onUpdate:modelValue":p=>s.value=p,onClickButton:h,onClear:v,onKeyup:k},null)]}),t.createVNode(Z,{position:"center","custom-class":"layout-border"},{default:()=>[t.createVNode("ul",{class:"w-100 functions-list",style:"user-select: none"},[F()])]}),t.createVNode(Z,{"custom-class":"position-relative",position:"bottom",minHeight:80},{default:()=>{var p;return[t.createVNode("textarea",{title:"函数说明",class:"h-100 w-100 function-remark p-1",disabled:!0},[(p=l.value)==null?void 0:p.description])]}})]})])}});function ua(e){async function n(){return fetch(e.esprimaPath).then(s=>s.json())}async function a(){if(window.esprima==null){const s=await n(),{path:c}=s;return new Promise((u,f)=>{const x=document.createElement("script");x.type="text/javascript",x.src=c+"?v="+Date.now(),x.onload=u,x.onerror=f,document.head.appendChild(x)})}}function o(s){const c=[],u=window.esprima.tokenize(s);for(let d=0;d<u.length;d++)c.push(u[d].value);const f=[];for(let d=0;d<c.length;d++){const C=s.indexOf(c[d]);C!==-1?f.push(s.substring(0,C)):f.push(""),s=s.slice(C+c[d].length),d===c.length-1&&f.push(s)}const x=[],m=c.length;for(let d=0;d<m;d++)f[d]!==""&&x.push(f[d]),c[d]!==""&&x.push(c[d]),d===m-1&&f[d+1]!==""&&x.push(f[d+1]);return x}function l(s,c="key2name"){const u=new Map;if(!s)return u;let x=Object.values(s).map(m=>m.items).flat();for(;x.length>0;){const m=x.filter(d=>d.name===x[0].name);m.length>1?x.filter(d=>d.name===x[0].name).forEach(d=>{c==="key2name"?u.set(d.key,d.key+"_"+d.name):c==="name2key"&&u.set(d.key+"_"+d.name,d.key)}):c==="key2name"?u.set(m[0].key,m[0].name):c==="name2key"&&u.set(m[0].name,m[0].key),x=x.filter(d=>d.name!==x[0].name)}return u}a();async function i(s){return window.esprima?s():await a().then(()=>s())}return{loadEsprima:a,getTokens:o,getVariableMaps:l,runWithEsprima:i}}function da(e,n,a){const o=t.ref(e.disabledFunctions),{getTokens:l,getVariableMaps:i,runWithEsprima:s}=ua(e);function c(){const r=J.cloneDeep(n);if(o.value){let h=Object.keys(r);const{types:v,functions:k}=o.value;return v&&v.length&&(h=h.filter(F=>v.includes(F))),k&&k.length&&Object.values(r).forEach(F=>{F.items.forEach(p=>{k.includes(p.name)&&(p.visible=!1)})}),r}return r}function u(r){const h=n.analytical.items.find(v=>v.key==="GetContextParameter");if(h)return h.name+'("'+r.name+'")'}function f(r){if(!r||r.length===0)return"";const h=v=>{switch(v.type){case"string":return`"${v.name}"`;case"list":return`[${v.name}]`;default:return v.name}};return r.map(h).join(",")}function x(r){let h=r.name;return r.type.toLowerCase()!=="advanced"&&(h+="("+f(r.params)+")"),h}function m(r){return r==null?void 0:r.bindingPath}function d(r){if(!r)return"";const h=l(r),v=i(a,"name2key");for(let F=0;F<h.length;F++){let p=0;if(p===0&&v&&h[F].length>2&&h[F][0]==='"'&&h[F][h[F].length-1]==='"'){const g=h[F].substring(1,h[F].length-1);if(v.has(g)&&h[F-1]==="("&&h[F+1]===")"){const w=v.get(g);w!==void 0&&(h[F]=`"${w}"`,p=1)}}if(p===0){const g=Object.values(n).map(w=>w.items).flat();for(let w=0;w<g.length;w++)if(h[F]===g[w].name){h[F]=g[w].keyFront+"."+g[w].key,p=1;break}}}const k=h.join("");return JSON.stringify({expr:k,sexpr:""})}function C(r,h,v,k){let F="";const p=[];for(const g of h)g.keyFront==="Math"&&p.push(g.key);for(let g=0;g<r.length;g++){if(r[g]==="Math"&&r[g+1]==="."&&!p.includes(r[g+2])){F=F+r[g]+r[g+1]+r[g+2],g=g+2;continue}if(k.includes(r[g])&&r[g+1]==="."){g=g+1;continue}else{let w=0;if(w===0&&r[g].length>2&&r[g][0]==='"'&&r[g][r[g].length-1]==='"'){const N=r[g].substring(1,r[g].length-1);if(v.has(N)&&r[g-1]==="("&&r[g+1]===")"){const j=v.get(N);j!==void 0&&(F=F+`"${j}"`,w=1)}}if(w===0){for(let N=0;N<h.length;N++)if(r[g]===h[N].key&&h[N].type.toLowerCase()!=="advanced"){F=F+h[N].name,w=1;break}}w===0&&(F=F+r[g])}}return F}function b(r){if(!r)return"";const h=l(r),v=i(a,"key2name"),k=Object.values(n).map(p=>p.items).flat();return C(h,k,v,["DefaultFunction","Math","DefaultExtendFunctionProxy"])}async function y(r){return await s(()=>b(r))}return{resetFunctionItems:c,getFieldExpression:m,getFunctionExpression:x,getContextVariableExpression:u,getExpressionCodeValue:d,getExpressionTextValue:y}}function fa(e,n){const a=t.ref([]),o=J.cloneDeep(n.value),l=Object.values(o).map(c=>c.items).flat();function i(c){const u=J.cloneDeep(o);return Object.keys(u).forEach(f=>{const x=u[f].items.filter(m=>c.includes(m.key));x.length>0?u[f].items=x:delete u[f]}),u}function s(c){if(!c){n.value=o;return}const u=l.filter(f=>f.name.toLowerCase().includes(c.toLowerCase())).map(f=>f.key);n.value=i(u)}return{searchResultList:a,filterFunctions:i,onFunctionSearch:s}}const ma=t.defineComponent({name:"FExpressionEditor",props:rn,emits:[],setup(e,n){var T;const a=t.ref(),o=t.ref(e.validateMessage),l=t.ref(e.messageType),i=t.ref(e.modelValue),s=t.ref(),c=[{label:"提示",value:"info"},{label:"警告",value:"warning"},{label:"错误",value:"error"}],{getFunctionExpression:u,getContextVariableExpression:f,resetFunctionItems:x,getFieldExpression:m,getExpressionCodeValue:d,getExpressionTextValue:C}=da(e,hn,e.variables),b=t.ref(x()),{onFunctionSearch:y}=fa(e,b);function r({$event:O,item:S}){var D;const E=u(S);(D=s.value)==null||D.insertText(E)}function h({$event:O,item:S}){var D;const E=f(S);(D=s.value)==null||D.insertText(E)}function v(O){return O.reduce((S,E)=>{var D;return S.push(E.data),(D=E.children)!=null&&D.length&&S.push(...v(E.children)),S},[])}const k=v(((T=e==null?void 0:e.entities)==null?void 0:T.fields)||[]);function F(O){return O.map(S=>{const E=k.find(D=>D.bindingPath===S);return E&&E.type==="entity"?`${S}[0]`:S}).join(".")}function p({$event:O,item:S,parentCodes:E,entityCode:D}){var B;const P=m(S);E=e.isServerSide?F(S.parents):E;let z=`${E}.${P}`;D===P&&(z=P),(B=s.value)==null||B.insertText(`${z}`)}function g({$event:O,item:S}){var D;const E=m(S);(D=s.value)==null||D.insertText(`${E}`)}function w(){var O;return(O=s.value)==null?void 0:O.getContent()}function N(){var S;const O=(S=s.value)==null?void 0:S.getContent();return{value:d(O),message:o.value,messageType:l.value}}const j=t.ref("");function I(){var O;(O=s.value)==null||O.clearText()}return t.onMounted(async()=>{if(i.value){const O=JSON.parse(i.value),{expr:S}=O;S&&(j.value=await C(S)||"")}}),n.expose({getExpressionContext:w,getExpressionValue:N,resetExpression:I}),()=>t.createVNode("div",{ref:a,class:"h-100 d-flex flex-column f-utils-fill mx-3 expression-editor"},[t.createVNode(ee,null,{default:()=>[t.createVNode(Z,{position:"left",width:248,minWidth:130},{default:()=>[t.createVNode(ca,{functionItems:b.value,singleExpand:e.singleExpand,onInsertFunction:r,onSearch:y},null)]}),t.createVNode(Z,{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(aa,{modelValue:j.value,"onUpdate:modelValue":O=>j.value=O,ref:s},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(oe,{style:"width: 75px",data:c,modelValue:l.value,"onUpdate:modelValue":O=>l.value=O,textField:"label",valueField:"value",idField:"value",enableClear:!1,minPanelWidth:130,placement:"auto"},null)]),t.withDirectives(t.createVNode("textarea",{"onUpdate:modelValue":O=>o.value=O,class:"form-control",style:"resize:none;border:none;outline:1px solid var(--f-neutral-04);"},null),[[t.vModelText,o.value]])])]}),e.showDataPanel&&t.createVNode(Z,{position:"right",width:258,minWidth:130},{default:()=>[t.createVNode(ra,{dataSource:{entities:e.entities,variables:e.variables},onVariableItemDblClick:h,onEntityItemDblClick:p,onFieldClick:g},null)]})]})])}}),ya={$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"]},mt={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}};_.createPropsResolver(mt,ya);const pa={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}},ha={showCloseButton:{type:Boolean,default:!0},animate:{type:String,default:"fadeIn"},options:{type:Object}},Be=t.defineComponent({name:"Toast",props:ha,emits:["close","click"],setup:(e,n)=>{const a=t.ref(e.animate),o="fadeOut",l=t.computed(()=>e.options),i=t.ref(!1),s=t.computed(()=>l.value.title&&l.value.message),c=t.computed(()=>!l.value.title&&l.value.message),u=t.computed(()=>{const v={animated:i.value,toast:!0,"toast--only-content":!s.value};return v[e.animate]=!1,v[o]=i.value,v["toasty-type-"+l.value.type]=!0,l.value.theme&&(v[l.value.theme]=!0),v}),f=t.computed(()=>{const F=`f-icon-${l.value&&l.value.type?l.value.type.replace("toasty-type-",""):"default"}`,p={"f-icon":!0};return p[F]=!0,p}),x=t.computed(()=>l.value.title||l.value.message),m=t.computed(()=>e.showCloseButton),d=t.computed(()=>!!l.value.buttons||!!n.slots.default),C=t.computed(()=>q.LocaleService.getLocale()==="en"?{wordBreak:"keep-all",overflowWrap:"break-word"}:{});function b(v){v.stopPropagation(),v.preventDefault(),i.value=!1,setTimeout(()=>{n.emit("close",l.value)},200)}function y(v,k){}function r(v){return`f-preten-link ${v.customClass?v.customClass:""}`}t.watch(a,()=>{a.value});const h=()=>{var v;return t.createVNode(t.Fragment,null,[t.createVNode("div",{class:"after-toast-msg text-right"},[!n.slots.default&&((v=l.value.buttons)==null?void 0:v.map(k=>t.createVNode("span",{class:r(k),onClick:F=>void 0},[k.text]))),n.slots.default&&n.slots.default()])])};return()=>t.createVNode("div",{class:u.value,style:"min-height:44px"},[m.value&&t.createVNode("button",{title:q.LocaleService.getLocaleValue("messageBox.close"),class:"toast-close f-btn-icon f-bare",onClick:b},[t.createVNode("span",{class:"f-icon modal_close"},null)]),x.value&&t.createVNode("section",{class:"modal-tips"},[!s.value&&t.createVNode("div",{class:"float-left modal-tips-iconwrap"},[t.createVNode("span",{class:f.value},null)]),t.createVNode("div",{class:"modal-tips-content"},[s.value&&t.createVNode(t.Fragment,null,[t.createVNode("h5",{class:"toast-title modal-tips-title",innerHTML:l.value.title},null),t.createVNode("p",{class:"toast-msg",innerHTML:l.value.message,style:C.value},null),d.value&&h()]),c.value&&(l.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:C.value,innerHTML:l.value.message},null),t.createVNode("div",{class:"after-toast-title text-right ml-auto"},[h()])]):t.createVNode("h5",{class:"toast-title modal-tips-title only-toast-msg",style:C.value,innerHTML:l.value.message},null))])])])}}),ve=t.defineComponent({name:"Notify",props:pa,emits:["close","empty"],setup(e,n){const a=t.computed(()=>({"farris-notify":!0})),o={left:12,right:12,top:20,bottom:12},l=t.ref(),i=t.ref(e.options),s=t.ref(e.showCloseButton),c=t.computed(()=>e.position||"bottom-right"),u=t.computed(()=>e.timeout!=null?e.timeout:3e3),f=t.computed(()=>{const d=e.bottom?e.bottom:o.bottom,C=e.top?e.top:o.top,b={transition:"all 0.2s ease",left:c.value.indexOf("left")>-1?`${e.left?e.left:o.left}px`:"",right:c.value.indexOf("right")>-1?`${e.right?e.right:o.right}px`:"",top:c.value.indexOf("top")>-1?`${C}px`:"",bottom:c.value.indexOf("bottom")>-1?`${d}px`:""};return c.value.indexOf("center")>-1&&(b.left="50%",b.marginLeft="calc(-24rem / 2)",c.value==="center-center"&&(b.top="50%",b.transform="translate(-50%, -50%)")),b});function x(d){n.emit("close")}u.value&&setTimeout(()=>{x()},u.value),n.expose({closeToast:x,container:l,notifyPosition:c});function m(d,C){x()}return()=>t.createVNode("div",{class:a.value,style:f.value,ref:l},[t.createVNode(Be,{options:i.value,showCloseButton:s.value,animate:e.animate,onClose:d=>m(d,i.value)},null)])}});class ga{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,l=Object.assign({timeout:3e3,position:"bottom-right",showCloseButton:!0,safeHtml:!0},this.globalConfig,{...n}),i=document.createElement("div");i.style.display="contents";const s=t.createApp({setup(){var f;const c=t.ref();function u(){c.value.container.style.transform="scale(0)",setTimeout(()=>{a.updateNotifyPositionForClose(l,c),s.unmount()},220)}if(l.position.indexOf("top")>-1){const x=a.getNotifyInstances(l.position),m=x[x.length-1];if(m){const d=m.value.container.getBoundingClientRect();l.top=d.bottom}}return l.safeHtml&&((f=l.options)!=null&&f.message)&&(l.options.message=a.escapeAllHtml(l.options.message)),t.onUnmounted(()=>{document.body.removeChild(i)}),t.onMounted(()=>{a.updateNotifyPositionForCreate(l,c)}),()=>t.createVNode(t.Transition,{mode:"out-in",name:"fade",appear:!0},{default:()=>[t.createVNode(ve,t.mergeProps({ref:c},l,{onClose:u}),null)]})}});return s.provide("NotifyService",this),document.body.appendChild(i),s.use(q.LocaleService.i18n),s.mount(i),s}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(l=>{const i=l.value.container.getBoundingClientRect();l.value.container.style.bottom=i.height+o-i.bottom+"px"})}this.notifyRefs=[...this.notifyRefs,a]}updateNotifyPositionForClose(n,a){const o=this.notifyRefs.indexOf(a);if(n.position.indexOf("top")>-1){const l=this.getNotifyInstances(n.position),i=l.indexOf(a);l.slice(i+1).forEach(s=>{s.value.container.style.top=s.value.container.offsetTop-s.value.container.offsetHeight+"px"})}o>-1&&this.notifyRefs.splice(o,1)}show(n){return this.createNotifyInstance(n)}buildNotifyProps(n,a){let o="",l="",i,s,c;typeof a=="string"?o=a:a&&(o=a.message||"",l=a.title||"",s=a.position||null,c=a.showCloseButton!=null?a.showCloseButton:null,i=a.timeout!=null?a.timeout:null);const f={options:{type:n,message:o,title:l}};return s!=null&&(f.position=s),c!=null&&(f.showCloseButton=c),i!=null&&(f.timeout=i),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 Oe=Symbol("NOTIFY_SERVICE_TOKEN");ve.install=e=>{e.component(ve.name,ve),e.component(Be.name,Be);const n=new ga;e.provide(Oe,n),e.provide("FNotifyService",n)};const ba=t.defineComponent({name:"f-expression-textbox",props:mt,setup(e,n){const a=t.inject(Oe),o=t.inject("FLoadingService"),l='<i class="f-icon f-icon-lookup"></i>',i=t.ref(e.modelValue),s=t.ref(e.entities),c=t.ref(e.variables),u=t.ref(),f=t.ref(e.validateMessage||""),x=t.ref("info");async function m(){const{value:y,message:r,messageType:h}=u.value.getExpressionValue();if(f.value=r,x.value=h,e.beforeSubmit&&typeof e.beforeSubmit=="function"){const v=await e.beforeSubmit({notifyService:a,expressionValue:y});if(typeof v=="boolean"&&!v)return!1;if(typeof v=="object"){const{canClose:k,message:F}=v;if(!k)return F&&(a==null||a.error({message:F})),!1}}if(n.emit("update:modelValue",y),i.value=y,e.onSubmitModal){const v={expression:y,message:r};e.showMessageType&&(v.messageType=x.value);const k=e.onSubmitModal(v);e.onExpressionChanged&&e.onExpressionChanged(k)}return!0}const d={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:y=>{var r;return(r=u.value)==null||r.resetExpression(),!1}},{name:"cancel",text:"取消",class:"btn btn-secondary",handle:y=>!0},{name:"accept",text:"确定",class:"btn btn-primary",handle:async y=>await m()}]};async function C(){if(e.beforeOpen)try{o==null||o.show();const y=await e.beforeOpen({notifyService:a});if(y)return s.value=y.entities||{},c.value=y.variables||{},f.value=y.message||"",x.value=y.messageType||"info",o==null||o.clearAll(),!0}catch{return a==null||a.error({message:"获取数据失败!"}),!1}finally{o==null||o.clearAll()}return!0}function b(){if(n.emit("update:modelValue",""),i.value="",e.onSubmitModal){const y=e.onSubmitModal({expression:"",message:""});e.onExpressionChanged&&e.onExpressionChanged(y)}}return t.watch(()=>e.modelValue,y=>{i.value=y}),()=>t.createVNode(pe,{editable:!1,enableTitle:!0,modelValue:i.value,"onUpdate:modelValue":y=>i.value=y,disabled:e.disabled,readonly:e.readonly,inputType:"text",enableClear:e.enableClear,buttonContent:l,buttonBehavior:"Modal",modalOptions:d,beforeOpen:C,onClear:b},{default:()=>[t.createVNode("div",{class:"h-100 d-flex flex-column"},[t.createVNode(ma,{ref:u,validateMessage:f.value,showMessageType:e.showMessageType,messageType:x.value,modelValue:i.value,"onUpdate:modelValue":y=>i.value=y,esprimaPath:e.esprimaPath,showMessage:e.showMessage,entities:s.value,variables:c.value,disabledFunctions:e.disabledFunctions,showDataPanel:e.showDataPanel,singleExpand:e.singleExpand,isServerSide:e.isServerSide},null)])]})}});var Ee=(e=>(e[e.Equal=0]="Equal",e[e.NotEqual=1]="NotEqual",e[e.Greater=2]="Greater",e[e.GreaterOrEqual=3]="GreaterOrEqual",e[e.Less=4]="Less",e[e.LessOrEqual=5]="LessOrEqual",e[e.Like=6]="Like",e[e.LikeStartWith=7]="LikeStartWith",e[e.LikeEndWith=8]="LikeEndWith",e[e.NotLike=9]="NotLike",e[e.NotLikeStartWith=10]="NotLikeStartWith",e[e.NotLikeEndWith=11]="NotLikeEndWith",e[e.Is=12]="Is",e[e.IsNot=13]="IsNot",e[e.In=14]="In",e[e.NotIn=15]="NotIn",e))(Ee||{}),le=(e=>(e[e.Empty=0]="Empty",e[e.And=1]="And",e[e.Or=2]="Or",e))(le||{}),G=(e=>(e[e.Value=0]="Value",e[e.Expression=1]="Expression",e[e.Variable=2]="Variable",e))(G||{}),yt=(e=>(e.Asc="asc",e.Desc="desc",e))(yt||{});const pt=e=>((e.raw.$type!=="SimpleField"||e.raw.selectable===!1)&&(e.disabled=!0),e);function De(e){const n=[{value:"",label:" "},{value:"(",label:"("},{value:"((",label:"(("},{value:"(((",label:"((("}],a=[{value:"",label:" "},{value:")",label:")"},{value:"))",label:"))"},{value:")))",label:")))"}],o=[{label:"=",value:0},{label:"<>",value:1},{label:">",value:2},{label:">=",value:3},{label:"<",value:4},{label:"<=",value:5},{label:"like %...%",value:6},{label:"like ...%",value:7},{label:"like %...",value:8},{label:"not like %...%",value:9},{label:"not like ...%",value:10},{label:"not like %...",value:11},{label:"is",value:12},{label:"is not",value:13},{label:"in",value:14},{label:"not in",value:15}],l=[{label:" ",value:0},{label:"并且",value:1},{label:"或者",value:2}],i=[{label:"值",value:e!=null&&e.singleValue?G.Value:G.Variable}],s={label:"表达式",value:G.Expression},c=e!=null&&e.enableExpression?[...i,s]:i;return{leftBracketItems:n,righttBracketItems:a,compareOperators:o,relationItems:l,valueTypes:c,sortTypes:[{label:"升序",value:"asc"},{label:"降序",value:"desc"}]}}const va=new Map([["appearance",_.resolveAppearance]]),xa={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/combo-list.schema.json",title:"combo-tree",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-tree"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},binding:{description:"",type:"object",default:{}},editable:{description:"",type:"boolean",default:!0},enableLinkLabel:{description:"",type:"boolean",default:!1},label:{description:"",type:"string",default:""},lableWidth:{description:"",type:"number"},placeholder:{description:"",type:"string",default:""},valueField:{description:"",type:"string",default:"id"},titleField:{description:"",type:"string",default:"name"},textField:{description:"",type:"string",default:"name"},data:{description:"",type:"array"},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"},visible:{description:"",type:"boolean",default:!0},onBlur:{description:"",type:"string",default:""},onClickLinkLabel:{description:"",type:"string",default:""},formatter:{type:"object",default:null},customRowStatus:{type:"object",default:null},minPanelWidth:{description:"",type:"number",default:160},idField:{description:"",type:"string",default:"id"},multiSelect:{description:"",type:"boolean",default:!1},viewType:{description:"",type:"string",default:"text"},searchFields:{description:"",type:"array",default:[]},enableSearch:{description:"",type:"boolean",default:!1},displayFormatter:{type:"object",default:null},enableClear:{description:"",type:"boolean",default:!0}},required:["id","type"]};function Ca(e,n,a){return n}const ht={id:{type:String},data:{type:Array,default:[]},displayText:{type:String,default:""},disabled:{type:Boolean,default:!1},dropDownIcon:{type:String,default:'<span class="f-icon f-icon-arrow-chevron-down"></span>'},editable:{type:Boolean,default:!1},enableClear:{type:Boolean,default:!0},enableSearch:{type:Boolean,default:!1},enableTitle:{type:Boolean,default:!0},fitEditor:{type:Boolean,default:!1},forcePlaceholder:{type:Boolean,default:!1},hidePanelOnClear:{type:Boolean,default:!0},idField:{type:String,default:"id"},mapFields:{type:Object},maxHeight:{type:Number,default:350},maxLength:{type:Number},multiSelect:{type:Boolean,default:!1},modelValue:{type:String,default:""},placeholder:{type:String},placement:{type:String,default:"auto"},readonly:{type:Boolean,default:!1},remoteSearch:{type:Boolean,default:!1},separator:{type:String,default:","},tabIndex:{type:Number,default:-1},textField:{type:String,default:"name"},titleField:{type:String,default:"name"},valueField:{type:String,default:"id"},viewType:{type:String,default:"text"},focusOnCreated:{type:Boolean,default:!1},selectOnCreated:{type:Boolean,default:!1},formatter:{type:Function,default:null},displayFormatter:{type:Function,default:null},editorParams:{type:Object},repositoryToken:{type:Symbol,default:null},customRowStatus:{type:Object,default:null},minPanelWidth:{type:Number,default:160},searchFields:{type:Array,default:["name"]}},wa=_.createPropsResolver(ht,xa,va,Ca),ka={data:{type:Array,default:[]},enableSearch:{type:Boolean,default:!1},idField:{type:String,default:"id"},multiSelect:{default:!1,type:Boolean},selectedValues:{type:String,default:""},separator:{type:String,default:","},textField:{type:String,default:"name"},titleField:{type:String,default:"name"},width:{type:Number},height:{type:Number},valueField:{type:String,default:"id"},formatter:{type:Function},maxHeight:{type:Number,default:350},repositoryToken:{type:Symbol,default:null},editorParams:{type:Object},customRowStatus:{type:Object,default:null},searchHandler:{type:Function,default:()=>{}}},Fa=t.defineComponent({name:"FComboTreeContainer",props:ka,emits:["selectionChange","selectItem","unSelectItem"],setup(e,n){const a=t.ref(e.data),o=t.ref([]),l=t.ref(e.separator),i=t.ref(e.width),s=t.ref(e.height),c=t.ref(e.maxHeight),u=t.ref(String(e.selectedValues).split(l.value)),f=t.ref(),x={customRowStatus:e.customRowStatus};t.watch(()=>e.selectedValues,r=>{u.value=String(r).split(l.value)}),t.watch(()=>e.data,r=>{var h;a.value=r,(h=f.value)==null||h.updateDataSource(r)});const m={enableSelectRow:!0,multiSelect:e.multiSelect,showCheckbox:e.multiSelect,multiSelectMode:"OnCheckAndClick"};let d=null;e.repositoryToken&&(d=t.inject(e.repositoryToken));const C=t.computed(()=>[{field:e.textField,title:"",dataType:"string",formatter:e.formatter}]),b=t.computed(()=>{const r={};return i.value!==void 0&&(r.width=`${i.value}px`),s.value!==void 0&&(r.height=`${s.value}px`),c.value!==void 0&&c.value>0&&(r.maxHeight=`${c.value}px`,r.overflow="auto"),a.value.length===0&&(r.height="200px"),r.position="relative",r});function y(r=[]){r&&r.length>0?(o.value=[...r],u.value=o.value.map(h=>h[e.idField])):(o.value=[],u.value=[]),n.emit("selectionChange",o.value)}return t.onMounted(()=>{d&&d.getData(e.editorParams).then(r=>{a.value=r}),u.value&&f.value.activeRowById(u.value[0])}),n.expose({treeInstance:f}),()=>t.createVNode("div",{class:"f-combo-tree-container",style:b.value},[e.multiSelect&&e.enableSearch&&t.createVNode("div",{class:"p-2",style:"position: sticky;top:0;z-index: 2; background:white",onMousedown:r=>r.stopPropagation()},[t.createVNode(St.FInputGroup,{buttonContent:'<i class="f-icon f-icon-search"></i>',enableClear:!0,placeholder:"请输入搜索内容",onClear:()=>n.emit("clearSearch"),onInput:(r,h)=>e.searchHandler(h)},null)]),t.createVNode(Ae,{ref:f,fit:!0,data:a.value,idField:e.idField,columns:C.value,"selection-values":u.value,onSelectionUpdate:y,columnOption:{fitColumns:!0,fitMode:"expand"},rowOption:x,selection:m,rowNumber:{enable:!1},onSelectItem:r=>n.emit("selectItem",r.raw),onUnSelectItem:r=>n.emit("unSelectItem",r.raw)},null)])}});function Ta(e){const n=t.ref(""),a=t.ref(e.modelValue),o=t.ref(e.data||[]),l=t.ref(e.editable);function i(m,d=[]){return m=m||[],m.reduce((C,b)=>(b.id=b.id||b.data[e.idField],C.push(b),b.children&&b.children.length&&i(b.children,C),C),d)}function s(m){const d=String(m).split(e.separator).map((r,h)=>[r,h]),C=new Map(d),b=[];return i(o.value,b),b.filter(r=>{const h=r.data?String(r.data[e.valueField]):String(r[e.valueField]);return C.has(h)}).map(r=>r.data?r.data:r).sort((r,h)=>{const v=C.get(String(r[e.valueField]))||0,k=C.get(String(h[e.valueField]))||0;return v-k})}function c(m){const d=s(m),C=e.displayFormatter?e.displayFormatter(d):d.map(b=>b[e.textField]).join(e.separator);n.value=l.value?C||m:C}function u(m){const d=m.split(e.separator).map(y=>[y,!0]),C=new Map(d);let b=[];return o.value[0].data?i(o.value,b):b=o.value,b=b.map(y=>y.data?y.data:y),b.filter(y=>C.has(y[e.textField])||C.has(y[e.valueField]))}function f(m){const d={};return d[e.idField]=m,d[e.textField]=m,[d]}function x(m){let d=u(m);const C=d&&d.length>0;return l.value&&!C&&(d=f(m)),d}return t.watch(()=>e.data,()=>{o.value=e.data}),t.watch([o],([m])=>{if(e.modelValue){const d=m.find(C=>C[e.valueField]===e.modelValue);d&&(n.value=d[e.textField])}}),t.watch(()=>e.modelValue,(m,d)=>{m!==d&&(a.value=m,c(m))}),c(e.modelValue),{dataSource:o,displayText:n,editable:l,modelValue:a,getItemsByDisplayText:u,getItemsByValue:s,getSelectedItemsByDisplayText:x,flatTreeNodes:i}}function Sa(e,n){const{comboEditorRef:a,dataSource:o,searchFields:l,originalValue:i,showPopover:s,flatTreeNodes:c}=e;function u(b,y){b.forEach(r=>{const h=y.find(v=>v.id===r.id);r.selectable=h.selectable!=null?!!h.selectable:!0,r.children&&u(r.children,y)})}function f(b,y){const r=(b.children||[]).map(v=>f(v,y)).filter(v=>v!==null);return l.value.some(v=>{var k;return(k=b.data[v])==null?void 0:k.toString().toLowerCase().includes(y.toLowerCase())})?{data:{...b.data},children:b.children,id:b.data[n]}:r.length>0?{data:{...b.data},children:r,id:b.data[n]}:null}function x(){i.value=J.cloneDeep(o.value)}function m(b){var r;if(s.value||(r=a.value)==null||r.showPopup(),!b){x();return}const y=o.value.map(h=>f(h,b)).filter(h=>h!==null);if(y.length){const h=[];c(o.value,h),u(y,h)}i.value=J.cloneDeep(y)}const d=J.debounce(b=>{var r;const y=(r=b.target)==null?void 0:r.value;m(y)},200);function C(b){var r;let y=(r=b.target)==null?void 0:r.value;y!==""&&(y=y.trim()),b.target._value!==y&&d(b)}return{onValueChange:C,resetDataSource:x}}const xe=t.defineComponent({name:"FComboTree",props:ht,emits:["clear","update:modelValue","change","search"],setup(e,n){const a=t.ref(),o=t.ref(e.disabled),l=t.ref(e.enableClear),i=t.ref(e.enableSearch),s=t.ref(e.readonly),c=t.ref(e.searchFields||[e.textField]),u=t.ref(),f=t.ref(),x={},{dataSource:m,displayText:d,editable:C,modelValue:b,flatTreeNodes:y}=Ta(e),r=t.computed(()=>e.multiSelect);t.computed(()=>a.value?a.value.elementRef.getBoundingClientRect().width:0);const h=t.computed(()=>{var O;const T=(O=a.value)==null?void 0:O.popoverRef;return T?T.shown:!1}),{onValueChange:v,resetDataSource:k}=Sa({comboEditorRef:a,dataSource:m,searchFields:c,originalValue:u,showPopover:h,flatTreeNodes:y},e.idField);function F(){!r.value&&a.value&&a.value.hidePopup()}const p=T=>e.displayFormatter?e.displayFormatter(T):T.map(O=>O[e.textField]).join(e.separator);function g(T=[]){if(!r.value)d.value=p(T),b.value=T.map(O=>O[e.valueField]).join(e.separator),n.emit("update:modelValue",b.value),n.emit("change",T,b.value);else{const O=Object.keys(x),S=Object.values(x);d.value=p(S),b.value=O.join(e.separator),n.emit("update:modelValue",b.value),n.emit("change",S,b.value)}F()}function w(T){var O;b.value="",h.value&&((O=a.value)==null||O.hidePopup()),n.emit("update:modelValue",""),n.emit("change",null,b.value),n.emit("clear")}function N(T){r.value&&(delete x[T.id],g())}function j(T){r.value&&(x[T.id]=T.data,g())}t.watch([()=>e.disabled,()=>e.editable,()=>e.enableClear,()=>e.enableSearch,()=>e.readonly],([T,O,S,E,D])=>{o.value=T,C.value=O,l.value=S,i.value=E,s.value=D});const I=()=>{if(u.value=J.cloneDeep(m.value),r.value&&b.value){const T=[];y(m.value,T),b.value.split(e.separator).reduce((O,S)=>(O[S]=T.find(E=>E.id===S),O),x)}};return()=>t.createVNode(me,{ref:a,id:e.id,disable:o.value,readonly:s.value,forcePlaceholder:e.forcePlaceholder,editable:C.value&&!e.multiSelect,buttonContent:e.dropDownIcon,placeholder:e.placeholder,enableClear:l.value,maxLength:e.maxLength,tabIndex:e.tabIndex,enableTitle:e.enableTitle,inputType:e.viewType,popupOnClick:!0,modelValue:d.value,"onUpdate:modelValue":T=>d.value=T,onClear:w,onInput:v,focusOnCreated:e.focusOnCreated,selectOnCreated:e.selectOnCreated,beforeOpen:I,placement:e.placement,popupMinWidth:e.minPanelWidth},{default:()=>[h.value&&t.createVNode(Fa,{ref:f,maxHeight:e.maxHeight,multiSelect:e.multiSelect,enableSearch:e.enableSearch,idField:e.idField,valueField:e.valueField,textField:e.textField,titleField:e.titleField,data:u.value,selectedValues:b.value,onSelectionChange:g,formatter:e.formatter,editorParams:e.editorParams,repositoryToken:e.repositoryToken,customRowStatus:e.customRowStatus,searchHandler:v,onUnSelectItem:N,onSelectItem:j,onClearSearch:k},null)]})}});xe.register=(e,n,a,o)=>{e["combo-tree"]=xe,n["combo-tree"]=wa},Q.withInstall(xe);function Pe(e){function n(a,o,l="filterField"){return t.createVNode(xe,{formatter:e.formatter,modelValue:a[l],"onUpdate:modelValue":i=>a[l]=i,data:o,textField:e.textField||"name",valueField:e.valueField||"path",idField:e.idField||"id",enableClear:!1,minPanelWidth:220,customRowStatus:pt},null)}return{renderFieldsComboTree:n}}function Ie(e,n,a){const o=t.ref(e.activeIndex),l=t.ref(e.conditions),i=t.ref(e.fields);t.watch(()=>e.fields,d=>{i.value=d}),t.watch(()=>e.conditions,d=>{l.value=d}),t.watch(()=>e.activeIndex,d=>{o.value=d});const s=t.computed(()=>a.value.querySelector(`tr[index="${o.value}"]`));function c(){const d=s.value;d&&(d.scrollIntoView?d.scrollIntoView({block:"center",behavior:"smooth"}):d.scrollIntoViewIfNeeded&&d.scrollIntoViewIfNeeded(!1))}const u=t.computed(()=>d=>({"fv-grid-row-selected":d===o.value}));function f(d,C){C.stopPropagation(),n.emit("insert",{index:d,$event:C})}function x(d,C){C.stopPropagation(),n.emit("remove",{index:d,$event:C})}function m(d,C){n.emit("rowClick",{item:d,index:C})}return{itemIntoView:c,activeRowCls:u,fields:i,activeIndex:o,selectedRowRef:s,conditions:l,tbodyRef:a,onInsert:f,onRemove:x,onRowClick:m}}const Na=t.defineComponent({name:"filter-condition-grid",props:Xe,emits:["insert","remove","rowClick"],setup(e,n){const{compareOperators:a,leftBracketItems:o,valueTypes:l,relationItems:i,righttBracketItems:s}=De(e),{renderFieldsComboTree:c}=Pe(e),u=t.ref(),{conditions:f,fields:x,onInsert:m,onRemove:d,onRowClick:C,activeRowCls:b,itemIntoView:y}=Ie(e,n,u),r=t.ref(e.expressionOptions||{});function h(k){var F,p;switch(k.expresstype){case G.Variable:return t.createVNode(Tt,{modelValue:k.value,"onUpdate:modelValue":g=>k.value=g,showOutline:!1,fieldData:(F=e.formContextData)==null?void 0:F.fieldData,varData:(p=e.formContextData)==null?void 0:p.varData},null);case G.Expression:return t.createVNode(ba,t.mergeProps({modelValue:k.value,"onUpdate:modelValue":g=>k.value=g},r.value),null);case G.Value:default:return t.createVNode(pe,{enableTitle:!0,buttonContent:"",popupOnClick:!0,modelValue:k.value,"onUpdate:modelValue":g=>k.value=g},null)}}function v(k,F,p){return t.createVNode(oe,{data:F,modelValue:k[p],"onUpdate:modelValue":g=>k[p]=g,textField:"label",valueField:"value",idField:"value",enableClear:!1,minPanelWidth:130,placement:"auto"},null)}return t.onUpdated(()=>{y()}),()=>t.createVNode("div",{class:"fv-filter-condition-grid table-body f-utils-fill win11Scroll show nobtn",style:"margin-left:14px; margin-right: 0; overflow-y: scroll;"},[t.createVNode("table",{class:"table table-bordered",style:"margin-bottom: 0;"},[t.createVNode("thead",{style:"position: sticky; top: 0; z-index: 1;"},[t.createVNode("tr",null,[t.createVNode("th",{style:"width: 40px"},null),t.createVNode("th",{style:"width: 45px"},[t.createVNode("b",null,[t.createTextVNode("左括号")])]),t.createVNode("th",{style:"width: 90px"},[t.createVNode("b",null,[t.createTextVNode("字段")])]),t.createVNode("th",{style:"width: 70px"},[t.createVNode("b",null,[t.createTextVNode("操作符")])]),t.createVNode("th",{style:"width: 60px"},[t.createVNode("b",null,[t.createTextVNode("值类型")])]),t.createVNode("th",{style:"width: 100px"},[t.createVNode("b",null,[t.createTextVNode("值")])]),t.createVNode("th",{style:"width: 45px"},[t.createVNode("b",null,[t.createTextVNode("右括号")])]),t.createVNode("th",{style:"width: 60px"},[t.createVNode("b",null,[t.createTextVNode("关系")])])])]),t.createVNode("tbody",{ref:u},[f.value.map((k,F)=>t.createVNode("tr",{index:F,class:b.value(F),onClick:p=>C(k,F)},[t.createVNode("td",{style:"text-overflow: unset;",align:"center",class:"px-1"},[t.createVNode("button",{title:"插入",onClick:p=>m(F,p),type:"button",class:"btn btn-link p-1 mr-0"},[t.createVNode("span",{class:"f-icon f-icon-plus"},null)]),t.createVNode("button",{title:"移除",onClick:p=>d(F,p),type:"button",class:"btn btn-link p-1 m-0"},[t.createVNode("span",{class:"f-icon f-icon-minus"},null)])]),t.createVNode("td",{class:"px-1"},[v(k,o,"lbracket")]),t.createVNode("td",{class:"px-1"},[c(k,x.value,"filterField")]),t.createVNode("td",{class:"px-1"},[v(k,a,"compare")]),t.createVNode("td",{class:"px-1"},[v(k,l,"expresstype")]),t.createVNode("td",{class:"px-1"},[h(k)]),t.createVNode("td",{class:"px-1"},[v(k,s,"rbracket")]),t.createVNode("td",{class:"px-1"},[v(k,i,"relation")])]))])])])}}),Va={width:{Type:Number,default:400},type:{Type:String,default:"info"},title:{Type:String,default:""},detail:{Type:String,default:""},okButtonText:{Type:String,default:"确定"},showOkButton:{Type:Boolean,default:!0},showCancelButton:{Type:Boolean,default:!0},cancelButtonText:{Type:String,default:"取消"},exceptionInfo:{Type:Object,default:null},promptEditorType:{Type:String,default:"text-area"},buttons:{type:Object,default:[]}};function je(){return new DOMException("The request is not allowed","NotAllowedError")}async function Ma(e){if(!navigator.clipboard)throw je();return navigator.clipboard.writeText(e)}async function Ba(e){const n=document.createElement("span");n.textContent=e,n.style.whiteSpace="pre",n.style.webkitUserSelect="auto",n.style.userSelect="all",document.body.appendChild(n);const a=window.getSelection(),o=window.document.createRange();a==null||a.removeAllRanges(),o.selectNode(n),a==null||a.addRange(o);let l=!1;try{l=window.document.execCommand("copy")}finally{a==null||a.removeAllRanges(),window.document.body.removeChild(n)}if(!l)throw je()}async function Oa(e){try{await Ma(e)}catch(n){try{await Ba(e)}catch(a){throw a||n||je()}}}function Ea(){async function e(n){await Oa(n)}return{onCopy:e}}function Da(e,n,a,o){const l=t.ref(14),i=t.ref(140),s=t.ref(""),c=t.ref(o.value.length),u=t.computed(()=>o.value),f=t.computed(()=>({"font-size":`${l.value}px`,height:"100%"}));function x(m){if(m.currentTarget){const d=m.currentTarget.value||"";c.value=d.length}}return()=>t.createVNode(t.Fragment,null,[t.createVNode("textarea",{title:"promptMessage",name:"promptMessage",class:"form-control",style:f.value,rows:"4",maxlength:i.value,onInput:m=>x(m)},[u.value]),t.createVNode("span",{class:"textarea-wordcount",title:s.value,style:"position: absolute; bottom: 76px; right: 32px; cursor: pointer; text-align: right;"},[c.value+" / "+i.value])])}function Pa(e,n,a,o){const l=Da(e,n,a,o),i=new Map([["text-area",l]]);function s(c){return i.get(c)||null}return{getEditorRender:s}}function Ia(){const e=t.ref(!1),n=t.ref("复制成功");return{feedbackStyle:t.computed(()=>{const o={position:"absolute",left:"50%",top:"50%","min-width":"100px",height:"40px",background:"#303C53","line-height":"40px","text-align":"center","margin-left":"-30px","margin-top":"-50px","border-radius":"10px","box-shadow":"0px 2px 8px 0px",color:"#fff",transition:"all .3s ease",padding:"0 10px"};return o.opacity=e.value?"0.8":"0",o.display=e.value?"":"none",o}),feedbackMessage:n,toShowFeedback:e}}function ja(e,n){const a=n.getEditorRender(e.promptEditorType);return()=>a&&a()}function Ra(e,n){function a(C){if(C==null)return 0;let b=0;for(let y=0;y<C.length;y++){const r=C.charCodeAt(y);r>=0&&r<=128?b++:b=b+2}return b}function o(C,b){if(C!==""&&C!==void 0&&C!==null){C=""+C;const y=C.length;let r="",h=0;for(let v=0;v<y;v++){const k=C.charAt(v);if(h++,encodeURI(k).length>4&&h++,r=r.concat(k),h>=b)return r=r.concat("..."),r}if(h<b)return C}return""}const l=t.computed(()=>!!e.value&&!!e.value.date),i=t.computed(()=>{const C=e.value&&e.value.date||"";return`${n.exception.happend} : ${C}`}),s=t.computed(()=>!!e.value&&!!e.value.detail),c=t.computed(()=>e.value?a(e.value.detail)>160:!1),u=t.ref(!1),f=t.computed(()=>u.value?n.exception.collapse:n.exception.expand),x=t.computed(()=>{const C=n.exception.detail+" : "+(e.value&&e.value.detail)||"";return u.value?C:o(C,160)}),m=t.computed(()=>({position:"absolute",right:0,bottom:u.value?0:"2px",color:"#2A87FF",cursor:"pointer"}));function d(){u.value=!u.value}return()=>t.createVNode("div",{class:"toast-msg-detail",style:"max-height: calc(100vh - 200px);overflow: auto;"},[l.value&&t.createVNode("div",null,[i.value]),s.value&&t.createVNode("div",{class:"exception_wrap"},[t.createVNode("div",{class:"exception_error_msg"},[t.createVNode("div",{innerHTML:x.value},null),c.value&&t.createVNode("span",{style:m.value,onClick:d},[f.value])])])])}function La(e){return()=>t.createVNode("p",{class:"toast-msg-detail",innerHTML:e.value,style:"max-height: calc(100vh - 200px);overflow: auto;"},null)}function $a(e,n,a,o,l){const i=t.ref(e.exceptionInfo),s=t.computed(()=>{const b=n.value==="question"?"warning":n.value,y={"f-icon":!0},r=`f-icon-${b}`;return y[r]=!0,y}),c=t.computed(()=>a.value||i.value&&i.value.message),u=t.computed(()=>o.value),f=t.computed(()=>!!o.value),x=t.computed(()=>!!i.value);function m(){return x.value?Ra(i,l):f.value?La(u):()=>null}const d=m(),C=t.computed(()=>l.locale==="en"?{wordBreak:"keep-all",overflowWrap:"break-word"}:{});return()=>t.createVNode(t.Fragment,null,[t.createVNode("div",{class:"float-left modal-tips-iconwrap"},[t.createVNode("span",{class:s.value},null)]),t.createVNode("div",{class:"modal-tips-content"},[t.createVNode("p",{class:"toast-msg-title",innerHTML:c.value,style:C.value},null),d()])])}function za(e,n,a,o){const{onCopy:l}=n,{toShowFeedback:i}=a,s=t.ref(o.exception.copySuccess||"复制成功"),c=t.ref(o.exception.copy||"复制详细信息"),u=t.ref(e.exceptionInfo||{date:"",message:"",detail:""}),f=t.computed(()=>u.value&&u.value.detail||"");function x(m){l(f.value).catch(d=>{s.value=o.exception.copyFailed||"复制失败"}).finally(()=>{i.value=!0,setTimeout(()=>{i.value=!1},700)})}return()=>t.createVNode("span",{style:"width: 100%;color: #2A87FF;padding-left: 37px;"},[t.createVNode("span",{onClick:x,style:"cursor: pointer;"},[c.value])])}function Aa(e,n,a,o,l){const i=t.ref(e.type),s=t.ref(e.buttons),c=t.ref(e.exceptionInfo),u=t.ref(l.ok||e.okButtonText),f=t.ref(l.cancel||e.cancelButtonText),x=t.ref(e.showCancelButton),m=t.ref(e.showOkButton),d=t.computed(()=>!!(s.value&&s.value.length)),C=t.computed(()=>!!(c.value&&c.value.detail)),b=t.computed(()=>!(s.value&&s.value.length)&&(m.value||x.value)),y=za(e,a,o,l);u.value==="关闭"?u.value=l.close:u.value==="知道了"&&(u.value=l.exception.roger);function r(v){i.value==="question"&&n.emit("reject"),n.emit("close")}function h(v){i.value==="question"&&n.emit("accept"),n.emit("close")}return()=>t.createVNode("div",{class:"modal-footer"},[C.value&&y(),b.value&&x.value&&t.createVNode("button",{type:"button",class:"btn btn-secondary btn-lg",onClick:r},[f.value]),b.value&&m.value&&t.createVNode("button",{type:"button",class:"btn btn-primary btn-lg",onClick:h},[u.value]),d.value&&s.value.length&&s.value.map(v=>t.createVNode("button",{type:"button",onClick:v.handle,class:v.class},[v.iconClass&&t.createVNode("span",{class:v.iconClass},null),v.text]))])}function Ha(e){const{getLocaleValue:n}=q.LocaleService,a=q.LocaleService.getLocale();function o(l,i,s){return i===s?n(l):i}return{yes:o("messageBox.yes")||"是",no:o("messageBox.no")||"否",close:o("messageBox.close")||"关闭",ok:o("messageBox.ok",e.okButtonText,"确定")||"确定",cancel:o("messageBox.cancel",e.cancelButtonText,"取消")||"取消",title:o("messageBox.title")||"系统提示",errorTitle:o("messageBox.errorTitle")||"错误提示",exception:{expand:o("messageBox.exception.expand")||"展开",collapse:o("messageBox.exception.collapse")||"收起",happend:o("messageBox.exception.happend")||"发生时间",detail:o("messageBox.exception.detail")||"详细信息",copy:o("messageBox.exception.copy")||"复制详细信息",copySuccess:o("messageBox.exception.copySuccess")||"复制成功",copyFailed:o("messageBox.exception.copyFailed")||"复制失败",roger:o("messageBox.exception.roger")||"知道了"},locale:a}}const Ce=t.defineComponent({name:"FMessageBox",props:Va,emits:["accept","reject","close"],setup(e,n){const a=Ha(e),o=t.ref(e.type),l=t.ref(e.title),i=t.ref(e.detail),s=t.computed(()=>{const h={"modal-tips":!0,"d-flex":!0,"flex-row":!0},v=`messager-type-${o.value}`;return h[v]=!0,h}),c=t.computed(()=>{const h={cursor:"default"};return o.value==="prompt"?h.padding="0.5rem 0.5rem 1rem 1.5rem":o.value==="error"&&(h.padding="0.5rem 1.5rem 1rem 1.5rem"),h}),u=Ea(),f=Pa(e,o,l,i),x=Ia(),{feedbackStyle:m,feedbackMessage:d}=x;d.value=a.exception.copySuccess;function C(){return t.createVNode("div",{style:m.value},[d.value])}function b(){switch(o.value){case"prompt":return ja(e,f);default:return $a(e,o,l,i,a)}}const y=b(),r=Aa(e,n,u,x,a);return()=>t.createVNode("div",{class:"farris-messager"},[!e.exceptionInfo&&t.createVNode("div",{style:"height: 30px;width: 100%;position: absolute;",class:"messager-draggable"},null),t.createVNode("section",{class:s.value,style:c.value},[y()]),r(),C()])}}),X=class X{static show(n){const a=t.reactive({...n}),o=!1,l=a.type==="error"||a.type==="prompt",i=a.type==="error"?"错误提示":a.type==="prompt"&&a.title||"",s=a.acceptCallback||(()=>{}),c=a.rejectCallback||(()=>{});let u=null,f=new qe(X.app);const x=()=>{u&&(u==null||u.destroy(),f=null)};return u=f==null?void 0:f.open({class:"modal-message modal-message-type-info",title:i,showButtons:o,showHeader:l,width:a.width||400,fitContent:!0,showMaxButton:!1,draggable:!0,dragHandle:".messager-draggable",render:()=>t.createVNode(Ce,t.mergeProps(a,{onAccept:s,onReject:c,onClose:x}),null)}),f==null?void 0:f.getCurrentModal()}static info(n,a){const o=t.reactive({type:"info",title:n,detail:a,okButtonText:"知道了",showCancelButton:!1});X.show(o)}static warning(n,a){const o=t.reactive({type:"warning",title:n,detail:a,okButtonText:"知道了",showCancelButton:!1});X.show(o)}static success(n,a){const o=t.reactive({type:"success",title:n,detail:a,okButtonText:"关闭",showCancelButton:!1});X.show(o)}static error(n,a,o){const l=t.reactive({width:500,type:"error",okButtonText:"关闭",showCancelButton:!1,exceptionInfo:{date:o,message:n,detail:a}});X.show(l)}static prompt(n,a){const o=t.reactive({type:"prompt",title:n,detail:a,okButtonText:"确定",cancelButtonText:"取消"});X.show(o)}static question(n,a,o,l){const i=t.reactive({type:"question",title:n,detail:a,okButtonText:"确定",cancelButtonText:"取消",acceptCallback:o,rejectCallback:l});X.show(i)}};K(X,"app",null);let ie=X;Ce.install=e=>{e.component(Ce.name,Ce),ie.app=e,e.provide("FMessageBoxService",ie)};const gt=t.defineComponent({name:"filter-condition-actions",props:["canClear","canMove","questionMessage"],emits:["add","clear","moveTop","movePrev","moveNext","moveBottom"],setup(e,n){const a=t.ref(e.questionMessage||"确定要清空所有数据吗?"),o={position:"relative",top:"2px"};function l(){n.emit("add")}function i(){ie.question(a.value,"",()=>{n.emit("clear")},()=>{})}function s(){n.emit("moveTop")}function c(){n.emit("movePrev")}function u(){n.emit("moveNext")}function f(){n.emit("moveBottom")}return()=>t.createVNode("div",{class:"px-2 d-flex align-items-center",style:"height: 36px;background: #f0f0f0; margin-left: 14px; margin-right: 14px;"},[t.createVNode("button",{type:"button",onClick:l,class:"btn btn-default f-btn-ml"},[t.createVNode("span",{class:"f-icon f-icon-add",style:o},null),t.createTextVNode("添加")]),t.createVNode("button",{type:"button",onClick:i,disabled:!e.canClear.value,class:"btn btn-default f-btn-ml"},[t.createVNode("span",{class:"f-icon f-icon-close",style:o},null),t.createTextVNode("清空")]),t.createVNode("button",{type:"button",onClick:s,disabled:!e.canMove.value("up"),class:"btn btn-default f-btn-ml"},[t.createVNode("span",{class:"f-icon f-icon-arrow-end-up",style:o},null),t.createTextVNode("置顶")]),t.createVNode("button",{type:"button",onClick:c,disabled:!e.canMove.value("up"),class:"btn btn-default f-btn-ml"},[t.createVNode("span",{class:"f-icon f-icon-arrow-60-up",style:o},null),t.createTextVNode("上移")]),t.createVNode("button",{type:"button",onClick:u,disabled:!e.canMove.value("down"),class:"btn btn-default f-btn-ml"},[t.createVNode("span",{class:"f-icon f-icon-arrow-60-down",style:o},null),t.createTextVNode("下移")]),t.createVNode("button",{type:"button",onClick:f,disabled:!e.canMove.value("down"),class:"btn btn-default f-btn-ml"},[t.createVNode("span",{class:"f-icon f-icon-arrow-end-down",style:o},null),t.createTextVNode("置底")])])}}),Wa=t.defineComponent({name:"sort-editor-grid",props:Xe,emits:["insert","remove","rowClick"],setup(e,n){const{sortTypes:a}=De(),{renderFieldsComboTree:o}=Pe(e),l=t.ref(),{conditions:i,fields:s,onInsert:c,onRemove:u,onRowClick:f,activeRowCls:x,itemIntoView:m}=Ie(e,n,l);return t.onUpdated(()=>{m()}),()=>t.createVNode("div",{class:"table-body f-utils-fill win11Scroll show nobtn ",style:"margin-left:14px; margin-right: 0; overflow-y: scroll;"},[t.createVNode("table",{class:"table table-bordered",style:"margin-bottom: 0;"},[t.createVNode("thead",{style:"position: sticky; top: 0; z-index: 1;"},[t.createVNode("tr",null,[t.createVNode("th",{style:"width: 40px"},null),t.createVNode("th",{style:"width: 100px"},[t.createVNode("b",null,[t.createTextVNode("字段")])]),t.createVNode("th",{style:"width: 60px"},[t.createVNode("b",null,[t.createTextVNode("排序")])])])]),t.createVNode("tbody",{ref:l},[i.value.map((d,C)=>t.createVNode("tr",{index:C,class:x.value(C),onClick:b=>f(d,C)},[t.createVNode("td",{style:"text-overflow: unset;",align:"center",class:"px-1"},[t.createVNode("button",{title:"插入",onClick:b=>c(C,b),type:"button",class:"btn btn-link p-1 mr-0"},[t.createVNode("span",{class:"f-icon f-icon-plus"},null)]),t.createVNode("button",{title:"移除",onClick:b=>u(C,b),type:"button",class:"btn btn-link p-1 m-0"},[t.createVNode("span",{class:"f-icon f-icon-minus"},null)])]),t.createVNode("td",{class:"px-1"},[o(d,s.value,"sortField")]),t.createVNode("td",{class:"px-1"},[t.createVNode(oe,{data:a,textField:"label",valueField:"value",idField:"value",modelValue:d.sortType,"onUpdate:modelValue":b=>d.sortType=b,enableClear:!1,minPanelWidth:130,placement:"auto"},null)])]))])])])}});function bt(e,n){const a=t.ref(-1);function o(){return n.value[a.value]}function l(){n.value.length>0?a.value=0:a.value=-1}const i=t.computed(()=>e.displayText?e.displayText:typeof e.modelValue=="string"?e.modelValue:""),s=e.editorType!=="sort"?"filterField":"sortField",c=e.editorType!=="sort"?{filterField:"",value:"",lbracket:"",rbracket:"",relation:le.Empty,compare:Ee.Equal,expresstype:e.singleValue?G.Value:G.Variable}:{sortField:"",sortType:"asc"},u=t.computed(()=>n.value.length>0),f=t.computed(()=>(g="down")=>n.value.length>1?g==="up"?a.value>0:a.value<n.value.length-1:!1);function x(){if(e.editorType==="filter")for(let g=0;g<n.value.length-1;g++){const w=n.value[g];(w.relation===le.Empty||!w.relation)&&(w.relation=le.And)}}function m(){const g=Object.assign({},c);n.value=[...n.value,g];const w=n.value.length-1;a.value=w,x()}function d({index:g}){const w=Object.assign({},c);e.insertType==="above"?g===0?n.value.unshift(w):n.value.splice(g,0,w):n.value.splice(g+1,0,w),n.value=[...n.value],x()}function C({index:g}){n.value.splice(g,1),n.value=[...n.value],!(a.value<0)&&(g===a.value?n.value[g]?a.value=g:n.value[g-1]?a.value=g-1:a.value=-1:g<a.value&&(n.value[a.value-1]?a.value=a.value-1:n.value[a.value]||(a.value=-1)))}function b(){n.value=[]}function y(){a.value>=0&&(n.value.unshift(o()),n.value.splice(a.value+1,1),a.value=0)}function r(){if(a.value>=0){const g=a.value,w=n.value.splice(g,1);n.value.splice(g-1,0,...w),a.value=g-1}}function h(){if(a.value>=0){const g=a.value,w=n.value.splice(g,1);n.value.splice(g+1,0,...w),a.value=g+1}}function v(){a.value>=0&&(n.value.push(o()),n.value.splice(a.value,1),a.value=n.value.length-1)}function k({index:g}){a.value=g}function F(g){if(g.length%2!==0)return!1;let w="";for(const N of g)if(N==="(")w+=N;else if(N===")"){if(!w.endsWith("("))return!1;w=w.slice(0,-1)}return w.length===0}function p(){const g=n.value.length;if(!g)return!0;let w=!0,N=!0;if(e.editorType!=="sort"){n.value[g-1].relation=le.Empty,N=!n.value.slice(0,-1).some(O=>O.relation===le.Empty||!O.relation);const T=n.value.flatMap(O=>[O.lbracket,O.rbracket]).join("");w=F(T)}const j=n.value.some(I=>!I[s]);return[{result:w,message:"括号不匹配,请检查。"},{result:N,message:"关系设置不完整,请检查。"},{result:!j,message:"字段不允许为空,请检查。"}].find(I=>!I.result)}return{displayText:i,activeRowIndex:a,canClear:u,canMove:f,onAddFilter:m,onRemove:C,onInsert:d,onClear:b,onMoveTop:y,onMovePrev:r,onMoveNext:h,onMoveBottom:v,onSelectRow:k,validateCondition:p,resetActiveRow:l}}const we=t.defineComponent({name:"filter-condition-editor",props:ke,emits:["update:modelValue"],setup(e,n){const a=t.inject(e.repositoryToken),o=t.inject(Oe),l=t.inject("FLoadingService");o&&(o.globalConfig={position:"top-center"});const i=t.ref(e.expressionOptions||{}),s=t.ref(e.formContextData||{}),c=t.ref(e.fields||[]),u='<i class="f-icon f-icon-lookup"></i>',f=t.ref([]),x=t.ref([]),{displayText:m,onAddFilter:d,onClear:C,onMoveBottom:b,onMoveNext:y,onMovePrev:r,onMoveTop:h,onInsert:v,onRemove:k,activeRowIndex:F,onSelectRow:p,canClear:g,canMove:w,validateCondition:N,resetActiveRow:j}=bt(e,f),I=t.computed(()=>e.editorType==="sort"?"排序条件编辑器":"过滤条件编辑器");function T(){return e.editorType==="sort"?t.createVNode(Wa,{conditions:f.value,fields:c.value,activeIndex:F.value,onInsert:M=>v(M),onRemove:M=>k(M),idField:e.idField,onRowClick:M=>p(M)},null):t.createVNode(Na,{singleValue:e.singleValue,expressionOptions:i.value,enableExpression:e.enableExpression,conditions:f.value,fields:c.value,idField:e.idField,activeIndex:F.value,onInsert:M=>v(M),onRemove:M=>k(M),onRowClick:M=>p(M),formContextData:s.value},null)}const O=t.computed(()=>JSON.stringify(f.value)===JSON.stringify(x.value)),S=t.computed(()=>e.disableConfirmWhenUnchanged&&O.value);async function E(){if(n.emit("update:modelValue",f.value),e.onSubmitModal){l==null||l.show();const M=await e.onSubmitModal({loadingService:l,repository:a,conditions:f,originalConditions:x,FMessageBoxService:ie});return l==null||l.clearAll(),M&&(F.value=-1,o.success("过滤条件配置成功!")),M}return!0}const D={title:I.value,width:800,height:600,fitContent:!1,minWidth:300,minHeight:200,showMaxButton:!0,resizeable:!0,draggable:!0,closedCallback:()=>{F.value=-1},buttons:[{name:"cancel",text:"取消",class:"btn btn-secondary",handle:M=>!0},{name:"accept",text:"确定",class:"btn btn-primary",disabled:S,handle:async M=>{const $=N();return O.value?!0:typeof $=="object"&&$!==null&&$&&$.message?(o.warning($.message),!1):await E()}}]};async function P(){if(e.beforeOpen)try{l==null||l.show();const M=await e.beforeOpen({repository:a,notifyService:o});if(M){const{fieldList:$,conditionList:A,entities:H,variables:Re,formContextData:fe,isServerSide:Le}=M;return c.value=$||[],f.value=A||[],x.value=JSON.parse(JSON.stringify(f.value)),i.value={entities:H,variables:Re,isServerSide:Le},s.value=fe||{},l==null||l.clearAll(),j(),!0}}catch{return o==null||o.error({message:"获取数据失败!"}),!1}finally{l==null||l.clearAll()}return j(),!0}function z(){n.emit("update:modelValue","")}function B(M){n.emit("update:modelValue",M)}return()=>t.createVNode(pe,{modelValue:m.value,editable:e.editable,disabled:e.disabled,readonly:e.readonly,inputType:"text",enableClear:e.enableClear,buttonContent:u,buttonBehavior:"Modal",modalOptions:D,beforeOpen:P,onClear:z,enableTitle:e.enableTitle,"onUpdate:modelValue":B},{default:()=>[t.createVNode("div",{class:"h-100 d-flex flex-column"},[t.createVNode("div",{style:"border-top: 1px solid white; position: absolute; top: 0; width: 100%; z-index: 2;",class:"shading-border-top"},null),T(),t.createVNode(gt,{canClear:g,canMove:w,onAdd:d,onClear:C,onMoveBottom:b,onMoveNext:y,onMovePrev:r,onMoveTop:h},null)])]})}}),qa={install(e){e.component(we.name,we)},register(e,n,a,o){e["filter-condition-editor"]=we,n["filter-condition-editor"]=Ge}};R.Compare=Ee,R.ConditionActions=gt,R.FilterConditionEditor=we,R.FilterRelation=le,R.SortType=yt,R.ValueType=G,R.default=qa,R.filterConditionEditorProps=ke,R.propsResolver=Ge,R.treeNodeStatus=pt,R.useConditionData=bt,R.useConditionEditor=Ie,R.useConstantData=De,R.useFieldsTree=Pe,Object.defineProperties(R,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
1
+ (function(y,l){typeof exports=="object"&&typeof module<"u"?l(exports,require("vue"),require("../common/index.umd.js"),require("lodash-es"),require("../button-edit/index.umd.js"),require("../tree-view/index.umd.js"),require("../input-group/index.umd.js")):typeof define=="function"&&define.amd?define(["exports","vue","../common/index.umd.js","lodash-es","../button-edit/index.umd.js","../tree-view/index.umd.js","../input-group/index.umd.js"],l):(y=typeof globalThis<"u"?globalThis:y||self,l(y["filter-condition-editor"]={},y.Vue,y.common,y.LodashES,y.FButtonEdit,y.FTreeView,y.inputGroup))})(this,function(y,l,W,E,H,U,G){"use strict";const _={disabled:{type:Boolean,default:!1},readonly:{type:Boolean,default:!1},enableClear:{type:Boolean,default:!0},displayText:{type:String,default:""},enableExpression:{type:Boolean,default:!1},modelValue:{type:String,default:""},insertType:{type:String,default:"below"},fields:{type:Array,default:[]},repositoryToken:{type:Object,default:null},editorParams:{type:Object,default:null},onSubmitModal:{type:Function,default:null},beforeOpen:{type:Function,default:null},editorType:{type:String,default:"filter"},expressionOptions:{type:Object,default:null},formContextData:{type:Object,default:{}},singleValue:{type:Boolean,default:!0},idField:{type:String,default:"id"},textField:{type:String,default:""},valueField:{type:String,default:""},editable:{type:Boolean,default:!0},enableTitle:{type:Boolean,default:!0},disableConfirmWhenUnchanged:{type:Boolean,default:!1}};var j=(e=>(e[e.Equal=0]="Equal",e[e.NotEqual=1]="NotEqual",e[e.Greater=2]="Greater",e[e.GreaterOrEqual=3]="GreaterOrEqual",e[e.Less=4]="Less",e[e.LessOrEqual=5]="LessOrEqual",e[e.Like=6]="Like",e[e.LikeStartWith=7]="LikeStartWith",e[e.LikeEndWith=8]="LikeEndWith",e[e.NotLike=9]="NotLike",e[e.NotLikeStartWith=10]="NotLikeStartWith",e[e.NotLikeEndWith=11]="NotLikeEndWith",e[e.Is=12]="Is",e[e.IsNot=13]="IsNot",e[e.In=14]="In",e[e.NotIn=15]="NotIn",e))(j||{}),O=(e=>(e[e.Empty=0]="Empty",e[e.And=1]="And",e[e.Or=2]="Or",e))(O||{}),N=(e=>(e[e.Value=0]="Value",e[e.Expression=1]="Expression",e[e.Variable=2]="Variable",e))(N||{}),p=(e=>(e.Asc="asc",e.Desc="desc",e))(p||{});const Y={id:{type:String},data:{type:Array,default:[]},displayText:{type:String,default:""},disabled:{type:Boolean,default:!1},dropDownIcon:{type:String,default:'<span class="f-icon f-icon-arrow-chevron-down"></span>'},editable:{type:Boolean,default:!1},enableClear:{type:Boolean,default:!0},enableSearch:{type:Boolean,default:!1},enableTitle:{type:Boolean,default:!0},fitEditor:{type:Boolean,default:!1},forcePlaceholder:{type:Boolean,default:!1},hidePanelOnClear:{type:Boolean,default:!0},idField:{type:String,default:"id"},mapFields:{type:Object},maxHeight:{type:Number,default:350},maxLength:{type:Number},multiSelect:{type:Boolean,default:!1},modelValue:{type:String,default:""},placeholder:{type:String},placement:{type:String,default:"auto"},readonly:{type:Boolean,default:!1},remoteSearch:{type:Boolean,default:!1},separator:{type:String,default:","},tabIndex:{type:Number,default:-1},textField:{type:String,default:"name"},titleField:{type:String,default:"name"},valueField:{type:String,default:"id"},viewType:{type:String,default:"text"},focusOnCreated:{type:Boolean,default:!1},selectOnCreated:{type:Boolean,default:!1},formatter:{type:Function,default:null},displayFormatter:{type:Function,default:null},editorParams:{type:Object},repositoryToken:{type:Symbol,default:null},customRowStatus:{type:Object,default:null},minPanelWidth:{type:Number,default:160},searchFields:{type:Array,default:["name"]}},$={data:{type:Array,default:[]},enableSearch:{type:Boolean,default:!1},idField:{type:String,default:"id"},multiSelect:{default:!1,type:Boolean},selectedValues:{type:String,default:""},separator:{type:String,default:","},textField:{type:String,default:"name"},titleField:{type:String,default:"name"},width:{type:Number},height:{type:Number},valueField:{type:String,default:"id"},formatter:{type:Function},maxHeight:{type:Number,default:350},repositoryToken:{type:Symbol,default:null},editorParams:{type:Object},customRowStatus:{type:Object,default:null},searchHandler:{type:Function,default:()=>{}}},z=l.defineComponent({name:"FComboTreeContainer",props:$,emits:["selectionChange","selectItem","unSelectItem"],setup(e,t){const a=l.ref(e.data),v=l.ref([]),b=l.ref(e.separator),h=l.ref(e.width),I=l.ref(e.height),T=l.ref(e.maxHeight),S=l.ref(String(e.selectedValues).split(b.value)),V=l.ref(),w={customRowStatus:e.customRowStatus};l.watch(()=>e.selectedValues,i=>{S.value=String(i).split(b.value)}),l.watch(()=>e.data,i=>{var g;a.value=i,(g=V.value)==null||g.updateDataSource(i)});const d={enableSelectRow:!0,multiSelect:e.multiSelect,showCheckbox:e.multiSelect,multiSelectMode:"OnCheckAndClick"};let n=null;e.repositoryToken&&(n=l.inject(e.repositoryToken));const c=l.computed(()=>[{field:e.textField,title:"",dataType:"string",formatter:e.formatter}]),u=l.computed(()=>{const i={};return h.value!==void 0&&(i.width=`${h.value}px`),I.value!==void 0&&(i.height=`${I.value}px`),T.value!==void 0&&T.value>0&&(i.maxHeight=`${T.value}px`,i.overflow="auto"),a.value.length===0&&(i.height="200px"),i.position="relative",i});function f(i=[]){i&&i.length>0?(v.value=[...i],S.value=v.value.map(g=>g[e.idField])):(v.value=[],S.value=[]),t.emit("selectionChange",v.value)}l.onMounted(()=>{n&&n.getData(e.editorParams).then(i=>{a.value=i}),S.value&&V.value.activeRowById(S.value[0])});const o=i=>{V.value.selectItemByIds(i)};return t.expose({treeInstance:V,checkItems:o}),()=>l.createVNode("div",{class:"f-combo-tree-container",style:u.value},[e.multiSelect&&e.enableSearch&&l.createVNode("div",{class:"p-2",style:"position: sticky;top:0;z-index: 2; background:white",onMousedown:i=>i.stopPropagation()},[l.createVNode(G.FInputGroup,{buttonContent:'<i class="f-icon f-icon-search"></i>',enableClear:!0,placeholder:"请输入搜索内容",onClear:()=>t.emit("clearSearch"),onInput:(i,g)=>e.searchHandler(g)},null)]),l.createVNode(U,{ref:V,fit:!0,data:a.value,idField:e.idField,columns:c.value,"selection-values":S.value,onSelectionUpdate:f,columnOption:{fitColumns:!0,fitMode:"expand"},rowOption:w,selection:d,rowNumber:{enable:!1},onSelectItem:i=>t.emit("selectItem",i.raw),onUnSelectItem:i=>t.emit("unSelectItem",i.raw)},null)])}});function X(e){const t=l.ref(""),a=l.ref(e.modelValue),v=l.ref(e.data||[]),b=l.ref(e.editable);function h(d,n=[]){return d=d||[],d.reduce((c,u)=>(u.id=u.id||u.data[e.idField],c.push(u),u.children&&u.children.length&&h(u.children,c),c),n)}function I(d){const n=String(d).split(e.separator).map((o,i)=>[o,i]),c=new Map(n),u=[];return h(v.value,u),u.filter(o=>{const i=o.data?String(o.data[e.valueField]):String(o[e.valueField]);return c.has(i)}).map(o=>o.data?o.data:o).sort((o,i)=>{const g=c.get(String(o[e.valueField]))||0,k=c.get(String(i[e.valueField]))||0;return g-k})}function T(d){const n=I(d),c=e.displayFormatter?e.displayFormatter(n):n.map(u=>u[e.textField]).join(e.separator);t.value=b.value?c||d:c}function S(d){const n=d.split(e.separator).map(f=>[f,!0]),c=new Map(n);let u=[];return v.value[0].data?h(v.value,u):u=v.value,u=u.map(f=>f.data?f.data:f),u.filter(f=>c.has(f[e.textField])||c.has(f[e.valueField]))}function V(d){const n={};return n[e.idField]=d,n[e.textField]=d,[n]}function w(d){let n=S(d);const c=n&&n.length>0;return b.value&&!c&&(n=V(d)),n}return l.watch(()=>e.data,()=>{v.value=e.data}),l.watch([v],([d])=>{if(e.modelValue){const n=d.find(c=>c[e.valueField]===e.modelValue);n&&(t.value=n[e.textField])}}),l.watch(()=>e.modelValue,(d,n)=>{d!==n&&(a.value=d,T(d))}),T(e.modelValue),{dataSource:v,displayText:t,editable:b,modelValue:a,getItemsByDisplayText:S,getItemsByValue:I,getSelectedItemsByDisplayText:w,flatTreeNodes:h}}function J(e,t){const{comboEditorRef:a,dataSource:v,searchFields:b,originalValue:h,showPopover:I,flatTreeNodes:T}=e;function S(u,f){u.forEach(o=>{const i=f.find(g=>g.id===o.id);o.selectable=i.selectable!=null?!!i.selectable:!0,o.children&&S(o.children,f)})}function V(u,f){const o=(u.children||[]).map(g=>V(g,f)).filter(g=>g!==null);return b.value.some(g=>{var k;return(k=u.data[g])==null?void 0:k.toString().toLowerCase().includes(f.toLowerCase())})?{data:{...u.data},children:u.children,id:u.data[t]}:o.length>0?{data:{...u.data},children:o,id:u.data[t]}:null}function w(){h.value=E.cloneDeep(v.value)}function d(u){var o;if(I.value||(o=a.value)==null||o.showPopup(),!u){w();return}const f=v.value.map(i=>V(i,u)).filter(i=>i!==null);if(f.length){const i=[];T(v.value,i),S(f,i)}h.value=E.cloneDeep(f)}const n=E.debounce(u=>{var o;const f=(o=u.target)==null?void 0:o.value;d(f)},200);function c(u){var o;let f=(o=u.target)==null?void 0:o.value;f!==""&&(f=f.trim()),u.target._value!==f&&n(u)}return{onValueChange:c,resetDataSource:w}}const A=l.defineComponent({name:"FComboTree",props:Y,emits:["clear","update:modelValue","change","search"],setup(e,t){const a=l.ref(),v=l.ref(e.disabled),b=l.ref(e.enableClear),h=l.ref(e.enableSearch),I=l.ref(e.readonly),T=l.ref(e.searchFields||[e.textField]),S=l.ref(),V=l.ref();let w={};const{dataSource:d,displayText:n,editable:c,modelValue:u,flatTreeNodes:f}=X(e),o=l.computed(()=>e.multiSelect);l.computed(()=>a.value?a.value.elementRef.getBoundingClientRect().width:0);const i=l.computed(()=>{var F;const s=(F=a.value)==null?void 0:F.popoverRef;return s?s.shown:!1}),{onValueChange:g,resetDataSource:k}=J({comboEditorRef:a,dataSource:d,searchFields:T,originalValue:S,showPopover:i,flatTreeNodes:f},e.idField);function R(){!o.value&&a.value&&a.value.hidePopup()}const P=s=>{const F=s==null?void 0:s.map(x=>x.data||x);return e.displayFormatter?e.displayFormatter(F):F.map(x=>x[e.textField]).join(e.separator)};function r(s=[]){if(!o.value)n.value=P(s),u.value=s.map(F=>F.data?F.data[e.valueField]:F[e.valueField]).join(e.separator),t.emit("update:modelValue",u.value),t.emit("change",s,u.value);else{const F=Object.keys(w),x=Object.values(w);n.value=P(x),u.value=F.join(e.separator),t.emit("update:modelValue",u.value),t.emit("change",x,u.value)}R()}function m(s){var F;u.value="",w={},i.value&&((F=a.value)==null||F.hidePopup()),t.emit("update:modelValue",""),t.emit("change",null,u.value),t.emit("clear")}function C(s){o.value&&(delete w[s.id],r())}function L(s){o.value&&(w[s.id]=s.data,r())}l.watch([()=>e.disabled,()=>e.editable,()=>e.enableClear,()=>e.enableSearch,()=>e.readonly],([s,F,x,M,te])=>{v.value=s,c.value=F,b.value=x,h.value=M,I.value=te});const B=()=>{if(S.value=E.cloneDeep(d.value),o.value&&u.value){const s=[];f(d.value,s),u.value.split(e.separator).reduce((F,x)=>(F[x]=s.find(M=>M.id===x),F),w)}};function D(){k(),setTimeout(()=>{var s;(s=V.value)==null||s.checkItems(u.value.split(e.separator))})}return()=>l.createVNode(H,{ref:a,id:e.id,disable:v.value,readonly:I.value,forcePlaceholder:e.forcePlaceholder,editable:c.value&&!e.multiSelect,buttonContent:e.dropDownIcon,placeholder:e.placeholder,enableClear:b.value,maxLength:e.maxLength,tabIndex:e.tabIndex,enableTitle:e.enableTitle,inputType:e.viewType,popupOnClick:!0,modelValue:n.value,"onUpdate:modelValue":s=>n.value=s,onClear:m,onInput:g,focusOnCreated:e.focusOnCreated,selectOnCreated:e.selectOnCreated,beforeOpen:B,placement:e.placement,popupMinWidth:e.minPanelWidth},{default:()=>[i.value&&l.createVNode(z,{ref:V,maxHeight:e.maxHeight,multiSelect:e.multiSelect,enableSearch:e.enableSearch,idField:e.idField,valueField:e.valueField,textField:e.textField,titleField:e.titleField,data:S.value,selectedValues:u.value,onSelectionChange:r,formatter:e.formatter,editorParams:e.editorParams,repositoryToken:e.repositoryToken,customRowStatus:e.customRowStatus,searchHandler:g,onUnSelectItem:C,onSelectItem:L,onClearSearch:D},null)]})}});W.withInstall(A);const q=e=>((e.raw.$type!=="SimpleField"||e.raw.selectable===!1)&&(e.disabled=!0),e);function K(e){const t=[{value:"",label:" "},{value:"(",label:"("},{value:"((",label:"(("},{value:"(((",label:"((("}],a=[{value:"",label:" "},{value:")",label:")"},{value:"))",label:"))"},{value:")))",label:")))"}],v=[{label:"=",value:0},{label:"<>",value:1},{label:">",value:2},{label:">=",value:3},{label:"<",value:4},{label:"<=",value:5},{label:"like %...%",value:6},{label:"like ...%",value:7},{label:"like %...",value:8},{label:"not like %...%",value:9},{label:"not like ...%",value:10},{label:"not like %...",value:11},{label:"is",value:12},{label:"is not",value:13},{label:"in",value:14},{label:"not in",value:15}],b=[{label:" ",value:0},{label:"并且",value:1},{label:"或者",value:2}],h=[{label:"值",value:e!=null&&e.singleValue?N.Value:N.Variable}],I={label:"表达式",value:N.Expression},T=e!=null&&e.enableExpression?[...h,I]:h;return{leftBracketItems:t,righttBracketItems:a,compareOperators:v,relationItems:b,valueTypes:T,sortTypes:[{label:"升序",value:"asc"},{label:"降序",value:"desc"}]}}function Q(e){function t(a,v,b="filterField"){return l.createVNode(A,{formatter:e.formatter,modelValue:a[b],"onUpdate:modelValue":h=>a[b]=h,data:v,textField:e.textField||"name",valueField:e.valueField||"path",idField:e.idField||"id",enableClear:!1,minPanelWidth:220,customRowStatus:q},null)}return{renderFieldsComboTree:t}}function Z(e,t){const a=l.ref(-1);function v(){return t.value[a.value]}function b(){t.value.length>0?a.value=0:a.value=-1}const h=l.computed(()=>e.displayText?e.displayText:typeof e.modelValue=="string"?e.modelValue:""),I=e.editorType!=="sort"?"filterField":"sortField",T=e.editorType!=="sort"?{filterField:"",value:"",lbracket:"",rbracket:"",relation:O.Empty,compare:j.Equal,expresstype:e.singleValue?N.Value:N.Variable}:{sortField:"",sortType:"asc"},S=l.computed(()=>t.value.length>0),V=l.computed(()=>(r="down")=>t.value.length>1?r==="up"?a.value>0:a.value<t.value.length-1:!1);function w(){if(e.editorType==="filter")for(let r=0;r<t.value.length-1;r++){const m=t.value[r];(m.relation===O.Empty||!m.relation)&&(m.relation=O.And)}}function d(){const r=Object.assign({},T);t.value=[...t.value,r];const m=t.value.length-1;a.value=m,w()}function n({index:r}){const m=Object.assign({},T);e.insertType==="above"?r===0?t.value.unshift(m):t.value.splice(r,0,m):t.value.splice(r+1,0,m),t.value=[...t.value],w()}function c({index:r}){t.value.splice(r,1),t.value=[...t.value],!(a.value<0)&&(r===a.value?t.value[r]?a.value=r:t.value[r-1]?a.value=r-1:a.value=-1:r<a.value&&(t.value[a.value-1]?a.value=a.value-1:t.value[a.value]||(a.value=-1)))}function u(){t.value=[]}function f(){a.value>=0&&(t.value.unshift(v()),t.value.splice(a.value+1,1),a.value=0)}function o(){if(a.value>=0){const r=a.value,m=t.value.splice(r,1);t.value.splice(r-1,0,...m),a.value=r-1}}function i(){if(a.value>=0){const r=a.value,m=t.value.splice(r,1);t.value.splice(r+1,0,...m),a.value=r+1}}function g(){a.value>=0&&(t.value.push(v()),t.value.splice(a.value,1),a.value=t.value.length-1)}function k({index:r}){a.value=r}function R(r){if(r.length%2!==0)return!1;let m="";for(const C of r)if(C==="(")m+=C;else if(C===")"){if(!m.endsWith("("))return!1;m=m.slice(0,-1)}return m.length===0}function P(){const r=t.value.length;if(!r)return!0;let m=!0,C=!0;if(e.editorType!=="sort"){t.value[r-1].relation=O.Empty,C=!t.value.slice(0,-1).some(s=>s.relation===O.Empty||!s.relation);const D=t.value.flatMap(s=>[s.lbracket,s.rbracket]).join("");m=R(D)}const L=t.value.some(B=>!B[I]);return[{result:m,message:"括号不匹配,请检查。"},{result:C,message:"关系设置不完整,请检查。"},{result:!L,message:"字段不允许为空,请检查。"}].find(B=>!B.result)}return{displayText:h,activeRowIndex:a,canClear:S,canMove:V,onAddFilter:d,onRemove:c,onInsert:n,onClear:u,onMoveTop:f,onMovePrev:o,onMoveNext:i,onMoveBottom:g,onSelectRow:k,validateCondition:P,resetActiveRow:b}}function ee(e,t,a){const v=l.ref(e.activeIndex),b=l.ref(e.conditions),h=l.ref(e.fields);l.watch(()=>e.fields,n=>{h.value=n}),l.watch(()=>e.conditions,n=>{b.value=n}),l.watch(()=>e.activeIndex,n=>{v.value=n});const I=l.computed(()=>a.value.querySelector(`tr[index="${v.value}"]`));function T(){const n=I.value;n&&(n.scrollIntoView?n.scrollIntoView({block:"center",behavior:"smooth"}):n.scrollIntoViewIfNeeded&&n.scrollIntoViewIfNeeded(!1))}const S=l.computed(()=>n=>({"fv-grid-row-selected":n===v.value}));function V(n,c){c.stopPropagation(),t.emit("insert",{index:n,$event:c})}function w(n,c){c.stopPropagation(),t.emit("remove",{index:n,$event:c})}function d(n,c){t.emit("rowClick",{item:n,index:c})}return{itemIntoView:T,activeRowCls:S,fields:h,activeIndex:v,selectedRowRef:I,conditions:b,tbodyRef:a,onInsert:V,onRemove:w,onRowClick:d}}y.Compare=j,y.FilterRelation=O,y.SortType=p,y.ValueType=N,y.filterConditionEditorProps=_,y.treeNodeStatus=q,y.useConditionData=Z,y.useConditionEditor=ee,y.useConstantData=K,y.useFieldsTree=Q,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})});