plain-design 1.0.0-beta.98 → 3.0.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 (501) hide show
  1. package/dist/plain-design.commonjs.min.js +2 -18
  2. package/dist/plain-design.commonjs.min.js.LICENSE.txt +18 -0
  3. package/dist/plain-design.min.css +25 -24
  4. package/dist/plain-design.min.js +2 -18
  5. package/dist/plain-design.min.js.LICENSE.txt +18 -0
  6. package/dist/report.html +3 -3
  7. package/package.json +43 -40
  8. package/src/packages/components/$address/createAddressService.tsx +8 -3
  9. package/src/packages/components/$ai/index.tsx +368 -0
  10. package/src/packages/components/$configuration/index.tsx +4 -2
  11. package/src/packages/components/$file/index.tsx +44 -1
  12. package/src/packages/components/$imageSelector/index.tsx +56 -0
  13. package/src/packages/components/$message/image.service.utils.tsx +1 -1
  14. package/src/packages/components/$object/createObjectService.tsx +8 -6
  15. package/src/packages/components/$object/object.conver.ts +3 -3
  16. package/src/packages/components/$object/object.service.utils.ts +2 -2
  17. package/src/packages/components/$ov/createOvService.ts +2 -2
  18. package/src/packages/components/$previewer/ImagePreviewerFixedContainer.tsx +6 -6
  19. package/src/packages/components/$previewer/index.tsx +1 -1
  20. package/src/packages/components/$search/SearchFooter.tsx +1 -1
  21. package/src/packages/components/$search/SearchList.tsx +2 -2
  22. package/src/packages/components/$search/SearchServicePanel.tsx +4 -4
  23. package/src/packages/components/$search/createSearchService.tsx +1 -1
  24. package/src/packages/components/$search/search-service.scss +1 -0
  25. package/src/packages/components/$search/search.utils.tsx +1 -1
  26. package/src/packages/components/$upload/upload.utils.ts +7 -6
  27. package/src/packages/components/Address/index.tsx +2 -2
  28. package/src/packages/components/AddressCascade/address-cascade.utils.ts +1 -1
  29. package/src/packages/components/AddressCascade/createAddressCascade.hooks.ts +1 -1
  30. package/src/packages/components/AddressCascade/createAddressCascade.multiple.tsx +5 -6
  31. package/src/packages/components/AddressCascade/createAddressCascade.single.tsx +6 -7
  32. package/src/packages/components/AddressCascade/index.tsx +1 -1
  33. package/src/packages/components/AiChatBox/ai-chat-box.scss +74 -0
  34. package/src/packages/components/AiChatBox/index.tsx +306 -0
  35. package/src/packages/components/Alert/index.tsx +1 -1
  36. package/src/packages/components/Application/index.tsx +1 -1
  37. package/src/packages/components/Application/service/createApplicationService.tsx +2 -2
  38. package/src/packages/components/Application/service/createApplicationServiceComponent.tsx +1 -1
  39. package/src/packages/components/Application/service/createApplicationServiceManager.tsx +2 -2
  40. package/src/packages/components/Application/service/useApplicationService.tsx +3 -3
  41. package/src/packages/components/Application/utils/application.utils.ts +3 -4
  42. package/src/packages/components/Application/utils/createServiceReadyObserver.ts +1 -1
  43. package/src/packages/components/ArrowStep/index.tsx +1 -1
  44. package/src/packages/components/ArrowStepGroup/index.tsx +2 -2
  45. package/src/packages/components/AutoLoadingObserver/index.tsx +3 -3
  46. package/src/packages/components/AutoTable/AutoTable.tsx +1 -1
  47. package/src/packages/components/AutoTable/auto-table.scss +35 -4
  48. package/src/packages/components/AutoTable/createTableOptionUser.tsx +3 -1
  49. package/src/packages/components/AutoTable/filter/useTableOption.filter.form.tsx +8 -5
  50. package/src/packages/components/AutoTable/filter/useTableOption.filter.search.tsx +2 -2
  51. package/src/packages/components/AutoTable/filter/useTableOption.filter.state.ts +12 -7
  52. package/src/packages/components/AutoTable/setting/useTableOption.setting.all.fitler.tsx +1 -1
  53. package/src/packages/components/AutoTable/setting/useTableOption.setting.cache.tsx +3 -3
  54. package/src/packages/components/AutoTable/setting/useTableOption.setting.config.tsx +59 -17
  55. package/src/packages/components/AutoTable/setting/useTableOption.setting.export.tsx +5 -30
  56. package/src/packages/components/AutoTable/setting/useTableOption.setting.import.tsx +3 -3
  57. package/src/packages/components/AutoTable/setting/useTableOption.setting.senior.filter.tsx +388 -385
  58. package/src/packages/components/AutoTable/setting/useTableOption.setting.senior.sort.tsx +15 -8
  59. package/src/packages/components/AutoTable/setting/useTableOption.setting.tsx +109 -109
  60. package/src/packages/components/AutoTable/setting/useTableOption.setting.utils.ts +2 -2
  61. package/src/packages/components/AutoTable/use/useTableOption.ai.tsx +640 -0
  62. package/src/packages/components/AutoTable/use/useTableOption.buttons.tsx +27 -17
  63. package/src/packages/components/AutoTable/use/useTableOption.cache.ts +2 -2
  64. package/src/packages/components/AutoTable/use/useTableOption.check.tsx +3 -3
  65. package/src/packages/components/AutoTable/use/useTableOption.column.popper.tsx +5 -5
  66. package/src/packages/components/AutoTable/use/useTableOption.confirm.tsx +2 -2
  67. package/src/packages/components/AutoTable/use/useTableOption.fill.tsx +8 -8
  68. package/src/packages/components/AutoTable/use/useTableOption.hooks.tsx +6 -4
  69. package/src/packages/components/AutoTable/use/useTableOption.loading.tsx +3 -3
  70. package/src/packages/components/AutoTable/use/useTableOption.methods.tsx +7 -4
  71. package/src/packages/components/AutoTable/use/useTableOption.pagination.tsx +3 -3
  72. package/src/packages/components/AutoTable/use/useTableOption.parent.tsx +5 -2
  73. package/src/packages/components/AutoTable/use/useTableOption.permission.tsx +1 -1
  74. package/src/packages/components/AutoTable/use/useTableOption.sort.ts +8 -7
  75. package/src/packages/components/AutoTable/use/useTableOption.state.tsx +1 -1
  76. package/src/packages/components/AutoTable/use/useTableOption.table.tsx +14 -5
  77. package/src/packages/components/AutoTable/use/useTableOption.tips.tsx +3 -3
  78. package/src/packages/components/AutoTable/use/useTableOptionKeyboard.tsx +13 -4
  79. package/src/packages/components/AutoTable/utils/AutoModule.ts +1 -1
  80. package/src/packages/components/AutoTable/utils/AutoTable.utils.ts +76 -1
  81. package/src/packages/components/AutoTable/utils/TableOption.space.tsx +10 -6
  82. package/src/packages/components/AutoTable/utils/TableOption.url.ts +1 -1
  83. package/src/packages/components/AutoTable/utils/TableOption.utils.tsx +3 -3
  84. package/src/packages/components/AutoTable/utils/buildPlainDefaultUrlConfig.ts +6 -6
  85. package/src/packages/components/AutoWidthInput/index.tsx +2 -2
  86. package/src/packages/components/Badge/badge.scss +4 -0
  87. package/src/packages/components/Badge/index.tsx +1 -1
  88. package/src/packages/components/Box/index.tsx +31 -30
  89. package/src/packages/components/Button/index.tsx +11 -4
  90. package/src/packages/components/ButtonGroup/index.tsx +2 -2
  91. package/src/packages/components/Card/index.tsx +2 -2
  92. package/src/packages/components/Carousel/index.tsx +8 -8
  93. package/src/packages/components/CarouselItem/index.tsx +3 -3
  94. package/src/packages/components/Cascade/CascadeKeys.tsx +158 -0
  95. package/src/packages/components/Cascade/cascade.utils.ts +1 -1
  96. package/src/packages/components/Cascade/createCascadeHooks.ts +1 -1
  97. package/src/packages/components/Cascade/createCascadePopper.tsx +5 -4
  98. package/src/packages/components/Cascade/createCascadeUtils.ts +2 -2
  99. package/src/packages/components/Cascade/createMultipleCascadeRender.tsx +5 -6
  100. package/src/packages/components/Cascade/createSingleCascadeRender.tsx +7 -7
  101. package/src/packages/components/Cascade/index.tsx +3 -3
  102. package/src/packages/components/CascadeKeys/index.tsx +5 -0
  103. package/src/packages/components/CascadePanel/cascade-panel.utils.ts +3 -3
  104. package/src/packages/components/CascadePanel/flat/CascadeFlatPanelNode.tsx +1 -1
  105. package/src/packages/components/CascadePanel/flat/createCascadeFlatRender.tsx +14 -9
  106. package/src/packages/components/CascadePanel/index.tsx +22 -4
  107. package/src/packages/components/CascadePanel/list/CascadeListPanelItem.tsx +1 -1
  108. package/src/packages/components/CascadePanel/list/CascadeListPanelNode.tsx +1 -1
  109. package/src/packages/components/CascadePanel/list/createCascadeListRender.tsx +6 -2
  110. package/src/packages/components/Checkbox/index.tsx +8 -10
  111. package/src/packages/components/CheckboxGroup/index.tsx +1 -1
  112. package/src/packages/components/CheckboxInner/index.tsx +1 -1
  113. package/src/packages/components/Collapse/index.tsx +2 -2
  114. package/src/packages/components/CollapseGroup/index.tsx +1 -1
  115. package/src/packages/components/CollapseTransition/index.tsx +5 -5
  116. package/src/packages/components/ColorPicker/ColorPanel.tsx +146 -125
  117. package/src/packages/components/ColorPicker/color-panel.scss +117 -97
  118. package/src/packages/components/ColorPicker/index.tsx +144 -131
  119. package/src/packages/components/ColorPicker/sub/ColorAlphaSlider.tsx +1 -1
  120. package/src/packages/components/ColorPicker/sub/ColorHueSlider.tsx +1 -1
  121. package/src/packages/components/ColorPicker/sub/ColorSlider.tsx +5 -5
  122. package/src/packages/components/ColorPicker/sub/ColorSvPanel.tsx +4 -4
  123. package/src/packages/components/ColorPicker/useColorPanelEditor.tsx +1 -1
  124. package/src/packages/components/ColorPicker/useColorPanelHistory.tsx +1 -1
  125. package/src/packages/components/ColorPicker/utils/color-picker.utils.tsx +1 -1
  126. package/src/packages/components/ConfirmPopup/index.tsx +1 -1
  127. package/src/packages/components/Corner/index.tsx +3 -3
  128. package/src/packages/components/DatePicker/createDateRender.multiple.tsx +7 -7
  129. package/src/packages/components/DatePicker/createDateRender.single.tsx +8 -7
  130. package/src/packages/components/DatePicker/createRangeDateRender.range.tsx +3 -3
  131. package/src/packages/components/DatePicker/createRangeDateRender.separate.tsx +3 -3
  132. package/src/packages/components/DatePicker/date.utils.tsx +2 -2
  133. package/src/packages/components/DatePicker/index.tsx +3 -1
  134. package/src/packages/components/DatePicker/panel/DatePanel.tsx +1 -1
  135. package/src/packages/components/DatePicker/panel/DatePanelDate.tsx +2 -2
  136. package/src/packages/components/DatePicker/panel/DatePanelMonth.tsx +1 -1
  137. package/src/packages/components/DatePicker/panel/DatePanelQuarter.tsx +1 -1
  138. package/src/packages/components/DatePicker/panel/DatePanelRange.tsx +1 -1
  139. package/src/packages/components/DatePicker/panel/DatePanelWeek.tsx +1 -1
  140. package/src/packages/components/DatePicker/panel/DatePanelYear.tsx +1 -1
  141. package/src/packages/components/DatePicker/panel/useDatePanel.tsx +2 -2
  142. package/src/packages/components/DatePicker/panel/useDateWeek.tsx +2 -2
  143. package/src/packages/components/DatePicker/useRangeDateRender.tsx +8 -8
  144. package/src/packages/components/Dialog/dialog.scss +2 -2
  145. package/src/packages/components/Dialog/index.tsx +11 -7
  146. package/src/packages/components/Dialog/useDialogMovable.tsx +1 -1
  147. package/src/packages/components/Dialog/utils/dialog.utils.ts +1 -1
  148. package/src/packages/components/Dropdown/dropdown.utils.tsx +2 -3
  149. package/src/packages/components/Dropdown/index.tsx +18 -5
  150. package/src/packages/components/DropdownGroup/index.tsx +1 -1
  151. package/src/packages/components/DropdownOption/index.tsx +2 -2
  152. package/src/packages/components/DropdownSeparator/index.tsx +1 -1
  153. package/src/packages/components/Empty/index.tsx +1 -1
  154. package/src/packages/components/FilterFormMultiple/index.tsx +12 -7
  155. package/src/packages/components/FilterFormSingle/index.tsx +178 -173
  156. package/src/packages/components/FilterService/filter/filter.city.tsx +4 -3
  157. package/src/packages/components/FilterService/filter/filter.district.tsx +4 -3
  158. package/src/packages/components/FilterService/filter/filter.number.tsx +2 -2
  159. package/src/packages/components/FilterService/filter/filter.province.tsx +1 -1
  160. package/src/packages/components/FilterService/filter/filter.select.tsx +3 -2
  161. package/src/packages/components/FilterService/filter/fitler.object.tsx +1 -1
  162. package/src/packages/components/FilterService/index.tsx +2 -2
  163. package/src/packages/components/FilterService/utils/filter.service.utils.ts +2 -2
  164. package/src/packages/components/FilterService/utils/mergeQueryParam.ts +3 -3
  165. package/src/packages/components/Form/form.scss +4 -0
  166. package/src/packages/components/Form/index.tsx +1 -1
  167. package/src/packages/components/Form/layout/useFormLayout.tsx +6 -5
  168. package/src/packages/components/Form/types/any.tsx +1 -1
  169. package/src/packages/components/Form/types/array.tsx +1 -1
  170. package/src/packages/components/Form/types/date.tsx +1 -1
  171. package/src/packages/components/Form/types/number.tsx +1 -1
  172. package/src/packages/components/Form/types/string.tsx +1 -1
  173. package/src/packages/components/Form/validate/createValidation.tsx +2 -2
  174. package/src/packages/components/Form/validate/useFormItemValidation.tsx +32 -31
  175. package/src/packages/components/Form/validate/useFormValidation.tsx +2 -2
  176. package/src/packages/components/Form/validate/validate.utils.tsx +4 -4
  177. package/src/packages/components/FormItem/FormItemValidateMessage.tsx +1 -1
  178. package/src/packages/components/FormItem/createFormEditor.tsx +2 -2
  179. package/src/packages/components/FormItem/index.tsx +8 -1
  180. package/src/packages/components/Grid/GridCol.tsx +1 -1
  181. package/src/packages/components/Grid/GridRow.tsx +3 -3
  182. package/src/packages/components/Icon/icon.external.tsx +117 -0
  183. package/src/packages/components/Icon/icon.registry.tsx +2 -2
  184. package/src/packages/components/Icon/index.tsx +13 -7
  185. package/src/packages/components/IconPicker/DefaultIcons.ts +7 -0
  186. package/src/packages/components/IconPicker/icon-picker.scss +43 -0
  187. package/src/packages/components/IconPicker/index.tsx +189 -0
  188. package/src/packages/components/Illustration/index.tsx +1 -1
  189. package/src/packages/components/Image/image.scss +11 -2
  190. package/src/packages/components/Image/index.tsx +27 -18
  191. package/src/packages/components/ImagePreviewer/ImagePreviewer.tsx +6 -6
  192. package/src/packages/components/ImagePreviewer/ImagePreviewerButtonBar.tsx +1 -1
  193. package/src/packages/components/ImagePreviewer/ImagePreviewerCarouselImage.tsx +2 -2
  194. package/src/packages/components/ImagePreviewer/ImagePreviewerGallery.tsx +3 -3
  195. package/src/packages/components/ImagePreviewer/PreviewerLoading.tsx +1 -1
  196. package/src/packages/components/ImagePreviewer/image-previewer.utils.tsx +4 -4
  197. package/src/packages/components/ImageSelector/image-selector.scss +70 -0
  198. package/src/packages/components/ImageSelector/index.tsx +59 -0
  199. package/src/packages/components/ImageUploader/index.tsx +41 -23
  200. package/src/packages/components/Input/index.scss +14 -2
  201. package/src/packages/components/Input/index.tsx +3 -3
  202. package/src/packages/components/Input/input.utils.ts +1 -1
  203. package/src/packages/components/Input/useMultipleInput.tsx +11 -10
  204. package/src/packages/components/Input/useSingleInput.tsx +2 -2
  205. package/src/packages/components/Input/useSuggestionInput.tsx +9 -9
  206. package/src/packages/components/Input/useTextareaInput.tsx +6 -6
  207. package/src/packages/components/Input/uses/useInputEnterHandler.tsx +24 -13
  208. package/src/packages/components/Input/uses/useInputHooks.tsx +1 -1
  209. package/src/packages/components/Input/uses/useInputMaxLength.tsx +1 -1
  210. package/src/packages/components/Input/uses/useInputSuffixIcon.tsx +2 -2
  211. package/src/packages/components/InputGroup/index.tsx +1 -1
  212. package/src/packages/components/InputGroup/input-group.scss +9 -0
  213. package/src/packages/components/InputNumber/NumberResize.tsx +4 -4
  214. package/src/packages/components/InputNumber/index.tsx +1 -1
  215. package/src/packages/components/InputNumber/input-number.utils.tsx +1 -1
  216. package/src/packages/components/InputNumber/number.scss +3 -0
  217. package/src/packages/components/InputNumber/number.utils.ts +1 -1
  218. package/src/packages/components/InputNumber/useInputNumber.multiple.tsx +2 -2
  219. package/src/packages/components/InputNumber/useInputNumber.public.tsx +12 -11
  220. package/src/packages/components/InputNumber/useInputNumber.single.tsx +2 -2
  221. package/src/packages/components/Layout/index.tsx +9 -2
  222. package/src/packages/components/Layout/layout.scss +20 -0
  223. package/src/packages/components/Layout/layout.utils.ts +1 -1
  224. package/src/packages/components/LayoutSection/index.tsx +12 -3
  225. package/src/packages/components/LayoutSection/useLayoutSectionResizer.tsx +2 -2
  226. package/src/packages/components/List/index.tsx +1 -1
  227. package/src/packages/components/ListOption/index.tsx +20 -0
  228. package/src/packages/components/ListPanel/index.tsx +30 -0
  229. package/src/packages/components/ListPanel/list-panel.scss +20 -0
  230. package/src/packages/components/Loading/index.tsx +2 -2
  231. package/src/packages/components/LoadingMask/index.tsx +2 -2
  232. package/src/packages/components/NumberRange/index.tsx +94 -93
  233. package/src/packages/components/Object/createObjectHooks.tsx +1 -1
  234. package/src/packages/components/Object/createObjectRender.multiple.tsx +10 -10
  235. package/src/packages/components/Object/createObjectRender.single.tsx +18 -14
  236. package/src/packages/components/Object/index.tsx +3 -3
  237. package/src/packages/components/Object/object.scss +6 -0
  238. package/src/packages/components/Object/object.utils.ts +5 -3
  239. package/src/packages/components/Ov/index.tsx +1 -1
  240. package/src/packages/components/Ov/ov.utils.ts +1 -1
  241. package/src/packages/components/Ov/usePublicOv.tsx +1 -1
  242. package/src/packages/components/PageCard/index.tsx +4 -1
  243. package/src/packages/components/PageCardContent/index.tsx +4 -1
  244. package/src/packages/components/PageCardTitle/index.tsx +1 -1
  245. package/src/packages/components/PageRenderList/index.tsx +1 -1
  246. package/src/packages/components/PageThemeUtils/index.tsx +3 -3
  247. package/src/packages/components/Pagination/index.tsx +3 -3
  248. package/src/packages/components/Paragraph/index.tsx +1 -1
  249. package/src/packages/components/ParagraphItem/index.tsx +1 -1
  250. package/src/packages/components/PlcImage/index.tsx +14 -8
  251. package/src/packages/components/PlcObject/index.tsx +2 -2
  252. package/src/packages/components/PlcOv/index.tsx +1 -1
  253. package/src/packages/components/Popup/PopupProvider.tsx +1 -2
  254. package/src/packages/components/Popup/index.tsx +2 -2
  255. package/src/packages/components/ProgressBar/index.tsx +1 -1
  256. package/src/packages/components/ProgressBar/progress.utils.ts +2 -2
  257. package/src/packages/components/ProgressCircle/index.tsx +2 -2
  258. package/src/packages/components/ProgressMini/index.tsx +2 -2
  259. package/src/packages/components/Radio/index.tsx +4 -4
  260. package/src/packages/components/RadioGroup/index.tsx +1 -1
  261. package/src/packages/components/RadioInner/index.tsx +1 -1
  262. package/src/packages/components/Rate/index.tsx +3 -3
  263. package/src/packages/components/Reference/ReferenceProvider.tsx +1 -1
  264. package/src/packages/components/Reference/index.tsx +1 -1
  265. package/src/packages/components/RollingNumber/index.tsx +2 -2
  266. package/src/packages/components/Scroll/HorizontalScrollbar.tsx +4 -4
  267. package/src/packages/components/Scroll/VerticalScrollbar.tsx +4 -4
  268. package/src/packages/components/Scroll/index.tsx +6 -5
  269. package/src/packages/components/Scroll/useAutoScroll.ts +1 -1
  270. package/src/packages/components/Segment/index.tsx +1 -1
  271. package/src/packages/components/SegmentGroup/index.tsx +1 -1
  272. package/src/packages/components/Select/SelectPanel.tsx +1 -1
  273. package/src/packages/components/Select/createMultipleSelectRender.tsx +12 -8
  274. package/src/packages/components/Select/createPublicSelectRender.tsx +18 -12
  275. package/src/packages/components/Select/createSelectOptionDecoder.tsx +1 -1
  276. package/src/packages/components/Select/createSingleSelectRender.tsx +13 -9
  277. package/src/packages/components/Select/decodeSelectRenderNode.tsx +6 -4
  278. package/src/packages/components/Select/index.tsx +13 -1
  279. package/src/packages/components/Select/select.utils.tsx +5 -4
  280. package/src/packages/components/SelectDisplay/index.tsx +3 -3
  281. package/src/packages/components/SelectGroup/index.tsx +1 -1
  282. package/src/packages/components/SelectOption/index.tsx +2 -2
  283. package/src/packages/components/Skeleton/index.tsx +44 -0
  284. package/src/packages/components/Skeleton/skeleton.scss +27 -0
  285. package/src/packages/components/Slider/index.tsx +3 -3
  286. package/src/packages/components/Slider/slider.utils.tsx +1 -1
  287. package/src/packages/components/Slider/useSlider.range.tsx +13 -10
  288. package/src/packages/components/Slider/useSlider.single.tsx +8 -9
  289. package/src/packages/components/Slider/useSliderDotDragier.tsx +4 -4
  290. package/src/packages/components/SortList/index.tsx +4 -4
  291. package/src/packages/components/Space/index.tsx +1 -1
  292. package/src/packages/components/StackCard/index.tsx +4 -4
  293. package/src/packages/components/StackCardItem/index.tsx +1 -1
  294. package/src/packages/components/Step/index.tsx +1 -1
  295. package/src/packages/components/StepGroup/index.tsx +1 -1
  296. package/src/packages/components/Tab/index.tsx +1 -1
  297. package/src/packages/components/TabGroup/TabsHeader.tsx +1 -1
  298. package/src/packages/components/TabGroup/TabsInner.tsx +1 -1
  299. package/src/packages/components/TabGroup/header/horizontal/TabsHeaderHorizontal.tsx +3 -3
  300. package/src/packages/components/TabGroup/header/horizontal/TabsHeaderHorizontalCard.tsx +1 -1
  301. package/src/packages/components/TabGroup/header/horizontal/TabsHeaderHorizontalShadow.tsx +1 -1
  302. package/src/packages/components/TabGroup/header/horizontal/TabsHeaderHorizontalText.tsx +2 -2
  303. package/src/packages/components/TabGroup/header/vertical/TabsHeaderVertical.tsx +1 -1
  304. package/src/packages/components/TabGroup/index.tsx +1 -1
  305. package/src/packages/components/TabGroup/tabs.scss +23 -0
  306. package/src/packages/components/TabGroup/tabs.utils.tsx +1 -1
  307. package/src/packages/components/Table/editor/PlcAddress.tsx +1 -1
  308. package/src/packages/components/Table/editor/PlcAddressItem.tsx +1 -1
  309. package/src/packages/components/Table/editor/PlcCheckbox.tsx +1 -1
  310. package/src/packages/components/Table/editor/PlcColorPicker.tsx +1 -1
  311. package/src/packages/components/Table/editor/PlcDate.tsx +1 -1
  312. package/src/packages/components/Table/editor/PlcDate.utils.tsx +2 -2
  313. package/src/packages/components/Table/editor/PlcDateRange.tsx +1 -1
  314. package/src/packages/components/Table/editor/PlcInput.tsx +1 -1
  315. package/src/packages/components/Table/editor/PlcNumber.tsx +1 -1
  316. package/src/packages/components/Table/editor/PlcRate.tsx +1 -1
  317. package/src/packages/components/Table/editor/PlcSelect.tsx +2 -1
  318. package/src/packages/components/Table/editor/PlcTextarea.tsx +1 -1
  319. package/src/packages/components/Table/editor/PlcTime.tsx +1 -1
  320. package/src/packages/components/Table/editor/PlcTime.utils.ts +2 -2
  321. package/src/packages/components/Table/editor/PlcTimeRange.tsx +1 -1
  322. package/src/packages/components/Table/editor/PlcToggle.tsx +1 -1
  323. package/src/packages/components/Table/plc/group/PlcGroup.tsx +1 -1
  324. package/src/packages/components/Table/plc/plc/Plc.tsx +1 -1
  325. package/src/packages/components/Table/plc/process/copyPlcList.ts +1 -1
  326. package/src/packages/components/Table/plc/process/processPlcFixed.ts +1 -1
  327. package/src/packages/components/Table/plc/process/processPlcSort.ts +1 -1
  328. package/src/packages/components/Table/plc/use/useBasePlc.tsx +3 -3
  329. package/src/packages/components/Table/plc/use/useBasePlcGroup.tsx +1 -1
  330. package/src/packages/components/Table/plc/use/usePlc.tsx +1 -1
  331. package/src/packages/components/Table/plc/use/usePlcPropsState.tsx +2 -2
  332. package/src/packages/components/Table/plc/use/useTableAutoSpan.tsx +112 -0
  333. package/src/packages/components/Table/plc/useTablePlc.tsx +7 -4
  334. package/src/packages/components/Table/plc/utils/plc.render.ts +1 -1
  335. package/src/packages/components/Table/plc/utils/plc.scope-slots.ts +1 -1
  336. package/src/packages/components/Table/plc/utils/plc.utils.ts +9 -6
  337. package/src/packages/components/Table/standard/PlcCheck/PlcCheck.hooks.tsx +3 -3
  338. package/src/packages/components/Table/standard/PlcCheck/PlcCheck.multiple.tsx +7 -8
  339. package/src/packages/components/Table/standard/PlcCheck/PlcCheck.single.tsx +4 -5
  340. package/src/packages/components/Table/standard/PlcCheck/PlcCheck.tsx +2 -2
  341. package/src/packages/components/Table/standard/PlcCheck/PlcCheck.utils.ts +3 -3
  342. package/src/packages/components/Table/standard/PlcDraggier/PlcDraggier.tsx +2 -2
  343. package/src/packages/components/Table/standard/PlcExclusion.tsx +2 -2
  344. package/src/packages/components/Table/standard/PlcExpand.tsx +2 -2
  345. package/src/packages/components/Table/standard/PlcIndex.tsx +1 -1
  346. package/src/packages/components/Table/standard/PlcOperation/OuterOperation.tsx +3 -2
  347. package/src/packages/components/Table/standard/PlcOperation/PlcOperation.tsx +12 -6
  348. package/src/packages/components/Table/standard/PlcOperation/PlcOperation.utils.tsx +4 -4
  349. package/src/packages/components/Table/standard/PlcOperation/useOperationPermission.ts +1 -1
  350. package/src/packages/components/Table/standard/PlcTree/PlcTree.autoWidth.tsx +1 -1
  351. package/src/packages/components/Table/standard/PlcTree/PlcTree.renderNode.tsx +2 -2
  352. package/src/packages/components/Table/standard/PlcTree/PlcTree.tsx +4 -4
  353. package/src/packages/components/Table/standard/PlcTree/PlcTree.utils.ts +2 -2
  354. package/src/packages/components/Table/standard/PlcTree/PlcTreeHeader.tsx +3 -3
  355. package/src/packages/components/Table/standard/PlcTree/RenderPlcTreeNode.tsx +6 -5
  356. package/src/packages/components/Table/table/Table.tsx +14 -10
  357. package/src/packages/components/Table/table/body/cell.tsx +36 -5
  358. package/src/packages/components/Table/table/body/row.tsx +1 -1
  359. package/src/packages/components/Table/table/body/useCellValue.tsx +15 -6
  360. package/src/packages/components/Table/table/head/head-cell.tsx +8 -2
  361. package/src/packages/components/Table/table/head/useHeadCellResize.ts +4 -4
  362. package/src/packages/components/Table/table/node/useTableNode.tsx +2 -2
  363. package/src/packages/components/Table/table/table.scss +4 -0
  364. package/src/packages/components/Table/table/use/useFixedShadow.ts +2 -2
  365. package/src/packages/components/Table/table/use/useTableDraggier.col.tsx +6 -6
  366. package/src/packages/components/Table/table/use/useTableDraggier.row.tsx +7 -7
  367. package/src/packages/components/Table/table/use/useTableDraggier.tsx +3 -3
  368. package/src/packages/components/Table/table/use/useTableFormEditor.tsx +47 -39
  369. package/src/packages/components/Table/table/use/useTableLoading.tsx +2 -2
  370. package/src/packages/components/Table/table/use/useTableMethods.tsx +2 -2
  371. package/src/packages/components/Table/table/use/useTableModifyEditor.tsx +12 -6
  372. package/src/packages/components/Table/table/use/useTableScroll.tsx +1 -1
  373. package/src/packages/components/Table/table/utils/createTableHooks.ts +7 -5
  374. package/src/packages/components/Table/table/utils/table.utils.ts +7 -5
  375. package/src/packages/components/Tag/index.tsx +8 -3
  376. package/src/packages/components/Tag/tag.scss +10 -1
  377. package/src/packages/components/ThemeColor/index.tsx +1 -1
  378. package/src/packages/components/ThemeColorSelector/index.tsx +1 -1
  379. package/src/packages/components/ThemeDarkSelector/index.tsx +1 -2
  380. package/src/packages/components/ThemeEditor/index.tsx +3 -3
  381. package/src/packages/components/ThemeLocaleSelector/index.tsx +1 -2
  382. package/src/packages/components/ThemeShapeSelector/index.tsx +1 -2
  383. package/src/packages/components/ThemeSizeSelector/index.tsx +1 -2
  384. package/src/packages/components/TimePicker/createRangeTimeRender.tsx +3 -3
  385. package/src/packages/components/TimePicker/createSeparateRangeTimeRender.tsx +3 -3
  386. package/src/packages/components/TimePicker/createSingleTimeRender.tsx +7 -8
  387. package/src/packages/components/TimePicker/index.tsx +1 -1
  388. package/src/packages/components/TimePicker/panel/TimeBaseColumn.tsx +4 -4
  389. package/src/packages/components/TimePicker/panel/TimeBasePanel.tsx +1 -1
  390. package/src/packages/components/TimePicker/panel/TimePanel.tsx +2 -2
  391. package/src/packages/components/TimePicker/panel/TimeRangePanel.tsx +1 -1
  392. package/src/packages/components/TimePicker/panel/time-panel.utils.ts +1 -1
  393. package/src/packages/components/TimePicker/time.utils.ts +1 -1
  394. package/src/packages/components/TimePicker/useRangeTimeRender.tsx +9 -9
  395. package/src/packages/components/TimePicker/useTimeHooks.ts +1 -1
  396. package/src/packages/components/Toggle/index.tsx +4 -4
  397. package/src/packages/components/Tooltip/index.tsx +2 -2
  398. package/src/packages/components/Transition/index.tsx +2 -2
  399. package/src/packages/components/Tree/RenderTreeNode.tsx +4 -3
  400. package/src/packages/components/Tree/index.tsx +2 -2
  401. package/src/packages/components/TreeCore/TreeCore.type.tsx +3 -1
  402. package/src/packages/components/TreeCore/createTreeCore.tsx +3 -3
  403. package/src/packages/components/TreeCore/createTreeDraggier.tsx +9 -9
  404. package/src/packages/components/TreeCore/createTreeHooks.ts +1 -1
  405. package/src/packages/components/TreeCore/createTreeMethods.tsx +2 -2
  406. package/src/packages/components/TreeCore/createTreeNode.tsx +11 -6
  407. package/src/packages/components/TreeCore/createTreeProps.ts +4 -3
  408. package/src/packages/components/TreeCore/createTreeUtils.ts +2 -2
  409. package/src/packages/components/TreeNodeWithMenu/index.tsx +5 -1
  410. package/src/packages/components/TreeNodeWithMenu/treeNodeWithMenu.utils.ts +1 -1
  411. package/src/packages/components/Triangle/index.tsx +2 -2
  412. package/src/packages/components/Upload/index.tsx +6 -6
  413. package/src/packages/components/VirtualList/createVirtualDraggier.ts +7 -7
  414. package/src/packages/components/VirtualList/index.tsx +1 -1
  415. package/src/packages/components/VirtualList/useVirtualList.tsx +11 -11
  416. package/src/packages/components/VirtualTable/index.tsx +10 -4
  417. package/src/packages/components/VirtualTable/virtual-table.scss +3 -3
  418. package/src/packages/components/createPlainAddressService/index.tsx +2 -2
  419. package/src/packages/components/createRequestInterceptor/index.ts +2 -2
  420. package/src/packages/components/createScrollDraggier/index.ts +5 -5
  421. package/src/packages/components/createScrollUtils/index.tsx +1 -1
  422. package/src/packages/components/createSimpleDate/index.ts +49 -0
  423. package/src/packages/components/createTransitionHandler/index.ts +1 -1
  424. package/src/packages/components/useAutoScrollUtils/index.tsx +4 -4
  425. package/src/packages/components/useContextmenuOptions/index.tsx +40 -0
  426. package/src/packages/components/useDialog/DialogService.tsx +10 -10
  427. package/src/packages/components/useDialog/dialog.service.utils.tsx +5 -5
  428. package/src/packages/components/useDialog/index.tsx +4 -4
  429. package/src/packages/components/useImage/ImageService.tsx +5 -5
  430. package/src/packages/components/useLoading/LoadingService.tsx +3 -3
  431. package/src/packages/components/useLoading/index.tsx +1 -1
  432. package/src/packages/components/useLoading/loading.service.utils.tsx +2 -2
  433. package/src/packages/components/useMessage/Message.tsx +1 -1
  434. package/src/packages/components/useMessage/MessageContainer.tsx +1 -1
  435. package/src/packages/components/useMessage/MessageManager.tsx +1 -1
  436. package/src/packages/components/useMessage/index.tsx +1 -1
  437. package/src/packages/components/useMessage/message.service.utils.tsx +4 -4
  438. package/src/packages/components/useNotice/Notice.tsx +1 -1
  439. package/src/packages/components/useNotice/NoticeContainer.tsx +1 -1
  440. package/src/packages/components/useNotice/NoticeManager.tsx +1 -1
  441. package/src/packages/components/useNotice/index.tsx +1 -1
  442. package/src/packages/components/useNotice/noitice.service.utils.tsx +4 -4
  443. package/src/packages/components/usePageRenderContext/index.tsx +1 -1
  444. package/src/packages/components/usePopup/PopupItem.tsx +17 -10
  445. package/src/packages/components/usePopup/refresh/refreshArrow.ts +1 -1
  446. package/src/packages/components/usePopup/trigger/useManagerTrigger.clickOutside.tsx +19 -24
  447. package/src/packages/components/usePopup/trigger/usePopupTrigger.tsx +2 -2
  448. package/src/packages/components/usePopup/trigger/useReferenceTrigger.tsx +52 -46
  449. package/src/packages/components/usePopup/usePopup.tsx +2 -2
  450. package/src/packages/components/usePopup/usePopupManager.tsx +14 -3
  451. package/src/packages/components/usePopup/utils/createPopupManagerHooks.tsx +1 -1
  452. package/src/packages/components/usePopup/utils/ids2map.ts +1 -1
  453. package/src/packages/components/usePopup/utils/popup.utils.ts +3 -4
  454. package/src/packages/components/usePopupEditor/index.tsx +6 -9
  455. package/src/packages/components/usePopupEditor/popup-editor.utils.ts +1 -1
  456. package/src/packages/components/useTableFilter/index.ts +73 -0
  457. package/src/packages/components/useTooltip/index.tsx +6 -7
  458. package/src/packages/directives/ClickWave/index.tsx +2 -2
  459. package/src/packages/directives/ResizeDetector/index.tsx +2 -2
  460. package/src/packages/entry.tsx +326 -287
  461. package/src/packages/i18n/i18n.utils.ts +5 -5
  462. package/src/packages/i18n/lang/en-us.ts +37 -14
  463. package/src/packages/i18n/lang/zh-cn.ts +24 -1
  464. package/src/packages/styles/application/application.public.scss +7 -0
  465. package/src/packages/styles/global.import.scss +60 -15
  466. package/src/packages/uses/createInputPopperAttrs.ts +10 -3
  467. package/src/packages/uses/useCollapseStyles.tsx +2 -2
  468. package/src/packages/uses/useDragHorizontalScroll.ts +4 -5
  469. package/src/packages/uses/useEdit.ts +42 -15
  470. package/src/packages/uses/useFocusHandler.ts +26 -13
  471. package/src/packages/uses/useFunctionWrapper.ts +3 -1
  472. package/src/packages/uses/useMultipleModel.tsx +6 -4
  473. package/src/packages/uses/useRenderReference.tsx +1 -1
  474. package/src/packages/uses/useStyle.tsx +4 -4
  475. package/src/packages/utils/ClientZoom.ts +1 -1
  476. package/src/packages/utils/FixInput.ts +1 -1
  477. package/src/packages/utils/InnerTransition.ts +2 -2
  478. package/src/packages/utils/LoadingText.ts +1 -1
  479. package/src/packages/utils/OpenController.ts +1 -1
  480. package/src/packages/utils/constant.tsx +1 -1
  481. package/src/packages/utils/createDraggier.ts +7 -7
  482. package/src/packages/utils/createFlagManager.ts +1 -1
  483. package/src/packages/utils/findReactElement.tsx +1 -1
  484. package/src/packages/utils/getDeviceInfo.ts +1 -1
  485. package/src/packages/utils/getRowEl.ts +2 -2
  486. package/src/packages/utils/incrementalMerge.ts +1 -1
  487. package/src/packages/utils/inheritSlots.ts +3 -1
  488. package/src/packages/utils/installAllIcons.ts +20 -19
  489. package/src/packages/utils/installAllLazyIcons.ts +1 -1
  490. package/src/packages/utils/isObjectCommonMatch.ts +1 -1
  491. package/src/packages/utils/onParentElementsScroll.tsx +2 -2
  492. package/src/packages/utils/plainDate.ts +1 -1
  493. package/src/packages/utils/useMove.tsx +3 -3
  494. package/src/packages/utils/watchEffectAutoClear.ts +2 -2
  495. package/src/packages/components/KeyboardService/index.ts +0 -214
  496. package/src/packages/components/ThemeDarkSelector/theme-dark-selector.scss +0 -5
  497. package/src/packages/components/ThemeLocaleSelector/theme-locale-selector.scss +0 -5
  498. package/src/packages/components/ThemeShapeSelector/theme-shape-selector.scss +0 -5
  499. package/src/packages/components/ThemeSizeSelector/theme-size-selector.scss +0 -5
  500. package/src/packages/components/createProvider/index.ts +0 -5
  501. package/src/packages/utils/createProvider.tsx +0 -35
