amis 1.3.5-beta.7 → 1.4.2-beta.11

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 (577) hide show
  1. package/README.md +1 -1
  2. package/lib/Schema.d.ts +26 -2
  3. package/lib/Schema.js.map +1 -1
  4. package/lib/components/Alert.js +3 -1
  5. package/lib/components/Alert.js.map +2 -2
  6. package/lib/components/AnchorNav.d.ts +22 -21
  7. package/lib/components/AnchorNav.js +7 -3
  8. package/lib/components/AnchorNav.js.map +2 -2
  9. package/lib/components/ArrayInput.d.ts +84 -84
  10. package/lib/components/AssociatedSelection.d.ts +930 -0
  11. package/lib/components/AssociatedSelection.js +89 -0
  12. package/lib/components/AssociatedSelection.js.map +13 -0
  13. package/lib/components/Badge.d.ts +16 -3
  14. package/lib/components/Badge.js +54 -5
  15. package/lib/components/Badge.js.map +2 -2
  16. package/lib/components/Button.d.ts +24 -22
  17. package/lib/components/Button.js +13 -7
  18. package/lib/components/Button.js.map +2 -2
  19. package/lib/components/{ChainedCheckboxes.d.ts → ChainedSelection.d.ts} +267 -98
  20. package/lib/components/{ChainedCheckboxes.js → ChainedSelection.js} +30 -24
  21. package/lib/components/ChainedSelection.js.map +13 -0
  22. package/lib/components/Checkbox.d.ts +1 -1
  23. package/lib/components/Checkbox.js +1 -1
  24. package/lib/components/Checkbox.js.map +2 -2
  25. package/lib/components/Collapse.js +1 -1
  26. package/lib/components/Collapse.js.map +2 -2
  27. package/lib/components/ColorPicker.d.ts +84 -84
  28. package/lib/components/DatePicker.d.ts +84 -84
  29. package/lib/components/DatePicker.js +1 -1
  30. package/lib/components/DatePicker.js.map +2 -2
  31. package/lib/components/DateRangePicker.d.ts +84 -84
  32. package/lib/components/DateRangePicker.js +1 -1
  33. package/lib/components/DateRangePicker.js.map +2 -2
  34. package/lib/components/Drawer.js +1 -1
  35. package/lib/components/Drawer.js.map +2 -2
  36. package/lib/components/Editor.d.ts +84 -84
  37. package/lib/components/GroupedSelection.d.ts +907 -0
  38. package/lib/components/GroupedSelection.js +48 -0
  39. package/lib/components/GroupedSelection.js.map +13 -0
  40. package/lib/components/InputBox.js +1 -1
  41. package/lib/components/InputBox.js.map +2 -2
  42. package/lib/components/Link.d.ts +84 -0
  43. package/lib/components/Link.js +43 -0
  44. package/lib/components/Link.js.map +13 -0
  45. package/lib/components/ListGroup.d.ts +21 -21
  46. package/lib/components/Modal.js +1 -1
  47. package/lib/components/Modal.js.map +2 -2
  48. package/lib/components/ModalManager.js +1 -1
  49. package/lib/components/ModalManager.js.map +2 -2
  50. package/lib/components/MonthRangePicker.d.ts +84 -84
  51. package/lib/components/MonthRangePicker.js +1 -1
  52. package/lib/components/MonthRangePicker.js.map +2 -2
  53. package/lib/components/NumberInput.d.ts +20 -20
  54. package/lib/components/PickerColumn.d.ts +514 -0
  55. package/lib/components/PickerColumn.js +279 -0
  56. package/lib/components/PickerColumn.js.map +13 -0
  57. package/lib/components/PickerContainer.d.ts +513 -0
  58. package/lib/components/PickerContainer.js +96 -0
  59. package/lib/components/PickerContainer.js.map +13 -0
  60. package/lib/components/Radios.d.ts +22 -21
  61. package/lib/components/Radios.js +1 -0
  62. package/lib/components/Radios.js.map +2 -2
  63. package/lib/components/Rating.d.ts +21 -21
  64. package/lib/components/ResultBox.d.ts +84 -84
  65. package/lib/components/RichText.d.ts +6 -1
  66. package/lib/components/RichText.js +207 -8
  67. package/lib/components/RichText.js.map +2 -2
  68. package/lib/components/SearchBox.d.ts +84 -84
  69. package/lib/components/SearchBox.js +4 -4
  70. package/lib/components/SearchBox.js.map +2 -2
  71. package/lib/components/Select.d.ts +252 -237
  72. package/lib/components/Select.js +28 -4
  73. package/lib/components/Select.js.map +2 -2
  74. package/lib/components/{Checkboxes.d.ts → Selection.d.ts} +273 -98
  75. package/lib/components/Selection.js +134 -0
  76. package/lib/components/Selection.js.map +13 -0
  77. package/lib/components/SparkLine.d.ts +85 -84
  78. package/lib/components/SparkLine.js +2 -2
  79. package/lib/components/SparkLine.js.map +2 -2
  80. package/lib/components/Steps.d.ts +3 -3
  81. package/lib/components/Steps.js.map +1 -1
  82. package/lib/components/{TableCheckboxes.d.ts → TableSelection.d.ts} +266 -96
  83. package/lib/components/{TableCheckboxes.js → TableSelection.js} +30 -30
  84. package/lib/components/TableSelection.js.map +13 -0
  85. package/lib/components/Tabs.d.ts +20 -20
  86. package/lib/components/TabsTransfer.d.ts +84 -84
  87. package/lib/components/TabsTransfer.js +9 -9
  88. package/lib/components/TabsTransfer.js.map +2 -2
  89. package/lib/components/TabsTransferPicker.d.ts +489 -0
  90. package/lib/components/TabsTransferPicker.js +60 -0
  91. package/lib/components/TabsTransferPicker.js.map +13 -0
  92. package/lib/components/Toast.js +2 -2
  93. package/lib/components/Toast.js.map +2 -2
  94. package/lib/components/Transfer.d.ts +908 -274
  95. package/lib/components/Transfer.js +31 -24
  96. package/lib/components/Transfer.js.map +2 -2
  97. package/lib/components/TransferDropDown.d.ts +487 -0
  98. package/lib/components/TransferDropDown.js +59 -0
  99. package/lib/components/TransferDropDown.js.map +13 -0
  100. package/lib/components/TransferPicker.d.ts +489 -0
  101. package/lib/components/TransferPicker.js +60 -0
  102. package/lib/components/TransferPicker.js.map +13 -0
  103. package/lib/components/Tree.d.ts +84 -84
  104. package/lib/components/Tree.js +5 -3
  105. package/lib/components/Tree.js.map +2 -2
  106. package/lib/components/{TreeCheckboxes.d.ts → TreeSelection.d.ts} +269 -99
  107. package/lib/components/{TreeCheckboxes.js → TreeSelection.js} +36 -32
  108. package/lib/components/TreeSelection.js.map +13 -0
  109. package/lib/components/WithRemoteConfig.d.ts +8 -0
  110. package/lib/components/WithRemoteConfig.js +29 -3
  111. package/lib/components/WithRemoteConfig.js.map +2 -2
  112. package/lib/components/calendar/DaysView.js +2 -2
  113. package/lib/components/calendar/DaysView.js.map +2 -2
  114. package/lib/components/condition-builder/Field.js +5 -3
  115. package/lib/components/condition-builder/Field.js.map +2 -2
  116. package/lib/components/condition-builder/Func.js +2 -2
  117. package/lib/components/condition-builder/Func.js.map +2 -2
  118. package/lib/components/condition-builder/InputSwitch.js +2 -2
  119. package/lib/components/condition-builder/InputSwitch.js.map +2 -2
  120. package/lib/components/condition-builder/Item.js +3 -3
  121. package/lib/components/condition-builder/Item.js.map +2 -2
  122. package/lib/components/condition-builder/Value.js +2 -1
  123. package/lib/components/condition-builder/Value.js.map +2 -2
  124. package/lib/components/condition-builder/types.d.ts +5 -0
  125. package/lib/components/condition-builder/types.js.map +1 -1
  126. package/lib/components/icons.js +14 -0
  127. package/lib/components/icons.js.map +2 -2
  128. package/lib/components/index.d.ts +8 -8
  129. package/lib/components/index.js +16 -16
  130. package/lib/components/index.js.map +2 -2
  131. package/lib/envOverwrite.js.map +2 -2
  132. package/lib/factory.d.ts +9 -1
  133. package/lib/factory.js +13 -6
  134. package/lib/factory.js.map +2 -2
  135. package/lib/helper.css.map +1 -1
  136. package/lib/hooks/index.d.ts +5 -0
  137. package/lib/hooks/index.js +14 -0
  138. package/lib/hooks/index.js.map +13 -0
  139. package/lib/hooks/use-set-state.d.ts +2 -0
  140. package/lib/hooks/use-set-state.js +15 -0
  141. package/lib/hooks/use-set-state.js.map +13 -0
  142. package/lib/hooks/use-touch.d.ts +16 -0
  143. package/lib/hooks/use-touch.js +73 -0
  144. package/lib/hooks/use-touch.js.map +13 -0
  145. package/lib/hooks/use-update-effect.d.ts +3 -0
  146. package/lib/hooks/use-update-effect.js +17 -0
  147. package/lib/hooks/use-update-effect.js.map +13 -0
  148. package/lib/icons/clock.js +10 -0
  149. package/lib/icons/loading-outline.js +7 -0
  150. package/lib/icons/status-close.js +11 -0
  151. package/lib/icons/status-fail.js +11 -0
  152. package/lib/icons/status-info.js +10 -0
  153. package/lib/icons/status-success.js +11 -0
  154. package/lib/icons/status-warning.js +10 -0
  155. package/lib/index.d.ts +3 -0
  156. package/lib/index.js +4 -1
  157. package/lib/index.js.map +2 -2
  158. package/lib/locale/de-DE.js +5 -0
  159. package/lib/locale/de-DE.js.map +2 -2
  160. package/lib/locale/en-US.js +6 -1
  161. package/lib/locale/en-US.js.map +2 -2
  162. package/lib/locale/zh-CN.js +9 -4
  163. package/lib/locale/zh-CN.js.map +2 -2
  164. package/lib/renderers/Action.d.ts +17 -1
  165. package/lib/renderers/Action.js +21 -8
  166. package/lib/renderers/Action.js.map +2 -2
  167. package/lib/renderers/AnchorNav.d.ts +1 -0
  168. package/lib/renderers/AnchorNav.js +2 -2
  169. package/lib/renderers/AnchorNav.js.map +2 -2
  170. package/lib/renderers/Avatar.js +3 -3
  171. package/lib/renderers/Avatar.js.map +2 -2
  172. package/lib/renderers/Breadcrumb.js +1 -1
  173. package/lib/renderers/Breadcrumb.js.map +2 -2
  174. package/lib/renderers/CRUD.d.ts +9 -0
  175. package/lib/renderers/CRUD.js +48 -23
  176. package/lib/renderers/CRUD.js.map +2 -2
  177. package/lib/renderers/Card.d.ts +4 -0
  178. package/lib/renderers/Card.js +29 -23
  179. package/lib/renderers/Card.js.map +2 -2
  180. package/lib/renderers/Chart.js +1 -1
  181. package/lib/renderers/Chart.js.map +2 -2
  182. package/lib/renderers/Collapse.d.ts +1 -1
  183. package/lib/renderers/Collapse.js +8 -3
  184. package/lib/renderers/Collapse.js.map +2 -2
  185. package/lib/renderers/Dialog.d.ts +0 -252
  186. package/lib/renderers/Dialog.js +1 -4
  187. package/lib/renderers/Dialog.js.map +2 -2
  188. package/lib/renderers/Drawer.js +0 -3
  189. package/lib/renderers/Drawer.js.map +2 -2
  190. package/lib/renderers/DropDownButton.d.ts +13 -1
  191. package/lib/renderers/DropDownButton.js +9 -5
  192. package/lib/renderers/DropDownButton.js.map +2 -2
  193. package/lib/renderers/Form/Checkbox.d.ts +5 -0
  194. package/lib/renderers/Form/Checkbox.js +4 -0
  195. package/lib/renderers/Form/Checkbox.js.map +2 -2
  196. package/lib/renderers/Form/Combo.js +2 -2
  197. package/lib/renderers/Form/Combo.js.map +2 -2
  198. package/lib/renderers/Form/DiffEditor.d.ts +4 -5
  199. package/lib/renderers/Form/Editor.d.ts +3 -4
  200. package/lib/renderers/Form/Editor.js +1 -1
  201. package/lib/renderers/Form/Editor.js.map +2 -2
  202. package/lib/renderers/Form/InputCity.d.ts +84 -84
  203. package/lib/renderers/Form/InputCity.js +7 -6
  204. package/lib/renderers/Form/InputCity.js.map +2 -2
  205. package/lib/renderers/Form/InputColor.d.ts +84 -84
  206. package/lib/renderers/Form/InputExcel.d.ts +5 -0
  207. package/lib/renderers/Form/InputExcel.js +24 -3
  208. package/lib/renderers/Form/InputExcel.js.map +2 -2
  209. package/lib/renderers/Form/InputFile.js +12 -6
  210. package/lib/renderers/Form/InputFile.js.map +2 -2
  211. package/lib/renderers/Form/InputImage.d.ts +8 -0
  212. package/lib/renderers/Form/InputImage.js +18 -8
  213. package/lib/renderers/Form/InputImage.js.map +2 -2
  214. package/lib/renderers/Form/InputTable.d.ts +23 -5
  215. package/lib/renderers/Form/InputTable.js +32 -3
  216. package/lib/renderers/Form/InputTable.js.map +2 -2
  217. package/lib/renderers/Form/Item.d.ts +1 -1
  218. package/lib/renderers/Form/Item.js.map +1 -1
  219. package/lib/renderers/Form/Options.js +19 -6
  220. package/lib/renderers/Form/Options.js.map +2 -2
  221. package/lib/renderers/Form/Picker.js +2 -2
  222. package/lib/renderers/Form/Picker.js.map +2 -2
  223. package/lib/renderers/Form/Select.d.ts +41 -4
  224. package/lib/renderers/Form/Select.js +23 -3
  225. package/lib/renderers/Form/Select.js.map +2 -2
  226. package/lib/renderers/Form/TabsTransferPicker.d.ts +48 -0
  227. package/lib/renderers/Form/TabsTransferPicker.js +29 -0
  228. package/lib/renderers/Form/TabsTransferPicker.js.map +13 -0
  229. package/lib/renderers/Form/Transfer.js +3 -2
  230. package/lib/renderers/Form/Transfer.js.map +2 -2
  231. package/lib/renderers/Form/TransferPicker.d.ts +48 -0
  232. package/lib/renderers/Form/TransferPicker.js +29 -0
  233. package/lib/renderers/Form/TransferPicker.js.map +13 -0
  234. package/lib/renderers/Form/TreeSelect.js +2 -2
  235. package/lib/renderers/Form/TreeSelect.js.map +2 -2
  236. package/lib/renderers/Form/index.js +1 -1
  237. package/lib/renderers/Form/index.js.map +2 -2
  238. package/lib/renderers/Form/wrapControl.js +15 -3
  239. package/lib/renderers/Form/wrapControl.js.map +2 -2
  240. package/lib/renderers/IFrame.js +3 -5
  241. package/lib/renderers/IFrame.js.map +2 -2
  242. package/lib/renderers/Image.d.ts +1 -0
  243. package/lib/renderers/Image.js +15 -1
  244. package/lib/renderers/Image.js.map +2 -2
  245. package/lib/renderers/Json.d.ts +4 -0
  246. package/lib/renderers/Json.js +7 -12
  247. package/lib/renderers/Json.js.map +2 -2
  248. package/lib/renderers/Link.d.ts +18 -3
  249. package/lib/renderers/Link.js +27 -15
  250. package/lib/renderers/Link.js.map +2 -2
  251. package/lib/renderers/List.js +1 -1
  252. package/lib/renderers/List.js.map +2 -2
  253. package/lib/renderers/Log.d.ts +2 -2
  254. package/lib/renderers/Log.js +7 -1
  255. package/lib/renderers/Log.js.map +2 -2
  256. package/lib/renderers/Mapping.d.ts +9 -2
  257. package/lib/renderers/Mapping.js +18 -6
  258. package/lib/renderers/Mapping.js.map +2 -2
  259. package/lib/renderers/Nav.d.ts +81 -25
  260. package/lib/renderers/Nav.js +292 -31
  261. package/lib/renderers/Nav.js.map +2 -2
  262. package/lib/renderers/Page.js +4 -1
  263. package/lib/renderers/Page.js.map +2 -2
  264. package/lib/renderers/Portlet.d.ts +125 -0
  265. package/lib/renderers/Portlet.js +156 -0
  266. package/lib/renderers/Portlet.js.map +13 -0
  267. package/lib/renderers/Property.js +2 -1
  268. package/lib/renderers/Property.js.map +2 -2
  269. package/lib/renderers/SearchBox.d.ts +6 -1
  270. package/lib/renderers/SearchBox.js +19 -5
  271. package/lib/renderers/SearchBox.js.map +2 -2
  272. package/lib/renderers/Service.d.ts +10 -1
  273. package/lib/renderers/Service.js +85 -3
  274. package/lib/renderers/Service.js.map +2 -2
  275. package/lib/renderers/SparkLine.d.ts +4 -0
  276. package/lib/renderers/SparkLine.js.map +2 -2
  277. package/lib/renderers/Steps.d.ts +4 -4
  278. package/lib/renderers/Steps.js +5 -2
  279. package/lib/renderers/Steps.js.map +2 -2
  280. package/lib/renderers/Table/ColumnToggler.d.ts +113 -0
  281. package/lib/renderers/Table/ColumnToggler.js +216 -0
  282. package/lib/renderers/Table/ColumnToggler.js.map +13 -0
  283. package/lib/renderers/Table/ItemActionsWrapper.d.ts +11 -0
  284. package/lib/renderers/Table/ItemActionsWrapper.js +31 -0
  285. package/lib/renderers/Table/ItemActionsWrapper.js.map +13 -0
  286. package/lib/renderers/Table/TableBody.d.ts +5 -1
  287. package/lib/renderers/Table/TableBody.js.map +1 -1
  288. package/lib/renderers/Table/TableCell.js +3 -1
  289. package/lib/renderers/Table/TableCell.js.map +2 -2
  290. package/lib/renderers/Table/TableContent.d.ts +5 -2
  291. package/lib/renderers/Table/TableContent.js +21 -1
  292. package/lib/renderers/Table/TableContent.js.map +2 -2
  293. package/lib/renderers/Table/index.d.ts +27 -5
  294. package/lib/renderers/Table/index.js +251 -101
  295. package/lib/renderers/Table/index.js.map +2 -2
  296. package/lib/renderers/Tabs.js +9 -1
  297. package/lib/renderers/Tabs.js.map +2 -2
  298. package/lib/renderers/WebComponent.js +1 -1
  299. package/lib/renderers/WebComponent.js.map +2 -2
  300. package/lib/store/app.d.ts +0 -1
  301. package/lib/store/combo.d.ts +2 -18
  302. package/lib/store/crud.d.ts +0 -1
  303. package/lib/store/crud.js +3 -7
  304. package/lib/store/crud.js.map +2 -2
  305. package/lib/store/form.d.ts +1 -2
  306. package/lib/store/form.js +5 -6
  307. package/lib/store/form.js.map +2 -2
  308. package/lib/store/modal.d.ts +1 -1
  309. package/lib/store/modal.js +4 -0
  310. package/lib/store/modal.js.map +2 -2
  311. package/lib/store/root.d.ts +0 -1
  312. package/lib/store/service.d.ts +0 -1
  313. package/lib/store/service.js +5 -17
  314. package/lib/store/service.js.map +2 -2
  315. package/lib/store/table.d.ts +260 -5
  316. package/lib/store/table.js +83 -7
  317. package/lib/store/table.js.map +2 -2
  318. package/lib/themes/ang-ie11.css +1360 -244
  319. package/lib/themes/ang.css +1360 -244
  320. package/lib/themes/ang.css.map +1 -1
  321. package/lib/themes/antd-ie11.css +1360 -244
  322. package/lib/themes/antd.css +1360 -244
  323. package/lib/themes/antd.css.map +1 -1
  324. package/lib/themes/cxd-ie11.css +1960 -517
  325. package/lib/themes/cxd.css +1960 -517
  326. package/lib/themes/cxd.css.map +1 -1
  327. package/lib/themes/dark-ie11.css +1360 -244
  328. package/lib/themes/dark.css +1360 -244
  329. package/lib/themes/dark.css.map +1 -1
  330. package/lib/themes/default.css +1960 -517
  331. package/lib/themes/default.css.map +1 -1
  332. package/lib/types.d.ts +37 -0
  333. package/lib/types.js +0 -5
  334. package/lib/types.js.map +2 -2
  335. package/lib/utils/api.d.ts +3 -2
  336. package/lib/utils/api.js +43 -15
  337. package/lib/utils/api.js.map +2 -2
  338. package/lib/utils/attachmentAdpator.d.ts +7 -0
  339. package/lib/utils/attachmentAdpator.js +82 -0
  340. package/lib/utils/attachmentAdpator.js.map +13 -0
  341. package/lib/utils/dom.d.ts +4 -0
  342. package/lib/utils/dom.js +11 -1
  343. package/lib/utils/dom.js.map +2 -2
  344. package/lib/utils/handleAction.d.ts +7 -0
  345. package/lib/utils/handleAction.js +30 -0
  346. package/lib/utils/handleAction.js.map +13 -0
  347. package/lib/utils/helper.d.ts +3 -1
  348. package/lib/utils/helper.js +14 -5
  349. package/lib/utils/helper.js.map +2 -2
  350. package/lib/utils/icon.js +3 -0
  351. package/lib/utils/icon.js.map +2 -2
  352. package/lib/utils/tpl-builtin.d.ts +1 -1
  353. package/lib/utils/tpl-builtin.js +25 -15
  354. package/lib/utils/tpl-builtin.js.map +2 -2
  355. package/lib/utils/validations.js +62 -5
  356. package/lib/utils/validations.js.map +2 -2
  357. package/package.json +1 -2
  358. package/schema.json +3638 -1030
  359. package/scss/_mixins.scss +27 -0
  360. package/scss/_properties.scss +88 -13
  361. package/scss/_utilities.scss +4 -0
  362. package/scss/base/_normalize.scss +2 -0
  363. package/scss/components/_anchor-nav.scss +88 -29
  364. package/scss/components/_badge.scss +67 -2
  365. package/scss/components/_button.scss +34 -3
  366. package/scss/components/_card.scss +8 -14
  367. package/scss/components/_collapse.scss +41 -8
  368. package/scss/components/_column-toggler.scss +234 -0
  369. package/scss/components/_dropdown.scss +2 -1
  370. package/scss/components/_image-gallery.scss +1 -1
  371. package/scss/components/_images.scss +2 -1
  372. package/scss/components/_link.scss +6 -0
  373. package/scss/components/_mapping.scss +6 -0
  374. package/scss/components/_markdown.scss +266 -0
  375. package/scss/components/_nav.scss +236 -154
  376. package/scss/components/_page.scss +5 -4
  377. package/scss/components/_picker-columns.scss +123 -0
  378. package/scss/components/_popover.scss +17 -0
  379. package/scss/components/_portlet.scss +51 -0
  380. package/scss/components/_progress.scss +2 -0
  381. package/scss/components/_spinner.scss +6 -2
  382. package/scss/components/_status.scss +1 -1
  383. package/scss/components/_steps.scss +1 -1
  384. package/scss/components/_table.scss +51 -1
  385. package/scss/components/form/_checks.scss +0 -351
  386. package/scss/components/form/_color.scss +1 -0
  387. package/scss/components/form/_date-range.scss +2 -0
  388. package/scss/components/form/_date.scss +2 -0
  389. package/scss/components/form/_fieldset.scss +6 -3
  390. package/scss/components/form/_file.scss +5 -4
  391. package/scss/components/form/_group.scss +4 -0
  392. package/scss/components/form/_image.scss +7 -2
  393. package/scss/components/form/_list.scss +1 -0
  394. package/scss/components/form/_location.scss +1 -1
  395. package/scss/components/form/_selection.scss +354 -0
  396. package/scss/components/form/_text.scss +13 -0
  397. package/scss/components/form/_textarea.scss +10 -0
  398. package/scss/components/form/_transfer.scss +77 -18
  399. package/scss/themes/_common.scss +7 -0
  400. package/scss/themes/_cxd-colors.scss +56 -0
  401. package/scss/themes/_cxd-variables.scss +219 -91
  402. package/scss/themes/cxd.scss +370 -0
  403. package/sdk/ang-ie11.css +1752 -431
  404. package/sdk/ang.css +1706 -323
  405. package/sdk/antd-ie11.css +1739 -420
  406. package/sdk/antd.css +1706 -323
  407. package/sdk/charts.js +13 -13
  408. package/sdk/color-picker.js +65 -69
  409. package/sdk/cropperjs.js +2 -2
  410. package/sdk/cxd-ie11.css +3015 -1397
  411. package/sdk/cxd.css +2402 -651
  412. package/sdk/dark-ie11.css +1750 -429
  413. package/sdk/dark.css +1706 -323
  414. package/sdk/exceljs.js +1 -1
  415. package/sdk/helper.css.map +1 -1
  416. package/sdk/ie11-patch.css +1 -0
  417. package/sdk/locale/de-DE.js +5 -0
  418. package/sdk/markdown.js +69 -69
  419. package/sdk/papaparse.js +1 -1
  420. package/sdk/renderers/Form/CityDB.js +1 -1
  421. package/sdk/rest.js +20 -30
  422. package/sdk/rich-text.js +62 -64
  423. package/sdk/sdk-ie11.css +3015 -1397
  424. package/sdk/sdk.css +2402 -651
  425. package/sdk/sdk.js +1278 -1220
  426. package/sdk/thirds/hls.js/hls.js +1 -1
  427. package/sdk/thirds/mpegts.js/mpegts.js +1 -1
  428. package/sdk/tinymce.js +57 -57
  429. package/src/Schema.ts +32 -0
  430. package/src/components/Alert.tsx +3 -1
  431. package/src/components/AnchorNav.tsx +15 -4
  432. package/src/components/{AssociatedCheckboxes.tsx → AssociatedSelection.tsx} +41 -37
  433. package/src/components/Badge.tsx +126 -23
  434. package/src/components/Button.tsx +23 -7
  435. package/src/components/{ChainedCheckboxes.tsx → ChainedSelection.tsx} +57 -40
  436. package/src/components/Checkbox.tsx +5 -2
  437. package/src/components/Collapse.tsx +14 -9
  438. package/src/components/DatePicker.tsx +1 -1
  439. package/src/components/DateRangePicker.tsx +23 -11
  440. package/src/components/Drawer.tsx +3 -2
  441. package/src/components/{ListCheckboxes.tsx → GroupedSelection.tsx} +26 -21
  442. package/src/components/InputBox.tsx +1 -1
  443. package/src/components/Link.tsx +85 -0
  444. package/src/components/Modal.tsx +3 -2
  445. package/src/components/ModalManager.ts +1 -1
  446. package/src/components/MonthRangePicker.tsx +10 -2
  447. package/src/components/PickerColumn.tsx +429 -0
  448. package/src/components/PickerContainer.tsx +128 -0
  449. package/src/components/Radios.tsx +3 -8
  450. package/src/components/RichText.tsx +244 -3
  451. package/src/components/SearchBox.tsx +4 -5
  452. package/src/components/Select.tsx +61 -5
  453. package/src/components/{Checkboxes.tsx → Selection.tsx} +75 -21
  454. package/src/components/SparkLine.tsx +4 -1
  455. package/src/components/Steps.tsx +3 -3
  456. package/src/components/{TableCheckboxes.tsx → TableSelection.tsx} +46 -25
  457. package/src/components/TabsTransfer.tsx +13 -7
  458. package/src/components/TabsTransferPicker.tsx +85 -0
  459. package/src/components/Toast.tsx +5 -5
  460. package/src/components/Transfer.tsx +71 -50
  461. package/src/components/TransferDropDown.tsx +117 -0
  462. package/src/components/TransferPicker.tsx +84 -0
  463. package/src/components/Tree.tsx +6 -8
  464. package/src/components/{TreeCheckboxes.tsx → TreeSelection.tsx} +33 -26
  465. package/src/components/WithRemoteConfig.tsx +44 -4
  466. package/src/components/calendar/DaysView.tsx +2 -2
  467. package/src/components/condition-builder/Field.tsx +6 -7
  468. package/src/components/condition-builder/Func.tsx +3 -3
  469. package/src/components/condition-builder/InputSwitch.tsx +3 -3
  470. package/src/components/condition-builder/Item.tsx +5 -12
  471. package/src/components/condition-builder/Value.tsx +3 -0
  472. package/src/components/condition-builder/types.ts +6 -0
  473. package/src/components/icons.tsx +15 -0
  474. package/src/components/index.tsx +13 -13
  475. package/src/envOverwrite.ts +0 -1
  476. package/src/factory.tsx +31 -6
  477. package/src/hooks/index.ts +5 -0
  478. package/src/hooks/use-set-state.ts +19 -0
  479. package/src/hooks/use-touch.ts +100 -0
  480. package/src/hooks/use-update-effect.ts +16 -0
  481. package/src/icons/clock.svg +1 -0
  482. package/src/icons/loading-outline.svg +4 -0
  483. package/src/icons/status-close.svg +10 -0
  484. package/src/icons/status-fail.svg +10 -0
  485. package/src/icons/status-info.svg +8 -0
  486. package/src/icons/status-success.svg +10 -0
  487. package/src/icons/status-warning.svg +8 -0
  488. package/src/index.tsx +3 -0
  489. package/src/locale/de-DE.ts +5 -0
  490. package/src/locale/en-US.ts +6 -1
  491. package/src/locale/zh-CN.ts +9 -4
  492. package/src/renderers/Action.tsx +99 -15
  493. package/src/renderers/AnchorNav.tsx +4 -0
  494. package/src/renderers/Avatar.tsx +8 -4
  495. package/src/renderers/Breadcrumb.tsx +5 -1
  496. package/src/renderers/CRUD.tsx +70 -56
  497. package/src/renderers/Card.tsx +63 -34
  498. package/src/renderers/Chart.tsx +6 -2
  499. package/src/renderers/Collapse.tsx +9 -3
  500. package/src/renderers/Dialog.tsx +1 -5
  501. package/src/renderers/Drawer.tsx +0 -4
  502. package/src/renderers/DropDownButton.tsx +34 -12
  503. package/src/renderers/Form/Checkbox.tsx +8 -0
  504. package/src/renderers/Form/Combo.tsx +2 -3
  505. package/src/renderers/Form/Editor.tsx +19 -20
  506. package/src/renderers/Form/InputCity.tsx +4 -8
  507. package/src/renderers/Form/InputExcel.tsx +28 -3
  508. package/src/renderers/Form/InputFile.tsx +30 -20
  509. package/src/renderers/Form/InputImage.tsx +39 -13
  510. package/src/renderers/Form/InputTable.tsx +88 -9
  511. package/src/renderers/Form/Item.tsx +1 -1
  512. package/src/renderers/Form/Options.tsx +32 -7
  513. package/src/renderers/Form/Picker.tsx +3 -2
  514. package/src/renderers/Form/Select.tsx +144 -21
  515. package/src/renderers/Form/TabsTransferPicker.tsx +123 -0
  516. package/src/renderers/Form/Transfer.tsx +3 -2
  517. package/src/renderers/Form/TransferPicker.tsx +123 -0
  518. package/src/renderers/Form/TreeSelect.tsx +25 -0
  519. package/src/renderers/Form/index.tsx +1 -1
  520. package/src/renderers/Form/wrapControl.tsx +28 -3
  521. package/src/renderers/IFrame.tsx +4 -5
  522. package/src/renderers/Image.tsx +10 -0
  523. package/src/renderers/Json.tsx +19 -10
  524. package/src/renderers/Link.tsx +53 -14
  525. package/src/renderers/List.tsx +1 -1
  526. package/src/renderers/Log.tsx +16 -3
  527. package/src/renderers/Mapping.tsx +27 -11
  528. package/src/renderers/Nav.tsx +392 -60
  529. package/src/renderers/Page.tsx +3 -1
  530. package/src/renderers/Portlet.tsx +423 -0
  531. package/src/renderers/Property.tsx +3 -2
  532. package/src/renderers/SearchBox.tsx +23 -4
  533. package/src/renderers/Service.tsx +101 -3
  534. package/src/renderers/SparkLine.tsx +5 -0
  535. package/src/renderers/Steps.tsx +12 -9
  536. package/src/renderers/Table/ColumnToggler.tsx +544 -0
  537. package/src/renderers/Table/ItemActionsWrapper.tsx +44 -0
  538. package/src/renderers/Table/TableBody.tsx +1 -1
  539. package/src/renderers/Table/TableCell.tsx +16 -1
  540. package/src/renderers/Table/TableContent.tsx +41 -3
  541. package/src/renderers/Table/index.tsx +318 -92
  542. package/src/renderers/Tabs.tsx +9 -1
  543. package/src/renderers/WebComponent.tsx +2 -2
  544. package/src/store/crud.ts +3 -8
  545. package/src/store/form.ts +5 -10
  546. package/src/store/modal.ts +4 -0
  547. package/src/store/service.ts +5 -23
  548. package/src/store/table.ts +103 -4
  549. package/src/types.ts +57 -0
  550. package/src/utils/api.ts +63 -23
  551. package/src/utils/attachmentAdpator.ts +90 -0
  552. package/src/utils/dom.tsx +12 -0
  553. package/src/utils/handleAction.ts +41 -0
  554. package/src/utils/helper.ts +12 -3
  555. package/src/utils/icon.tsx +4 -0
  556. package/src/utils/tpl-builtin.ts +48 -17
  557. package/src/utils/validations.ts +80 -12
  558. package/dump.rdb +0 -0
  559. package/lib/components/AssociatedCheckboxes.d.ts +0 -762
  560. package/lib/components/AssociatedCheckboxes.js +0 -90
  561. package/lib/components/AssociatedCheckboxes.js.map +0 -13
  562. package/lib/components/ChainedCheckboxes.js.map +0 -13
  563. package/lib/components/Checkboxes.js +0 -101
  564. package/lib/components/Checkboxes.js.map +0 -13
  565. package/lib/components/ListCheckboxes.d.ts +0 -739
  566. package/lib/components/ListCheckboxes.js +0 -48
  567. package/lib/components/ListCheckboxes.js.map +0 -13
  568. package/lib/components/ListRadios.d.ts +0 -763
  569. package/lib/components/ListRadios.js +0 -86
  570. package/lib/components/ListRadios.js.map +0 -13
  571. package/lib/components/TableCheckboxes.js.map +0 -13
  572. package/lib/components/TreeCheckboxes.js.map +0 -13
  573. package/lib/components/TreeRadios.d.ts +0 -838
  574. package/lib/components/TreeRadios.js +0 -116
  575. package/lib/components/TreeRadios.js.map +0 -13
  576. package/src/components/ListRadios.tsx +0 -159
  577. package/src/components/TreeRadios.tsx +0 -202
