amis 2.0.0-rc.10 → 2.0.0-rc.16

Sign up to get free protection for your applications and to get access to all the features.
Files changed (535) hide show
  1. package/esm/Schema.d.ts +442 -0
  2. package/esm/compat.d.ts +1 -0
  3. package/esm/compat.js +459 -0
  4. package/esm/index.d.ts +146 -0
  5. package/esm/index.js +144 -0
  6. package/esm/preset.d.ts +1 -0
  7. package/esm/preset.js +40 -0
  8. package/esm/renderers/Action.d.ts +393 -0
  9. package/esm/renderers/Action.js +443 -0
  10. package/esm/renderers/Alert.d.ts +49 -0
  11. package/esm/renderers/Alert.js +35 -0
  12. package/esm/renderers/AnchorNav.d.ts +69 -0
  13. package/esm/renderers/AnchorNav.js +97 -0
  14. package/esm/renderers/App.d.ts +121 -0
  15. package/esm/renderers/App.js +198 -0
  16. package/esm/renderers/Audio.d.ts +88 -0
  17. package/esm/renderers/Audio.js +382 -0
  18. package/esm/renderers/Avatar.d.ts +75 -0
  19. package/esm/renderers/Avatar.js +54 -0
  20. package/esm/renderers/BarCode.d.ts +35 -0
  21. package/esm/renderers/BarCode.js +38 -0
  22. package/esm/renderers/Breadcrumb.d.ts +89 -0
  23. package/esm/renderers/Breadcrumb.js +58 -0
  24. package/esm/renderers/ButtonGroup.d.ts +64 -0
  25. package/esm/renderers/ButtonGroup.js +22 -0
  26. package/esm/renderers/CRUD.d.ts +302 -0
  27. package/esm/renderers/CRUD.js +1245 -0
  28. package/esm/renderers/CRUD2.d.ts +215 -0
  29. package/esm/renderers/CRUD2.js +742 -0
  30. package/esm/renderers/Calendar.d.ts +45 -0
  31. package/esm/renderers/Calendar.js +22 -0
  32. package/esm/renderers/Card.d.ts +231 -0
  33. package/esm/renderers/Card.js +372 -0
  34. package/esm/renderers/Card2.d.ts +77 -0
  35. package/esm/renderers/Card2.js +83 -0
  36. package/esm/renderers/Cards.d.ts +170 -0
  37. package/esm/renderers/Cards.js +556 -0
  38. package/esm/renderers/Carousel.d.ts +103 -0
  39. package/esm/renderers/Carousel.js +329 -0
  40. package/esm/renderers/Chart.d.ts +116 -0
  41. package/esm/renderers/Chart.js +352 -0
  42. package/esm/renderers/Code.d.ts +84 -0
  43. package/esm/renderers/Code.js +130 -0
  44. package/esm/renderers/Collapse.d.ts +83 -0
  45. package/esm/renderers/Collapse.js +47 -0
  46. package/esm/renderers/CollapseGroup.d.ts +42 -0
  47. package/esm/renderers/CollapseGroup.js +35 -0
  48. package/esm/renderers/Color.d.ts +36 -0
  49. package/esm/renderers/Color.js +42 -0
  50. package/esm/renderers/Container.d.ts +44 -0
  51. package/esm/renderers/Container.js +49 -0
  52. package/esm/renderers/Copyable.d.ts +25 -0
  53. package/esm/renderers/Copyable.js +49 -0
  54. package/esm/renderers/Custom.d.ts +51 -0
  55. package/esm/renderers/Custom.js +163 -0
  56. package/esm/renderers/Date.d.ts +58 -0
  57. package/esm/renderers/Date.js +121 -0
  58. package/esm/renderers/Dialog.d.ts +1357 -0
  59. package/esm/renderers/Dialog.js +633 -0
  60. package/esm/renderers/Divider.d.ts +20 -0
  61. package/esm/renderers/Divider.js +38 -0
  62. package/esm/renderers/Drawer.d.ts +153 -0
  63. package/esm/renderers/Drawer.js +608 -0
  64. package/esm/renderers/DropDownButton.d.ts +114 -0
  65. package/esm/renderers/DropDownButton.js +151 -0
  66. package/esm/renderers/Each.d.ts +38 -0
  67. package/esm/renderers/Each.js +59 -0
  68. package/esm/renderers/Flex.d.ts +77 -0
  69. package/esm/renderers/Flex.js +83 -0
  70. package/esm/renderers/Form/ButtonGroupSelect.d.ts +26 -0
  71. package/esm/renderers/Form/ButtonGroupSelect.js +114 -0
  72. package/esm/renderers/Form/ButtonToolbar.d.ts +28 -0
  73. package/esm/renderers/Form/ButtonToolbar.js +50 -0
  74. package/esm/renderers/Form/ChainedSelect.d.ts +36 -0
  75. package/esm/renderers/Form/ChainedSelect.js +213 -0
  76. package/esm/renderers/Form/ChartRadios.d.ts +34 -0
  77. package/esm/renderers/Form/ChartRadios.js +121 -0
  78. package/esm/renderers/Form/Checkbox.d.ts +47 -0
  79. package/esm/renderers/Form/Checkbox.js +83 -0
  80. package/esm/renderers/Form/Checkboxes.d.ts +65 -0
  81. package/esm/renderers/Form/Checkboxes.js +226 -0
  82. package/esm/renderers/Form/Combo.d.ts +251 -0
  83. package/esm/renderers/Form/Combo.js +822 -0
  84. package/esm/renderers/Form/ConditionBuilder.d.ts +56 -0
  85. package/esm/renderers/Form/ConditionBuilder.js +69 -0
  86. package/esm/renderers/Form/Control.d.ts +18 -0
  87. package/esm/renderers/Form/Control.js +38 -0
  88. package/esm/renderers/Form/DiffEditor.d.ts +3925 -0
  89. package/esm/renderers/Form/DiffEditor.js +199 -0
  90. package/esm/renderers/Form/Editor.d.ts +3856 -0
  91. package/esm/renderers/Form/Editor.js +247 -0
  92. package/esm/renderers/Form/FieldSet.d.ts +70 -0
  93. package/esm/renderers/Form/FieldSet.js +59 -0
  94. package/esm/renderers/Form/Formula.d.ts +53 -0
  95. package/esm/renderers/Form/Formula.js +128 -0
  96. package/esm/renderers/Form/Group.d.ts +57 -0
  97. package/esm/renderers/Form/Group.js +99 -0
  98. package/esm/renderers/Form/Hidden.d.ts +15 -0
  99. package/esm/renderers/Form/Hidden.js +35 -0
  100. package/esm/renderers/Form/IconPicker.d.ts +49 -0
  101. package/esm/renderers/Form/IconPicker.js +305 -0
  102. package/esm/renderers/Form/IconPickerIcons.d.ts +8 -0
  103. package/esm/renderers/Form/IconPickerIcons.js +26 -0
  104. package/esm/renderers/Form/InputArray.d.ts +31 -0
  105. package/esm/renderers/Form/InputArray.js +45 -0
  106. package/esm/renderers/Form/InputCity.d.ts +654 -0
  107. package/esm/renderers/Form/InputCity.js +347 -0
  108. package/esm/renderers/Form/InputColor.d.ts +504 -0
  109. package/esm/renderers/Form/InputColor.js +52 -0
  110. package/esm/renderers/Form/InputDate.d.ts +359 -0
  111. package/esm/renderers/Form/InputDate.js +258 -0
  112. package/esm/renderers/Form/InputDateRange.d.ts +121 -0
  113. package/esm/renderers/Form/InputDateRange.js +166 -0
  114. package/esm/renderers/Form/InputExcel.d.ts +51 -0
  115. package/esm/renderers/Form/InputExcel.js +195 -0
  116. package/esm/renderers/Form/InputFile.d.ts +257 -0
  117. package/esm/renderers/Form/InputFile.js +927 -0
  118. package/esm/renderers/Form/InputFormula.d.ts +91 -0
  119. package/esm/renderers/Form/InputFormula.js +67 -0
  120. package/esm/renderers/Form/InputGroup.d.ts +33 -0
  121. package/esm/renderers/Form/InputGroup.js +111 -0
  122. package/esm/renderers/Form/InputImage.d.ts +315 -0
  123. package/esm/renderers/Form/InputImage.js +896 -0
  124. package/esm/renderers/Form/InputMonthRange.d.ts +22 -0
  125. package/esm/renderers/Form/InputMonthRange.js +46 -0
  126. package/esm/renderers/Form/InputNumber.d.ts +128 -0
  127. package/esm/renderers/Form/InputNumber.js +210 -0
  128. package/esm/renderers/Form/InputQuarterRange.d.ts +22 -0
  129. package/esm/renderers/Form/InputQuarterRange.js +46 -0
  130. package/esm/renderers/Form/InputRange.d.ts +271 -0
  131. package/esm/renderers/Form/InputRange.js +388 -0
  132. package/esm/renderers/Form/InputRating.d.ts +74 -0
  133. package/esm/renderers/Form/InputRating.js +82 -0
  134. package/esm/renderers/Form/InputRepeat.d.ts +35 -0
  135. package/esm/renderers/Form/InputRepeat.js +115 -0
  136. package/esm/renderers/Form/InputRichText.d.ts +56 -0
  137. package/esm/renderers/Form/InputRichText.js +177 -0
  138. package/esm/renderers/Form/InputSubForm.d.ts +123 -0
  139. package/esm/renderers/Form/InputSubForm.js +269 -0
  140. package/esm/renderers/Form/InputTable.d.ts +180 -0
  141. package/esm/renderers/Form/InputTable.js +677 -0
  142. package/esm/renderers/Form/InputTag.d.ts +108 -0
  143. package/esm/renderers/Form/InputTag.js +439 -0
  144. package/esm/renderers/Form/InputText.d.ts +133 -0
  145. package/esm/renderers/Form/InputText.js +632 -0
  146. package/esm/renderers/Form/InputTree.d.ts +86 -0
  147. package/esm/renderers/Form/InputTree.js +108 -0
  148. package/esm/renderers/Form/InputYearRange.d.ts +22 -0
  149. package/esm/renderers/Form/InputYearRange.js +46 -0
  150. package/esm/renderers/Form/JSONSchema.d.ts +24 -0
  151. package/esm/renderers/Form/JSONSchema.js +45 -0
  152. package/esm/renderers/Form/JSONSchemaEditor.d.ts +64 -0
  153. package/esm/renderers/Form/JSONSchemaEditor.js +57 -0
  154. package/esm/renderers/Form/ListSelect.d.ts +45 -0
  155. package/esm/renderers/Form/ListSelect.js +89 -0
  156. package/esm/renderers/Form/LocationPicker.d.ts +35 -0
  157. package/esm/renderers/Form/LocationPicker.js +39 -0
  158. package/esm/renderers/Form/MatrixCheckboxes.d.ts +79 -0
  159. package/esm/renderers/Form/MatrixCheckboxes.js +266 -0
  160. package/esm/renderers/Form/NestedSelect.d.ts +91 -0
  161. package/esm/renderers/Form/NestedSelect.js +703 -0
  162. package/esm/renderers/Form/Picker.d.ts +86 -0
  163. package/esm/renderers/Form/Picker.js +361 -0
  164. package/esm/renderers/Form/Radios.d.ts +39 -0
  165. package/esm/renderers/Form/Radios.js +91 -0
  166. package/esm/renderers/Form/Select.d.ts +140 -0
  167. package/esm/renderers/Form/Select.js +309 -0
  168. package/esm/renderers/Form/Static.d.ts +59 -0
  169. package/esm/renderers/Form/Static.js +109 -0
  170. package/esm/renderers/Form/Switch.d.ts +54 -0
  171. package/esm/renderers/Form/Switch.js +77 -0
  172. package/esm/renderers/Form/TabsTransfer.d.ts +30 -0
  173. package/esm/renderers/Form/TabsTransfer.js +241 -0
  174. package/esm/renderers/Form/TabsTransferPicker.d.ts +26 -0
  175. package/esm/renderers/Form/TabsTransferPicker.js +72 -0
  176. package/esm/renderers/Form/Textarea.d.ts +69 -0
  177. package/esm/renderers/Form/Textarea.js +103 -0
  178. package/esm/renderers/Form/Transfer.d.ts +115 -0
  179. package/esm/renderers/Form/Transfer.js +276 -0
  180. package/esm/renderers/Form/TransferPicker.d.ts +26 -0
  181. package/esm/renderers/Form/TransferPicker.js +66 -0
  182. package/esm/renderers/Form/TreeSelect.d.ts +132 -0
  183. package/esm/renderers/Form/TreeSelect.js +376 -0
  184. package/esm/renderers/Form/UUID.d.ts +22 -0
  185. package/esm/renderers/Form/UUID.js +52 -0
  186. package/esm/renderers/Form/UserSelect.d.ts +55 -0
  187. package/esm/renderers/Form/UserSelect.js +194 -0
  188. package/esm/renderers/Grid.d.ts +82 -0
  189. package/esm/renderers/Grid.js +88 -0
  190. package/esm/renderers/Grid2D.d.ts +91 -0
  191. package/esm/renderers/Grid2D.js +113 -0
  192. package/esm/renderers/GridNav.d.ts +99 -0
  193. package/esm/renderers/GridNav.js +80 -0
  194. package/esm/renderers/HBox.d.ts +95 -0
  195. package/esm/renderers/HBox.js +75 -0
  196. package/esm/renderers/IFrame.d.ts +49 -0
  197. package/esm/renderers/IFrame.js +169 -0
  198. package/esm/renderers/Icon.d.ts +28 -0
  199. package/esm/renderers/Icon.js +60 -0
  200. package/esm/renderers/Image.d.ts +415 -0
  201. package/esm/renderers/Image.js +120 -0
  202. package/esm/renderers/Images.d.ts +80 -0
  203. package/esm/renderers/Images.js +89 -0
  204. package/esm/renderers/Json.d.ts +68 -0
  205. package/esm/renderers/Json.js +98 -0
  206. package/esm/renderers/Link.d.ts +56 -0
  207. package/esm/renderers/Link.js +61 -0
  208. package/esm/renderers/List.d.ts +260 -0
  209. package/esm/renderers/List.js +680 -0
  210. package/esm/renderers/Log.d.ts +91 -0
  211. package/esm/renderers/Log.js +247 -0
  212. package/esm/renderers/Mapping.d.ts +354 -0
  213. package/esm/renderers/Mapping.js +160 -0
  214. package/esm/renderers/Markdown.d.ts +42 -0
  215. package/esm/renderers/Markdown.js +97 -0
  216. package/esm/renderers/Nav.d.ts +258 -0
  217. package/esm/renderers/Nav.js +544 -0
  218. package/esm/renderers/Operation.d.ts +28 -0
  219. package/esm/renderers/Operation.js +43 -0
  220. package/esm/renderers/Page.d.ts +228 -0
  221. package/esm/renderers/Page.js +593 -0
  222. package/esm/renderers/Pagination.d.ts +68 -0
  223. package/esm/renderers/Pagination.js +35 -0
  224. package/esm/renderers/PaginationWrapper.d.ts +67 -0
  225. package/esm/renderers/PaginationWrapper.js +73 -0
  226. package/esm/renderers/Panel.d.ts +86 -0
  227. package/esm/renderers/Panel.js +144 -0
  228. package/esm/renderers/Plain.d.ts +35 -0
  229. package/esm/renderers/Plain.js +42 -0
  230. package/esm/renderers/PopOver.d.ts +69 -0
  231. package/esm/renderers/PopOver.js +166 -0
  232. package/esm/renderers/Portlet.d.ts +125 -0
  233. package/esm/renderers/Portlet.js +152 -0
  234. package/esm/renderers/Progress.d.ts +81 -0
  235. package/esm/renderers/Progress.js +61 -0
  236. package/esm/renderers/Property.d.ts +99 -0
  237. package/esm/renderers/Property.js +95 -0
  238. package/esm/renderers/QRCode.d.ts +63 -0
  239. package/esm/renderers/QRCode.js +75 -0
  240. package/esm/renderers/QuickEdit.d.ts +65 -0
  241. package/esm/renderers/QuickEdit.js +337 -0
  242. package/esm/renderers/Remark.d.ts +105 -0
  243. package/esm/renderers/Remark.js +100 -0
  244. package/esm/renderers/SearchBox.d.ts +69 -0
  245. package/esm/renderers/SearchBox.js +77 -0
  246. package/esm/renderers/Service.d.ts +120 -0
  247. package/esm/renderers/Service.js +437 -0
  248. package/esm/renderers/SparkLine.d.ts +44 -0
  249. package/esm/renderers/SparkLine.js +40 -0
  250. package/esm/renderers/Spinner.d.ts +64 -0
  251. package/esm/renderers/Spinner.js +32 -0
  252. package/esm/renderers/Status.d.ts +55 -0
  253. package/esm/renderers/Status.js +84 -0
  254. package/esm/renderers/Steps.d.ts +66 -0
  255. package/esm/renderers/Steps.js +77 -0
  256. package/esm/renderers/Table/ColumnToggler.d.ts +120 -0
  257. package/esm/renderers/Table/ColumnToggler.js +255 -0
  258. package/esm/renderers/Table/HeadCellFilterDropdown.d.ts +32 -0
  259. package/esm/renderers/Table/HeadCellFilterDropdown.js +211 -0
  260. package/esm/renderers/Table/HeadCellSearchDropdown.d.ts +32 -0
  261. package/esm/renderers/Table/HeadCellSearchDropdown.js +193 -0
  262. package/esm/renderers/Table/ItemActionsWrapper.d.ts +11 -0
  263. package/esm/renderers/Table/ItemActionsWrapper.js +35 -0
  264. package/esm/renderers/Table/TableBody.d.ts +90 -0
  265. package/esm/renderers/Table/TableBody.js +105 -0
  266. package/esm/renderers/Table/TableCell.d.ts +21 -0
  267. package/esm/renderers/Table/TableCell.js +139 -0
  268. package/esm/renderers/Table/TableContent.d.ts +54 -0
  269. package/esm/renderers/Table/TableContent.js +69 -0
  270. package/esm/renderers/Table/TableRow.d.ts +27 -0
  271. package/esm/renderers/Table/TableRow.js +129 -0
  272. package/esm/renderers/Table/exportExcel.d.ts +6 -0
  273. package/esm/renderers/Table/exportExcel.js +301 -0
  274. package/esm/renderers/Table/index.d.ts +371 -0
  275. package/esm/renderers/Table/index.js +1533 -0
  276. package/esm/renderers/Table-v2/ColumnToggler.d.ts +19 -0
  277. package/esm/renderers/Table-v2/ColumnToggler.js +88 -0
  278. package/esm/renderers/Table-v2/HeadCellSearchDropdown.d.ts +29 -0
  279. package/esm/renderers/Table-v2/HeadCellSearchDropdown.js +206 -0
  280. package/esm/renderers/Table-v2/TableCell.d.ts +6 -0
  281. package/esm/renderers/Table-v2/TableCell.js +30 -0
  282. package/esm/renderers/Table-v2/index.d.ts +285 -0
  283. package/esm/renderers/Table-v2/index.js +832 -0
  284. package/esm/renderers/TableView.d.ts +136 -0
  285. package/esm/renderers/TableView.js +95 -0
  286. package/esm/renderers/Tabs.d.ts +204 -0
  287. package/esm/renderers/Tabs.js +501 -0
  288. package/esm/renderers/Tag.d.ts +66 -0
  289. package/esm/renderers/Tag.js +50 -0
  290. package/esm/renderers/Tasks.d.ts +140 -0
  291. package/esm/renderers/Tasks.js +209 -0
  292. package/esm/renderers/Timeline.d.ts +65 -0
  293. package/esm/renderers/Timeline.js +54 -0
  294. package/esm/renderers/TooltipWrapper.d.ts +133 -0
  295. package/esm/renderers/TooltipWrapper.js +70 -0
  296. package/esm/renderers/Tpl.d.ts +51 -0
  297. package/esm/renderers/Tpl.js +88 -0
  298. package/esm/renderers/VBox.d.ts +30 -0
  299. package/esm/renderers/VBox.js +48 -0
  300. package/esm/renderers/Video.d.ts +171 -0
  301. package/esm/renderers/Video.js +457 -0
  302. package/esm/renderers/WebComponent.d.ts +33 -0
  303. package/esm/renderers/WebComponent.js +48 -0
  304. package/esm/renderers/Wizard.d.ts +179 -0
  305. package/esm/renderers/Wizard.js +926 -0
  306. package/esm/renderers/Wrapper.d.ts +36 -0
  307. package/esm/renderers/Wrapper.js +53 -0
  308. package/esm/schemaExtend.d.ts +1 -0
  309. package/esm/schemaExtend.js +72 -0
  310. package/esm/types.d.ts +160 -0
  311. package/lib/Schema.d.ts +4 -3
  312. package/lib/compat.js +1 -1
  313. package/lib/helper.css +0 -1
  314. package/lib/index.d.ts +1 -0
  315. package/lib/index.js +2 -1
  316. package/lib/preset.js +1 -1
  317. package/lib/renderers/Action.js +1 -1
  318. package/lib/renderers/Alert.js +1 -1
  319. package/lib/renderers/AnchorNav.js +1 -1
  320. package/lib/renderers/App.js +1 -1
  321. package/lib/renderers/Audio.js +1 -1
  322. package/lib/renderers/Avatar.js +1 -1
  323. package/lib/renderers/BarCode.js +1 -1
  324. package/lib/renderers/Breadcrumb.js +1 -1
  325. package/lib/renderers/ButtonGroup.d.ts +2 -2
  326. package/lib/renderers/ButtonGroup.js +1 -1
  327. package/lib/renderers/CRUD.d.ts +1 -1
  328. package/lib/renderers/CRUD.js +5 -5
  329. package/lib/renderers/CRUD2.d.ts +215 -0
  330. package/lib/renderers/CRUD2.js +752 -0
  331. package/lib/renderers/Calendar.js +1 -1
  332. package/lib/renderers/Card.js +1 -1
  333. package/lib/renderers/Card2.d.ts +1 -1
  334. package/lib/renderers/Card2.js +3 -3
  335. package/lib/renderers/Cards.d.ts +4 -0
  336. package/lib/renderers/Cards.js +50 -6
  337. package/lib/renderers/Carousel.js +1 -1
  338. package/lib/renderers/Chart.js +19 -3
  339. package/lib/renderers/Code.js +1 -1
  340. package/lib/renderers/Collapse.js +1 -1
  341. package/lib/renderers/CollapseGroup.js +1 -1
  342. package/lib/renderers/Color.js +1 -1
  343. package/lib/renderers/Container.js +1 -1
  344. package/lib/renderers/Copyable.js +1 -1
  345. package/lib/renderers/Custom.js +1 -1
  346. package/lib/renderers/Date.js +1 -1
  347. package/lib/renderers/Dialog.d.ts +40 -40
  348. package/lib/renderers/Dialog.js +1 -1
  349. package/lib/renderers/Divider.js +1 -1
  350. package/lib/renderers/Drawer.js +1 -1
  351. package/lib/renderers/DropDownButton.js +3 -3
  352. package/lib/renderers/Each.js +1 -1
  353. package/lib/renderers/Flex.js +1 -1
  354. package/lib/renderers/Form/ButtonGroupSelect.js +2 -2
  355. package/lib/renderers/Form/ButtonToolbar.js +1 -1
  356. package/lib/renderers/Form/ChainedSelect.js +2 -2
  357. package/lib/renderers/Form/ChartRadios.js +1 -1
  358. package/lib/renderers/Form/Checkbox.js +1 -1
  359. package/lib/renderers/Form/Checkboxes.d.ts +5 -0
  360. package/lib/renderers/Form/Checkboxes.js +8 -3
  361. package/lib/renderers/Form/Combo.js +3 -2
  362. package/lib/renderers/Form/ConditionBuilder.d.ts +10 -0
  363. package/lib/renderers/Form/ConditionBuilder.js +7 -3
  364. package/lib/renderers/Form/Control.js +1 -1
  365. package/lib/renderers/Form/DiffEditor.d.ts +718 -154
  366. package/lib/renderers/Form/DiffEditor.js +1 -1
  367. package/lib/renderers/Form/Editor.d.ts +703 -139
  368. package/lib/renderers/Form/Editor.js +1 -1
  369. package/lib/renderers/Form/FieldSet.js +1 -1
  370. package/lib/renderers/Form/Formula.js +1 -1
  371. package/lib/renderers/Form/Group.js +2 -2
  372. package/lib/renderers/Form/Hidden.js +1 -1
  373. package/lib/renderers/Form/IconPicker.js +1 -1
  374. package/lib/renderers/Form/IconPickerIcons.js +1 -1
  375. package/lib/renderers/Form/InputArray.js +1 -1
  376. package/lib/renderers/Form/InputCity.d.ts +40 -40
  377. package/lib/renderers/Form/InputCity.js +1 -1
  378. package/lib/renderers/Form/InputColor.d.ts +40 -40
  379. package/lib/renderers/Form/InputColor.js +1 -1
  380. package/lib/renderers/Form/InputDate.js +1 -1
  381. package/lib/renderers/Form/InputDateRange.js +1 -1
  382. package/lib/renderers/Form/InputExcel.js +1 -1
  383. package/lib/renderers/Form/InputFile.d.ts +5 -0
  384. package/lib/renderers/Form/InputFile.js +15 -6
  385. package/lib/renderers/Form/InputFormula.js +1 -1
  386. package/lib/renderers/Form/InputGroup.d.ts +1 -1
  387. package/lib/renderers/Form/InputGroup.js +1 -1
  388. package/lib/renderers/Form/InputImage.js +5 -1
  389. package/lib/renderers/Form/InputMonthRange.js +1 -1
  390. package/lib/renderers/Form/InputNumber.js +1 -1
  391. package/lib/renderers/Form/InputQuarterRange.js +1 -1
  392. package/lib/renderers/Form/InputRange.d.ts +12 -5
  393. package/lib/renderers/Form/InputRange.js +1 -1
  394. package/lib/renderers/Form/InputRating.js +1 -1
  395. package/lib/renderers/Form/InputRepeat.js +1 -1
  396. package/lib/renderers/Form/InputRichText.js +1 -1
  397. package/lib/renderers/Form/InputSubForm.js +1 -1
  398. package/lib/renderers/Form/InputTable.js +2 -2
  399. package/lib/renderers/Form/InputTag.d.ts +34 -0
  400. package/lib/renderers/Form/InputTag.js +78 -40
  401. package/lib/renderers/Form/InputText.js +1 -1
  402. package/lib/renderers/Form/InputTree.d.ts +5 -2
  403. package/lib/renderers/Form/InputTree.js +7 -3
  404. package/lib/renderers/Form/InputYearRange.js +1 -1
  405. package/lib/renderers/Form/JSONSchema.js +1 -1
  406. package/lib/renderers/Form/JSONSchemaEditor.js +1 -1
  407. package/lib/renderers/Form/ListSelect.js +1 -1
  408. package/lib/renderers/Form/LocationPicker.js +1 -1
  409. package/lib/renderers/Form/MatrixCheckboxes.js +1 -1
  410. package/lib/renderers/Form/NestedSelect.js +4 -4
  411. package/lib/renderers/Form/Picker.js +1 -1
  412. package/lib/renderers/Form/Radios.d.ts +6 -1
  413. package/lib/renderers/Form/Radios.js +5 -3
  414. package/lib/renderers/Form/Select.js +1 -1
  415. package/lib/renderers/Form/Static.js +1 -1
  416. package/lib/renderers/Form/Switch.d.ts +3 -0
  417. package/lib/renderers/Form/Switch.js +3 -3
  418. package/lib/renderers/Form/TabsTransfer.js +1 -1
  419. package/lib/renderers/Form/TabsTransferPicker.js +1 -1
  420. package/lib/renderers/Form/Textarea.d.ts +2 -1
  421. package/lib/renderers/Form/Textarea.js +13 -2
  422. package/lib/renderers/Form/Transfer.js +1 -1
  423. package/lib/renderers/Form/TransferPicker.js +1 -1
  424. package/lib/renderers/Form/TreeSelect.js +4 -4
  425. package/lib/renderers/Form/UUID.js +1 -1
  426. package/lib/renderers/Form/UserSelect.js +3 -3
  427. package/lib/renderers/Grid.js +1 -1
  428. package/lib/renderers/Grid2D.js +1 -1
  429. package/lib/renderers/GridNav.js +1 -1
  430. package/lib/renderers/HBox.js +1 -1
  431. package/lib/renderers/IFrame.js +1 -1
  432. package/lib/renderers/Icon.d.ts +1 -1
  433. package/lib/renderers/Icon.js +11 -6
  434. package/lib/renderers/Image.js +1 -1
  435. package/lib/renderers/Images.js +1 -1
  436. package/lib/renderers/Json.d.ts +4 -0
  437. package/lib/renderers/Json.js +5 -4
  438. package/lib/renderers/Link.js +1 -1
  439. package/lib/renderers/List.d.ts +1 -0
  440. package/lib/renderers/List.js +30 -25
  441. package/lib/renderers/Log.js +1 -1
  442. package/lib/renderers/Mapping.js +1 -1
  443. package/lib/renderers/Markdown.js +1 -1
  444. package/lib/renderers/Nav.d.ts +10 -10
  445. package/lib/renderers/Nav.js +1 -1
  446. package/lib/renderers/Operation.js +1 -1
  447. package/lib/renderers/Page.js +1 -1
  448. package/lib/renderers/Pagination.js +1 -1
  449. package/lib/renderers/PaginationWrapper.js +1 -1
  450. package/lib/renderers/Panel.js +1 -1
  451. package/lib/renderers/Plain.js +1 -1
  452. package/lib/renderers/PopOver.js +4 -4
  453. package/lib/renderers/Portlet.js +1 -1
  454. package/lib/renderers/Progress.js +1 -1
  455. package/lib/renderers/Property.js +1 -1
  456. package/lib/renderers/QRCode.js +1 -1
  457. package/lib/renderers/QuickEdit.js +4 -3
  458. package/lib/renderers/Remark.d.ts +1 -1
  459. package/lib/renderers/Remark.js +1 -1
  460. package/lib/renderers/SearchBox.js +1 -1
  461. package/lib/renderers/Service.js +1 -1
  462. package/lib/renderers/SparkLine.js +1 -1
  463. package/lib/renderers/Spinner.js +1 -1
  464. package/lib/renderers/Status.js +1 -1
  465. package/lib/renderers/Steps.js +3 -2
  466. package/lib/renderers/Table/ColumnToggler.d.ts +4 -3
  467. package/lib/renderers/Table/ColumnToggler.js +4 -4
  468. package/lib/renderers/Table/HeadCellFilterDropdown.js +3 -3
  469. package/lib/renderers/Table/HeadCellSearchDropdown.js +4 -4
  470. package/lib/renderers/Table/ItemActionsWrapper.js +1 -1
  471. package/lib/renderers/Table/TableBody.js +1 -1
  472. package/lib/renderers/Table/TableCell.js +1 -1
  473. package/lib/renderers/Table/TableContent.js +1 -1
  474. package/lib/renderers/Table/TableRow.js +1 -1
  475. package/lib/renderers/Table/exportExcel.js +6 -6
  476. package/lib/renderers/Table/index.d.ts +1 -0
  477. package/lib/renderers/Table/index.js +15 -1
  478. package/lib/renderers/Table-v2/ColumnToggler.d.ts +18 -2
  479. package/lib/renderers/Table-v2/ColumnToggler.js +72 -2
  480. package/lib/renderers/Table-v2/HeadCellSearchDropdown.js +1 -1
  481. package/lib/renderers/Table-v2/TableCell.js +1 -1
  482. package/lib/renderers/Table-v2/index.d.ts +12 -10
  483. package/lib/renderers/Table-v2/index.js +122 -98
  484. package/lib/renderers/TableView.js +1 -1
  485. package/lib/renderers/Tabs.js +1 -1
  486. package/lib/renderers/Tag.js +1 -1
  487. package/lib/renderers/Tasks.js +1 -1
  488. package/lib/renderers/Timeline.js +1 -1
  489. package/lib/renderers/TooltipWrapper.js +1 -1
  490. package/lib/renderers/Tpl.js +1 -1
  491. package/lib/renderers/VBox.js +1 -1
  492. package/lib/renderers/Video.js +1 -1
  493. package/lib/renderers/WebComponent.js +1 -1
  494. package/lib/renderers/Wizard.js +1 -1
  495. package/lib/renderers/Wrapper.js +1 -1
  496. package/lib/schemaExtend.js +1 -1
  497. package/lib/themes/ang-ie11.css +257 -230
  498. package/lib/themes/ang.css +272 -237
  499. package/lib/themes/antd-ie11.css +257 -230
  500. package/lib/themes/antd.css +272 -237
  501. package/lib/themes/cxd-ie11.css +281 -270
  502. package/lib/themes/cxd.css +287 -266
  503. package/lib/themes/dark-ie11.css +257 -230
  504. package/lib/themes/dark.css +272 -237
  505. package/lib/themes/default-ie11.css +281 -270
  506. package/lib/themes/default.css +287 -266
  507. package/lib/types.d.ts +1 -1
  508. package/package.json +13 -2
  509. package/schema.json +2494 -836
  510. package/sdk/ang-ie11.css +276 -42
  511. package/sdk/ang.css +291 -49
  512. package/sdk/antd-ie11.css +276 -42
  513. package/sdk/antd.css +291 -49
  514. package/sdk/barcode.js +50 -50
  515. package/sdk/charts.js +14 -14
  516. package/sdk/codemirror.js +7 -7
  517. package/sdk/color-picker.js +65 -65
  518. package/sdk/cropperjs.js +2 -2
  519. package/sdk/cxd-ie11.css +300 -87
  520. package/sdk/cxd.css +306 -83
  521. package/sdk/dark-ie11.css +276 -42
  522. package/sdk/dark.css +291 -49
  523. package/sdk/exceljs.js +1 -1
  524. package/sdk/helper.css +0 -1
  525. package/sdk/locale/de-DE.js +2 -1
  526. package/sdk/markdown.js +68 -68
  527. package/sdk/papaparse.js +1 -1
  528. package/sdk/rest.js +24 -24
  529. package/sdk/rich-text.js +62 -62
  530. package/sdk/sdk-ie11.css +300 -87
  531. package/sdk/sdk.css +306 -83
  532. package/sdk/sdk.js +1784 -1674
  533. package/sdk/thirds/hls.js/hls.js +1 -1
  534. package/sdk/thirds/mpegts.js/mpegts.js +1 -1
  535. package/sdk/tinymce.js +57 -57