@@ -1,385 +1,388 @@
1
- import {eAutoTableFilterMode} from "../filter/useTableOption.filter.state";
2
- import {computed, Fragment, iMouseEvent, reactive, RenderNode, useRefList} from "plain-design-composition";
3
- import {FilterFormSingle, iFilterFormSingleData} from "../../FilterFormSingle";
4
- import {eTableOptionSettingView} from "./useTableOption.setting.utils";
5
- import {Button} from "../../Button";
6
- import {Checkbox} from "../../Checkbox";
7
- import {Input} from "../../Input";
8
- import {Empty} from "../../Empty";
9
- import {iFilterQueryMeta} from "../../FilterService/utils/filter.service.utils";
10
- import {$message} from "../../$message";
11
- import {delay} from "plain-utils/utils/delay";
12
- import {Icon} from "../../Icon";
13
- import {doNothing} from "plain-utils/utils/doNothing";
14
- import {deepcopy} from "plain-utils/object/deepcopy";
15
- import {TableOptionSpace} from "../utils/TableOption.space";
16
- import '../utils/TableOption.space';
17
- import {TableOptionUtils} from "../utils/TableOption.utils";
18
- import i18n from "../../i18n";
19
- import {AutoModule} from "../utils/AutoModule";
20
-
21
- declare module '../utils/TableOption.space' {
22
- namespace TableOptionSpace {
23
- interface iTableOption {
24
- settingSeniorFilter: ReturnType<typeof useTableOptionSettingSeniorFilter>;
25
- }
26
- }
27
- }
28
-
29
- export const useTableOptionSettingSeniorFilter = AutoModule.createRegistration((
30
- {
31
- cache,
32
- setting,
33
- hooks,
34
- methods,
35
- filterState,
36
- }
37
- ) => {
38
-
39
- const { refList, onRefList } = useRefList(FilterFormSingle);
40
-
41
- const filterOptions = filterState.createComputedFilterOptions(eAutoTableFilterMode.filterSenior);
42
-
43
- const utils = {
44
- nextId: (() => {
45
- const maxCount = computed(() => {
46
- const max = edit.state.metas.reduce((prev, item) => {
47
- let [_, val] = item.id.split('_');
48
- const v = Number(val);
49
- return !isNaN(v) && v > prev ? v : prev;
50
- }, 0);
51
- return Math.max(max, edit.state.metas.length);
52
- });
53
- return () => `F_${maxCount.value + 1}`;
54
- })(),
55
- resetOperator: () => {
56
- edit.state.expression = edit.defaultExpression.value;
57
- },
58
- createState: () => {
59
- const state: iTableOptionSeniorData = reactive({
60
- metas: [],
61
- expression: null,
62
- isCustomExpression: false,
63
- });
64
- const defaultExpression = computed(() => state.metas.map(i => i.id).join(` ${DEFAULT_EXPRESSION_JOIN} `));
65
- return {
66
- state, defaultExpression,
67
- };
68
- },
69
- };
70
-
71
- /**
72
- * 查询的时候的数据
73
- * @author 韦胜健
74
- * @date 2021/7/22 21:05
75
- */
76
- const query = (() => {
77
- const { state, defaultExpression } = utils.createState();
78
-
79
- const apply = async () => {
80
- await delay();
81
- const dataList = refList.length === 0 ? [] : await Promise.all(refList.map(i => i.getData()));
82
- const metas = !isSettingSeniorOpen() ? edit.state.metas : dataList.map((data, index) => ({ data, id: edit.state.metas[index].id }));
83
- const invalidIndex = metas.findIndex(i => !i.data || !i.data.filterQueryParam || !i.data.filterQueryParam.queries?.length);
84
- if (invalidIndex > -1) {
85
- $message.error(i18n.$it('table.pleaseEnterCompleteParamsForCondition').d(`第${invalidIndex + 1}个条件请输入完整参数!`));
86
- return;
87
- }
88
- state.metas = metas;
89
- state.expression = edit.state.expression;
90
- state.isCustomExpression = edit.state.isCustomExpression;
91
- await methods.pageMethods.reload();
92
- };
93
-
94
- return {
95
- state,
96
- defaultExpression,
97
- apply,
98
- };
99
- })();
100
-
101
- /**
102
- * 编辑的时候的数据
103
- * @author 韦胜健
104
- * @date 2021/7/22 21:05
105
- */
106
- const edit = (() => {
107
-
108
- /**
109
- * 状态需要与query同步初始化,因为应用的时候可能filter form single没有初始化,此时应该用edit的状态
110
- * 因为 edit.remove 删除的是edit内部的状态
111
- * @author 韦胜健
112
- * @date 2023.1.15 22:11
113
- */
114
- const { state, defaultExpression } = {
115
- state: reactive(deepcopy(query.state)),
116
- defaultExpression: query.defaultExpression,
117
- };
118
-
119
- const add = () => {
120
- const id = utils.nextId();
121
- if (state.metas.length === 0) {
122
- state.expression = id;
123
- } else {
124
- state.expression += ` ${DEFAULT_EXPRESSION_JOIN} ${id}`;
125
- }
126
- state.metas.push({ id, data: undefined });
127
- };
128
-
129
- const remove = (index: number) => {
130
- const isMatchDefaultOperator = !!state.expression && state.expression.trim() === defaultExpression.value;
131
- state.metas.splice(index, 1);
132
- if (isMatchDefaultOperator) {state.expression = defaultExpression.value;}
133
- };
134
-
135
- const clear = () => {
136
- state.metas = [];
137
- state.expression = null;
138
- query.apply();
139
- };
140
-
141
- return {
142
- state,
143
- defaultExpression,
144
- add,
145
- remove,
146
- clear,
147
- };
148
- })();
149
-
150
- cache.registry<iTableOptionSeniorData>({
151
- cacheKey: 'filter-state-senior',
152
- applyCache: ({ plcList, cacheData }) => {
153
- query.state.isCustomExpression = !cacheData ? false : cacheData.isCustomExpression;
154
- query.state.expression = !cacheData ? null : cacheData.expression;
155
- query.state.metas = !cacheData ? [] : cacheData.metas.map(item => {
156
- /*有些字段可能从代码中去掉了,这里将无效的字段对应的缓存筛选条件去除*/
157
- if (!item.data?.field) {return null;}
158
- const { field } = item.data || {};
159
- const plc = plcList.find(i => i.props.searchField === field || i.props.field === field);
160
- if (!plc) {return null;}
161
- return item;
162
- }).filter(Boolean) as iTableOptionSeniorFilterMeta[];
163
- /*同步edit与query的状态*/
164
- edit.state.metas = deepcopy(query.state.metas);
165
- edit.state.expression = query.state.expression;
166
- edit.state.isCustomExpression = query.state.isCustomExpression;
167
- },
168
- getCache: () => {
169
- return {
170
- expression: query.state.expression,
171
- metas: query.state.metas,
172
- isCustomExpression: query.state.isCustomExpression,
173
- };
174
- },
175
- });
176
-
177
- const { isOpen: isSettingSeniorOpen } = setting.useTableOptionSettingInner({
178
- key: eTableOptionSettingView.seniorFilter,
179
- title: i18n.$it('table.seniorFilter').d('高级筛选'),
180
- seq: 1,
181
- beforeOpen: () => {
182
- edit.state.metas = deepcopy(query.state.metas);
183
- edit.state.expression = query.state.expression;
184
- edit.state.isCustomExpression = query.state.isCustomExpression;
185
- },
186
- render: () => {
187
- refList.splice(0, refList.length);
188
- return (
189
- <div className="auto-table-setting-senior-filter">
190
- <div className="auto-table-setting-senior-filter-button">
191
- <div>
192
- <Button label={i18n.$it('base.edit.apply').d('应用')} onClick={query.apply} mode="fill" icon="pi-find-replace"/>
193
- <Button label={i18n.$it('base.edit.add').d('添加')} onClick={edit.add} icon="pi-plus"/>
194
- </div>
195
- <Button label={i18n.$it('base.clear').d('清空')} icon="pi-delete" status="error" onClick={edit.clear}/>
196
- </div>
197
- <div className="auto-table-setting-senior-filter-list">
198
- {edit.state.metas.length === 0 ? (
199
- <Empty noData label={i18n.$it('table.pleaseAddFilterCondition').d('请添加筛选条件')}/>
200
- ) : (
201
- edit.state.metas.map((meta, index) => (
202
- <div key={meta.id} className="auto-table-setting-senior-filter-list-item">
203
- <FilterFormSingle
204
- ref={onRefList(index)}
205
- filterOptions={filterOptions.value}
206
- initialState={meta.data}
207
- onSearch={query.apply}
208
- width="calc(100% - 40px)"
209
- hideSearchButton
210
- v-slots={{
211
- prepend: () => (<Input readonly modelValue={meta.id} width={60}/>)
212
- }}
213
- />
214
- <Button icon="pi-delete" onClick={() => edit.remove(index)}/>
215
- </div>
216
- ))
217
- )}
218
- </div>
219
- <div className="auto-table-setting-senior-filter-expression-header">
220
- <div className="auto-table-setting-senior-filter-expression-title">{i18n.$it('table.expression').d('表达式')}</div>
221
- </div>
222
- <Input textarea v-model={edit.state.expression} disabled={!edit.state.isCustomExpression}/>
223
- <Checkbox label={i18n.$it('base.custom').d('自定义')} v-model={edit.state.isCustomExpression} onChange={utils.resetOperator}/>
224
- </div>
225
- );
226
- },
227
- });
228
-
229
- /**
230
- * 获取查询参数时返回当前绑定的参数
231
- * @author 韦胜健
232
- * @date 2023.1.8 19:09
233
- */
234
- hooks.onQueryParam.use(async () => {
235
- let expression = !query.state.isCustomExpression || !query.state.expression ? query.defaultExpression.value : query.state.expression;
236
- /*处理空格*/
237
- expression = expression.replace(/\s*(\|\||&&|或者|并且|or|and)\s*/gi, ' $1 ').replace(/\s+/, ' ');
238
- /*目标queries数组*/
239
- const resultQueries: iFilterQueryMeta[] = [];
240
-
241
- /*id映射senior meta查询参数*/
242
- const idToSeniorMeta: Record<string, iTableOptionSeniorFilterMeta & { index: number }> = query.state.metas.reduce((prev, item) => {
243
- prev[item.id] = item;
244
- return prev;
245
- }, {} as any);
246
-
247
- expression = expression.replace(/\w+/g, (input) => {
248
- if (ExpressionJoins.indexOf(input) > -1) {return input;}
249
- const senior = idToSeniorMeta[input];
250
- if (!senior || !senior.data) {return input;}
251
- const { queries } = senior.data.filterQueryParam;
252
- if (!queries || queries.length === 0) {return input;}
253
- if (queries.length === 1) {
254
- queries[0].id = input;
255
- resultQueries.push(...queries);
256
- return input;
257
- }
258
- const itemQueryIds: string[] = [];
259
- queries.forEach((i, idx) => {
260
- const itemId = `${input}-${idx + 1}`;
261
- itemQueryIds.push(itemId);
262
- resultQueries.push({
263
- ...i,
264
- id: itemId,
265
- });
266
- });
267
- return `(${itemQueryIds.join(' 并且 ')})`;
268
- });
269
-
270
- // console.log(resultQueries.length === 0 ? null : { queries: resultQueries, expression: expression });
271
-
272
- return resultQueries.length === 0 ? null : { queries: resultQueries, expression: expression };
273
- });
274
-
275
- /*只显示激活的筛选条件*/
276
- filterState.useState<any>({
277
- seq: Infinity,
278
- key: 'senior-filter',
279
- title: i18n.$it('table.seniorQuery').d('高级查询'),
280
- applyCache: () => null,
281
- getCache: () => null,
282
- getDisplay: () => () => (
283
- <Button onClick={() => setting.openSetting(eTableOptionSettingView.seniorFilter)}>
284
- <span>{i18n.$it('table.configSeniorFilter').d('配置高级筛选')}</span>
285
- <Icon icon="pi-arrow-right"/>
286
- </Button>
287
- ),
288
- clear: () => null,
289
- getActiveFilterCount: () => query.state.metas.length
290
- });
291
-
292
- const tips = computed((): TableOptionSpace.iTableOptionTipMeta[] => {
293
- const list: TableOptionSpace.iTableOptionTipMeta[] = [];
294
- const { metas, expression, isCustomExpression } = query.state;
295
- if (!metas.length || !filterOptions.value) {return list;}
296
- if (metas.every(i => !i.data?.filterQueryParam.queries?.length)) {return list;}
297
- if (!isCustomExpression) {
298
- metas.forEach((meta, index) => {
299
- if (!meta.data) {return;}
300
- const { field, filterHandler, formData } = meta.data;
301
- let filterOption = filterOptions.value!.find(i => i.field === field);
302
- if (!filterOption) {return;}
303
- filterOption = { ...filterOption, filterHandler };
304
- const tip = TableOptionUtils.createTableOptionTipMeta({
305
- formData,
306
- filterOption,
307
- onClear: async () => {
308
- edit.remove(index);
309
- await delay();
310
- await query.apply();
311
- },
312
- onClick: () => {setting.openSetting(eTableOptionSettingView.seniorFilter);},
313
- });
314
- !!tip && list.push(tip);
315
- });
316
- } else {
317
- if (!expression || !filterOptions.value.length) {return list;}
318
- /*id映射senior meta查询参数*/
319
- const idToSeniorMeta: Record<string, iTableOptionSeniorFilterMeta & { index: number }> = query.state.metas.reduce((prev, item) => {
320
- prev[item.id] = item;
321
- return prev;
322
- }, {} as any);
323
- const renderList: (() => RenderNode)[] = [];
324
- expression.split(' ').forEach(work => {
325
- if (!work.trim().length) {return; }
326
- if (ExpressionJoins.indexOf(work) > -1) {
327
- renderList.push(() => work);
328
- return;
329
- }
330
- const senior = idToSeniorMeta[work];
331
- if (!senior || !senior.data) {
332
- renderList.push(() => work);
333
- return;
334
- }
335
- const { filterHandler, field, formData } = senior.data;
336
- let filterOption = filterOptions.value!.find(i => i.field === field);
337
- if (!filterOption) {
338
- renderList.push(() => work);
339
- return;
340
- }
341
- filterOption = { ...filterOption, filterHandler };
342
- const tip = TableOptionUtils.createTableOptionTipMeta({
343
- filterOption,
344
- formData,
345
- onClick: doNothing,
346
- onClear: doNothing,
347
- });
348
- if (!tip) {
349
- renderList.push(() => work);
350
- return;
351
- }
352
- renderList.push(tip.display);
353
- });
354
- list.push({
355
- display: () => renderList.map((i, index) => <Fragment key={index}>{i()}</Fragment>),
356
- onClear: async (e: iMouseEvent) => {
357
- e.stopPropagation();
358
- Object.assign(edit.state, utils.createState().state);
359
- await query.apply();
360
- },
361
- onClick: () => {setting.openSetting(eTableOptionSettingView.seniorFilter);},
362
- });
363
- }
364
- return list;
365
- });
366
-
367
- hooks.onTips.use(list => {
368
- !!tips.value.length && list.push(...tips.value);
369
- });
370
- });
371
-
372
- export type iTableOptionSeniorFilterMeta = {
373
- id: string,
374
- data: undefined | iFilterFormSingleData,
375
- }
376
-
377
- export interface iTableOptionSeniorData {
378
- metas: iTableOptionSeniorFilterMeta[],
379
- expression: null | string,
380
- isCustomExpression: boolean,
381
- }
382
-
383
- const ExpressionJoins = ['&&', '||', 'and', 'or', '并且', '或者'];
384
-
385
- const DEFAULT_EXPRESSION_JOIN = '或者';
1
+ import {eAutoTableFilterMode} from "../filter/useTableOption.filter.state";
2
+ import {computed, Fragment, iMouseEvent, reactive, RenderNode, useRefList} from "@peryl/react-compose";
3
+ import {FilterFormSingle, iFilterFormSingleData} from "../../FilterFormSingle";
4
+ import {eTableOptionSettingView} from "./useTableOption.setting.utils";
5
+ import {Button} from "../../Button";
6
+ import {Checkbox} from "../../Checkbox";
7
+ import {Input} from "../../Input";
8
+ import {Empty} from "../../Empty";
9
+ import {iFilterQueryMeta} from "../../FilterService/utils/filter.service.utils";
10
+ import {$message} from "../../$message";
11
+ import {delay} from "@peryl/utils/delay";
12
+ import {Icon} from "../../Icon";
13
+ import {doNothing} from "@peryl/utils/doNothing";
14
+ import {deepcopy} from "@peryl/utils/deepcopy";
15
+ import {TableOptionSpace} from "../utils/TableOption.space";
16
+ import '../utils/TableOption.space';
17
+ import {TableOptionUtils} from "../utils/TableOption.utils";
18
+ import i18n from "../../i18n";
19
+ import {AutoModule} from "../utils/AutoModule";
20
+
21
+ declare module '../utils/TableOption.space' {
22
+ namespace TableOptionSpace {
23
+ interface iTableOption {
24
+ settingSeniorFilter: ReturnType<typeof useTableOptionSettingSeniorFilter>;
25
+ }
26
+ }
27
+ }
28
+
29
+ export const useTableOptionSettingSeniorFilter = AutoModule.createRegistration((
30
+ {
31
+ cache,
32
+ setting,
33
+ hooks,
34
+ methods,
35
+ filterState,
36
+ }
37
+ ) => {
38
+
39
+ const { refList, onRefList } = useRefList(FilterFormSingle);
40
+
41
+ const filterOptions = filterState.createComputedFilterOptions(eAutoTableFilterMode.filterSenior);
42
+
43
+ const utils = {
44
+ /*按照F_1, F_2, F_3...的规则生成ID*/
45
+ nextId: (() => {
46
+ /*这里maxCount使用computed,导致出现异常*/
47
+ /*第二次打开高级筛选配置页面的时候,点击添加触发这里会导致内容渲染异常,这里把computed去掉*/
48
+ const maxCount = () => {
49
+ const max = edit.state.metas.reduce((prev, item) => {
50
+ let [_, val] = item.id.split('_');
51
+ const v = Number(val);
52
+ return !isNaN(v) && v > prev ? v : prev;
53
+ }, 0);
54
+ return Math.max(max, edit.state.metas.length);
55
+ };
56
+ return () => `F_${maxCount() + 1}`;
57
+ })(),
58
+ /*重置查询表达式*/
59
+ resetOperator: () => {
60
+ edit.state.expression = edit.getDefaultExpression();
61
+ },
62
+ /*创建初始状态变量*/
63
+ createState: () => {
64
+ const state: iTableOptionSeniorData = ({
65
+ /*iTableOptionSeniorFilterMeta*/
66
+ metas: [],
67
+ /*查询表达式*/
68
+ expression: null,
69
+ /*当前是否开启自定义表达式*/
70
+ isCustomExpression: true,
71
+ });
72
+ /*默认的查询表达式*/
73
+ const getDefaultExpression = (): string => state.metas.map(i => i.id).join(` ${DEFAULT_EXPRESSION_JOIN} `);
74
+ return {
75
+ state, getDefaultExpression,
76
+ };
77
+ },
78
+ };
79
+
80
+ /**
81
+ * 查询的时候的数据
82
+ * @author 韦胜健
83
+ * @date 2021/7/22 21:05
84
+ */
85
+ const query = (() => {
86
+ const { state: _state, getDefaultExpression } = utils.createState();
87
+ const state = reactive(_state);
88
+
89
+ const apply = async (autoReload: boolean) => {
90
+ await delay();
91
+ const dataList = refList.length === 0 ? [] : await Promise.all(refList.map(i => i.getData()));
92
+ const metas = !isSettingSeniorOpen() ? edit.state.metas : dataList.map((data, index) => ({ data, id: edit.state.metas[index].id }));
93
+ /*检查每一个条件是否输入正确*/
94
+ const invalidIndex = metas.findIndex(i => !i.data || !i.data.filterQueryParam || !i.data.filterQueryParam.queries?.length);
95
+ if (invalidIndex > -1) {
96
+ $message.error(i18n.$it('table.pleaseEnterCompleteParamsForCondition', { invalidIndex: invalidIndex + 1 }).d(`第${invalidIndex + 1}个条件请输入完整参数!`));
97
+ return;
98
+ }
99
+ state.metas = metas;
100
+ state.expression = edit.state.expression;
101
+ state.isCustomExpression = edit.state.isCustomExpression;
102
+
103
+ if (autoReload) {await methods.pageMethods.reload();}
104
+ };
105
+
106
+ return {
107
+ state,
108
+ getDefaultExpression,
109
+ apply,
110
+ };
111
+ })();
112
+
113
+ /**
114
+ * 编辑的时候的数据
115
+ * @author 韦胜健
116
+ * @date 2021/7/22 21:05
117
+ */
118
+ const edit = (() => {
119
+
120
+ /**
121
+ * 状态需要与query同步初始化,因为应用的时候可能filter form single没有初始化,此时应该用edit的状态
122
+ * 因为 edit.remove 删除的是edit内部的状态
123
+ * @author 韦胜健
124
+ * @date 2023.1.15 22:11
125
+ */
126
+ const { state: _state, getDefaultExpression } = utils.createState();
127
+ const state = reactive(_state);
128
+
129
+ const add = () => {
130
+ const id = utils.nextId();
131
+ if (state.metas.length === 0) {
132
+ state.expression = id;
133
+ } else {
134
+ state.expression += ` ${DEFAULT_EXPRESSION_JOIN} ${id}`;
135
+ }
136
+ state.metas.push({ id, data: undefined });
137
+ };
138
+
139
+ const remove = (index: number) => {
140
+ const isMatchDefaultOperator = !!state.expression && state.expression.trim() === getDefaultExpression();
141
+ state.metas.splice(index, 1);
142
+ if (isMatchDefaultOperator) {state.expression = getDefaultExpression();}
143
+ };
144
+
145
+ const clear = async (autoReload: boolean) => {
146
+ Object.assign(state, utils.createState().state);
147
+ await query.apply(autoReload);
148
+ };
149
+
150
+ return {
151
+ state,
152
+ getDefaultExpression,
153
+
154
+ add,
155
+ remove,
156
+ clear,
157
+ };
158
+ })();
159
+
160
+ cache.registry<iTableOptionSeniorData>({
161
+ cacheKey: 'filter-state-senior',
162
+ applyCache: ({ plcList, cacheData }) => {
163
+ query.state.isCustomExpression = !cacheData ? false : cacheData.isCustomExpression;
164
+ query.state.expression = !cacheData ? null : cacheData.expression;
165
+ query.state.metas = !cacheData ? [] : cacheData.metas.map(item => {
166
+ /*有些字段可能从代码中去掉了,这里将无效的字段对应的缓存筛选条件去除*/
167
+ if (!item.data?.field) {return null;}
168
+ const { field } = item.data || {};
169
+ const plc = plcList.find(i => i.props.searchField === field || i.props.field === field);
170
+ if (!plc) {return null;}
171
+ return item;
172
+ }).filter(Boolean) as iTableOptionSeniorFilterMeta[];
173
+ /*同步edit与query的状态*/
174
+ edit.state.metas = deepcopy(query.state.metas);
175
+ edit.state.expression = query.state.expression;
176
+ edit.state.isCustomExpression = query.state.isCustomExpression;
177
+ },
178
+ getCache: () => {
179
+ return {
180
+ expression: query.state.expression,
181
+ metas: query.state.metas,
182
+ isCustomExpression: query.state.isCustomExpression,
183
+ };
184
+ },
185
+ });
186
+
187
+ const { isOpen: isSettingSeniorOpen } = setting.useTableOptionSettingInner({
188
+ key: eTableOptionSettingView.seniorFilter,
189
+ title: i18n.$it('table.seniorFilter').d('高级筛选'),
190
+ seq: 1,
191
+ beforeOpen: () => {
192
+ edit.state.metas = deepcopy(query.state.metas);
193
+ edit.state.expression = query.state.expression;
194
+ edit.state.isCustomExpression = query.state.isCustomExpression;
195
+ },
196
+ render: () => {
197
+ refList.splice(0, refList.length);
198
+
199
+ const apply = () => query.apply(true);
200
+ const clear = () => edit.clear(true);
201
+
202
+ return (
203
+ <div className="auto-table-setting-senior-filter">
204
+ <div className="auto-table-setting-senior-filter-button">
205
+ <div>
206
+ <Button label={i18n.$it('base.edit.apply').d('应用')} onClick={apply} mode="fill" icon="pi-find-replace"/>
207
+ <Button label={i18n.$it('base.edit.add').d('添加')} onClick={edit.add} icon="pi-plus"/>
208
+ </div>
209
+ <Button label={i18n.$it('base.clear').d('清空')} icon="pi-delete" status="error" onClick={clear}/>
210
+ </div>
211
+ <div className="auto-table-setting-senior-filter-list">
212
+ {edit.state.metas.length === 0 ? (
213
+ <Empty noData label={i18n.$it('table.pleaseAddFilterCondition').d('请添加筛选条件')}/>
214
+ ) : (
215
+ edit.state.metas.map((meta, index) => (
216
+ <div key={meta.id} className="auto-table-setting-senior-filter-list-item">
217
+ <FilterFormSingle
218
+ ref={onRefList(index)}
219
+ filterOptions={filterOptions.value}
220
+ initialState={meta.data}
221
+ onSearch={apply}
222
+ width="calc(100% - 40px)"
223
+ hideSearchButton
224
+ v-slots={{
225
+ prepend: () => (<Input readonly modelValue={meta.id} width={60}/>)
226
+ }}
227
+ />
228
+ <Button icon="pi-delete" onClick={() => edit.remove(index)}/>
229
+ </div>
230
+ ))
231
+ )}
232
+ </div>
233
+ <div className="auto-table-setting-senior-filter-expression-header">
234
+ <div className="auto-table-setting-senior-filter-expression-title">{i18n.$it('table.expression').d('表达式')}</div>
235
+ </div>
236
+ <Input textarea v-model={edit.state.expression} disabled={!edit.state.isCustomExpression}/>
237
+ <Checkbox label={i18n.$it('base.custom').d('自定义')} v-model={edit.state.isCustomExpression} onChange={utils.resetOperator}/>
238
+ </div>
239
+ );
240
+ },
241
+ });
242
+
243
+ /**
244
+ * 获取查询参数时返回当前绑定的参数
245
+ * @author 韦胜健
246
+ * @date 2023.1.8 19:09
247
+ */
248
+ hooks.onQueryParam.use(async () => {
249
+ let expression = !query.state.isCustomExpression || !query.state.expression ? query.getDefaultExpression() : query.state.expression;
250
+ /*处理空格*/
251
+ expression = expression.replace(/\s*(\|\||&&|或者|并且|or|and)\s*/gi, ' $1 ').replace(/\s+/, ' ');
252
+ /*目标queries数组*/
253
+ const resultQueries: iFilterQueryMeta[] = [];
254
+
255
+ /*id映射senior meta查询参数*/
256
+ const idToSeniorMeta: Record<string, iTableOptionSeniorFilterMeta & { index: number }> = query.state.metas.reduce((prev, item) => {
257
+ prev[item.id] = item;
258
+ return prev;
259
+ }, {} as any);
260
+
261
+ expression = expression.replace(/\w+/g, (input) => {
262
+ if (ExpressionJoins.indexOf(input) > -1) {return input;}
263
+ const senior = idToSeniorMeta[input];
264
+ if (!senior || !senior.data) {return input;}
265
+ const { queries } = senior.data.filterQueryParam;
266
+ if (!queries || queries.length === 0) {return input;}
267
+ if (queries.length === 1) {
268
+ queries[0].id = input;
269
+ resultQueries.push(...queries);
270
+ return input;
271
+ }
272
+ const itemQueryIds: string[] = [];
273
+ queries.forEach((i, idx) => {
274
+ const itemId = `${input}-${idx + 1}`;
275
+ itemQueryIds.push(itemId);
276
+ resultQueries.push({
277
+ ...i,
278
+ id: itemId,
279
+ });
280
+ });
281
+ return `(${itemQueryIds.join(' 并且 ')})`;
282
+ });
283
+
284
+ // console.log(resultQueries.length === 0 ? null : { queries: resultQueries, expression: expression });
285
+
286
+ return resultQueries.length === 0 ? null : { queries: resultQueries, expression: expression };
287
+ });
288
+
289
+ /*只显示激活的筛选条件*/
290
+ filterState.useState<any>({
291
+ seq: Infinity,
292
+ key: 'senior-filter',
293
+ title: i18n.$it('table.seniorQuery').d('高级查询'),
294
+ applyCache: () => null,
295
+ getCache: () => null,
296
+ getDisplay: () => () => (
297
+ <Button onClick={() => setting.openSetting(eTableOptionSettingView.seniorFilter)}>
298
+ <span>{i18n.$it('table.configSeniorFilter').d('配置高级筛选')}</span>
299
+ <Icon icon="pi-arrow-right"/>
300
+ </Button>
301
+ ),
302
+ clear: () => edit.clear(false),
303
+ getActiveFilterCount: () => query.state.metas.length
304
+ });
305
+
306
+ const tips = computed((): TableOptionSpace.iTableOptionTipMeta[] => {
307
+ const list: TableOptionSpace.iTableOptionTipMeta[] = [];
308
+ const { metas } = query.state;
309
+ if (!metas.length || !filterOptions.value) {return list;}
310
+ if (metas.every(i => !i.data?.filterQueryParam.queries?.length)) {return list;}
311
+
312
+ let expression = !query.state.isCustomExpression || !query.state.expression ? query.getDefaultExpression() : query.state.expression;
313
+ /*处理空格*/
314
+ expression = expression.replace(/\s*(\|\||&&|或者|并且|or|and)\s*/gi, ' $1 ').replace(/\s+/, ' ');
315
+
316
+ if (!expression || !filterOptions.value.length) {return list;}
317
+ /*id映射senior meta查询参数*/
318
+ const idToSeniorMeta: Record<string, iTableOptionSeniorFilterMeta & { index: number }> = query.state.metas.reduce((prev, item) => {
319
+ prev[item.id] = item;
320
+ return prev;
321
+ }, {} as any);
322
+ const renderList: (() => RenderNode)[] = [];
323
+ expression.split(' ').forEach(work => {
324
+ if (!work.trim().length) {return; }
325
+ if (ExpressionJoins.indexOf(work) > -1) {
326
+ renderList.push(() => ` ${work} `);
327
+ return;
328
+ }
329
+ const senior = idToSeniorMeta[work];
330
+ if (!senior || !senior.data) {
331
+ renderList.push(() => work);
332
+ return;
333
+ }
334
+ const { filterHandler, field, formData } = senior.data;
335
+ let filterOption = filterOptions.value!.find(i => i.field === field);
336
+ if (!filterOption) {
337
+ renderList.push(() => work);
338
+ return;
339
+ }
340
+ filterOption = { ...filterOption, filterHandler };
341
+ const tip = TableOptionUtils.createTableOptionTipMeta({
342
+ filterOption,
343
+ formData,
344
+ onClick: doNothing,
345
+ onClear: doNothing,
346
+ });
347
+ if (!tip) {
348
+ renderList.push(() => work);
349
+ return;
350
+ }
351
+ renderList.push(tip.display);
352
+ });
353
+ list.push({
354
+ display: () => renderList.map((i, index) => <Fragment key={index}>{i()}</Fragment>),
355
+ onClear: async (e: iMouseEvent) => {
356
+ e.stopPropagation();
357
+ await edit.clear(true);
358
+ },
359
+ onClick: () => {setting.openSetting(eTableOptionSettingView.seniorFilter);},
360
+ });
361
+
362
+ return list;
363
+ });
364
+
365
+ hooks.onTips.use(list => {
366
+ !!tips.value.length && list.push(...tips.value);
367
+ });
368
+
369
+ return {
370
+ query,
371
+ edit,
372
+ };
373
+ });
374
+
375
+ export type iTableOptionSeniorFilterMeta = {
376
+ id: string,
377
+ data: undefined | iFilterFormSingleData,
378
+ }
379
+
380
+ export interface iTableOptionSeniorData {
381
+ metas: iTableOptionSeniorFilterMeta[],
382
+ expression: null | string,
383
+ isCustomExpression: boolean,
384
+ }
385
+
386
+ const ExpressionJoins = ['&&', '||', 'and', 'or', '并且', '或者'];
387
+
388
+ const DEFAULT_EXPRESSION_JOIN = '或者';