amis 2.0.0-rc.9 → 2.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (542) 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 +133 -0
  15. package/esm/renderers/App.js +214 -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 +1244 -0
  28. package/esm/renderers/CRUD2.d.ts +215 -0
  29. package/esm/renderers/CRUD2.js +748 -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 +236 -0
  33. package/esm/renderers/Card.js +376 -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 +555 -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 +153 -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 +84 -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 +218 -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 +227 -0
  82. package/esm/renderers/Form/Combo.d.ts +253 -0
  83. package/esm/renderers/Form/Combo.js +856 -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 +52 -0
  115. package/esm/renderers/Form/InputExcel.js +200 -0
  116. package/esm/renderers/Form/InputFile.d.ts +257 -0
  117. package/esm/renderers/Form/InputFile.js +939 -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 +908 -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 +681 -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 +141 -0
  145. package/esm/renderers/Form/InputText.js +636 -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 +145 -0
  167. package/esm/renderers/Form/Select.js +310 -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 +93 -0
  211. package/esm/renderers/Log.js +278 -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 +74 -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 +373 -0
  275. package/esm/renderers/Table/index.js +1583 -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 +833 -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 +923 -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 +144 -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.d.ts +12 -0
  321. package/lib/renderers/App.js +32 -16
  322. package/lib/renderers/Audio.js +1 -1
  323. package/lib/renderers/Avatar.js +1 -1
  324. package/lib/renderers/BarCode.js +1 -1
  325. package/lib/renderers/Breadcrumb.js +1 -1
  326. package/lib/renderers/ButtonGroup.d.ts +2 -2
  327. package/lib/renderers/ButtonGroup.js +1 -1
  328. package/lib/renderers/CRUD.js +6 -7
  329. package/lib/renderers/CRUD2.d.ts +215 -0
  330. package/lib/renderers/CRUD2.js +758 -0
  331. package/lib/renderers/Calendar.js +1 -1
  332. package/lib/renderers/Card.d.ts +7 -2
  333. package/lib/renderers/Card.js +12 -7
  334. package/lib/renderers/Card2.d.ts +1 -1
  335. package/lib/renderers/Card2.js +3 -3
  336. package/lib/renderers/Cards.d.ts +4 -0
  337. package/lib/renderers/Cards.js +49 -6
  338. package/lib/renderers/Carousel.js +1 -1
  339. package/lib/renderers/Chart.js +19 -3
  340. package/lib/renderers/Code.js +1 -1
  341. package/lib/renderers/Collapse.js +1 -1
  342. package/lib/renderers/CollapseGroup.js +1 -1
  343. package/lib/renderers/Color.js +1 -1
  344. package/lib/renderers/Container.js +1 -1
  345. package/lib/renderers/Copyable.js +1 -1
  346. package/lib/renderers/Custom.js +1 -1
  347. package/lib/renderers/Date.js +1 -1
  348. package/lib/renderers/Dialog.d.ts +40 -40
  349. package/lib/renderers/Dialog.js +1 -1
  350. package/lib/renderers/Divider.js +1 -1
  351. package/lib/renderers/Drawer.js +1 -1
  352. package/lib/renderers/DropDownButton.js +9 -7
  353. package/lib/renderers/Each.js +1 -1
  354. package/lib/renderers/Flex.js +3 -2
  355. package/lib/renderers/Form/ButtonGroupSelect.js +2 -2
  356. package/lib/renderers/Form/ButtonToolbar.js +1 -1
  357. package/lib/renderers/Form/ChainedSelect.d.ts +1 -1
  358. package/lib/renderers/Form/ChainedSelect.js +14 -9
  359. package/lib/renderers/Form/ChartRadios.js +1 -1
  360. package/lib/renderers/Form/Checkbox.js +3 -3
  361. package/lib/renderers/Form/Checkboxes.d.ts +5 -0
  362. package/lib/renderers/Form/Checkboxes.js +10 -4
  363. package/lib/renderers/Form/Combo.d.ts +3 -1
  364. package/lib/renderers/Form/Combo.js +38 -3
  365. package/lib/renderers/Form/ConditionBuilder.d.ts +10 -0
  366. package/lib/renderers/Form/ConditionBuilder.js +7 -3
  367. package/lib/renderers/Form/Control.js +1 -1
  368. package/lib/renderers/Form/DiffEditor.d.ts +707 -143
  369. package/lib/renderers/Form/DiffEditor.js +1 -1
  370. package/lib/renderers/Form/Editor.d.ts +703 -139
  371. package/lib/renderers/Form/Editor.js +1 -1
  372. package/lib/renderers/Form/FieldSet.js +1 -1
  373. package/lib/renderers/Form/Formula.js +1 -1
  374. package/lib/renderers/Form/Group.js +2 -2
  375. package/lib/renderers/Form/Hidden.js +1 -1
  376. package/lib/renderers/Form/IconPicker.js +1 -1
  377. package/lib/renderers/Form/IconPickerIcons.js +1 -1
  378. package/lib/renderers/Form/InputArray.js +1 -1
  379. package/lib/renderers/Form/InputCity.d.ts +40 -40
  380. package/lib/renderers/Form/InputCity.js +1 -1
  381. package/lib/renderers/Form/InputColor.d.ts +40 -40
  382. package/lib/renderers/Form/InputColor.js +1 -1
  383. package/lib/renderers/Form/InputDate.js +1 -1
  384. package/lib/renderers/Form/InputDateRange.js +1 -1
  385. package/lib/renderers/Form/InputExcel.d.ts +1 -0
  386. package/lib/renderers/Form/InputExcel.js +6 -1
  387. package/lib/renderers/Form/InputFile.d.ts +5 -0
  388. package/lib/renderers/Form/InputFile.js +39 -18
  389. package/lib/renderers/Form/InputFormula.js +1 -1
  390. package/lib/renderers/Form/InputGroup.js +1 -1
  391. package/lib/renderers/Form/InputImage.js +27 -11
  392. package/lib/renderers/Form/InputMonthRange.js +1 -1
  393. package/lib/renderers/Form/InputNumber.js +1 -1
  394. package/lib/renderers/Form/InputQuarterRange.js +1 -1
  395. package/lib/renderers/Form/InputRange.d.ts +12 -5
  396. package/lib/renderers/Form/InputRange.js +1 -1
  397. package/lib/renderers/Form/InputRating.js +1 -1
  398. package/lib/renderers/Form/InputRepeat.js +1 -1
  399. package/lib/renderers/Form/InputRichText.js +1 -1
  400. package/lib/renderers/Form/InputSubForm.js +1 -1
  401. package/lib/renderers/Form/InputTable.js +9 -5
  402. package/lib/renderers/Form/InputTag.d.ts +34 -0
  403. package/lib/renderers/Form/InputTag.js +78 -40
  404. package/lib/renderers/Form/InputText.d.ts +8 -0
  405. package/lib/renderers/Form/InputText.js +13 -9
  406. package/lib/renderers/Form/InputTree.d.ts +5 -2
  407. package/lib/renderers/Form/InputTree.js +7 -3
  408. package/lib/renderers/Form/InputYearRange.js +1 -1
  409. package/lib/renderers/Form/JSONSchema.js +1 -1
  410. package/lib/renderers/Form/JSONSchemaEditor.js +1 -1
  411. package/lib/renderers/Form/ListSelect.js +1 -1
  412. package/lib/renderers/Form/LocationPicker.js +1 -1
  413. package/lib/renderers/Form/MatrixCheckboxes.js +1 -1
  414. package/lib/renderers/Form/NestedSelect.js +4 -4
  415. package/lib/renderers/Form/Picker.js +1 -1
  416. package/lib/renderers/Form/Radios.d.ts +6 -1
  417. package/lib/renderers/Form/Radios.js +5 -3
  418. package/lib/renderers/Form/Select.d.ts +5 -0
  419. package/lib/renderers/Form/Select.js +5 -4
  420. package/lib/renderers/Form/Static.js +1 -1
  421. package/lib/renderers/Form/Switch.d.ts +3 -0
  422. package/lib/renderers/Form/Switch.js +3 -3
  423. package/lib/renderers/Form/TabsTransfer.js +1 -1
  424. package/lib/renderers/Form/TabsTransferPicker.js +1 -1
  425. package/lib/renderers/Form/Textarea.d.ts +2 -1
  426. package/lib/renderers/Form/Textarea.js +13 -2
  427. package/lib/renderers/Form/Transfer.js +1 -1
  428. package/lib/renderers/Form/TransferPicker.js +1 -1
  429. package/lib/renderers/Form/TreeSelect.js +4 -4
  430. package/lib/renderers/Form/UUID.js +1 -1
  431. package/lib/renderers/Form/UserSelect.js +3 -3
  432. package/lib/renderers/Grid.js +1 -1
  433. package/lib/renderers/Grid2D.js +1 -1
  434. package/lib/renderers/GridNav.js +1 -1
  435. package/lib/renderers/HBox.js +1 -1
  436. package/lib/renderers/IFrame.js +1 -1
  437. package/lib/renderers/Icon.d.ts +1 -1
  438. package/lib/renderers/Icon.js +11 -6
  439. package/lib/renderers/Image.js +1 -1
  440. package/lib/renderers/Images.js +1 -1
  441. package/lib/renderers/Json.d.ts +4 -0
  442. package/lib/renderers/Json.js +5 -4
  443. package/lib/renderers/Link.js +1 -1
  444. package/lib/renderers/List.d.ts +1 -0
  445. package/lib/renderers/List.js +30 -25
  446. package/lib/renderers/Log.d.ts +8 -6
  447. package/lib/renderers/Log.js +63 -32
  448. package/lib/renderers/Mapping.js +1 -1
  449. package/lib/renderers/Markdown.js +1 -1
  450. package/lib/renderers/Nav.d.ts +10 -10
  451. package/lib/renderers/Nav.js +1 -1
  452. package/lib/renderers/Operation.js +1 -1
  453. package/lib/renderers/Page.js +1 -1
  454. package/lib/renderers/Pagination.js +1 -1
  455. package/lib/renderers/PaginationWrapper.js +2 -1
  456. package/lib/renderers/Panel.js +1 -1
  457. package/lib/renderers/Plain.js +1 -1
  458. package/lib/renderers/PopOver.js +4 -4
  459. package/lib/renderers/Portlet.js +1 -1
  460. package/lib/renderers/Progress.js +1 -1
  461. package/lib/renderers/Property.js +1 -1
  462. package/lib/renderers/QRCode.js +1 -1
  463. package/lib/renderers/QuickEdit.js +4 -3
  464. package/lib/renderers/Remark.d.ts +1 -1
  465. package/lib/renderers/Remark.js +1 -1
  466. package/lib/renderers/SearchBox.js +1 -1
  467. package/lib/renderers/Service.js +1 -1
  468. package/lib/renderers/SparkLine.js +1 -1
  469. package/lib/renderers/Spinner.js +1 -1
  470. package/lib/renderers/Status.js +1 -1
  471. package/lib/renderers/Steps.js +3 -2
  472. package/lib/renderers/Table/ColumnToggler.d.ts +4 -3
  473. package/lib/renderers/Table/ColumnToggler.js +4 -4
  474. package/lib/renderers/Table/HeadCellFilterDropdown.js +3 -3
  475. package/lib/renderers/Table/HeadCellSearchDropdown.js +4 -4
  476. package/lib/renderers/Table/ItemActionsWrapper.js +1 -1
  477. package/lib/renderers/Table/TableBody.js +1 -1
  478. package/lib/renderers/Table/TableCell.js +1 -1
  479. package/lib/renderers/Table/TableContent.js +1 -1
  480. package/lib/renderers/Table/TableRow.js +1 -1
  481. package/lib/renderers/Table/exportExcel.js +6 -6
  482. package/lib/renderers/Table/index.d.ts +4 -1
  483. package/lib/renderers/Table/index.js +94 -30
  484. package/lib/renderers/Table-v2/ColumnToggler.d.ts +18 -2
  485. package/lib/renderers/Table-v2/ColumnToggler.js +72 -2
  486. package/lib/renderers/Table-v2/HeadCellSearchDropdown.js +1 -1
  487. package/lib/renderers/Table-v2/TableCell.js +1 -1
  488. package/lib/renderers/Table-v2/index.d.ts +12 -10
  489. package/lib/renderers/Table-v2/index.js +125 -100
  490. package/lib/renderers/TableView.js +1 -1
  491. package/lib/renderers/Tabs.js +1 -1
  492. package/lib/renderers/Tag.js +3 -3
  493. package/lib/renderers/Tasks.js +1 -1
  494. package/lib/renderers/Timeline.js +1 -1
  495. package/lib/renderers/TooltipWrapper.js +3 -3
  496. package/lib/renderers/Tpl.js +1 -1
  497. package/lib/renderers/VBox.js +1 -1
  498. package/lib/renderers/Video.js +1 -1
  499. package/lib/renderers/WebComponent.js +1 -1
  500. package/lib/renderers/Wizard.d.ts +1 -1
  501. package/lib/renderers/Wizard.js +73 -76
  502. package/lib/renderers/Wrapper.js +1 -1
  503. package/lib/schemaExtend.js +77 -1
  504. package/lib/themes/ang-ie11.css +499 -282
  505. package/lib/themes/ang.css +516 -277
  506. package/lib/themes/antd-ie11.css +517 -300
  507. package/lib/themes/antd.css +520 -277
  508. package/lib/themes/cxd-ie11.css +520 -319
  509. package/lib/themes/cxd.css +531 -308
  510. package/lib/themes/dark-ie11.css +504 -287
  511. package/lib/themes/dark.css +521 -279
  512. package/lib/themes/default-ie11.css +520 -319
  513. package/lib/themes/default.css +531 -308
  514. package/lib/types.d.ts +1 -1
  515. package/package.json +33 -4
  516. package/schema.json +2532 -844
  517. package/sdk/ang-ie11.css +547 -95
  518. package/sdk/ang.css +564 -90
  519. package/sdk/antd-ie11.css +581 -129
  520. package/sdk/antd.css +568 -90
  521. package/sdk/barcode.js +50 -50
  522. package/sdk/charts.js +15 -15
  523. package/sdk/codemirror.js +7 -7
  524. package/sdk/color-picker.js +65 -65
  525. package/sdk/cropperjs.js +2 -2
  526. package/sdk/cxd-ie11.css +590 -159
  527. package/sdk/cxd.css +579 -126
  528. package/sdk/dark-ie11.css +552 -100
  529. package/sdk/dark.css +569 -92
  530. package/sdk/exceljs.js +1 -1
  531. package/sdk/helper.css +0 -1
  532. package/sdk/locale/de-DE.js +3 -1
  533. package/sdk/markdown.js +68 -68
  534. package/sdk/papaparse.js +1 -1
  535. package/sdk/rest.js +24 -24
  536. package/sdk/rich-text.js +62 -62
  537. package/sdk/sdk-ie11.css +590 -159
  538. package/sdk/sdk.css +579 -126
  539. package/sdk/sdk.js +1789 -1711
  540. package/sdk/thirds/hls.js/hls.js +1 -1
  541. package/sdk/thirds/mpegts.js/mpegts.js +1 -1
  542. package/sdk/tinymce.js +57 -57
