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
@@ -7,10 +7,11 @@ var react_dom_1 = require("react-dom");
7
7
  var factory_1 = require("../../factory");
8
8
  var forEach_1 = (0, tslib_1.__importDefault)(require("lodash/forEach"));
9
9
  var tpl_1 = require("../../utils/tpl");
10
- var DropDownButton_1 = (0, tslib_1.__importDefault)(require("../DropDownButton"));
10
+ require("./ColumnToggler");
11
11
  var Checkbox_1 = (0, tslib_1.__importDefault)(require("../../components/Checkbox"));
12
12
  var Button_1 = (0, tslib_1.__importDefault)(require("../../components/Button"));
13
13
  var table_1 = require("../../store/table");
14
+ var file_saver_1 = require("file-saver");
14
15
  var helper_1 = require("../../utils/helper");
15
16
  var tpl_builtin_1 = require("../../utils/tpl-builtin");
16
17
  var debounce_1 = (0, tslib_1.__importDefault)(require("lodash/debounce"));
@@ -26,6 +27,9 @@ var TableContent_1 = require("./TableContent");
26
27
  var image_1 = require("../../utils/image");
27
28
  var TableBody_1 = require("./TableBody");
28
29
  var mobx_state_tree_1 = require("mobx-state-tree");
30
+ var ColumnToggler_1 = (0, tslib_1.__importDefault)(require("./ColumnToggler"));
31
+ var offset_1 = (0, tslib_1.__importDefault)(require("../../utils/offset"));
32
+ var dom_1 = require("../../utils/dom");
29
33
  /**
30
34
  * 将 url 转成绝对地址
31
35
  */