@@ -0,0 +1,822 @@
1
+ /**
2
+ * amis v2.0.0-rc.16
3
+ * Copyright 2018-2022 baidu
4
+ */
5
+
6
+ import { __extends, __assign, __awaiter, __generator, __decorate, __metadata, __spreadArray } from 'tslib';
7
+ import React from 'react';
8
+ import { findDOMNode } from 'react-dom';
9
+ import cloneDeep from 'lodash/cloneDeep';
10
+ import { guid, createObject, extendObject, resolveVariable, anyChanged, isEffectiveApi, isObjectShallowModified, evalExpression, dataMapping, filter, isObject, str2AsyncFunction, autobind, FormItem, ComboStore } from 'amis-core';
11
+ import { Tabs, Icon, Tab, Select, Alert2, Button } from 'amis-ui';
12
+ import Sortable from 'sortablejs';
13
+ import find from 'lodash/find';
14
+ import memoize from 'lodash/memoize';
15
+ import { isAlive } from 'mobx-state-tree';
16
+
17
+ function pickVars(vars, fields) {
18
+ return fields.reduce(function (data, key) {
19
+ data[key] = resolveVariable(key, vars);
20
+ return data;
21
+ }, {});
22
+ }
23
+ var ComboControl = /** @class */ (function (_super) {
24
+ __extends(ComboControl, _super);
25
+ function ComboControl(props) {
26
+ var _this = _super.call(this, props) || this;
27
+ _this.subForms = [];
28
+ _this.subFormDefaultValues = [];
29
+ _this.keys = [];
30
+ _this.toDispose = [];
31
+ _this.id = guid();
32
+ _this.refsMap = {};
33
+ _this.makeFormRef = memoize(function (index) { return function (ref) { return _this.formRef(ref, index); }; });
34
+ _this.memoizedFormatValue = memoize(function (strictMode, syncFields, value, index, data) {
35
+ return createObject(extendObject(data, __assign({ index: index, __index: index }, data)), __assign(__assign({}, value), (Array.isArray(syncFields) ? pickVars(data, syncFields) : null)));
36
+ }, function (strictMode, syncFields, value, index, data) {
37
+ return Array.isArray(syncFields)
38
+ ? JSON.stringify([value, index, data, pickVars(data, syncFields)])
39
+ : strictMode
40
+ ? JSON.stringify([value, index])
41
+ : JSON.stringify([value, index, data]);
42
+ });
43
+ _this.handleChange = _this.handleChange.bind(_this);
44
+ _this.handleSingleFormChange = _this.handleSingleFormChange.bind(_this);
45
+ _this.handleSingleFormInit = _this.handleSingleFormInit.bind(_this);
46
+ _this.handleFormInit = _this.handleFormInit.bind(_this);
47
+ _this.handleAction = _this.handleAction.bind(_this);
48
+ _this.addItem = _this.addItem.bind(_this);
49
+ _this.deleteItem = _this.deleteItem.bind(_this);
50
+ _this.dragTipRef = _this.dragTipRef.bind(_this);
51
+ _this.flush = _this.flush.bind(_this);
52
+ _this.handleComboTypeChange = _this.handleComboTypeChange.bind(_this);
53
+ _this.defaultValue = __assign({}, props.scaffold);
54
+ var store = props.store; props.value; var multiple = props.multiple, minLength = props.minLength, maxLength = props.maxLength, formItem = props.formItem, addHook = props.addHook;
55
+ store.config({
56
+ multiple: multiple,
57
+ minLength: minLength,
58
+ maxLength: maxLength,
59
+ length: _this.getValueAsArray(props).length
60
+ });
61
+ formItem && isAlive(formItem) && formItem.setSubStore(store);
62
+ addHook && _this.toDispose.push(addHook(_this.flush, 'flush'));
63
+ return _this;
64
+ }
65
+ ComboControl.prototype.componentDidUpdate = function (prevProps) {
66
+ var props = this.props;
67
+ if (anyChanged(['minLength', 'maxLength', 'value'], prevProps, props)) {
68
+ var store = props.store, minLength = props.minLength, maxLength = props.maxLength, multiple = props.multiple;
69
+ var values_1 = this.getValueAsArray(props);
70
+ store.config({
71
+ multiple: multiple,
72
+ minLength: minLength,
73
+ maxLength: maxLength,
74
+ length: values_1.length
75
+ });
76
+ if (store.activeKey >= values_1.length) {
77
+ store.setActiveKey(Math.max(0, values_1.length - 1));
78
+ }
79
+ // combo 进来了新的值,且这次 form 初始化时带来的新值变化,但是之前的值已经 onInit 过了
80
+ // 所以,之前 onInit 设置进去的初始值是过时了的。这个时候修复一下。
81
+ if (props.value !== prevProps.value &&
82
+ !prevProps.formInited &&
83
+ this.subFormDefaultValues.length) {
84
+ this.subFormDefaultValues = this.subFormDefaultValues.map(function (item, index) {
85
+ return __assign(__assign({}, item), { values: values_1[index] });
86
+ });
87
+ }
88
+ }
89
+ };
90
+ ComboControl.prototype.componentWillUnmount = function () {
91
+ var _a, _b, _c, _d;
92
+ var formItem = this.props.formItem;
93
+ formItem && isAlive(formItem) && formItem.setSubStore(null);
94
+ this.toDispose.forEach(function (fn) { return fn(); });
95
+ this.toDispose = [];
96
+ (_b = (_a = this.memoizedFormatValue.cache).clear) === null || _b === void 0 ? void 0 : _b.call(_a);
97
+ (_d = (_c = this.makeFormRef.cache).clear) === null || _d === void 0 ? void 0 : _d.call(_c);
98
+ };
99
+ ComboControl.prototype.doAction = function (action, args) {
100
+ var actionType = action === null || action === void 0 ? void 0 : action.actionType;
101
+ var _a = this.props, onChange = _a.onChange, resetValue = _a.resetValue;
102
+ if (actionType === 'clear') {
103
+ onChange('');
104
+ }
105
+ else if (actionType === 'reset') {
106
+ onChange(resetValue !== null && resetValue !== void 0 ? resetValue : '');
107
+ }
108
+ };
109
+ ComboControl.prototype.getValueAsArray = function (props) {
110
+ if (props === void 0) { props = this.props; }
111
+ var flat = props.flat, joinValues = props.joinValues, delimiter = props.delimiter; props.type;
112
+ var value = props.value;
113
+ if (joinValues && flat && typeof value === 'string') {
114
+ value = value.split(delimiter || ',');
115
+ }
116
+ else if (!Array.isArray(value)) {
117
+ value = [];
118
+ }
119
+ else {
120
+ value = value.concat();
121
+ }
122
+ return value;
123
+ };
124
+ ComboControl.prototype.addItemWith = function (condition) {
125
+ var _a = this.props, flat = _a.flat, joinValues = _a.joinValues, delimiter = _a.delimiter, scaffold = _a.scaffold, disabled = _a.disabled, submitOnChange = _a.submitOnChange;
126
+ if (disabled) {
127
+ return;
128
+ }
129
+ var value = this.getValueAsArray();
130
+ value.push(flat
131
+ ? condition.scaffold || scaffold || ''
132
+ : __assign({}, (condition.scaffold || scaffold)));
133
+ this.keys.push(guid());
134
+ if (flat && joinValues) {
135
+ value = value.join(delimiter || ',');
136
+ }
137
+ this.props.onChange(value, submitOnChange, true);
138
+ };
139
+ ComboControl.prototype.addItem = function () {
140
+ return __awaiter(this, void 0, void 0, function () {
141
+ var _a, flat, joinValues, delimiter, scaffold, disabled, submitOnChange, data, dispatchEvent, value, rendererEvent;
142
+ return __generator(this, function (_b) {
143
+ switch (_b.label) {
144
+ case 0:
145
+ _a = this.props, flat = _a.flat, joinValues = _a.joinValues, delimiter = _a.delimiter, scaffold = _a.scaffold, disabled = _a.disabled, submitOnChange = _a.submitOnChange, data = _a.data, dispatchEvent = _a.dispatchEvent;
146
+ if (disabled) {
147
+ return [2 /*return*/];
148
+ }
149
+ value = this.getValueAsArray();
150
+ return [4 /*yield*/, dispatchEvent('add', createObject(data, {
151
+ value: flat && joinValues ? value.join(delimiter || ',') : cloneDeep(value)
152
+ }))];
153
+ case 1:
154
+ rendererEvent = _b.sent();
155
+ if (rendererEvent === null || rendererEvent === void 0 ? void 0 : rendererEvent.prevented) {
156
+ return [2 /*return*/];
157
+ }
158
+ value.push(flat
159
+ ? scaffold || ''
160
+ : __assign({}, scaffold));
161
+ this.keys.push(guid());
162
+ if (flat && joinValues) {
163
+ value = value.join(delimiter || ',');
164
+ }
165
+ this.props.onChange(value, submitOnChange, true);
166
+ return [2 /*return*/];
167
+ }
168
+ });
169
+ });
170
+ };
171
+ ComboControl.prototype.deleteItem = function (key) {
172
+ return __awaiter(this, void 0, void 0, function () {
173
+ var _a, flat, joinValues, delimiter, disabled, deleteApi, deleteConfirmText, data, env, __, dispatchEvent, value, ctx, rendererEvent, confirmed, result;
174
+ return __generator(this, function (_b) {
175
+ switch (_b.label) {
176
+ case 0:
177
+ _a = this.props, flat = _a.flat, joinValues = _a.joinValues, delimiter = _a.delimiter, disabled = _a.disabled, deleteApi = _a.deleteApi, deleteConfirmText = _a.deleteConfirmText, data = _a.data, env = _a.env, __ = _a.translate, dispatchEvent = _a.dispatchEvent;
178
+ if (disabled) {
179
+ return [2 /*return*/];
180
+ }
181
+ value = this.getValueAsArray();
182
+ ctx = createObject(data, value[key]);
183
+ return [4 /*yield*/, dispatchEvent('delete', createObject(data, {
184
+ key: key,
185
+ value: flat && joinValues ? value.join(delimiter || ',') : cloneDeep(value)
186
+ }))];
187
+ case 1:
188
+ rendererEvent = _b.sent();
189
+ if (rendererEvent === null || rendererEvent === void 0 ? void 0 : rendererEvent.prevented) {
190
+ return [2 /*return*/];
191
+ }
192
+ if (!isEffectiveApi(deleteApi, ctx)) return [3 /*break*/, 4];
193
+ return [4 /*yield*/, env.confirm(deleteConfirmText ? filter(deleteConfirmText, ctx) : __('deleteConfirm'))];
194
+ case 2:
195
+ confirmed = _b.sent();
196
+ if (!confirmed) {
197
+ // 如果不确认,则跳过!
198
+ return [2 /*return*/];
199
+ }
200
+ return [4 /*yield*/, env.fetcher(deleteApi, ctx)];
201
+ case 3:
202
+ result = _b.sent();
203
+ if (!result.ok) {
204
+ env.notify('error', __('deleteFailed'));
205
+ return [2 /*return*/];
206
+ }
207
+ _b.label = 4;
208
+ case 4:
209
+ value.splice(key, 1);
210
+ this.keys.splice(key, 1);
211
+ if (flat && joinValues) {
212
+ value = value.join(delimiter || ',');
213
+ }
214
+ this.props.onChange(value);
215
+ return [2 /*return*/];
216
+ }
217
+ });
218
+ });
219
+ };
220
+ ComboControl.prototype.handleChange = function (values, diff, _a) {
221
+ var index = _a.index;
222
+ var _b = this.props, flat = _b.flat, store = _b.store, joinValues = _b.joinValues, delimiter = _b.delimiter, disabled = _b.disabled, submitOnChange = _b.submitOnChange, type = _b.type;
223
+ if (disabled) {
224
+ return;
225
+ }
226
+ var value = this.getValueAsArray();
227
+ value[index] = flat ? values.flat : __assign({}, values);
228
+ if (flat && joinValues) {
229
+ value = value.join(delimiter || ',');
230
+ }
231
+ if (type === 'input-kv') {
232
+ var hasDuplicateKey = false;
233
+ var keys = {};
234
+ for (var _i = 0, value_1 = value; _i < value_1.length; _i++) {
235
+ var item = value_1[_i];
236
+ if (keys[item.key]) {
237
+ hasDuplicateKey = true;
238
+ }
239
+ else {
240
+ keys[item.key] = true;
241
+ }
242
+ }
243
+ // 有重复值就不触发修改,因为 KV 模式下无法支持重复值
244
+ if (!hasDuplicateKey) {
245
+ this.props.onChange(value, submitOnChange, true);
246
+ }
247
+ }
248
+ else {
249
+ this.props.onChange(value, submitOnChange, true);
250
+ }
251
+ store.forms.forEach(function (form) {
252
+ return isAlive(form) &&
253
+ form.items.forEach(function (item) { return item.unique && item.syncOptions(undefined, form.data); });
254
+ });
255
+ };
256
+ ComboControl.prototype.handleSingleFormChange = function (values) {
257
+ this.props.onChange(__assign({}, values), this.props.submitOnChange, true);
258
+ };
259
+ ComboControl.prototype.handleFormInit = function (values, _a) {
260
+ var index = _a.index;
261
+ var _b = this.props, syncDefaultValue = _b.syncDefaultValue, flat = _b.flat, joinValues = _b.joinValues, delimiter = _b.delimiter, formInited = _b.formInited, onChange = _b.onChange, submitOnChange = _b.submitOnChange, setPrinstineValue = _b.setPrinstineValue;
262
+ this.subFormDefaultValues.push({
263
+ index: index,
264
+ values: values,
265
+ setted: false
266
+ });
267
+ if (syncDefaultValue === false ||
268
+ this.subFormDefaultValues.length !==
269
+ this.subForms.filter(function (item) { return item !== undefined; }).length) {
270
+ return;
271
+ }
272
+ var value = this.getValueAsArray();
273
+ var isModified = false;
274
+ this.subFormDefaultValues = this.subFormDefaultValues.map(function (_a) {
275
+ var index = _a.index, values = _a.values, setted = _a.setted;
276
+ var newValue = flat ? values.flat : __assign({}, values);
277
+ if (!setted && isObjectShallowModified(value[index], newValue)) {
278
+ value[index] = flat ? values.flat : __assign({}, values);
279
+ isModified = true;
280
+ }
281
+ return {
282
+ index: index,
283
+ values: values,
284
+ setted: true
285
+ };
286
+ });
287
+ if (!isModified) {
288
+ return;
289
+ }
290
+ if (flat && joinValues) {
291
+ value = value.join(delimiter || ',');
292
+ }
293
+ formInited
294
+ ? onChange(value, submitOnChange, true)
295
+ : setPrinstineValue(value);
296
+ };
297
+ ComboControl.prototype.handleSingleFormInit = function (values) {
298
+ var _a = this.props, syncDefaultValue = _a.syncDefaultValue, setPrinstineValue = _a.setPrinstineValue, value = _a.value, nullable = _a.nullable;
299
+ if (syncDefaultValue !== false &&
300
+ !nullable &&
301
+ isObjectShallowModified(value, values)) {
302
+ setPrinstineValue(__assign({}, values));
303
+ }
304
+ };
305
+ ComboControl.prototype.handleAction = function (action) {
306
+ var onAction = this.props.onAction;
307
+ if (action.actionType === 'delete') {
308
+ action.index !== void 0 && this.deleteItem(action.index);
309
+ return;
310
+ }
311
+ onAction && onAction.apply(null, arguments);
312
+ };
313
+ ComboControl.prototype.validate = function () {
314
+ var _a = this.props, minLength = _a.minLength, maxLength = _a.maxLength, messages = _a.messages, nullable = _a.nullable, __ = _a.translate;
315
+ var value = this.getValueAsArray();
316
+ if (minLength && (!Array.isArray(value) || value.length < minLength)) {
317
+ return __((messages && messages.minLengthValidateFailed) || 'Combo.minLength', { minLength: minLength });
318
+ }
319
+ else if (maxLength && Array.isArray(value) && value.length > maxLength) {
320
+ return __((messages && messages.maxLengthValidateFailed) || 'Combo.maxLength', { maxLength: maxLength });
321
+ }
322
+ else if (this.subForms.length && (!nullable || value)) {
323
+ return Promise.all(this.subForms.map(function (item) { return item.validate(); })).then(function (values) {
324
+ if (~values.indexOf(false)) {
325
+ return __((messages && messages.validateFailed) || 'validateFailed');
326
+ }
327
+ return;
328
+ });
329
+ }
330
+ };
331
+ ComboControl.prototype.flush = function () {
332
+ this.subForms.forEach(function (form) { return form.flush(); });
333
+ };
334
+ ComboControl.prototype.dragTipRef = function (ref) {
335
+ if (!this.dragTip && ref) {
336
+ this.initDragging();
337
+ }
338
+ else if (this.dragTip && !ref) {
339
+ this.destroyDragging();
340
+ }
341
+ this.dragTip = ref;
342
+ };
343
+ ComboControl.prototype.initDragging = function () {
344
+ var _this = this;
345
+ var ns = this.props.classPrefix;
346
+ var submitOnChange = this.props.submitOnChange;
347
+ var dom = findDOMNode(this);
348
+ this.sortable = new Sortable(dom.querySelector(".".concat(ns, "Combo-items")), {
349
+ group: "combo-".concat(this.id),
350
+ animation: 150,
351
+ handle: ".".concat(ns, "Combo-itemDrager"),
352
+ ghostClass: "".concat(ns, "Combo-item--dragging"),
353
+ onEnd: function (e) {
354
+ // 没有移动
355
+ if (e.newIndex === e.oldIndex) {
356
+ return;
357
+ }
358
+ // 换回来
359
+ var parent = e.to;
360
+ if (e.oldIndex < parent.childNodes.length - 1) {
361
+ parent.insertBefore(e.item, parent.childNodes[e.oldIndex]);
362
+ }
363
+ else {
364
+ parent.appendChild(e.item);
365
+ }
366
+ var value = _this.props.value;
367
+ if (!Array.isArray(value)) {
368
+ return;
369
+ }
370
+ var newValue = value.concat();
371
+ newValue.splice(e.newIndex, 0, newValue.splice(e.oldIndex, 1)[0]);
372
+ _this.keys.splice(e.newIndex, 0, _this.keys.splice(e.oldIndex, 1)[0]);
373
+ _this.props.onChange(newValue, submitOnChange, true);
374
+ }
375
+ });
376
+ };
377
+ ComboControl.prototype.destroyDragging = function () {
378
+ this.sortable && this.sortable.destroy();
379
+ };
380
+ ComboControl.prototype.formRef = function (ref, index) {
381
+ if (index === void 0) { index = 0; }
382
+ if (ref) {
383
+ while (ref && ref.getWrappedInstance) {
384
+ ref = ref.getWrappedInstance();
385
+ }
386
+ this.subForms[index] = ref;
387
+ this.refsMap[index] = ref;
388
+ }
389
+ else {
390
+ var form_1 = this.refsMap[index];
391
+ this.subForms = this.subForms.filter(function (item) { return item !== form_1; });
392
+ this.subFormDefaultValues = this.subFormDefaultValues.filter(function (_a) {
393
+ var dIndex = _a.index;
394
+ return dIndex !== index;
395
+ });
396
+ delete this.refsMap[index];
397
+ }
398
+ };
399
+ ComboControl.prototype.formatValue = function (value, index) {
400
+ if (index === void 0) { index = -1; }
401
+ var _a = this.props, flat = _a.flat, data = _a.data, strictMode = _a.strictMode, syncFields = _a.syncFields;
402
+ if (flat) {
403
+ value = {
404
+ flat: value
405
+ };
406
+ }
407
+ value = value || this.defaultValue;
408
+ return this.memoizedFormatValue(strictMode !== false, syncFields, value, index, data);
409
+ };
410
+ ComboControl.prototype.pickCondition = function (value) {
411
+ var conditions = this.props.conditions;
412
+ return find(conditions, function (item) { return item.test && evalExpression(item.test, value); });
413
+ };
414
+ ComboControl.prototype.handleComboTypeChange = function (index, selection) {
415
+ var _a = this.props, multiple = _a.multiple, onChange = _a.onChange, value = _a.value; _a.flat; var submitOnChange = _a.submitOnChange;
416
+ var conditions = this.props
417
+ .conditions;
418
+ var condition = find(conditions, function (item) { return item.label === selection.label; });
419
+ if (!condition) {
420
+ return;
421
+ }
422
+ if (multiple) {
423
+ var newValue = this.getValueAsArray();
424
+ newValue.splice(index, 1, __assign({}, dataMapping(condition.scaffold || {}, newValue[index])));
425
+ // todo 支持 flat
426
+ onChange(newValue, submitOnChange, true);
427
+ }
428
+ else {
429
+ onChange(__assign({}, dataMapping(condition.scaffold || {}, value)), submitOnChange, true);
430
+ }
431
+ };
432
+ ComboControl.prototype.handleTabSelect = function (key) {
433
+ return __awaiter(this, void 0, void 0, function () {
434
+ var _a, store, data, dispatchEvent, rendererEvent;
435
+ return __generator(this, function (_b) {
436
+ switch (_b.label) {
437
+ case 0:
438
+ _a = this.props, store = _a.store, data = _a.data, dispatchEvent = _a.dispatchEvent;
439
+ return [4 /*yield*/, dispatchEvent('tabsChange', createObject(data, {
440
+ key: key
441
+ }))];
442
+ case 1:
443
+ rendererEvent = _b.sent();
444
+ if (rendererEvent === null || rendererEvent === void 0 ? void 0 : rendererEvent.prevented) {
445
+ return [2 /*return*/];
446
+ }
447
+ store.setActiveKey(key);
448
+ return [2 /*return*/];
449
+ }
450
+ });
451
+ });
452
+ };
453
+ ComboControl.prototype.setNull = function (e) {
454
+ e.preventDefault();
455
+ var onChange = this.props.onChange;
456
+ onChange(null);
457
+ Array.isArray(this.subForms) &&
458
+ this.subForms.forEach(function (subForm) {
459
+ subForm.clearErrors();
460
+ });
461
+ };
462
+ ComboControl.prototype.renderPlaceholder = function () {
463
+ var _a = this.props, placeholder = _a.placeholder, __ = _a.translate;
464
+ return (React.createElement("span", { className: "text-muted" }, __(placeholder || 'placeholder.noData')));
465
+ };
466
+ ComboControl.prototype.renderTabsMode = function () {
467
+ var _this = this;
468
+ var _a = this.props; _a.classPrefix; var cx = _a.classnames, tabsStyle = _a.tabsStyle, formClassName = _a.formClassName, render = _a.render, disabled = _a.disabled, store = _a.store, flat = _a.flat, subFormMode = _a.subFormMode; _a.addButtonText; _a.addable; var removable = _a.removable, typeSwitchable = _a.typeSwitchable, itemRemovableOn = _a.itemRemovableOn, delimiter = _a.delimiter, canAccessSuperData = _a.canAccessSuperData; _a.addIcon; var deleteIcon = _a.deleteIcon, tabsLabelTpl = _a.tabsLabelTpl, conditions = _a.conditions, changeImmediately = _a.changeImmediately, addBtnText = _a.addBtnText, __ = _a.translate;
469
+ var items = this.props.items;
470
+ var value = this.props.value;
471
+ if (flat && typeof value === 'string') {
472
+ value = value.split(delimiter || ',');
473
+ }
474
+ var finnalRemovable = store.removable !== false && // minLength ?
475
+ !disabled && // 控件自身是否禁用
476
+ removable !== false; // 是否可以删除
477
+ if (!Array.isArray(value)) {
478
+ value = []; // 让 tabs 输出,否则会没有新增按钮。
479
+ }
480
+ // todo 支持拖拽排序。
481
+ return (React.createElement(Tabs, { addBtnText: __(addBtnText || 'add'), className: 'ComboTabs', mode: tabsStyle, activeKey: store.activeKey, onSelect: this.handleTabSelect, additionBtns: !disabled ? (React.createElement("li", { className: cx("Tabs-link ComboTabs-addLink") }, this.renderAddBtn())) : null }, value.map(function (value, index) {
482
+ var data = _this.formatValue(value, index);
483
+ var condition = null;
484
+ var toolbar = undefined;
485
+ if (finnalRemovable && // 表达式判断单条是否可删除
486
+ (!itemRemovableOn ||
487
+ evalExpression(itemRemovableOn, value) !== false)) {
488
+ toolbar = (React.createElement("div", { onClick: _this.deleteItem.bind(_this, index), key: "delete", className: cx("Combo-tab-delBtn ".concat(!store.removable ? 'is-disabled' : '')), "data-tooltip": __('delete'), "data-position": "bottom" }, deleteIcon ? (React.createElement("i", { className: deleteIcon })) : (React.createElement(Icon, { icon: "status-close", className: "icon" }))));
489
+ }
490
+ if (Array.isArray(conditions) && conditions.length) {
491
+ condition = _this.pickCondition(data);
492
+ items = condition ? condition.items : undefined;
493
+ }
494
+ var finnalControls = flat && items
495
+ ? [
496
+ __assign(__assign({}, (items && items[0])), { name: 'flat' })
497
+ ]
498
+ : items;
499
+ var hasUnique = Array.isArray(finnalControls) &&
500
+ finnalControls.some(function (item) { return item.unique; });
501
+ return (React.createElement(Tab, { title: filter(tabsLabelTpl ||
502
+ __('{{index}}', { index: data.index + 1 }), data), key: _this.keys[index] || (_this.keys[index] = guid()), toolbar: toolbar, eventKey: index,
503
+ // 不能按需渲染,因为 unique 会失效。
504
+ mountOnEnter: !hasUnique, unmountOnExit: false },
505
+ condition && typeSwitchable !== false ? (React.createElement("div", { className: cx('Combo-itemTag') },
506
+ React.createElement("label", null, __('Combo.type')),
507
+ React.createElement(Select, { onChange: _this.handleComboTypeChange.bind(_this, index), options: conditions.map(function (item) { return ({
508
+ label: item.label,
509
+ value: item.label
510
+ }); }), value: condition.label, clearable: false }))) : null,
511
+ React.createElement("div", { className: cx("Combo-itemInner") }, finnalControls ? (render("multiple/".concat(index), {
512
+ type: 'form',
513
+ body: finnalControls,
514
+ wrapperComponent: 'div',
515
+ wrapWithPanel: false,
516
+ mode: subFormMode,
517
+ className: cx("Combo-form", formClassName)
518
+ }, {
519
+ index: index,
520
+ disabled: disabled,
521
+ data: data,
522
+ onChange: _this.handleChange,
523
+ onInit: _this.handleFormInit,
524
+ onAction: _this.handleAction,
525
+ ref: _this.makeFormRef(index),
526
+ canAccessSuperData: canAccessSuperData,
527
+ lazyChange: changeImmediately ? false : true,
528
+ formLazyChange: false,
529
+ value: undefined,
530
+ formItemValue: undefined,
531
+ formStore: undefined
532
+ })) : (React.createElement(Alert2, { level: "warning", className: "m-b-none" }, __('Combo.invalidData'))))));
533
+ })));
534
+ };
535
+ ComboControl.prototype.renderDelBtn = function (value, index) {
536
+ var _this = this;
537
+ var _a = this.props; _a.classPrefix; var cx = _a.classnames, render = _a.render, store = _a.store, deleteIcon = _a.deleteIcon, __ = _a.translate, itemRemovableOn = _a.itemRemovableOn, disabled = _a.disabled, removable = _a.removable, deleteBtn = _a.deleteBtn;
538
+ var finnalRemovable = store.removable !== false && // minLength ?
539
+ !disabled && // 控件自身是否禁用
540
+ removable !== false; // 是否可以删除
541
+ if (!(finnalRemovable && // 表达式判断单条是否可删除
542
+ (!itemRemovableOn || evalExpression(itemRemovableOn, value) !== false))) {
543
+ // 不符合删除条件,则不渲染删除按钮
544
+ return null;
545
+ }
546
+ // deleteBtn是对象,则根据自定义配置渲染按钮
547
+ if (isObject(deleteBtn)) {
548
+ return render('delete-btn', __assign(__assign({}, deleteBtn), { type: 'button', className: cx('Combo-delController', deleteBtn ? deleteBtn.className : ''), onClick: function (e) {
549
+ if (!deleteBtn.onClick) {
550
+ _this.deleteItem(index);
551
+ return;
552
+ }
553
+ var originClickHandler = deleteBtn.onClick;
554
+ if (typeof originClickHandler === 'string') {
555
+ originClickHandler = str2AsyncFunction(deleteBtn.onClick, 'e', 'index', 'props');
556
+ }
557
+ var result = originClickHandler(e, index, _this.props);
558
+ if (result && result.then) {
559
+ result.then(function () {
560
+ _this.deleteItem(index);
561
+ });
562
+ }
563
+ else {
564
+ _this.deleteItem(index);
565
+ }
566
+ } }));
567
+ }
568
+ // deleteBtn是string,则渲染按钮文本
569
+ if (typeof deleteBtn === 'string') {
570
+ return render('delete-btn', {
571
+ type: 'button',
572
+ className: cx('Combo-delController'),
573
+ label: deleteBtn,
574
+ onClick: this.deleteItem.bind(this, index)
575
+ });
576
+ }
577
+ // 如果上述按钮不满足,则渲染默认按钮
578
+ return (React.createElement("a", { onClick: this.deleteItem.bind(this, index), key: "delete", className: cx("Combo-delBtn ".concat(!store.removable ? 'is-disabled' : '')), "data-tooltip": __('delete'), "data-position": "bottom" }, deleteIcon ? (React.createElement("i", { className: deleteIcon })) : (React.createElement(Icon, { icon: "status-close", className: "icon" }))));
579
+ };
580
+ ComboControl.prototype.renderAddBtn = function () {
581
+ var _this = this;
582
+ var _a = this.props; _a.classPrefix; var cx = _a.classnames, render = _a.render, addButtonClassName = _a.addButtonClassName, store = _a.store, addButtonText = _a.addButtonText, addBtn = _a.addBtn, addable = _a.addable, addIcon = _a.addIcon, conditions = _a.conditions, __ = _a.translate, tabsMode = _a.tabsMode;
583
+ var hasConditions = Array.isArray(conditions) && conditions.length;
584
+ return (React.createElement(React.Fragment, null, store.addable &&
585
+ addable !== false &&
586
+ (hasConditions ? (render('add-button', {
587
+ type: 'dropdown-button',
588
+ icon: addIcon ? React.createElement(Icon, { icon: "plus", className: "icon" }) : '',
589
+ label: __(addButtonText || 'Combo.add'),
590
+ level: 'info',
591
+ size: 'sm',
592
+ closeOnClick: true
593
+ }, {
594
+ buttons: conditions === null || conditions === void 0 ? void 0 : conditions.map(function (item) { return ({
595
+ label: item.label,
596
+ onClick: function (e) {
597
+ _this.addItemWith(item);
598
+ return false;
599
+ }
600
+ }); })
601
+ })) : tabsMode ? (React.createElement("a", { onClick: this.addItem },
602
+ addIcon ? React.createElement(Icon, { icon: "plus", className: "icon" }) : null,
603
+ React.createElement("span", null, __(addButtonText || 'Combo.add')))) : isObject(addBtn) ? (render('add-button', __assign(__assign({}, addBtn), { type: 'button', onClick: function () { return _this.addItem(); } }))) : (React.createElement(Button, { className: cx("Combo-addBtn", addButtonClassName), onClick: this.addItem },
604
+ addIcon ? React.createElement(Icon, { icon: "plus", className: "icon" }) : null,
605
+ React.createElement("span", null, __(addButtonText || 'Combo.add')))))));
606
+ };
607
+ ComboControl.prototype.renderMultipe = function () {
608
+ var _this = this;
609
+ if (this.props.tabsMode) {
610
+ return this.renderTabsMode();
611
+ }
612
+ var _a = this.props; _a.classPrefix; var cx = _a.classnames, formClassName = _a.formClassName, render = _a.render, multiLine = _a.multiLine; _a.addButtonClassName; var disabled = _a.disabled; _a.store; var flat = _a.flat, subFormMode = _a.subFormMode, draggable = _a.draggable, draggableTip = _a.draggableTip; _a.addButtonText; _a.addable; _a.removable; var typeSwitchable = _a.typeSwitchable, delimiter = _a.delimiter, canAccessSuperData = _a.canAccessSuperData; _a.addIcon; var dragIcon = _a.dragIcon, noBorder = _a.noBorder, conditions = _a.conditions, lazyLoad = _a.lazyLoad, changeImmediately = _a.changeImmediately, placeholder = _a.placeholder, __ = _a.translate, itemClassName = _a.itemClassName, itemsWrapperClassName = _a.itemsWrapperClassName;
613
+ var items = this.props.items;
614
+ var value = this.props.value;
615
+ if (flat && typeof value === 'string') {
616
+ value = value.split(delimiter || ',');
617
+ }
618
+ return (React.createElement("div", { className: cx("Combo Combo--multi", multiLine ? "Combo--ver" : "Combo--hor", noBorder ? "Combo--noBorder" : '', disabled ? 'is-disabled' : '', !disabled && draggable && Array.isArray(value) && value.length > 1
619
+ ? 'is-draggable'
620
+ : '') },
621
+ React.createElement("div", { className: cx("Combo-items", itemsWrapperClassName) }, Array.isArray(value) && value.length ? (value.map(function (value, index, thelist) {
622
+ var delBtn = _this.renderDelBtn(value, index);
623
+ var data = _this.formatValue(value, index);
624
+ var condition = null;
625
+ if (Array.isArray(conditions) && conditions.length) {
626
+ condition = _this.pickCondition(data);
627
+ items = condition ? condition.items : undefined;
628
+ }
629
+ var finnalControls = flat && items
630
+ ? [
631
+ __assign(__assign({}, (items && items[0])), { name: 'flat' })
632
+ ]
633
+ : items;
634
+ return (React.createElement("div", { className: cx("Combo-item", itemClassName), key: _this.keys[index] || (_this.keys[index] = guid()) },
635
+ !disabled && draggable && thelist.length > 1 ? (React.createElement("div", { className: cx('Combo-itemDrager') },
636
+ React.createElement("a", { key: "drag", "data-tooltip": __('Combo.dragDropSort'), "data-position": "bottom" }, dragIcon ? (React.createElement("i", { className: dragIcon })) : (React.createElement(Icon, { icon: "drag-bar", className: "icon" }))))) : null,
637
+ condition && typeSwitchable !== false ? (React.createElement("div", { className: cx('Combo-itemTag') },
638
+ React.createElement("label", null, __('Combo.type')),
639
+ React.createElement(Select, { onChange: _this.handleComboTypeChange.bind(_this, index), options: conditions.map(function (item) { return ({
640
+ label: item.label,
641
+ value: item.label
642
+ }); }), value: condition.label, clearable: false }))) : null,
643
+ React.createElement("div", { className: cx("Combo-itemInner") }, finnalControls ? (render("multiple/".concat(index), {
644
+ type: 'form',
645
+ body: finnalControls,
646
+ wrapperComponent: 'div',
647
+ wrapWithPanel: false,
648
+ mode: multiLine ? subFormMode : 'row',
649
+ className: cx("Combo-form", formClassName)
650
+ }, {
651
+ index: index,
652
+ disabled: disabled,
653
+ data: data,
654
+ onChange: _this.handleChange,
655
+ onInit: _this.handleFormInit,
656
+ onAction: _this.handleAction,
657
+ ref: _this.makeFormRef(index),
658
+ lazyChange: changeImmediately ? false : true,
659
+ formLazyChange: false,
660
+ lazyLoad: lazyLoad,
661
+ canAccessSuperData: canAccessSuperData,
662
+ value: undefined,
663
+ formItemValue: undefined,
664
+ formStore: undefined
665
+ })) : (React.createElement(Alert2, { level: "warning", className: "m-b-none" }, __('Combo.invalidData')))),
666
+ delBtn));
667
+ })) : placeholder ? (React.createElement("div", { className: cx("Combo-placeholder") }, __(placeholder))) : null),
668
+ !disabled ? (React.createElement("div", { className: cx("Combo-toolbar") },
669
+ this.renderAddBtn(),
670
+ draggable ? (React.createElement("span", { className: cx("Combo-dragableTip"), ref: this.dragTipRef }, Array.isArray(value) && value.length > 1
671
+ ? __(draggableTip)
672
+ : '')) : null)) : null));
673
+ };
674
+ ComboControl.prototype.renderSingle = function () {
675
+ var _a = this.props, conditions = _a.conditions, cx = _a.classnames, render = _a.render, value = _a.value, multiLine = _a.multiLine, formClassName = _a.formClassName, canAccessSuperData = _a.canAccessSuperData, noBorder = _a.noBorder, disabled = _a.disabled, typeSwitchable = _a.typeSwitchable, nullable = _a.nullable, __ = _a.translate, itemClassName = _a.itemClassName;
676
+ var items = this.props.items;
677
+ var data = isObject(value) ? this.formatValue(value) : this.defaultValue;
678
+ var condition = null;
679
+ if (Array.isArray(conditions) && conditions.length) {
680
+ condition = this.pickCondition(data);
681
+ items = condition ? condition.items : undefined;
682
+ }
683
+ return (React.createElement("div", { className: cx("Combo Combo--single", multiLine ? "Combo--ver" : "Combo--hor", noBorder ? "Combo--noBorder" : '', disabled ? 'is-disabled' : '') },
684
+ React.createElement("div", { className: cx("Combo-item", itemClassName) },
685
+ condition && typeSwitchable !== false ? (React.createElement("div", { className: cx('Combo-itemTag') },
686
+ React.createElement("label", null, __('Combo.type')),
687
+ React.createElement(Select, { onChange: this.handleComboTypeChange.bind(this, 0), options: conditions.map(function (item) { return ({
688
+ label: item.label,
689
+ value: item.label
690
+ }); }), value: condition.label, clearable: false }))) : null,
691
+ React.createElement("div", { className: cx("Combo-itemInner") }, items ? (render('single', {
692
+ type: 'form',
693
+ body: items,
694
+ wrapperComponent: 'div',
695
+ wrapWithPanel: false,
696
+ mode: multiLine ? 'normal' : 'row',
697
+ className: cx("Combo-form", formClassName)
698
+ }, {
699
+ disabled: disabled,
700
+ data: data,
701
+ onChange: this.handleSingleFormChange,
702
+ ref: this.makeFormRef(0),
703
+ onInit: this.handleSingleFormInit,
704
+ canAccessSuperData: canAccessSuperData,
705
+ formStore: undefined
706
+ })) : (React.createElement(Alert2, { level: "warning", className: "m-b-none" }, __('Combo.invalidData'))))),
707
+ value && nullable ? (React.createElement("a", { className: cx('Combo-setNullBtn'), href: "#", onClick: this.setNull }, __('clear'))) : null));
708
+ };
709
+ ComboControl.prototype.render = function () {
710
+ var _a = this.props, formInited = _a.formInited, multiple = _a.multiple, className = _a.className; _a.classPrefix; var cx = _a.classnames; _a.disabled;
711
+ return formInited || typeof formInited === 'undefined' ? (React.createElement("div", { className: cx("ComboControl", className) }, multiple ? this.renderMultipe() : this.renderSingle())) : null;
712
+ };
713
+ ComboControl.defaultProps = {
714
+ minLength: 0,
715
+ maxLength: 0,
716
+ multiple: false,
717
+ multiLine: false,
718
+ addButtonClassName: '',
719
+ formClassName: '',
720
+ subFormMode: 'normal',
721
+ draggableTip: '',
722
+ addButtonText: 'add',
723
+ canAccessSuperData: false,
724
+ addIcon: true,
725
+ dragIcon: '',
726
+ deleteIcon: '',
727
+ tabsMode: false,
728
+ tabsStyle: '',
729
+ placeholder: 'placeholder.empty',
730
+ itemClassName: '',
731
+ itemsWrapperClassName: ''
732
+ };
733
+ ComboControl.propsList = [
734
+ 'minLength',
735
+ 'maxLength',
736
+ 'multiple',
737
+ 'multiLine',
738
+ 'addButtonClassName',
739
+ 'subFormMode',
740
+ 'draggableTip',
741
+ 'addButtonText',
742
+ 'draggable',
743
+ 'scaffold',
744
+ 'canAccessSuperData',
745
+ 'addIcon',
746
+ 'dragIcon',
747
+ 'deleteIcon',
748
+ 'noBorder',
749
+ 'conditions',
750
+ 'tabsMode',
751
+ 'tabsStyle',
752
+ 'lazyLoad',
753
+ 'changeImmediately',
754
+ 'strictMode',
755
+ 'items',
756
+ 'conditions',
757
+ 'messages',
758
+ 'formStore',
759
+ 'itemClassName',
760
+ 'itemsWrapperClassName'
761
+ ];
762
+ __decorate([
763
+ autobind,
764
+ __metadata("design:type", Function),
765
+ __metadata("design:paramtypes", [Number]),
766
+ __metadata("design:returntype", Promise)
767
+ ], ComboControl.prototype, "handleTabSelect", null);
768
+ __decorate([
769
+ autobind,
770
+ __metadata("design:type", Function),
771
+ __metadata("design:paramtypes", [Object]),
772
+ __metadata("design:returntype", void 0)
773
+ ], ComboControl.prototype, "setNull", null);
774
+ return ComboControl;
775
+ }(React.Component));
776
+ /** @class */ ((function (_super) {
777
+ __extends(ComboControlRenderer, _super);
778
+ function ComboControlRenderer() {
779
+ return _super !== null && _super.apply(this, arguments) || this;
780
+ }
781
+ // 支持更新指定索引的值
782
+ ComboControlRenderer.prototype.setData = function (value, index) {
783
+ var _a = this.props, multiple = _a.multiple, onChange = _a.onChange, submitOnChange = _a.submitOnChange;
784
+ if (multiple) {
785
+ if (index !== undefined && ~index) {
786
+ var newValue = __spreadArray([], this.getValueAsArray(), true);
787
+ newValue.splice(index, 1, __assign(__assign({}, newValue[index]), value));
788
+ onChange === null || onChange === void 0 ? void 0 : onChange(newValue, submitOnChange, true);
789
+ }
790
+ else {
791
+ onChange === null || onChange === void 0 ? void 0 : onChange(value, submitOnChange, true);
792
+ }
793
+ }
794
+ else {
795
+ onChange === null || onChange === void 0 ? void 0 : onChange(value, submitOnChange, true);
796
+ }
797
+ };
798
+ ComboControlRenderer = __decorate([
799
+ FormItem({
800
+ type: 'combo',
801
+ storeType: ComboStore.name,
802
+ extendsData: false
803
+ })
804
+ ], ComboControlRenderer);
805
+ return ComboControlRenderer;
806
+ })(ComboControl));
807
+ /** @class */ ((function (_super) {
808
+ __extends(KVControlRenderer, _super);
809
+ function KVControlRenderer() {
810
+ return _super !== null && _super.apply(this, arguments) || this;
811
+ }
812
+ KVControlRenderer = __decorate([
813
+ FormItem({
814
+ type: 'input-kv',
815
+ storeType: ComboStore.name,
816
+ extendsData: false
817
+ })
818
+ ], KVControlRenderer);
819
+ return KVControlRenderer;
820
+ })(ComboControl));
821
+
822
+ export { ComboControl as default };