@@ -18,7 +18,7 @@ import {autobind, findTree, noop} from '../../utils/helper';
18
18
  import Expression from './Expression';
19
19
  import {Config, OperationMap} from './config';
20
20
  import PopOverContainer from '../PopOverContainer';
21
- import ListRadios from '../ListRadios';
21
+ import GroupedSelection from '../GroupedSelection';
22
22
  import ResultBox from '../ResultBox';
23
23
  import {localeable, LocaleProps} from '../../locale';
24
24
 
@@ -100,15 +100,8 @@ export class ConditionItem extends React.Component<ConditionItemProps> {
100
100
  }
101
101
 
102
102
  renderLeft() {
103
- const {
104
- value,
105
- fields,
106
- funcs,
107
- config,
108
- disabled,
109
- fieldClassName,
110
- searchable
111
- } = this.props;
103
+ const {value, fields, funcs, config, disabled, fieldClassName, searchable} =
104
+ this.props;
112
105
  return (
113
106
  <Expression
114
107
  config={config}
@@ -158,7 +151,7 @@ export class ConditionItem extends React.Component<ConditionItemProps> {
158
151
  return (
159
152
  <PopOverContainer
160
153
  popOverRender={({onClose}) => (
161
- <ListRadios
154
+ <GroupedSelection
162
155
  onClick={onClose}
163
156
  option2value={option2value}
164
157
  onChange={this.handleOperatorChange}
@@ -167,7 +160,7 @@ export class ConditionItem extends React.Component<ConditionItemProps> {
167
160
  value: operator
168
161
  }))}
169
162
  value={value.op}
170
- showRadio={false}
163
+ multiple={false}
171
164
  />
172
165
  )}
173
166
  >
@@ -92,11 +92,14 @@ export class Value extends React.Component<ValueProps> {
92
92
  />
93
93
  );
94
94
  } else if (field.type === 'select') {
95
+ const autoComplete = field.autoComplete;
96
+
95
97
  input = (
96
98
  <Select
97
99
  simpleValue
98
100
  options={field.options!}
99
101
  source={field.source}
102
+ autoComplete={autoComplete}
100
103
  searchable={field.searchable}
101
104
  value={value ?? field.defaultValue ?? ''}
102
105
  data={data}
@@ -145,6 +145,12 @@ interface SelectField extends BaseField {
145
145
  options?: Array<any>;
146
146
  source?: SchemaApi;
147
147
  searchable?: boolean;
148
+
149
+ /**
150
+ * 自动完成 API,当输入部分文字的时候,会将这些文字通过 ${term} 可以取到,发送给接口。
151
+ * 接口可以返回匹配到的选项,帮助用户输入。
152
+ */
153
+ autoComplete?: SchemaApi;
148
154
  }
149
155
 
150
156
  interface BooleanField extends BaseField {
@@ -6,6 +6,7 @@
6
6
  import React from 'react';
7
7
 
8
8
  import CloseIcon from '../icons/close.svg';
9
+ import StatusCloseIcon from '../icons/status-close.svg';
9
10
  import UnDoIcon from '../icons/undo.svg';
10
11
  import ReDoIcon from '../icons/redo.svg';
11
12
  import EnterIcon from '../icons/enter.svg';
@@ -24,6 +25,10 @@ import RemoveIcon from '../icons/remove.svg';
24
25
  import RetryIcon from '../icons/retry.svg';
25
26
  import UploadIcon from '../icons/upload.svg';
26
27
  import FileIcon from '../icons/file.svg';
28
+ import StatusSuccessIcon from '../icons/status-success.svg';
29
+ import StatusFailIcon from '../icons/status-fail.svg';
30
+ import StatusInfoIcon from '../icons/status-info.svg';
31
+ import StatusWarningIcon from '../icons/status-warning.svg';
27
32
  import SuccessIcon from '../icons/success.svg';
28
33
  import FailIcon from '../icons/fail.svg';
29
34
  import SearchIcon from '../icons/search.svg';
@@ -36,6 +41,8 @@ import ReloadIcon from '../icons/reload.svg';
36
41
  import ExchangeIcon from '../icons/exchange.svg';
37
42
  import ColmunsIcon from '../icons/columns.svg';
38
43
  import CalendarIcon from '../icons/calendar.svg';
44
+ import ClockIcon from '../icons/clock.svg';
45
+
39
46
  import CopyIcon from '../icons/copy.svg';
40
47
  import FilterIcon from '../icons/filter.svg';
41
48
  import CaretIcon from '../icons/caret.svg';
@@ -61,6 +68,7 @@ import EllipsisVIcon from '../icons/ellipsis-v.svg';
61
68
  import ExpandAltIcon from '../icons/expand-alt.svg';
62
69
  import CompressAltIcon from '../icons/compress-alt.svg';
63
70
  import TransparentIcon from '../icons/transparent.svg';
71
+ import LoadingOutline from '../icons/loading-outline.svg';
64
72
 
65
73
  // 兼容原来的用法,后续不直接试用。
66
74
 
@@ -91,6 +99,7 @@ export function registerIcon(key: string, component: React.ReactType<{}>) {
91
99
  }
92
100
 
93
101
  registerIcon('close', CloseIcon);
102
+ registerIcon('status-close', StatusCloseIcon);
94
103
  registerIcon('undo', UnDoIcon);
95
104
  registerIcon('redo', ReDoIcon);
96
105
  registerIcon('enter', EnterIcon);
@@ -112,6 +121,10 @@ registerIcon('remove', RemoveIcon);
112
121
  registerIcon('retry', RetryIcon);
113
122
  registerIcon('upload', UploadIcon);
114
123
  registerIcon('file', FileIcon);
124
+ registerIcon('status-success', StatusSuccessIcon);
125
+ registerIcon('status-fail', StatusFailIcon);
126
+ registerIcon('status-info', StatusInfoIcon);
127
+ registerIcon('status-warning', StatusWarningIcon);
115
128
  registerIcon('success', SuccessIcon);
116
129
  registerIcon('fail', FailIcon);
117
130
  registerIcon('warning', WarningIcon);
@@ -127,6 +140,7 @@ registerIcon('reload', ReloadIcon);
127
140
  registerIcon('exchange', ExchangeIcon);
128
141
  registerIcon('columns', ColmunsIcon);
129
142
  registerIcon('calendar', CalendarIcon);
143
+ registerIcon('clock', ClockIcon);
130
144
  registerIcon('copy', CopyIcon);
131
145
  registerIcon('filter', FilterIcon);
132
146
  registerIcon('column-filter', ColumnFilterIcon);
@@ -149,6 +163,7 @@ registerIcon('ellipsis-v', EllipsisVIcon);
149
163
  registerIcon('expand-alt', ExpandAltIcon);
150
164
  registerIcon('compress-alt', CompressAltIcon);
151
165
  registerIcon('transparent', TransparentIcon);
166
+ registerIcon('loading-outline', LoadingOutline);
152
167
 
153
168
  export function Icon({
154
169
  icon,
@@ -10,7 +10,7 @@ import {default as ContextMenu, openContextMenus} from './ContextMenu';
10
10
  import AsideNav from './AsideNav';
11
11
  import Button from './Button';
12
12
  import Checkbox from './Checkbox';
13
- import Checkboxes from './Checkboxes';
13
+ import Checkboxes from './Selection';
14
14
  import Collapse from './Collapse';
15
15
  import DatePicker from './DatePicker';
16
16
  import DateRangePicker from './DateRangePicker';
@@ -41,19 +41,19 @@ import Tree from './Tree';
41
41
  import Alert2 from './Alert2';
42
42
  import Transfer from './Transfer';
43
43
  import TabsTransfer from './TabsTransfer';
44
- import ListCheckboxes from './ListCheckboxes';
45
- import TableCheckboxes from './TableCheckboxes';
46
- import TreeCheckboxes from './TreeCheckboxes';
47
- import ChainedCheckboxes from './ChainedCheckboxes';
48
44
  import ResultBox from './ResultBox';
49
45
  import InputBox from './InputBox';
50
- import ListRadios from './ListRadios';
51
- import TreeRadios from './TreeRadios';
52
46
  import ListGroup from './ListGroup';
53
47
  import NumberInput from './NumberInput';
54
48
  import ArrayInput from './ArrayInput';
55
49
  import SearchBox from './SearchBox';
56
50
  import AnchorNav from './AnchorNav';
51
+ import Selection from './Selection';
52
+ import GroupedSelection from './GroupedSelection';
53
+ import ChainedSelection from './ChainedSelection';
54
+ import TableSelection from './TableSelection';
55
+ import TreeSelection from './TreeSelection';
56
+ import AssociatedSelection from './AssociatedSelection';
57
57
 
58
58
  export {
59
59
  NotFound,
@@ -99,15 +99,15 @@ export {
99
99
  Tree,
100
100
  Transfer,
101
101
  TabsTransfer,
102
- ListCheckboxes,
103
- TableCheckboxes,
104
- TreeCheckboxes,
105
- ChainedCheckboxes,
102
+ Selection,
103
+ GroupedSelection,
104
+ ChainedSelection,
105
+ TableSelection,
106
+ TreeSelection,
107
+ AssociatedSelection,
106
108
  ResultBox,
107
109
  InputBox,
108
- ListRadios,
109
110
  SearchBox,
110
- TreeRadios,
111
111
  ListGroup,
112
112
  NumberInput,
113
113
  ArrayInput,
@@ -4,7 +4,6 @@
4
4
 
5
5
  import {SchemaNode, Schema} from './types';
6
6
  import {RendererProps, RendererConfig, addSchemaFilter} from './factory';
7
-
8
7
  const isMobile = (window as any).matchMedia?.('(max-width: 768px)').matches
9
8
  ? true
10
9
  : false;
package/src/factory.tsx CHANGED
@@ -4,7 +4,16 @@ import {getEnv, destroy} from 'mobx-state-tree';
4
4
  import {wrapFetcher} from './utils/api';
5
5
  import {normalizeLink} from './utils/normalizeLink';
6
6
  import {findIndex, promisify, qsparse, string2regExp} from './utils/helper';
7
- import {Api, fetcherResult, Payload, SchemaNode, Schema, Action} from './types';
7
+ import {
8
+ Api,
9
+ fetcherResult,
10
+ Payload,
11
+ SchemaNode,
12
+ Schema,
13
+ Action,
14
+ EventTrack,
15
+ PlainObject
16
+ } from './types';
8
17
  import {observer} from 'mobx-react';
9
18
  import Scoped from './Scoped';
10
19
  import {getTheme, ThemeInstance, ThemeProps} from './theme';
@@ -58,6 +67,10 @@ export interface RendererProps extends ThemeProps, LocaleProps {
58
67
  };
59
68
  defaultData?: object;
60
69
  className?: any;
70
+ /**
71
+ * 是否使用移动端交互
72
+ */
73
+ useMobileUI?: boolean;
61
74
  [propName: string]: any;
62
75
  }
63
76
 
@@ -74,11 +87,16 @@ export interface RenderSchemaFilter {
74
87
  (schema: Schema, renderer: RendererConfig, props?: any): Schema;
75
88
  }
76
89
 
90
+ export interface wsObject {
91
+ url: string;
92
+ body?: any;
93
+ }
94
+
77
95
  export interface RenderOptions {
78
96
  session?: string;
79
97
  fetcher?: (config: fetcherConfig) => Promise<fetcherResult>;
80
98
  wsFetcher?: (
81
- ws: string,
99
+ ws: wsObject,
82
100
  onMessage: (data: any) => void,
83
101
  onError: (error: any) => void
84
102
  ) => void;
@@ -234,8 +252,13 @@ const defaultOptions: RenderOptions = {
234
252
  // 使用 WebSocket 来实时获取数据
235
253
  wsFetcher(ws, onMessage, onError) {
236
254
  if (ws) {
237
- const socket = new WebSocket(ws);
238
- socket.onmessage = (event: any) => {
255
+ const socket = new WebSocket(ws.url);
256
+ socket.onopen = event => {
257
+ if (ws.body) {
258
+ socket.send(JSON.stringify(ws.body));
259
+ }
260
+ };
261
+ socket.onmessage = event => {
239
262
  if (event.data) {
240
263
  onMessage(JSON.parse(event.data));
241
264
  }
@@ -310,6 +333,8 @@ const defaultOptions: RenderOptions = {
310
333
  copy(contents: string) {
311
334
  console.error('copy contents', contents);
312
335
  },
336
+ // 用于跟踪用户在界面中的各种操作
337
+ tracker(eventTrack: EventTrack, props: PlainObject) {},
313
338
  rendererResolver: resolveRenderer
314
339
  };
315
340
  let stores: {
@@ -335,7 +360,7 @@ export function render(
335
360
  ...defaultOptions,
336
361
  ...options,
337
362
  fetcher: options.fetcher
338
- ? wrapFetcher(options.fetcher)
363
+ ? wrapFetcher(options.fetcher, options.tracker)
339
364
  : defaultOptions.fetcher,
340
365
  confirm: promisify(
341
366
  options.confirm || defaultOptions.confirm || window.confirm
@@ -406,7 +431,7 @@ export function updateEnv(options: Partial<RenderOptions>, session = 'global') {
406
431
  };
407
432
 
408
433
  if (options.fetcher) {
409
- options.fetcher = wrapFetcher(options.fetcher) as any;
434
+ options.fetcher = wrapFetcher(options.fetcher, options.tracker) as any;
410
435
  }
411
436
 
412
437
  if (options.confirm) {
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @file 常用 hooks
3
+ */
4
+ export {default as useSetState} from './use-set-state';
5
+ export {default as useUpdateEffect} from './use-update-effect';
@@ -0,0 +1,19 @@
1
+ import {useCallback, useState} from 'react';
2
+ import isFunction from 'lodash/isFunction';
3
+
4
+ const useSetState = <T extends object>(
5
+ initialState: T = {} as T
6
+ ): [T, (patch: Partial<T> | ((prevState: T) => Partial<T>)) => void] => {
7
+ const [state, setState] = useState<T>(initialState);
8
+
9
+ const setMergeState = useCallback(patch => {
10
+ setState(prevState => ({
11
+ ...prevState,
12
+ ...(isFunction(patch) ? patch(prevState) : patch)
13
+ }));
14
+ }, []);
15
+
16
+ return [state, setMergeState];
17
+ };
18
+
19
+ export default useSetState;
@@ -0,0 +1,100 @@
1
+ import {useCallback, useRef} from 'react';
2
+
3
+ const MIN_DISTANCE = 10;
4
+
5
+ type Direction = '' | 'vertical' | 'horizontal';
6
+
7
+ function getDirection(x: number, y: number) {
8
+ if (x > y && x > MIN_DISTANCE) {
9
+ return 'horizontal';
10
+ }
11
+ if (y > x && y > MIN_DISTANCE) {
12
+ return 'vertical';
13
+ }
14
+ return '';
15
+ }
16
+
17
+ const INITIAL_STATE = {
18
+ startX: 0,
19
+ startY: 0,
20
+ deltaX: 0,
21
+ deltaY: 0,
22
+ offsetX: 0,
23
+ offsetY: 0,
24
+ direction: '' as Direction
25
+ };
26
+
27
+ type StateType = Partial<typeof INITIAL_STATE>;
28
+ type StateFunctionType = (value: StateType) => typeof INITIAL_STATE;
29
+
30
+ const useTouch = () => {
31
+ const refState = useRef(INITIAL_STATE);
32
+ const innerState = refState.current;
33
+
34
+ const update = (value: StateType | StateFunctionType) => {
35
+ if (typeof value === 'function') {
36
+ value = value(refState.current);
37
+ }
38
+ Object.entries(value).forEach(([k, v]) => {
39
+ //@ts-ignore
40
+ refState.current[k] = v;
41
+ });
42
+ };
43
+
44
+ const isVertical = useCallback(
45
+ () => innerState.direction === 'vertical',
46
+ [innerState.direction]
47
+ );
48
+ const isHorizontal = useCallback(
49
+ () => innerState.direction === 'horizontal',
50
+ [innerState.direction]
51
+ );
52
+
53
+ const reset = () => {
54
+ update({
55
+ deltaX: 0,
56
+ deltaY: 0,
57
+ offsetX: 0,
58
+ offsetY: 0,
59
+ direction: ''
60
+ });
61
+ };
62
+
63
+ const start = ((event: TouchEvent) => {
64
+ reset();
65
+ update({
66
+ startX: event.touches[0].clientX,
67
+ startY: event.touches[0].clientY
68
+ });
69
+ }) as EventListener;
70
+
71
+ const move = ((event: TouchEvent) => {
72
+ const touch = event.touches[0];
73
+
74
+ update(value => {
75
+ // Fix: Safari back will set clientX to negative number
76
+ const newState = {...value} as typeof innerState;
77
+
78
+ newState.deltaX = touch.clientX < 0 ? 0 : touch.clientX - newState.startX;
79
+ newState.deltaY = touch.clientY - newState.startY;
80
+ newState.offsetX = Math.abs(newState.deltaX);
81
+ newState.offsetY = Math.abs(newState.deltaY);
82
+
83
+ if (!newState.direction) {
84
+ newState.direction = getDirection(newState.offsetX, newState.offsetY);
85
+ }
86
+ return newState;
87
+ });
88
+ }) as EventListener;
89
+
90
+ return {
91
+ ...innerState,
92
+ move,
93
+ start,
94
+ reset,
95
+ isVertical,
96
+ isHorizontal
97
+ };
98
+ };
99
+
100
+ export default useTouch;
@@ -0,0 +1,16 @@
1
+ import {useEffect, useRef} from 'react';
2
+
3
+ const useUpdateEffect: typeof useEffect = (effect, deps) => {
4
+ const isMounted = useRef(false);
5
+
6
+ useEffect(() => {
7
+ if (!isMounted.current) {
8
+ isMounted.current = true;
9
+ } else {
10
+ return effect();
11
+ }
12
+ return undefined;
13
+ }, deps);
14
+ };
15
+
16
+ export default useUpdateEffect;
@@ -0,0 +1 @@
1
+ <svg width="24px" height="24px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><title>ic_时间</title><g id="ic_时间" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><circle id="1-FL" stroke="#000" cx="8" cy="8" r="6.5" stroke-width="1px" fill="none" stroke-linecap="butt" stroke-linejoin="round"/><polyline id="2-FLW" stroke="#000" points="7.87443646 5.5 7.87443646 8.53778873 5.5 9.28133409" stroke-width="1px" fill="none" stroke-linecap="butt" stroke-linejoin="round"/></g></svg>
@@ -0,0 +1,4 @@
1
+ <svg viewBox="0 0 1024 1024" focusable="false" data-icon="loading" width="1em" height="1em" fill="currentColor" aria-hidden="true">
2
+ <path d="M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z">
3
+ </path>
4
+ </svg>
@@ -0,0 +1,10 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>关闭</title>
4
+ <g id="关闭" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <g id="图标-关闭">
6
+ <rect id="矩形" stroke="#979797" fill="#D8D8D8" opacity="0" x="0.5" y="0.5" width="15" height="15"></rect>
7
+ <path d="M12.549,2.65 L13.256,3.357 L8.659,7.952 L13.2563,12.549 L12.5493,13.257 L7.953,8.659 L3.357,13.257 L2.65,12.549 L7.246,7.952 L2.6503,3.357 L3.3573,2.65 L7.953,7.245 L12.549,2.65 Z" id="图标-填色" fill="#080E1A" opacity="0.5"></path>
8
+ </g>
9
+ </g>
10
+ </svg>
@@ -0,0 +1,10 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>状态-失败</title>
4
+ <g id="状态-失败" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <g id="图示-图标">
6
+ <rect id="矩形" stroke="#979797" stroke-width="1.33333333" fill="#D8D8D8" opacity="0" x="0.666666667" y="0.666666667" width="14.6666667" height="14.6666667"></rect>
7
+ <path d="M10.4361,11.0054 L7.9531,8.5394 L5.4861,11.0224 L4.7771,10.3184 L7.2431,7.8344 L4.7601,5.3674 L5.4651,4.6584 L7.9481,7.1244 L10.4151,4.6424 L11.1241,5.3464 L8.6571,7.8294 L11.1411,10.2964 L10.4361,11.0054 Z M1.00001937,8.0244 C1.0131,11.8894 4.1581,15.0134 8.0231,14.9994934 C11.8901,14.9864 15.0131,11.8424 15.0001806,7.9764 C14.9871,4.1104 11.8421,0.9864 7.9771,1.00030657 C4.1101,1.0134 0.9871,4.1574 1.00001937,8.0244 Z" id="图标-填色" fill="#E8684A"></path>
8
+ </g>
9
+ </g>
10
+ </svg>
@@ -0,0 +1,8 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>6.图标/6.提示/通知/面</title>
4
+ <g id="6.图标/6.提示/通知/面" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <polygon id="Clip-2" points="1.0001 1 15 1 15 14.9999 1.0001 14.9999"></polygon>
6
+ <path d="M8.0001,0.9999 C11.8661,0.9999 15.0001,4.1349 15.0001,7.9999 C15.0001,11.8659 11.8661,14.9999 8.0001,14.9999 C4.1341,14.9999 1.0001,11.8659 1.0001,7.9999 C1.0001,4.1349 4.1341,0.9999 8.0001,0.9999 Z M8.5001,6.5459 L7.5001,6.5459 L7.5001,11.9999 L8.5001,11.9999 L8.5001,6.5459 Z M8.0001,3.9999 C7.6681,3.9999 7.4001,4.2679 7.4001,4.5999 C7.4001,4.9309 7.6681,5.1999 8.0001,5.1999 C8.3321,5.1999 8.6001,4.9309 8.6001,4.5999 C8.6001,4.2679 8.3321,3.9999 8.0001,3.9999 Z" id="图标-填色" fill="#2468F2"></path>
7
+ </g>
8
+ </svg>
@@ -0,0 +1,10 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>状态-成功</title>
4
+ <g id="状态-成功" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <g id="图标-提示">
6
+ <rect id="矩形" stroke="#979797" stroke-width="1.33333333" fill="#D8D8D8" opacity="0" x="0.666666667" y="0.666666667" width="14.6666667" height="14.6666667"></rect>
7
+ <path d="M7.0286,11.0408 L6.3196,10.3358 L6.3206,10.3348 L4.1896,8.2188 L4.8946,7.5088 L7.0256,9.6258 L11.2526,5.3698 L11.9616,6.0738 L7.0286,11.0408 Z M7.9766,0.999759561 C4.1106,1.0138 0.9866,4.1578 0.999559574,8.0228 C1.0126,11.8898 4.1576,15.0138 8.0236,14.9998469 C11.8896,14.9868 15.0126,11.8428 14.9996404,7.9768 C14.9866,4.1098 11.8426,0.9868 7.9766,0.999759561 L7.9766,0.999759561 Z" id="图标-填色" fill="#0BC280"></path>
8
+ </g>
9
+ </g>
10
+ </svg>
@@ -0,0 +1,8 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>6.图标/6.提示/异常/面</title>
4
+ <g id="6.图标/6.提示/异常/面" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <polygon id="Clip-2" points="1.0001 1 15 1 15 14.9997 1.0001 14.9997"></polygon>
6
+ <path d="M8.0001,0.9997 C11.8661,0.9997 15.0001,4.1347 15.0001,7.9997 C15.0001,11.8657 11.8661,14.9997 8.0001,14.9997 C4.1341,14.9997 1.0001,11.8657 1.0001,7.9997 C1.0001,4.1347 4.1341,0.9997 8.0001,0.9997 Z M8.0001,10.7997 C7.6681,10.7997 7.4001,11.0687 7.4001,11.3997 C7.4001,11.7307 7.6681,11.9997 8.0001,11.9997 C8.3321,11.9997 8.6001,11.7307 8.6001,11.3997 C8.6001,11.0687 8.3321,10.7997 8.0001,10.7997 Z M8.5001,3.9997 L7.5001,3.9997 L7.5001,9.4547 L8.5001,9.4547 L8.5001,3.9997 Z" id="形状结合" fill="#FFB200"></path>
7
+ </g>
8
+ </svg>
package/src/index.tsx CHANGED
@@ -111,12 +111,14 @@ import './renderers/Form/InputColor';
111
111
  import './renderers/Form/ChainedSelect';
112
112
  import './renderers/Form/NestedSelect';
113
113
  import './renderers/Form/Transfer';
114
+ import './renderers/Form/TransferPicker';
114
115
  import './renderers/Form/InputTable';
115
116
  import './renderers/Form/Picker';
116
117
  import './renderers/Form/IconPicker';
117
118
  import './renderers/Form/Formula';
118
119
  import './renderers/Form/FieldSet';
119
120
  import './renderers/Form/TabsTransfer';
121
+ import './renderers/Form/TabsTransferPicker';
120
122
  import './renderers/Form/Group';
121
123
  import './renderers/Form/InputGroup';
122
124
  import './renderers/Grid';
@@ -133,6 +135,7 @@ import './renderers/PaginationWrapper';
133
135
  import './renderers/Panel';
134
136
  import './renderers/Plain';
135
137
  import './renderers/Property';
138
+ import './renderers/Portlet';
136
139
  import './renderers/Spinner';
137
140
  import './renderers/Table/index';
138
141
  import './renderers/Tabs';
@@ -158,6 +158,7 @@ register('de-DE', {
158
158
  'System.requestError': 'Anfragefehler: ',
159
159
  'System.requestErrorStatus': 'Anfragefehler, Statuscode:',
160
160
  'Table.addRow': 'Zeile hinzufügen',
161
+ 'Table.copyRow': 'Zeile kopieren',
161
162
  'Table.columnsVisibility': 'Klicken, um die Sichtbarkeit der Spalten zu steuern',
162
163
  'Table.deleteRow': 'Aktuele Zeile löschen',
163
164
  'Table.discard': 'Verwerfen',
@@ -171,6 +172,8 @@ register('de-DE', {
171
172
  'Table.startSort': 'Klicken, um Sortierung zu starten',
172
173
  'Table.valueField': 'valueField muss vorhanden sein',
173
174
  'Table.index': 'Index',
175
+ 'Table.toggleColumn': 'Spalten anzeigen',
176
+ 'Table.searchFields': 'Abfragefelder setzen',
174
177
  'Tag.placeholder': 'Noch kein Tag',
175
178
  'Tag.tip': 'Kürzlich verwendetes Tag',
176
179
  'Text.add': 'Neu {{label}}',
@@ -178,6 +181,7 @@ register('de-DE', {
178
181
  'Transfer.configError': 'Konfigurationsfehler',
179
182
  'Transfer.refreshIcon': 'Zum Aktualisieren klicken',
180
183
  'Transfer.searchKeyword': 'Stichwörter eingeben',
184
+ 'Transfer.available': 'Verfügbar',
181
185
  'Transfer.selectd': 'Ausgewählt',
182
186
  'Transfer.selectFromLeft': 'Von links auswählen',
183
187
  'Tree.addChild': 'Untergeordnetes Element hinzufügen',
@@ -219,6 +223,7 @@ register('de-DE', {
219
223
  'Wizard.saveAndNext': 'Speichern & Weiter',
220
224
  'year-to-year': '{{from}} - {{to}}',
221
225
  'Year.placeholder': 'Wählen Sie ein Jahr',
226
+ 'reload': 'Neu laden',
222
227
  'rotate': 'Drehen',
223
228
  'Editor.fullscreen': 'Schirmfüllend Modus',
224
229
  'Editor.exitFullscreen': 'Zurücktreten Schirmfüllend Modus',
@@ -158,7 +158,8 @@ register('en-US', {
158
158
  'System.copy': 'Content copied',
159
159
  'System.requestError': 'Request error: ',
160
160
  'System.requestErrorStatus': 'Request error, status code: ',
161
- 'Table.addRow': 'Add a row',
161
+ 'Table.addRow': 'Add row',
162
+ 'Table.copyRow': 'Copy row',
162
163
  'Table.columnsVisibility': 'Click to control columns visibility',
163
164
  'Table.deleteRow': 'Delete current row',
164
165
  'Table.discard': 'Discard',
@@ -172,6 +173,8 @@ register('en-US', {
172
173
  'Table.startSort': 'Click to start sorting',
173
174
  'Table.valueField': 'Must have valueField',
174
175
  'Table.index': 'Index',
176
+ 'Table.toggleColumn': 'Display columns',
177
+ 'Table.searchFields': 'Set query fields',
175
178
  'Tag.placeholder': 'No tag yet',
176
179
  'Tag.tip': 'Recently used tag',
177
180
  'Text.add': 'New {{label}}',
@@ -179,6 +182,7 @@ register('en-US', {
179
182
  'Transfer.configError': 'Config error',
180
183
  'Transfer.refreshIcon': 'Click to refresh',
181
184
  'Transfer.searchKeyword': 'Enter keywords',
185
+ 'Transfer.available': 'Available',
182
186
  'Transfer.selectd': 'Selected',
183
187
  'Transfer.selectFromLeft': 'Select from the left',
184
188
  'Tree.addChild': 'Add child',
@@ -220,6 +224,7 @@ register('en-US', {
220
224
  'Wizard.saveAndNext': 'Save & Next',
221
225
  'year-to-year': '{{from}} - {{to}}',
222
226
  'Year.placeholder': 'Select a Year',
227
+ 'reload': 'Reload',
223
228
  'rotate': 'Rotate',
224
229
  'Editor.fullscreen': 'full screen',
225
230
  'Editor.exitFullscreen': 'exit fullscreen mode',
@@ -83,7 +83,7 @@ register('zh-CN', {
83
83
  'desc': '降序',
84
84
  'Dialog.close': '关闭',
85
85
  'Embed.invalidRoot': '选择器不对,页面上没有此元素',
86
- 'Embed.downloading': '文件即将开始下载。。',
86
+ 'Embed.downloading': '文件即将开始下载',
87
87
  'Excel.placeholder': '拖拽 Excel 到这,或点击上传',
88
88
  'fetchFailed': '初始化失败',
89
89
  'File.continueAdd': '继续添加',
@@ -99,7 +99,7 @@ register('zh-CN', {
99
99
  'File.start': '开始上传',
100
100
  'File.upload': '上传文件',
101
101
  'File.uploadFailed': '接口返回错误,请仔细检查',
102
- 'File.uploading': '文件上传中',
102
+ 'File.uploading': '上传中...',
103
103
  'Form.loadOptionsFailed': '加载选项失败,原因:{{reason}}',
104
104
  'Form.submit': '提交',
105
105
  'Form.title': '表单',
@@ -163,6 +163,7 @@ register('zh-CN', {
163
163
  'System.requestError': '接口报错:',
164
164
  'System.requestErrorStatus': '接口出错,状态码是:',
165
165
  'Table.addRow': '新增一行',
166
+ 'Table.copyRow': '复制一行',
166
167
  'Table.columnsVisibility': '点击选择显示列',
167
168
  'Table.deleteRow': '删除当前行',
168
169
  'Table.discard': '放弃',
@@ -176,6 +177,8 @@ register('zh-CN', {
176
177
  'Table.startSort': '点击开始排序',
177
178
  'Table.valueField': '请配置 valueField',
178
179
  'Table.index': '序号',
180
+ 'Table.toggleColumn': '显示列',
181
+ 'Table.searchFields': '设置查询字段',
179
182
  'Tag.placeholder': '暂无标签',
180
183
  'Tag.tip': '最近使用的标签',
181
184
  'Text.add': '新增:{{label}}',
@@ -183,8 +186,9 @@ register('zh-CN', {
183
186
  'Transfer.configError': '配置错误,选项无法与左侧选项对应',
184
187
  'Transfer.refreshIcon': '点击刷新重新加载',
185
188
  'Transfer.searchKeyword': '请输入关键字',
186
- 'Transfer.selectd': '当前选择',
187
- 'Transfer.selectFromLeft': '请从左侧选择数据',
189
+ 'Transfer.available': '可选项',
190
+ 'Transfer.selectd': '已选项',
191
+ 'Transfer.selectFromLeft': '请选择左侧数据',
188
192
  'Tree.addChild': '添加子节点',
189
193
  'Tree.addRoot': '添加一级节点',
190
194
  'Tree.editNode': '编辑该节点',
@@ -224,6 +228,7 @@ register('zh-CN', {
224
228
  'Wizard.saveAndNext': '保存并下一步',
225
229
  'year-to-year': '{{from}} 年 - {{to}} 年',
226
230
  'Year.placeholder': '请选择年',
231
+ 'reload': '刷新',
227
232
  'rotate': '旋转',
228
233
  'Editor.fullscreen': '全屏',
229
234
  'Editor.exitFullscreen': '退出全屏',