@@ -75,6 +79,9 @@ var Table = /** @class */ (function (_super) {
75
79
  _this.handleMouseMove = _this.handleMouseMove.bind(_this);
76
80
  _this.handleMouseLeave = _this.handleMouseLeave.bind(_this);
77
81
  _this.subFormRef = _this.subFormRef.bind(_this);
82
+ _this.handleColumnToggle = _this.handleColumnToggle.bind(_this);
83
+ _this.renderAutoFilterForm = _this.renderAutoFilterForm.bind(_this);
84
+ _this.updateAutoFillHeight = _this.updateAutoFillHeight.bind(_this);
78
85
  var store = props.store, columns = props.columns, selectable = props.selectable, columnsTogglable = props.columnsTogglable, draggable = props.draggable, orderBy = props.orderBy, orderDir = props.orderDir, multiple = props.multiple, footable = props.footable, primaryField = props.primaryField, itemCheckableOn = props.itemCheckableOn, itemDraggableOn = props.itemDraggableOn, hideCheckToggler = props.hideCheckToggler, combineFromIndex = props.combineFromIndex, expandConfig = props.expandConfig, formItem = props.formItem, keepItemSelectionOnPageChange = props.keepItemSelectionOnPageChange, maxKeepItemSelectionLength = props.maxKeepItemSelectionLength;
79
86
  var combineNum = props.combineNum;
80
87
  if (typeof combineNum === 'string') {
@@ -145,6 +152,54 @@ var Table = /** @class */ (function (_super) {
145
152
  this.affixDetect();
146
153
  parent.addEventListener('scroll', this.affixDetect);
147
154
  window.addEventListener('resize', this.affixDetect);
155
+ this.updateAutoFillHeight();
156
+ window.addEventListener('resize', this.updateAutoFillHeight);
157
+ };
158
+ /**
159
+ * 自动设置表格高度占满界面剩余区域
160
+ * 用 css 实现有点麻烦,要改很多结构,所以先用 dom hack 了,避免对之前的功能有影响
161
+ */
162
+ Table.prototype.updateAutoFillHeight = function () {
163
+ var _this = this;
164
+ var _a = this.props, autoFillHeight = _a.autoFillHeight, footerToolbar = _a.footerToolbar, ns = _a.classPrefix;
165
+ if (!autoFillHeight) {
166
+ return;
167
+ }
168
+ var table = (0, react_dom_1.findDOMNode)(this);
169
+ var tableContent = table.querySelector("." + ns + "Table-content");
170
+ var tableContentWrap = table.querySelector("." + ns + "Table-contentWrap");
171
+ var footToolbar = table.querySelector("." + ns + "Table-footToolbar");
172
+ if (!tableContent) {
173
+ return;
174
+ }
175
+ // 计算 table-content 在 dom 中的位置
176
+ var tableContentTop = (0, offset_1.default)(tableContent).top;
177
+ var viewportHeight = window.innerHeight;
178
+ // 有时候会拿不到 footToolbar?
179
+ var footToolbarHeight = footToolbar ? (0, offset_1.default)(footToolbar).height : 0;
180
+ // 有时候会拿不到 footToolbar,等一下在执行
181
+ if (!footToolbarHeight && footerToolbar && footerToolbar.length) {
182
+ setTimeout(function () {
183
+ _this.updateAutoFillHeight();
184
+ }, 100);
185
+ return;
186
+ }
187
+ var tableContentWrapMarginButtom = (0, dom_1.getStyleNumber)(tableContentWrap, 'margin-bottom');
188
+ // 循环计算父级节点的 pddding,这里不考虑父级节点还可能会有其它兄弟节点的情况了
189
+ var allParentPaddingButtom = 0;
190
+ var parentNode = tableContent.parentElement;
191
+ while (parentNode) {
192
+ var paddingButtom = (0, dom_1.getStyleNumber)(parentNode, 'padding-bottom');
193
+ var borderBottom = (0, dom_1.getStyleNumber)(parentNode, 'border-bottom-width');
194
+ allParentPaddingButtom =
195
+ allParentPaddingButtom + paddingButtom + borderBottom;
196
+ parentNode = parentNode.parentElement;
197
+ }
198
+ tableContent.style.height = viewportHeight -
199
+ tableContentTop -
200
+ tableContentWrapMarginButtom -
201
+ footToolbarHeight -
202
+ allParentPaddingButtom + "px";
148
203
  };
149
204
  Table.prototype.componentDidUpdate = function (prevProps) {
150
205
  var props = this.props;
@@ -199,8 +254,12 @@ var Table = /** @class */ (function (_super) {
199
254
  Table.syncRows(store, props, prevProps) && this.syncSelected();
200
255
  }
201
256
  else if ((0, helper_1.isArrayChildrenModified)(prevProps.selected, props.selected)) {
257
+ var prevSelectedRows = store.selectedRows
258
+ .map(function (item) { return item.id; })
259
+ .join(',');
202
260
  store.updateSelected(props.selected || [], props.valueField);
203
- this.syncSelected();
261
+ var selectedRows = store.selectedRows.map(function (item) { return item.id; }).join(',');
262
+ prevSelectedRows !== selectedRows && this.syncSelected();
204
263
  }
205
264
  this.updateTableInfoLazy();
206
265
  };
@@ -209,6 +268,7 @@ var Table = /** @class */ (function (_super) {
209
268
  var parent = this.parentNode;
210
269
  parent && parent.removeEventListener('scroll', this.affixDetect);
211
270
  window.removeEventListener('resize', this.affixDetect);
271
+ window.removeEventListener('resize', this.updateAutoFillHeight);
212
272
  this.updateTableInfoLazy.cancel();
213
273
  this.unSensor && this.unSensor();
214
274
  formItem && (0, mobx_state_tree_1.isAlive)(formItem) && formItem.setSubStore(null);
@@ -224,8 +284,14 @@ var Table = /** @class */ (function (_super) {
224
284
  // todo
225
285
  onAction(e, action, ctx);
226
286
  };
227
- Table.prototype.handleCheck = function (item) {
228
- item.toggle();
287
+ Table.prototype.handleCheck = function (item, value, shift) {
288
+ var store = this.props.store;
289
+ if (shift) {
290
+ store.toggleShift(item);
291
+ }
292
+ else {
293
+ item.toggle();
294
+ }
229
295
  this.syncSelected();
230
296
  };
231
297
  Table.prototype.handleCheckAll = function () {
@@ -337,7 +403,7 @@ var Table = /** @class */ (function (_super) {
337
403
  };
338
404
  Table.prototype.affixDetect = function () {
339
405
  var _a, _b, _c, _d;
340
- if (!this.props.affixHeader || !this.table) {
406
+ if (!this.props.affixHeader || !this.table || this.props.autoFillHeight) {
341
407
  return;
342
408
  }
343
409
  var ns = this.props.classPrefix;
@@ -509,7 +575,7 @@ var Table = /** @class */ (function (_super) {
509
575
  return (0, react_dom_1.findDOMNode)(this);
510
576
  };
511
577
  Table.prototype.handleMouseMove = function (e) {
512
- var tr = e.target.closest('tr[data-index]');
578
+ var tr = e.target.closest('tr[data-id]');
513
579
  if (!tr) {
514
580
  return;
515
581
  }
@@ -520,17 +586,17 @@ var Table = /** @class */ (function (_super) {
520
586
  (!itemActions || !itemActions.filter(function (item) { return !item.hiddenOnHover; }).length)) {
521
587
  return;
522
588
  }
523
- var index = parseInt(tr.getAttribute('data-index'), 10);
524
- if (store.hoverIndex === index) {
589
+ var id = tr.getAttribute('data-id');
590
+ var row = store.hoverRow;
591
+ if ((row === null || row === void 0 ? void 0 : row.id) === id) {
525
592
  return;
526
593
  }
527
- store.rows.forEach(function (item, key) { return item.setIsHover(index === key); });
594
+ (0, helper_1.eachTree)(store.rows, function (item) { return item.setIsHover(item.id === id); });
528
595
  };
529
596
  Table.prototype.handleMouseLeave = function () {
530
597
  var store = this.props.store;
531
- if (~store.hoverIndex) {
532
- store.rows[store.hoverIndex].setIsHover(false);
533
- }
598
+ var row = store.hoverRow;
599
+ row === null || row === void 0 ? void 0 : row.setIsHover(false);
534
600
  };
535
601
  Table.prototype.handleDragStart = function (e) {
536
602
  var store = this.props.store;
@@ -668,6 +734,87 @@ var Table = /** @class */ (function (_super) {
668
734
  document.removeEventListener('mousemove', this.handleColResizeMouseMove);
669
735
  document.removeEventListener('mouseup', this.handleColResizeMouseUp);
670
736
  };
737
+ Table.prototype.handleColumnToggle = function (columns) {
738
+ var store = this.props.store;
739
+ store.update({ columns: columns });
740
+ };
741
+ Table.prototype.renderAutoFilterForm = function () {
742
+ var _a = this.props, render = _a.render, store = _a.store, onSearchableFromReset = _a.onSearchableFromReset, onSearchableFromSubmit = _a.onSearchableFromSubmit, onSearchableFromInit = _a.onSearchableFromInit, cx = _a.classnames, __ = _a.translate;
743
+ var searchableColumns = store.searchableColumns;
744
+ var activedSearchableColumns = store.activedSearchableColumns;
745
+ if (!searchableColumns.length) {
746
+ return null;
747
+ }
748
+ var groupedSearchableColumns = [
749
+ { body: [], md: 4 },
750
+ { body: [], md: 4 },
751
+ { body: [], md: 4 }
752
+ ];
753
+ activedSearchableColumns.forEach(function (column, index) {
754
+ var _a, _b, _c, _d;
755
+ groupedSearchableColumns[index % 3].body.push((0, tslib_1.__assign)((0, tslib_1.__assign)({}, column.searchable), { name: (_b = (_a = column.searchable) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : column.name, label: (_d = (_c = column.searchable) === null || _c === void 0 ? void 0 : _c.label) !== null && _d !== void 0 ? _d : column.label, mode: 'horizontal' }));
756
+ });
757
+ return render('searchable-form', {
758
+ type: 'form',
759
+ api: null,
760
+ title: '',
761
+ mode: 'normal',
762
+ submitText: __('search'),
763
+ body: [
764
+ {
765
+ type: 'grid',
766
+ columns: groupedSearchableColumns
767
+ }
768
+ ],
769
+ actions: [
770
+ {
771
+ type: 'dropdown-button',
772
+ label: __('Table.searchFields'),
773
+ className: cx('Table-searchableForm-dropdown', 'mr-2'),
774
+ level: 'link',
775
+ trigger: 'click',
776
+ size: 'sm',
777
+ align: 'right',
778
+ buttons: searchableColumns.map(function (column) {
779
+ var _a, _b, _c, _d;
780
+ return {
781
+ type: 'checkbox',
782
+ className: cx('Table-searchableForm-checkbox'),
783
+ name: "__search_" + ((_b = (_a = column.searchable) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : column.name),
784
+ option: (_d = (_c = column.searchable) === null || _c === void 0 ? void 0 : _c.label) !== null && _d !== void 0 ? _d : column.label,
785
+ value: column.enableSearch,
786
+ badge: {
787
+ offset: [-10, 5],
788
+ visibleOn: "" + (column.toggable && !column.toggled && column.enableSearch)
789
+ },
790
+ onChange: function (value) {
791
+ column.setEnableSearch(value);
792
+ }
793
+ };
794
+ })
795
+ },
796
+ {
797
+ type: 'submit',
798
+ label: __('search'),
799
+ level: 'primary',
800
+ className: 'w-18'
801
+ },
802
+ {
803
+ type: 'reset',
804
+ label: __('reset'),
805
+ className: 'w-18'
806
+ }
807
+ ]
808
+ }, {
809
+ key: 'searchable-form',
810
+ panelClassName: cx('Table-searchableForm'),
811
+ actionsClassName: cx('Table-searchableForm-footer'),
812
+ onReset: onSearchableFromReset,
813
+ onSubmit: onSearchableFromSubmit,
814
+ onInit: onSearchableFromInit,
815
+ formStore: undefined
816
+ });
817
+ };
671
818
  Table.prototype.renderHeading = function () {
672
819
  var _a = this.props, title = _a.title, store = _a.store, hideQuickSaveBtn = _a.hideQuickSaveBtn, data = _a.data, cx = _a.classnames, saveImmediately = _a.saveImmediately, headingClassName = _a.headingClassName, quickSaveApi = _a.quickSaveApi, __ = _a.translate;
673
820
  if (title ||
@@ -699,7 +846,7 @@ var Table = /** @class */ (function (_super) {
699
846
  return null;
700
847
  };
701
848
  Table.prototype.renderHeadCell = function (column, props) {
702
- var _a = this.props, store = _a.store, query = _a.query, onQuery = _a.onQuery, multiple = _a.multiple, env = _a.env, render = _a.render, ns = _a.classPrefix, resizable = _a.resizable, cx = _a.classnames;
849
+ var _a = this.props, store = _a.store, query = _a.query, onQuery = _a.onQuery, multiple = _a.multiple, env = _a.env, render = _a.render, ns = _a.classPrefix, resizable = _a.resizable, cx = _a.classnames, autoGenerateFilter = _a.autoGenerateFilter;
703
850
  if (column.type === '__checkme') {
704
851
  return (react_1.default.createElement("th", (0, tslib_1.__assign)({}, props, { className: cx(column.pristine.className) }), store.rows.length && multiple ? (react_1.default.createElement(Checkbox_1.default, { classPrefix: ns, partial: !store.allChecked, checked: store.someChecked, disabled: store.disabledHeadCheckbox, onChange: this.handleCheckAll })) : ('\u00A0')));
705
852
  }
@@ -718,7 +865,7 @@ var Table = /** @class */ (function (_super) {
718
865
  react_1.default.createElement(icons_1.Icon, { icon: "right-arrow-bold", className: "icon" })))));
719
866
  }
720
867
  var affix = null;
721
- if (column.searchable && column.name) {
868
+ if (column.searchable && column.name && !autoGenerateFilter) {
722
869
  affix = (react_1.default.createElement(HeadCellSearchDropdown_1.HeadCellSearchDropDown, (0, tslib_1.__assign)({}, this.props, { onQuery: onQuery, name: column.name, searchable: column.searchable, sortable: column.sortable, type: column.type, data: query, orderBy: store.orderBy, orderDir: store.orderDir, popOverContainer: this.getPopOverContainer })));
723
870
  }
724
871
  else if (column.sortable && column.name) {
@@ -787,7 +934,7 @@ var Table = /** @class */ (function (_super) {
787
934
  };
788
935
  Table.prototype.renderCell = function (region, column, item, props, ignoreDrag) {
789
936
  if (ignoreDrag === void 0) { ignoreDrag = false; }
790
- var _a = this.props, render = _a.render, store = _a.store, multiple = _a.multiple, ns = _a.classPrefix, cx = _a.classnames, checkOnItemClick = _a.checkOnItemClick, popOverContainer = _a.popOverContainer, canAccessSuperData = _a.canAccessSuperData;
937
+ var _a = this.props, render = _a.render, store = _a.store, multiple = _a.multiple, ns = _a.classPrefix, cx = _a.classnames, checkOnItemClick = _a.checkOnItemClick, popOverContainer = _a.popOverContainer, canAccessSuperData = _a.canAccessSuperData, itemBadge = _a.itemBadge;
791
938
  if (column.name && item.rowSpans[column.name] === 0) {
792
939
  return null;
793
940
  }
@@ -820,7 +967,9 @@ var Table = /** @class */ (function (_super) {
820
967
  }
821
968
  var subProps = (0, tslib_1.__assign)((0, tslib_1.__assign)({}, props), { btnDisabled: store.dragging, data: item.locals, value: column.name
822
969
  ? (0, tpl_builtin_1.resolveVariable)(column.name, canAccessSuperData ? item.locals : item.data)
823
- : column.value, popOverContainer: popOverContainer || this.getPopOverContainer, rowSpan: item.rowSpans[column.name], quickEditFormRef: this.subFormRef, prefix: prefix, onImageEnlarge: this.handleImageEnlarge, canAccessSuperData: canAccessSuperData });
970
+ : column.value, popOverContainer: popOverContainer || this.getPopOverContainer, rowSpan: item.rowSpans[column.name], quickEditFormRef: this.subFormRef, prefix: prefix, onImageEnlarge: this.handleImageEnlarge, canAccessSuperData: canAccessSuperData, row: item, itemBadge: itemBadge, showBadge: !props.isHead &&
971
+ itemBadge &&
972
+ store.firstToggledColumnIndex === props.colIndex });
824
973
  delete subProps.label;
825
974
  return render(region, (0, tslib_1.__assign)((0, tslib_1.__assign)({}, column.pristine), { column: column.pristine, type: 'cell' }), subProps);
826
975
  };
@@ -901,14 +1050,15 @@ var Table = /** @class */ (function (_super) {
901
1050
  return void 0;
902
1051
  };
903
1052
  Table.prototype.renderColumnsToggler = function (config) {
904
- var _a = this.props, className = _a.className, store = _a.store, ns = _a.classPrefix, cx = _a.classnames, rest = (0, tslib_1.__rest)(_a, ["className", "store", "classPrefix", "classnames"]);
1053
+ var _a;
1054
+ var _b = this.props, className = _b.className, store = _b.store, ns = _b.classPrefix, cx = _b.classnames, rest = (0, tslib_1.__rest)(_b, ["className", "store", "classPrefix", "classnames"]);
905
1055
  var __ = rest.translate;
906
1056
  var env = rest.env;
907
1057
  var render = this.props.render;
908
1058
  if (!store.columnsTogglable) {
909
1059
  return null;
910
1060
  }
911
- return (react_1.default.createElement(DropDownButton_1.default, (0, tslib_1.__assign)({}, rest, { tooltip: __('Table.columnsVisibility'), tooltipContainer: env && env.getModalContainer ? env.getModalContainer : undefined, align: config ? config.align : 'left', isActived: store.hasColumnHidden(), classnames: cx, classPrefix: ns, key: "columns-toggable", size: "sm", label: react_1.default.createElement(icons_1.Icon, { icon: "columns", className: "icon m-r-none" }) }), store.toggableColumns.map(function (column) { return (react_1.default.createElement("li", { className: cx('DropDown-menuItem'), key: column.index, onClick: column.toggleToggle },
1061
+ return (react_1.default.createElement(ColumnToggler_1.default, (0, tslib_1.__assign)({}, rest, ((0, helper_1.isObject)(config) ? config : {}), { tooltip: (config === null || config === void 0 ? void 0 : config.tooltip) || __('Table.columnsVisibility'), tooltipContainer: env && env.getModalContainer ? env.getModalContainer : undefined, align: (_a = config === null || config === void 0 ? void 0 : config.align) !== null && _a !== void 0 ? _a : 'left', isActived: store.hasColumnHidden(), classnames: cx, classPrefix: ns, key: "columns-toggable", size: (config === null || config === void 0 ? void 0 : config.size) || 'sm', label: (config === null || config === void 0 ? void 0 : config.label) || react_1.default.createElement(icons_1.Icon, { icon: "columns", className: "icon m-r-none" }), draggable: config === null || config === void 0 ? void 0 : config.draggable, columns: store.columnsData, onColumnToggle: this.handleColumnToggle }), store.toggableColumns.map(function (column) { return (react_1.default.createElement("li", { className: cx('ColumnToggler-menuItem'), key: column.index, onClick: column.toggleToggle },
912
1062
  react_1.default.createElement(Checkbox_1.default, { size: "sm", classPrefix: ns, checked: column.toggled }, column.label ? render('tpl', column.label) : null))); })));
913
1063
  };
914
1064
  Table.prototype.renderDragToggler = function () {
@@ -931,7 +1081,7 @@ var Table = /** @class */ (function (_super) {
931
1081
  }
932
1082
  return (react_1.default.createElement(Button_1.default, { classPrefix: ns, onClick: function () {
933
1083
  Promise.resolve().then(function () { return new Promise(function(resolve){require(['exceljs'], function(ret) {resolve(tslib_1.__importStar(ret));})}); }).then(function (ExcelJS) { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
934
- var rows, tmpStore, filename, res, workbook, worksheet, firstRowLabels, firstRow, rowIndex, _i, rows_1, row, sheetRow, columIndex, cols, _a, cols_1, column, name, value, type, imageData, imageDimensions, imageWidth, imageHeight, imageMaxSize, imageMatch, imageExt, imageId, linkURL, e_1, linkURL, map, viewValue, buffer, blob;
1084
+ var rows, tmpStore, filename, res, workbook, worksheet, filteredColumns, firstRowLabels, firstRow, remoteMappingCache, rowIndex, _i, rows_1, row, sheetRow, columIndex, _a, filteredColumns_1, column, name, value, type, imageData, imageDimensions, imageWidth, imageHeight, imageMaxSize, imageMatch, imageExt, imageId, linkURL, e_1, linkURL, map, source, sourceValue, mapKey, res, viewValue, buffer, blob;
935
1085
  var _b, _c;
936
1086
  return (0, tslib_1.__generator)(this, function (_d) {
937
1087
  switch (_d.label) {
@@ -973,7 +1123,16 @@ var Table = /** @class */ (function (_super) {
973
1123
  properties: { defaultColWidth: 15 }
974
1124
  });
975
1125
  worksheet.views = [{ state: 'frozen', xSplit: 0, ySplit: 1 }];
976
- firstRowLabels = columns.map(function (column) {
1126
+ filteredColumns = toolbar.columns
1127
+ ? columns.filter(function (column) {
1128
+ var filterColumnsNames = toolbar.columns;
1129
+ if (filterColumnsNames.indexOf(column.name) !== -1) {
1130
+ return true;
1131
+ }
1132
+ return false;
1133
+ })
1134
+ : columns;
1135
+ firstRowLabels = filteredColumns.map(function (column) {
977
1136
  return column.label;
978
1137
  });
979
1138
  firstRow = worksheet.getRow(1);
@@ -988,32 +1147,32 @@ var Table = /** @class */ (function (_super) {
988
1147
  column: firstRowLabels.length
989
1148
  }
990
1149
  };
1150
+ remoteMappingCache = {};
991
1151
  rowIndex = 1;
992
1152
  _i = 0, rows_1 = rows;
993
1153
  _d.label = 4;
994
1154
  case 4:
995
- if (!(_i < rows_1.length)) return [3 /*break*/, 14];
1155
+ if (!(_i < rows_1.length)) return [3 /*break*/, 19];
996
1156
  row = rows_1[_i];
997
1157
  rowIndex += 1;
998
1158
  sheetRow = worksheet.getRow(rowIndex);
999
1159
  columIndex = 0;
1000
- cols = columns;
1001
- _a = 0, cols_1 = cols;
1160
+ _a = 0, filteredColumns_1 = filteredColumns;
1002
1161
  _d.label = 5;
1003
1162
  case 5:
1004
- if (!(_a < cols_1.length)) return [3 /*break*/, 13];
1005
- column = cols_1[_a];
1163
+ if (!(_a < filteredColumns_1.length)) return [3 /*break*/, 18];
1164
+ column = filteredColumns_1[_a];
1006
1165
  columIndex += 1;
1007
1166
  name = column.name;
1008
1167
  value = (0, helper_1.getVariable)(row.data, name);
1009
1168
  if (typeof value === 'undefined' &&
1010
1169
  !column.tpl) {
1011
- return [3 /*break*/, 12];
1170
+ return [3 /*break*/, 17];
1012
1171
  }
1013
1172
  // 处理合并单元格
1014
1173
  if (name in row.rowSpans) {
1015
1174
  if (row.rowSpans[name] === 0) {
1016
- return [3 /*break*/, 12];
1175
+ return [3 /*break*/, 17];
1017
1176
  }
1018
1177
  else {
1019
1178
  // start row, start column, end row, end column
@@ -1056,7 +1215,7 @@ var Table = /** @class */ (function (_super) {
1056
1215
  imageExt != 'jpeg' &&
1057
1216
  imageExt != 'gif') {
1058
1217
  sheetRow.getCell(columIndex).value = value;
1059
- return [3 /*break*/, 12];
1218
+ return [3 /*break*/, 17];
1060
1219
  }
1061
1220
  imageId = workbook.addImage({
1062
1221
  base64: imageData,
@@ -1079,54 +1238,74 @@ var Table = /** @class */ (function (_super) {
1079
1238
  e_1 = _d.sent();
1080
1239
  console.warn(e_1.stack);
1081
1240
  return [3 /*break*/, 10];
1082
- case 10: return [3 /*break*/, 12];
1241
+ case 10: return [3 /*break*/, 17];
1083
1242
  case 11:
1084
- if (type == 'link') {
1085
- linkURL = getAbsoluteUrl(value);
1086
- sheetRow.getCell(columIndex).value = {
1087
- text: value,
1088
- hyperlink: linkURL
1089
- };
1243
+ if (!(type == 'link')) return [3 /*break*/, 12];
1244
+ linkURL = getAbsoluteUrl(value);
1245
+ sheetRow.getCell(columIndex).value = {
1246
+ text: value,
1247
+ hyperlink: linkURL
1248
+ };
1249
+ return [3 /*break*/, 17];
1250
+ case 12:
1251
+ if (!(type === 'mapping')) return [3 /*break*/, 16];
1252
+ map = column.map;
1253
+ source = column.source;
1254
+ if (!source) return [3 /*break*/, 15];
1255
+ sourceValue = source;
1256
+ if ((0, tpl_builtin_1.isPureVariable)(source)) {
1257
+ sourceValue = (0, tpl_builtin_1.resolveVariableAndFilter)(source, data, '| raw');
1090
1258
  }
1091
- else if (type === 'mapping') {
1092
- map = column.map;
1093
- if (typeof value !== 'undefined' &&
1094
- map &&
1095
- ((_b = map[value]) !== null && _b !== void 0 ? _b : map['*'])) {
1096
- viewValue = (_c = map[value]) !== null && _c !== void 0 ? _c : (value === true && map['1']
1097
- ? map['1']
1098
- : value === false && map['0']
1099
- ? map['0']
1100
- : map['*']);
1101
- sheetRow.getCell(columIndex).value = viewValue;
1102
- }
1103
- else {
1104
- sheetRow.getCell(columIndex).value = value;
1105
- }
1259
+ mapKey = JSON.stringify(source);
1260
+ if (!(mapKey in remoteMappingCache)) return [3 /*break*/, 13];
1261
+ map = remoteMappingCache[mapKey];
1262
+ return [3 /*break*/, 15];
1263
+ case 13: return [4 /*yield*/, env.fetcher(sourceValue, data)];
1264
+ case 14:
1265
+ res = _d.sent();
1266
+ if (res.data) {
1267
+ remoteMappingCache[mapKey] = res.data;
1268
+ map = res.data;
1269
+ }
1270
+ _d.label = 15;
1271
+ case 15:
1272
+ if (typeof value !== 'undefined' &&
1273
+ map &&
1274
+ ((_b = map[value]) !== null && _b !== void 0 ? _b : map['*'])) {
1275
+ viewValue = (_c = map[value]) !== null && _c !== void 0 ? _c : (value === true && map['1']
1276
+ ? map['1']
1277
+ : value === false && map['0']
1278
+ ? map['0']
1279
+ : map['*']);
1280
+ sheetRow.getCell(columIndex).value =
1281
+ (0, helper_1.removeHTMLTag)(viewValue);
1106
1282
  }
1107
1283
  else {
1108
- if (column.tpl) {
1109
- sheetRow.getCell(columIndex).value = (0, helper_1.removeHTMLTag)((0, tpl_1.filter)(column.tpl, row.data));
1110
- }
1111
- else {
1112
- sheetRow.getCell(columIndex).value = value;
1113
- }
1284
+ sheetRow.getCell(columIndex).value = (0, helper_1.removeHTMLTag)(value);
1114
1285
  }
1115
- _d.label = 12;
1116
- case 12:
1286
+ return [3 /*break*/, 17];
1287
+ case 16:
1288
+ if (column.tpl) {
1289
+ sheetRow.getCell(columIndex).value = (0, helper_1.removeHTMLTag)((0, tpl_1.filter)(column.tpl, (0, helper_1.createObject)(data, row.data)));
1290
+ }
1291
+ else {
1292
+ sheetRow.getCell(columIndex).value = value;
1293
+ }
1294
+ _d.label = 17;
1295
+ case 17:
1117
1296
  _a++;
1118
1297
  return [3 /*break*/, 5];
1119
- case 13:
1298
+ case 18:
1120
1299
  _i++;
1121
1300
  return [3 /*break*/, 4];
1122
- case 14: return [4 /*yield*/, workbook.xlsx.writeBuffer()];
1123
- case 15:
1301
+ case 19: return [4 /*yield*/, workbook.xlsx.writeBuffer()];
1302
+ case 20:
1124
1303
  buffer = _d.sent();
1125
1304
  if (buffer) {
1126
1305
  blob = new Blob([buffer], {
1127
1306
  type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
1128
1307
  });
1129
- saveAs(blob, filename + '.xlsx');
1308
+ (0, file_saver_1.saveAs)(blob, filename + '.xlsx');
1130
1309
  }
1131
1310
  return [2 /*return*/];
1132
1311
  }
@@ -1204,55 +1383,25 @@ var Table = /** @class */ (function (_super) {
1204
1383
  ? [toolbarNode, footerNode]
1205
1384
  : footerNode || toolbarNode || null;
1206
1385
  };
1207
- Table.prototype.renderItemActions = function () {
1208
- var _a = this.props, itemActions = _a.itemActions, render = _a.render, store = _a.store, cx = _a.classnames;
1209
- var finalActions = Array.isArray(itemActions)
1210
- ? itemActions.filter(function (action) { return !action.hiddenOnHover; })
1211
- : [];
1212
- if (!finalActions.length) {
1213
- return null;
1214
- }
1215
- var rowIndex = store.hoverIndex;
1216
- var heights = this.heights;
1217
- var height = 40;
1218
- var top = 0;
1219
- if (heights && heights[rowIndex]) {
1220
- height = heights[rowIndex];
1221
- top += heights.header;
1222
- for (var i = rowIndex - 1; i >= 0; i--) {
1223
- top += heights[i];
1224
- }
1225
- }
1226
- return (react_1.default.createElement("div", { className: cx('Table-itemActions-wrap'), style: {
1227
- top: top,
1228
- height: height
1229
- } },
1230
- react_1.default.createElement("div", { className: cx('Table-itemActions') }, finalActions.map(function (action, index) {
1231
- return render("itemAction/" + index, (0, tslib_1.__assign)((0, tslib_1.__assign)({}, action), { isMenuItem: true }), {
1232
- key: index,
1233
- item: store.rows[rowIndex],
1234
- data: store.rows[rowIndex].locals,
1235
- rowIndex: rowIndex
1236
- });
1237
- }))));
1238
- };
1239
1386
  Table.prototype.renderTableContent = function () {
1240
- var _a = this.props, cx = _a.classnames, tableClassName = _a.tableClassName, store = _a.store, placeholder = _a.placeholder, render = _a.render, checkOnItemClick = _a.checkOnItemClick, buildItemProps = _a.buildItemProps, rowClassNameExpr = _a.rowClassNameExpr, rowClassName = _a.rowClassName, prefixRow = _a.prefixRow, locale = _a.locale, affixRow = _a.affixRow, translate = _a.translate, itemAction = _a.itemAction;
1387
+ var _a = this.props, cx = _a.classnames, tableClassName = _a.tableClassName, store = _a.store, placeholder = _a.placeholder, render = _a.render, checkOnItemClick = _a.checkOnItemClick, buildItemProps = _a.buildItemProps, rowClassNameExpr = _a.rowClassNameExpr, rowClassName = _a.rowClassName, prefixRow = _a.prefixRow, locale = _a.locale, affixRow = _a.affixRow, tableContentClassName = _a.tableContentClassName, translate = _a.translate, itemAction = _a.itemAction, autoFillHeight = _a.autoFillHeight, itemActions = _a.itemActions;
1241
1388
  // 理论上来说 store.rows 应该也行啊
1242
1389
  // 不过目前看来只有这样写它才会重新更新视图
1243
1390
  store.rows.length;
1244
- return (react_1.default.createElement(TableContent_1.TableContent, { tableClassName: cx(store.combineNum > 0 ? 'Table-table--withCombine' : '', tableClassName), itemAction: itemAction, classnames: cx, columns: store.filteredColumns, columnsGroup: store.columnGroup, rows: store.rows, placeholder: placeholder, render: render, onMouseMove: this.handleMouseMove, onScroll: this.handleOutterScroll, tableRef: this.tableRef, renderHeadCell: this.renderHeadCell, renderCell: this.renderCell, onCheck: this.handleCheck, onQuickChange: store.dragging ? undefined : this.handleQuickChange, footable: store.footable, footableColumns: store.footableColumns, checkOnItemClick: checkOnItemClick, buildItemProps: buildItemProps, onAction: this.handleAction, rowClassNameExpr: rowClassNameExpr, rowClassName: rowClassName, data: store.data, prefixRow: prefixRow, affixRow: affixRow, locale: locale, translate: translate }));
1391
+ return (react_1.default.createElement(TableContent_1.TableContent, { tableClassName: cx(store.combineNum > 0 ? 'Table-table--withCombine' : '', { 'Table-table--checkOnItemClick': checkOnItemClick }, tableClassName), className: tableContentClassName, itemActions: itemActions, itemAction: itemAction, store: store, classnames: cx, columns: store.filteredColumns, columnsGroup: store.columnGroup, rows: store.rows, placeholder: placeholder, render: render, onMouseMove: this.handleMouseMove, onScroll: this.handleOutterScroll, tableRef: this.tableRef, renderHeadCell: this.renderHeadCell, renderCell: this.renderCell, onCheck: this.handleCheck, onQuickChange: store.dragging ? undefined : this.handleQuickChange, footable: store.footable, footableColumns: store.footableColumns, checkOnItemClick: checkOnItemClick, buildItemProps: buildItemProps, onAction: this.handleAction, rowClassNameExpr: rowClassNameExpr, rowClassName: rowClassName, data: store.data, prefixRow: prefixRow, affixRow: affixRow, locale: locale, translate: translate }));
1245
1392
  };
1246
1393
  Table.prototype.render = function () {
1247
- var _a = this.props, className = _a.className, store = _a.store, cx = _a.classnames, affixColumns = _a.affixColumns;
1394
+ var _a = this.props, className = _a.className, store = _a.store, cx = _a.classnames, affixColumns = _a.affixColumns, autoFillHeight = _a.autoFillHeight, autoGenerateFilter = _a.autoGenerateFilter;
1248
1395
  this.renderedToolbars = []; // 用来记录哪些 toolbar 已经渲染了,已经渲染了就不重复渲染了。
1249
1396
  var heading = this.renderHeading();
1250
1397
  var header = this.renderHeader();
1251
1398
  var footer = this.renderFooter();
1252
1399
  var tableClassName = cx('Table-table', store.combineNum > 0 ? 'Table-table--withCombine' : '', this.props.tableClassName);
1253
1400
  return (react_1.default.createElement("div", { className: cx('Table', className, {
1254
- 'Table--unsaved': !!store.modified || !!store.moved
1401
+ 'Table--unsaved': !!store.modified || !!store.moved,
1402
+ 'Table--autoFillHeight': autoFillHeight
1255
1403
  }) },
1404
+ autoGenerateFilter ? this.renderAutoFilterForm() : null,
1256
1405
  header,
1257
1406
  heading,
1258
1407
  react_1.default.createElement("div", { className: cx('Table-contentWrap'), onMouseLeave: this.handleMouseLeave },
@@ -1262,8 +1411,7 @@ var Table = /** @class */ (function (_super) {
1262
1411
  react_1.default.createElement("div", { className: cx('Table-fixedRight'), onMouseMove: this.handleMouseMove }, affixColumns !== false && store.rightFixedColumns.length
1263
1412
  ? this.renderFixedColumns(store.rows, store.rightFixedColumns, false, tableClassName)
1264
1413
  : null),
1265
- this.renderTableContent(),
1266
- ~store.hoverIndex ? this.renderItemActions() : null),
1414
+ this.renderTableContent()),
1267
1415
  this.renderAffixHeader(tableClassName),
1268
1416
  footer));
1269
1417
  };
@@ -1306,7 +1454,9 @@ var Table = /** @class */ (function (_super) {
1306
1454
  'popOverContainer',
1307
1455
  'headerToolbarClassName',
1308
1456
  'toolbarClassName',
1309
- 'footerToolbarClassName'
1457
+ 'footerToolbarClassName',
1458
+ 'itemBadge',
1459
+ 'autoFillHeight'
1310
1460
  ];
1311
1461
  Table.defaultProps = {
1312
1462
  className: '',