@@ -0,0 +1,856 @@
1
+ /**
2
+ * amis v2.0.2
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 if (type === 'input-kvs') {
249
+ // input-kvs 为了避免冲突 key 改成了 _key
250
+ var hasDuplicateKey = false;
251
+ var keys = {};
252
+ for (var _c = 0, value_2 = value; _c < value_2.length; _c++) {
253
+ var item = value_2[_c];
254
+ if ('_key' in item) {
255
+ if (keys[item._key]) {
256
+ hasDuplicateKey = true;
257
+ }
258
+ else {
259
+ keys[item._key] = true;
260
+ }
261
+ }
262
+ }
263
+ // 有重复值就不触发修改,因为 KV 模式下无法支持重复值
264
+ if (!hasDuplicateKey) {
265
+ this.props.onChange(value, submitOnChange, true);
266
+ }
267
+ }
268
+ else {
269
+ this.props.onChange(value, submitOnChange, true);
270
+ }
271
+ store.forms.forEach(function (form) {
272
+ return isAlive(form) &&
273
+ form.items.forEach(function (item) { return item.unique && item.syncOptions(undefined, form.data); });
274
+ });
275
+ };
276
+ ComboControl.prototype.handleSingleFormChange = function (values) {
277
+ this.props.onChange(__assign({}, values), this.props.submitOnChange, true);
278
+ };
279
+ ComboControl.prototype.handleFormInit = function (values, _a) {
280
+ var index = _a.index;
281
+ 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;
282
+ this.subFormDefaultValues.push({
283
+ index: index,
284
+ values: values,
285
+ setted: false
286
+ });
287
+ if (syncDefaultValue === false ||
288
+ this.subFormDefaultValues.length !==
289
+ this.subForms.filter(function (item) { return item !== undefined; }).length) {
290
+ return;
291
+ }
292
+ var value = this.getValueAsArray();
293
+ var isModified = false;
294
+ this.subFormDefaultValues = this.subFormDefaultValues.map(function (_a) {
295
+ var index = _a.index, values = _a.values, setted = _a.setted;
296
+ var newValue = flat ? values.flat : __assign({}, values);
297
+ if (!setted && isObjectShallowModified(value[index], newValue)) {
298
+ value[index] = flat ? values.flat : __assign({}, values);
299
+ isModified = true;
300
+ }
301
+ return {
302
+ index: index,
303
+ values: values,
304
+ setted: true
305
+ };
306
+ });
307
+ if (!isModified) {
308
+ return;
309
+ }
310
+ if (flat && joinValues) {
311
+ value = value.join(delimiter || ',');
312
+ }
313
+ formInited
314
+ ? onChange(value, submitOnChange, true)
315
+ : setPrinstineValue(value);
316
+ };
317
+ ComboControl.prototype.handleSingleFormInit = function (values) {
318
+ var _a = this.props, syncDefaultValue = _a.syncDefaultValue, setPrinstineValue = _a.setPrinstineValue, value = _a.value, nullable = _a.nullable;
319
+ if (syncDefaultValue !== false &&
320
+ !nullable &&
321
+ isObjectShallowModified(value, values)) {
322
+ setPrinstineValue(__assign({}, values));
323
+ }
324
+ };
325
+ ComboControl.prototype.handleAction = function (e, action) {
326
+ var onAction = this.props.onAction;
327
+ if (action.actionType === 'delete') {
328
+ action.index !== void 0 && this.deleteItem(action.index);
329
+ return;
330
+ }
331
+ onAction && onAction.apply(null, arguments);
332
+ };
333
+ ComboControl.prototype.validate = function () {
334
+ var _a = this.props, minLength = _a.minLength, maxLength = _a.maxLength, messages = _a.messages, nullable = _a.nullable, __ = _a.translate;
335
+ var value = this.getValueAsArray();
336
+ if (minLength && (!Array.isArray(value) || value.length < minLength)) {
337
+ return __((messages && messages.minLengthValidateFailed) || 'Combo.minLength', { minLength: minLength });
338
+ }
339
+ else if (maxLength && Array.isArray(value) && value.length > maxLength) {
340
+ return __((messages && messages.maxLengthValidateFailed) || 'Combo.maxLength', { maxLength: maxLength });
341
+ }
342
+ else if (this.subForms.length && (!nullable || value)) {
343
+ return Promise.all(this.subForms.map(function (item) { return item.validate(); })).then(function (values) {
344
+ if (~values.indexOf(false)) {
345
+ return __((messages && messages.validateFailed) || 'validateFailed');
346
+ }
347
+ return;
348
+ });
349
+ }
350
+ };
351
+ ComboControl.prototype.flush = function () {
352
+ this.subForms.forEach(function (form) { return form.flush(); });
353
+ };
354
+ ComboControl.prototype.dragTipRef = function (ref) {
355
+ if (!this.dragTip && ref) {
356
+ this.initDragging();
357
+ }
358
+ else if (this.dragTip && !ref) {
359
+ this.destroyDragging();
360
+ }
361
+ this.dragTip = ref;
362
+ };
363
+ ComboControl.prototype.initDragging = function () {
364
+ var _this = this;
365
+ var ns = this.props.classPrefix;
366
+ var submitOnChange = this.props.submitOnChange;
367
+ var dom = findDOMNode(this);
368
+ this.sortable = new Sortable(dom.querySelector(".".concat(ns, "Combo-items")), {
369
+ group: "combo-".concat(this.id),
370
+ animation: 150,
371
+ handle: ".".concat(ns, "Combo-itemDrager"),
372
+ ghostClass: "".concat(ns, "Combo-item--dragging"),
373
+ onEnd: function (e) {
374
+ // 没有移动
375
+ if (e.newIndex === e.oldIndex) {
376
+ return;
377
+ }
378
+ // 换回来
379
+ var parent = e.to;
380
+ if (e.oldIndex < parent.childNodes.length - 1) {
381
+ parent.insertBefore(e.item, parent.childNodes[e.oldIndex]);
382
+ }
383
+ else {
384
+ parent.appendChild(e.item);
385
+ }
386
+ var value = _this.props.value;
387
+ if (!Array.isArray(value)) {
388
+ return;
389
+ }
390
+ var newValue = value.concat();
391
+ newValue.splice(e.newIndex, 0, newValue.splice(e.oldIndex, 1)[0]);
392
+ _this.keys.splice(e.newIndex, 0, _this.keys.splice(e.oldIndex, 1)[0]);
393
+ _this.props.onChange(newValue, submitOnChange, true);
394
+ }
395
+ });
396
+ };
397
+ ComboControl.prototype.destroyDragging = function () {
398
+ this.sortable && this.sortable.destroy();
399
+ };
400
+ ComboControl.prototype.formRef = function (ref, index) {
401
+ if (index === void 0) { index = 0; }
402
+ if (ref) {
403
+ while (ref && ref.getWrappedInstance) {
404
+ ref = ref.getWrappedInstance();
405
+ }
406
+ this.subForms[index] = ref;
407
+ this.refsMap[index] = ref;
408
+ }
409
+ else {
410
+ var form_1 = this.refsMap[index];
411
+ this.subForms = this.subForms.filter(function (item) { return item !== form_1; });
412
+ this.subFormDefaultValues = this.subFormDefaultValues.filter(function (_a) {
413
+ var dIndex = _a.index;
414
+ return dIndex !== index;
415
+ });
416
+ delete this.refsMap[index];
417
+ }
418
+ };
419
+ ComboControl.prototype.formatValue = function (value, index) {
420
+ if (index === void 0) { index = -1; }
421
+ var _a = this.props, flat = _a.flat, data = _a.data, strictMode = _a.strictMode, syncFields = _a.syncFields;
422
+ if (flat) {
423
+ value = {
424
+ flat: value
425
+ };
426
+ }
427
+ value = value || this.defaultValue;
428
+ return this.memoizedFormatValue(strictMode !== false, syncFields, value, index, data);
429
+ };
430
+ ComboControl.prototype.pickCondition = function (value) {
431
+ var conditions = this.props.conditions;
432
+ return find(conditions, function (item) { return item.test && evalExpression(item.test, value); });
433
+ };
434
+ ComboControl.prototype.handleComboTypeChange = function (index, selection) {
435
+ var _a = this.props, multiple = _a.multiple, onChange = _a.onChange, value = _a.value; _a.flat; var submitOnChange = _a.submitOnChange;
436
+ var conditions = this.props
437
+ .conditions;
438
+ var condition = find(conditions, function (item) { return item.label === selection.label; });
439
+ if (!condition) {
440
+ return;
441
+ }
442
+ if (multiple) {
443
+ var newValue = this.getValueAsArray();
444
+ newValue.splice(index, 1, __assign({}, dataMapping(condition.scaffold || {}, newValue[index])));
445
+ // todo 支持 flat
446
+ onChange(newValue, submitOnChange, true);
447
+ }
448
+ else {
449
+ onChange(__assign({}, dataMapping(condition.scaffold || {}, value)), submitOnChange, true);
450
+ }
451
+ };
452
+ ComboControl.prototype.handleTabSelect = function (key) {
453
+ return __awaiter(this, void 0, void 0, function () {
454
+ var _a, store, data, dispatchEvent, rendererEvent;
455
+ return __generator(this, function (_b) {
456
+ switch (_b.label) {
457
+ case 0:
458
+ _a = this.props, store = _a.store, data = _a.data, dispatchEvent = _a.dispatchEvent;
459
+ return [4 /*yield*/, dispatchEvent('tabsChange', createObject(data, {
460
+ key: key
461
+ }))];
462
+ case 1:
463
+ rendererEvent = _b.sent();
464
+ if (rendererEvent === null || rendererEvent === void 0 ? void 0 : rendererEvent.prevented) {
465
+ return [2 /*return*/];
466
+ }
467
+ store.setActiveKey(key);
468
+ return [2 /*return*/];
469
+ }
470
+ });
471
+ });
472
+ };
473
+ ComboControl.prototype.setNull = function (e) {
474
+ e.preventDefault();
475
+ var onChange = this.props.onChange;
476
+ onChange(null);
477
+ Array.isArray(this.subForms) &&
478
+ this.subForms.forEach(function (subForm) {
479
+ subForm.clearErrors();
480
+ });
481
+ };
482
+ ComboControl.prototype.renderPlaceholder = function () {
483
+ var _a = this.props, placeholder = _a.placeholder, __ = _a.translate;
484
+ return (React.createElement("span", { className: "text-muted" }, __(placeholder || 'placeholder.noData')));
485
+ };
486
+ ComboControl.prototype.renderTabsMode = function () {
487
+ var _this = this;
488
+ 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;
489
+ var items = this.props.items;
490
+ var value = this.props.value;
491
+ if (flat && typeof value === 'string') {
492
+ value = value.split(delimiter || ',');
493
+ }
494
+ var finnalRemovable = store.removable !== false && // minLength ?
495
+ !disabled && // 控件自身是否禁用
496
+ removable !== false; // 是否可以删除
497
+ if (!Array.isArray(value)) {
498
+ value = []; // 让 tabs 输出,否则会没有新增按钮。
499
+ }
500
+ // todo 支持拖拽排序。
501
+ 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) {
502
+ var data = _this.formatValue(value, index);
503
+ var condition = null;
504
+ var toolbar = undefined;
505
+ if (finnalRemovable && // 表达式判断单条是否可删除
506
+ (!itemRemovableOn ||
507
+ evalExpression(itemRemovableOn, value) !== false)) {
508
+ 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" }))));
509
+ }
510
+ if (Array.isArray(conditions) && conditions.length) {
511
+ condition = _this.pickCondition(data);
512
+ items = condition ? condition.items : undefined;
513
+ }
514
+ var finnalControls = flat && items
515
+ ? [
516
+ __assign(__assign({}, (items && items[0])), { name: 'flat' })
517
+ ]
518
+ : items;
519
+ var hasUnique = Array.isArray(finnalControls) &&
520
+ finnalControls.some(function (item) { return item.unique; });
521
+ return (React.createElement(Tab, { title: filter(tabsLabelTpl ||
522
+ __('{{index}}', { index: data.index + 1 }), data), key: _this.keys[index] || (_this.keys[index] = guid()), toolbar: toolbar, eventKey: index,
523
+ // 不能按需渲染,因为 unique 会失效。
524
+ mountOnEnter: !hasUnique, unmountOnExit: false },
525
+ condition && typeSwitchable !== false ? (React.createElement("div", { className: cx('Combo-itemTag') },
526
+ React.createElement("label", null, __('Combo.type')),
527
+ React.createElement(Select, { onChange: _this.handleComboTypeChange.bind(_this, index), options: conditions.map(function (item) { return ({
528
+ label: item.label,
529
+ value: item.label
530
+ }); }), value: condition.label, clearable: false }))) : null,
531
+ React.createElement("div", { className: cx("Combo-itemInner") }, finnalControls ? (render("multiple/".concat(index), {
532
+ type: 'form',
533
+ body: finnalControls,
534
+ wrapperComponent: 'div',
535
+ wrapWithPanel: false,
536
+ mode: subFormMode,
537
+ className: cx("Combo-form", formClassName)
538
+ }, {
539
+ index: index,
540
+ disabled: disabled,
541
+ data: data,
542
+ onChange: _this.handleChange,
543
+ onInit: _this.handleFormInit,
544
+ onAction: _this.handleAction,
545
+ ref: _this.makeFormRef(index),
546
+ canAccessSuperData: canAccessSuperData,
547
+ lazyChange: changeImmediately ? false : true,
548
+ formLazyChange: false,
549
+ value: undefined,
550
+ formItemValue: undefined,
551
+ formStore: undefined
552
+ })) : (React.createElement(Alert2, { level: "warning", className: "m-b-none" }, __('Combo.invalidData'))))));
553
+ })));
554
+ };
555
+ ComboControl.prototype.renderDelBtn = function (value, index) {
556
+ var _this = this;
557
+ 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;
558
+ var finnalRemovable = store.removable !== false && // minLength ?
559
+ !disabled && // 控件自身是否禁用
560
+ removable !== false; // 是否可以删除
561
+ if (!(finnalRemovable && // 表达式判断单条是否可删除
562
+ (!itemRemovableOn || evalExpression(itemRemovableOn, value) !== false))) {
563
+ // 不符合删除条件,则不渲染删除按钮
564
+ return null;
565
+ }
566
+ // deleteBtn是对象,则根据自定义配置渲染按钮
567
+ if (isObject(deleteBtn)) {
568
+ return render('delete-btn', __assign(__assign({}, deleteBtn), { type: 'button', className: cx('Combo-delController', deleteBtn ? deleteBtn.className : ''), onClick: function (e) {
569
+ if (!deleteBtn.onClick) {
570
+ _this.deleteItem(index);
571
+ return;
572
+ }
573
+ var originClickHandler = deleteBtn.onClick;
574
+ if (typeof originClickHandler === 'string') {
575
+ originClickHandler = str2AsyncFunction(deleteBtn.onClick, 'e', 'index', 'props');
576
+ }
577
+ var result = originClickHandler(e, index, _this.props);
578
+ if (result && result.then) {
579
+ result.then(function () {
580
+ _this.deleteItem(index);
581
+ });
582
+ }
583
+ else {
584
+ _this.deleteItem(index);
585
+ }
586
+ } }));
587
+ }
588
+ // deleteBtn是string,则渲染按钮文本
589
+ if (typeof deleteBtn === 'string') {
590
+ return render('delete-btn', {
591
+ type: 'button',
592
+ className: cx('Combo-delController'),
593
+ label: deleteBtn,
594
+ onClick: this.deleteItem.bind(this, index)
595
+ });
596
+ }
597
+ // 如果上述按钮不满足,则渲染默认按钮
598
+ 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" }))));
599
+ };
600
+ ComboControl.prototype.renderAddBtn = function () {
601
+ var _this = this;
602
+ 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;
603
+ var hasConditions = Array.isArray(conditions) && conditions.length;
604
+ return (React.createElement(React.Fragment, null, store.addable &&
605
+ addable !== false &&
606
+ (hasConditions ? (render('add-button', {
607
+ type: 'dropdown-button',
608
+ icon: addIcon ? React.createElement(Icon, { icon: "plus", className: "icon" }) : '',
609
+ label: __(addButtonText || 'Combo.add'),
610
+ level: 'info',
611
+ size: 'sm',
612
+ closeOnClick: true
613
+ }, {
614
+ buttons: conditions === null || conditions === void 0 ? void 0 : conditions.map(function (item) { return ({
615
+ label: item.label,
616
+ onClick: function (e) {
617
+ _this.addItemWith(item);
618
+ return false;
619
+ }
620
+ }); })
621
+ })) : tabsMode ? (React.createElement("a", { onClick: this.addItem },
622
+ addIcon ? React.createElement(Icon, { icon: "plus", className: "icon" }) : null,
623
+ 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 },
624
+ addIcon ? React.createElement(Icon, { icon: "plus", className: "icon" }) : null,
625
+ React.createElement("span", null, __(addButtonText || 'Combo.add')))))));
626
+ };
627
+ ComboControl.prototype.renderMultipe = function () {
628
+ var _this = this;
629
+ if (this.props.tabsMode) {
630
+ return this.renderTabsMode();
631
+ }
632
+ 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;
633
+ var items = this.props.items;
634
+ var value = this.props.value;
635
+ if (flat && typeof value === 'string') {
636
+ value = value.split(delimiter || ',');
637
+ }
638
+ 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
639
+ ? 'is-draggable'
640
+ : '') },
641
+ React.createElement("div", { className: cx("Combo-items", itemsWrapperClassName) }, Array.isArray(value) && value.length ? (value.map(function (value, index, thelist) {
642
+ var delBtn = _this.renderDelBtn(value, index);
643
+ var data = _this.formatValue(value, index);
644
+ var condition = null;
645
+ if (Array.isArray(conditions) && conditions.length) {
646
+ condition = _this.pickCondition(data);
647
+ items = condition ? condition.items : undefined;
648
+ }
649
+ var finnalControls = flat && items
650
+ ? [
651
+ __assign(__assign({}, (items && items[0])), { name: 'flat' })
652
+ ]
653
+ : items;
654
+ return (React.createElement("div", { className: cx("Combo-item", itemClassName), key: _this.keys[index] || (_this.keys[index] = guid()) },
655
+ !disabled && draggable && thelist.length > 1 ? (React.createElement("div", { className: cx('Combo-itemDrager') },
656
+ 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,
657
+ condition && typeSwitchable !== false ? (React.createElement("div", { className: cx('Combo-itemTag') },
658
+ React.createElement("label", null, __('Combo.type')),
659
+ React.createElement(Select, { onChange: _this.handleComboTypeChange.bind(_this, index), options: conditions.map(function (item) { return ({
660
+ label: item.label,
661
+ value: item.label
662
+ }); }), value: condition.label, clearable: false }))) : null,
663
+ React.createElement("div", { className: cx("Combo-itemInner") }, finnalControls ? (render("multiple/".concat(index), {
664
+ type: 'form',
665
+ body: finnalControls,
666
+ wrapperComponent: 'div',
667
+ wrapWithPanel: false,
668
+ mode: multiLine ? subFormMode : 'row',
669
+ className: cx("Combo-form", formClassName)
670
+ }, {
671
+ index: index,
672
+ disabled: disabled,
673
+ data: data,
674
+ onChange: _this.handleChange,
675
+ onInit: _this.handleFormInit,
676
+ onAction: _this.handleAction,
677
+ ref: _this.makeFormRef(index),
678
+ lazyChange: changeImmediately ? false : true,
679
+ formLazyChange: false,
680
+ lazyLoad: lazyLoad,
681
+ canAccessSuperData: canAccessSuperData,
682
+ value: undefined,
683
+ formItemValue: undefined,
684
+ formStore: undefined
685
+ })) : (React.createElement(Alert2, { level: "warning", className: "m-b-none" }, __('Combo.invalidData')))),
686
+ delBtn));
687
+ })) : placeholder ? (React.createElement("div", { className: cx("Combo-placeholder") }, __(placeholder))) : null),
688
+ !disabled ? (React.createElement("div", { className: cx("Combo-toolbar") },
689
+ this.renderAddBtn(),
690
+ draggable ? (React.createElement("span", { className: cx("Combo-dragableTip"), ref: this.dragTipRef }, Array.isArray(value) && value.length > 1
691
+ ? __(draggableTip)
692
+ : '')) : null)) : null));
693
+ };
694
+ ComboControl.prototype.renderSingle = function () {
695
+ 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;
696
+ var items = this.props.items;
697
+ var data = isObject(value) ? this.formatValue(value) : this.defaultValue;
698
+ var condition = null;
699
+ if (Array.isArray(conditions) && conditions.length) {
700
+ condition = this.pickCondition(data);
701
+ items = condition ? condition.items : undefined;
702
+ }
703
+ return (React.createElement("div", { className: cx("Combo Combo--single", multiLine ? "Combo--ver" : "Combo--hor", noBorder ? "Combo--noBorder" : '', disabled ? 'is-disabled' : '') },
704
+ React.createElement("div", { className: cx("Combo-item", itemClassName) },
705
+ condition && typeSwitchable !== false ? (React.createElement("div", { className: cx('Combo-itemTag') },
706
+ React.createElement("label", null, __('Combo.type')),
707
+ React.createElement(Select, { onChange: this.handleComboTypeChange.bind(this, 0), options: conditions.map(function (item) { return ({
708
+ label: item.label,
709
+ value: item.label
710
+ }); }), value: condition.label, clearable: false }))) : null,
711
+ React.createElement("div", { className: cx("Combo-itemInner") }, items ? (render('single', {
712
+ type: 'form',
713
+ body: items,
714
+ wrapperComponent: 'div',
715
+ wrapWithPanel: false,
716
+ mode: multiLine ? 'normal' : 'row',
717
+ className: cx("Combo-form", formClassName)
718
+ }, {
719
+ disabled: disabled,
720
+ data: data,
721
+ onChange: this.handleSingleFormChange,
722
+ ref: this.makeFormRef(0),
723
+ onInit: this.handleSingleFormInit,
724
+ canAccessSuperData: canAccessSuperData,
725
+ formStore: undefined
726
+ })) : (React.createElement(Alert2, { level: "warning", className: "m-b-none" }, __('Combo.invalidData'))))),
727
+ value && nullable ? (React.createElement("a", { className: cx('Combo-setNullBtn'), href: "#", onClick: this.setNull }, __('clear'))) : null));
728
+ };
729
+ ComboControl.prototype.render = function () {
730
+ var _a = this.props, formInited = _a.formInited, multiple = _a.multiple, className = _a.className; _a.classPrefix; var cx = _a.classnames; _a.disabled;
731
+ return formInited || typeof formInited === 'undefined' ? (React.createElement("div", { className: cx("ComboControl", className) }, multiple ? this.renderMultipe() : this.renderSingle())) : null;
732
+ };
733
+ ComboControl.defaultProps = {
734
+ minLength: 0,
735
+ maxLength: 0,
736
+ multiple: false,
737
+ multiLine: false,
738
+ addButtonClassName: '',
739
+ formClassName: '',
740
+ subFormMode: 'normal',
741
+ draggableTip: '',
742
+ addButtonText: 'add',
743
+ canAccessSuperData: false,
744
+ addIcon: true,
745
+ dragIcon: '',
746
+ deleteIcon: '',
747
+ tabsMode: false,
748
+ tabsStyle: '',
749
+ placeholder: 'placeholder.empty',
750
+ itemClassName: '',
751
+ itemsWrapperClassName: ''
752
+ };
753
+ ComboControl.propsList = [
754
+ 'minLength',
755
+ 'maxLength',
756
+ 'multiple',
757
+ 'multiLine',
758
+ 'addButtonClassName',
759
+ 'subFormMode',
760
+ 'draggableTip',
761
+ 'addButtonText',
762
+ 'draggable',
763
+ 'scaffold',
764
+ 'canAccessSuperData',
765
+ 'addIcon',
766
+ 'dragIcon',
767
+ 'deleteIcon',
768
+ 'noBorder',
769
+ 'conditions',
770
+ 'tabsMode',
771
+ 'tabsStyle',
772
+ 'lazyLoad',
773
+ 'changeImmediately',
774
+ 'strictMode',
775
+ 'items',
776
+ 'conditions',
777
+ 'messages',
778
+ 'formStore',
779
+ 'itemClassName',
780
+ 'itemsWrapperClassName'
781
+ ];
782
+ __decorate([
783
+ autobind,
784
+ __metadata("design:type", Function),
785
+ __metadata("design:paramtypes", [Number]),
786
+ __metadata("design:returntype", Promise)
787
+ ], ComboControl.prototype, "handleTabSelect", null);
788
+ __decorate([
789
+ autobind,
790
+ __metadata("design:type", Function),
791
+ __metadata("design:paramtypes", [Object]),
792
+ __metadata("design:returntype", void 0)
793
+ ], ComboControl.prototype, "setNull", null);
794
+ return ComboControl;
795
+ }(React.Component));
796
+ /** @class */ ((function (_super) {
797
+ __extends(ComboControlRenderer, _super);
798
+ function ComboControlRenderer() {
799
+ return _super !== null && _super.apply(this, arguments) || this;
800
+ }
801
+ // 支持更新指定索引的值
802
+ ComboControlRenderer.prototype.setData = function (value, index) {
803
+ var _a = this.props, multiple = _a.multiple, onChange = _a.onChange, submitOnChange = _a.submitOnChange;
804
+ if (multiple) {
805
+ if (index !== undefined && ~index) {
806
+ var newValue = __spreadArray([], this.getValueAsArray(), true);
807
+ newValue.splice(index, 1, __assign(__assign({}, newValue[index]), value));
808
+ onChange === null || onChange === void 0 ? void 0 : onChange(newValue, submitOnChange, true);
809
+ }
810
+ else {
811
+ onChange === null || onChange === void 0 ? void 0 : onChange(value, submitOnChange, true);
812
+ }
813
+ }
814
+ else {
815
+ onChange === null || onChange === void 0 ? void 0 : onChange(value, submitOnChange, true);
816
+ }
817
+ };
818
+ ComboControlRenderer = __decorate([
819
+ FormItem({
820
+ type: 'combo',
821
+ storeType: ComboStore.name,
822
+ extendsData: false
823
+ })
824
+ ], ComboControlRenderer);
825
+ return ComboControlRenderer;
826
+ })(ComboControl));
827
+ /** @class */ ((function (_super) {
828
+ __extends(KVControlRenderer, _super);
829
+ function KVControlRenderer() {
830
+ return _super !== null && _super.apply(this, arguments) || this;
831
+ }
832
+ KVControlRenderer = __decorate([
833
+ FormItem({
834
+ type: 'input-kv',
835
+ storeType: ComboStore.name,
836
+ extendsData: false
837
+ })
838
+ ], KVControlRenderer);
839
+ return KVControlRenderer;
840
+ })(ComboControl));
841
+ /** @class */ ((function (_super) {
842
+ __extends(KVSControlRenderer, _super);
843
+ function KVSControlRenderer() {
844
+ return _super !== null && _super.apply(this, arguments) || this;
845
+ }
846
+ KVSControlRenderer = __decorate([
847
+ FormItem({
848
+ type: 'input-kvs',
849
+ storeType: ComboStore.name,
850
+ extendsData: false
851
+ })
852
+ ], KVSControlRenderer);
853
+ return KVSControlRenderer;
854
+ })(ComboControl));
855
+
856
+ export { ComboControl as default };