amis 1.4.2-beta.1 → 1.4.2-beta.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (381) hide show
  1. package/lib/Schema.d.ts +9 -2
  2. package/lib/Schema.js.map +1 -1
  3. package/lib/components/AnchorNav.d.ts +22 -21
  4. package/lib/components/AnchorNav.js +7 -3
  5. package/lib/components/AnchorNav.js.map +2 -2
  6. package/lib/components/ArrayInput.d.ts +84 -84
  7. package/lib/components/AssociatedSelection.d.ts +930 -0
  8. package/lib/components/AssociatedSelection.js +89 -0
  9. package/lib/components/AssociatedSelection.js.map +13 -0
  10. package/lib/components/Badge.js +2 -2
  11. package/lib/components/Badge.js.map +2 -2
  12. package/lib/components/{ChainedCheckboxes.d.ts → ChainedSelection.d.ts} +267 -98
  13. package/lib/components/{ChainedCheckboxes.js → ChainedSelection.js} +30 -24
  14. package/lib/components/ChainedSelection.js.map +13 -0
  15. package/lib/components/ColorPicker.d.ts +84 -84
  16. package/lib/components/DatePicker.d.ts +84 -84
  17. package/lib/components/DateRangePicker.d.ts +84 -84
  18. package/lib/components/Editor.d.ts +84 -84
  19. package/lib/components/GroupedSelection.d.ts +907 -0
  20. package/lib/components/GroupedSelection.js +48 -0
  21. package/lib/components/GroupedSelection.js.map +13 -0
  22. package/lib/components/Link.d.ts +29 -36
  23. package/lib/components/Link.js +14 -15
  24. package/lib/components/Link.js.map +2 -2
  25. package/lib/components/ListGroup.d.ts +21 -21
  26. package/lib/components/ModalManager.js +1 -1
  27. package/lib/components/ModalManager.js.map +2 -2
  28. package/lib/components/MonthRangePicker.d.ts +84 -84
  29. package/lib/components/NumberInput.d.ts +20 -20
  30. package/lib/components/PickerColumn.d.ts +514 -0
  31. package/lib/components/PickerColumn.js +279 -0
  32. package/lib/components/PickerColumn.js.map +13 -0
  33. package/lib/components/PickerContainer.d.ts +513 -0
  34. package/lib/components/PickerContainer.js +96 -0
  35. package/lib/components/PickerContainer.js.map +13 -0
  36. package/lib/components/Radios.d.ts +22 -21
  37. package/lib/components/Radios.js +1 -0
  38. package/lib/components/Radios.js.map +2 -2
  39. package/lib/components/Rating.d.ts +21 -21
  40. package/lib/components/ResultBox.d.ts +84 -84
  41. package/lib/components/SearchBox.d.ts +84 -84
  42. package/lib/components/SearchBox.js +4 -4
  43. package/lib/components/SearchBox.js.map +2 -2
  44. package/lib/components/Select.d.ts +245 -237
  45. package/lib/components/Select.js +25 -4
  46. package/lib/components/Select.js.map +2 -2
  47. package/lib/components/{Checkboxes.d.ts → Selection.d.ts} +273 -98
  48. package/lib/components/Selection.js +134 -0
  49. package/lib/components/Selection.js.map +13 -0
  50. package/lib/components/{TableCheckboxes.d.ts → TableSelection.d.ts} +266 -96
  51. package/lib/components/{TableCheckboxes.js → TableSelection.js} +30 -30
  52. package/lib/components/TableSelection.js.map +13 -0
  53. package/lib/components/Tabs.d.ts +20 -20
  54. package/lib/components/TabsTransfer.d.ts +84 -84
  55. package/lib/components/TabsTransfer.js +9 -9
  56. package/lib/components/TabsTransfer.js.map +2 -2
  57. package/lib/components/TabsTransferPicker.d.ts +489 -0
  58. package/lib/components/TabsTransferPicker.js +60 -0
  59. package/lib/components/TabsTransferPicker.js.map +13 -0
  60. package/lib/components/Transfer.d.ts +908 -274
  61. package/lib/components/Transfer.js +31 -24
  62. package/lib/components/Transfer.js.map +2 -2
  63. package/lib/components/TransferDropDown.d.ts +487 -0
  64. package/lib/components/TransferDropDown.js +59 -0
  65. package/lib/components/TransferDropDown.js.map +13 -0
  66. package/lib/components/TransferPicker.d.ts +489 -0
  67. package/lib/components/TransferPicker.js +60 -0
  68. package/lib/components/TransferPicker.js.map +13 -0
  69. package/lib/components/Tree.d.ts +84 -84
  70. package/lib/components/{TreeCheckboxes.d.ts → TreeSelection.d.ts} +269 -99
  71. package/lib/components/{TreeCheckboxes.js → TreeSelection.js} +36 -32
  72. package/lib/components/TreeSelection.js.map +13 -0
  73. package/lib/components/WithRemoteConfig.js +1 -1
  74. package/lib/components/WithRemoteConfig.js.map +2 -2
  75. package/lib/components/condition-builder/Field.js +5 -2
  76. package/lib/components/condition-builder/Field.js.map +2 -2
  77. package/lib/components/condition-builder/Func.js +2 -2
  78. package/lib/components/condition-builder/Func.js.map +2 -2
  79. package/lib/components/condition-builder/InputSwitch.js +2 -2
  80. package/lib/components/condition-builder/InputSwitch.js.map +2 -2
  81. package/lib/components/condition-builder/Item.js +3 -3
  82. package/lib/components/condition-builder/Item.js.map +2 -2
  83. package/lib/components/index.d.ts +8 -8
  84. package/lib/components/index.js +16 -16
  85. package/lib/components/index.js.map +2 -2
  86. package/lib/envOverwrite.js.map +2 -2
  87. package/lib/factory.d.ts +4 -0
  88. package/lib/factory.js +4 -2
  89. package/lib/factory.js.map +2 -2
  90. package/lib/helper.css.map +1 -1
  91. package/lib/hooks/index.d.ts +5 -0
  92. package/lib/hooks/index.js +14 -0
  93. package/lib/hooks/index.js.map +13 -0
  94. package/lib/hooks/use-set-state.d.ts +2 -0
  95. package/lib/hooks/use-set-state.js +15 -0
  96. package/lib/hooks/use-set-state.js.map +13 -0
  97. package/lib/hooks/use-touch.d.ts +16 -0
  98. package/lib/hooks/use-touch.js +73 -0
  99. package/lib/hooks/use-touch.js.map +13 -0
  100. package/lib/hooks/use-update-effect.d.ts +3 -0
  101. package/lib/hooks/use-update-effect.js +17 -0
  102. package/lib/hooks/use-update-effect.js.map +13 -0
  103. package/lib/index.d.ts +3 -0
  104. package/lib/index.js +4 -1
  105. package/lib/index.js.map +2 -2
  106. package/lib/locale/de-DE.js +2 -0
  107. package/lib/locale/de-DE.js.map +2 -2
  108. package/lib/locale/en-US.js +2 -0
  109. package/lib/locale/en-US.js.map +2 -2
  110. package/lib/locale/zh-CN.js +4 -2
  111. package/lib/locale/zh-CN.js.map +2 -2
  112. package/lib/renderers/Action.d.ts +4 -3
  113. package/lib/renderers/Action.js +17 -4
  114. package/lib/renderers/Action.js.map +2 -2
  115. package/lib/renderers/AnchorNav.d.ts +1 -0
  116. package/lib/renderers/AnchorNav.js +2 -2
  117. package/lib/renderers/AnchorNav.js.map +2 -2
  118. package/lib/renderers/Avatar.js +3 -3
  119. package/lib/renderers/Avatar.js.map +2 -2
  120. package/lib/renderers/Breadcrumb.js +1 -1
  121. package/lib/renderers/Breadcrumb.js.map +2 -2
  122. package/lib/renderers/CRUD.d.ts +9 -0
  123. package/lib/renderers/CRUD.js +24 -4
  124. package/lib/renderers/CRUD.js.map +2 -2
  125. package/lib/renderers/Card.d.ts +4 -0
  126. package/lib/renderers/Card.js +29 -23
  127. package/lib/renderers/Card.js.map +2 -2
  128. package/lib/renderers/Chart.js +1 -1
  129. package/lib/renderers/Chart.js.map +2 -2
  130. package/lib/renderers/Collapse.js +3 -2
  131. package/lib/renderers/Collapse.js.map +2 -2
  132. package/lib/renderers/DropDownButton.js +1 -1
  133. package/lib/renderers/DropDownButton.js.map +2 -2
  134. package/lib/renderers/Form/DiffEditor.d.ts +4 -3
  135. package/lib/renderers/Form/Editor.d.ts +3 -2
  136. package/lib/renderers/Form/InputCity.d.ts +84 -84
  137. package/lib/renderers/Form/InputCity.js +7 -6
  138. package/lib/renderers/Form/InputCity.js.map +2 -2
  139. package/lib/renderers/Form/InputColor.d.ts +84 -84
  140. package/lib/renderers/Form/InputFile.js +10 -4
  141. package/lib/renderers/Form/InputFile.js.map +2 -2
  142. package/lib/renderers/Form/InputImage.js +11 -4
  143. package/lib/renderers/Form/InputImage.js.map +2 -2
  144. package/lib/renderers/Form/Item.d.ts +1 -1
  145. package/lib/renderers/Form/Item.js.map +1 -1
  146. package/lib/renderers/Form/Options.js +13 -3
  147. package/lib/renderers/Form/Options.js.map +2 -2
  148. package/lib/renderers/Form/Select.d.ts +41 -4
  149. package/lib/renderers/Form/Select.js +23 -3
  150. package/lib/renderers/Form/Select.js.map +2 -2
  151. package/lib/renderers/Form/TabsTransferPicker.d.ts +48 -0
  152. package/lib/renderers/Form/TabsTransferPicker.js +29 -0
  153. package/lib/renderers/Form/TabsTransferPicker.js.map +13 -0
  154. package/lib/renderers/Form/Transfer.js +3 -2
  155. package/lib/renderers/Form/Transfer.js.map +2 -2
  156. package/lib/renderers/Form/TransferPicker.d.ts +48 -0
  157. package/lib/renderers/Form/TransferPicker.js +29 -0
  158. package/lib/renderers/Form/TransferPicker.js.map +13 -0
  159. package/lib/renderers/Form/TreeSelect.js +2 -2
  160. package/lib/renderers/Form/TreeSelect.js.map +2 -2
  161. package/lib/renderers/Form/index.js +1 -1
  162. package/lib/renderers/Form/index.js.map +2 -2
  163. package/lib/renderers/Form/wrapControl.js +13 -1
  164. package/lib/renderers/Form/wrapControl.js.map +2 -2
  165. package/lib/renderers/IFrame.js +1 -3
  166. package/lib/renderers/IFrame.js.map +2 -2
  167. package/lib/renderers/Json.d.ts +4 -0
  168. package/lib/renderers/Json.js +4 -13
  169. package/lib/renderers/Json.js.map +2 -2
  170. package/lib/renderers/Link.d.ts +4 -2
  171. package/lib/renderers/Link.js +15 -6
  172. package/lib/renderers/Link.js.map +2 -2
  173. package/lib/renderers/List.js +1 -1
  174. package/lib/renderers/List.js.map +2 -2
  175. package/lib/renderers/Mapping.d.ts +9 -2
  176. package/lib/renderers/Mapping.js +18 -6
  177. package/lib/renderers/Mapping.js.map +2 -2
  178. package/lib/renderers/Nav.d.ts +21 -21
  179. package/lib/renderers/Nav.js +39 -21
  180. package/lib/renderers/Nav.js.map +2 -2
  181. package/lib/renderers/Portlet.d.ts +125 -0
  182. package/lib/renderers/Portlet.js +156 -0
  183. package/lib/renderers/Portlet.js.map +13 -0
  184. package/lib/renderers/Property.js +2 -1
  185. package/lib/renderers/Property.js.map +2 -2
  186. package/lib/renderers/SearchBox.d.ts +6 -1
  187. package/lib/renderers/SearchBox.js +19 -5
  188. package/lib/renderers/SearchBox.js.map +2 -2
  189. package/lib/renderers/Table/TableContent.d.ts +4 -1
  190. package/lib/renderers/Table/TableContent.js +21 -1
  191. package/lib/renderers/Table/TableContent.js.map +2 -2
  192. package/lib/renderers/Table/index.d.ts +5 -1
  193. package/lib/renderers/Table/index.js +64 -29
  194. package/lib/renderers/Table/index.js.map +2 -2
  195. package/lib/renderers/Tabs.js +9 -1
  196. package/lib/renderers/Tabs.js.map +2 -2
  197. package/lib/renderers/WebComponent.js +1 -1
  198. package/lib/renderers/WebComponent.js.map +2 -2
  199. package/lib/store/combo.d.ts +2 -16
  200. package/lib/store/crud.js +3 -7
  201. package/lib/store/crud.js.map +2 -2
  202. package/lib/store/form.d.ts +1 -1
  203. package/lib/store/form.js +5 -6
  204. package/lib/store/form.js.map +2 -2
  205. package/lib/store/service.js +5 -4
  206. package/lib/store/service.js.map +2 -2
  207. package/lib/store/table.d.ts +2 -2
  208. package/lib/themes/ang-ie11.css +422 -149
  209. package/lib/themes/ang.css +422 -149
  210. package/lib/themes/ang.css.map +1 -1
  211. package/lib/themes/antd-ie11.css +422 -149
  212. package/lib/themes/antd.css +422 -149
  213. package/lib/themes/antd.css.map +1 -1
  214. package/lib/themes/cxd-ie11.css +456 -182
  215. package/lib/themes/cxd.css +456 -182
  216. package/lib/themes/cxd.css.map +1 -1
  217. package/lib/themes/dark-ie11.css +422 -149
  218. package/lib/themes/dark.css +422 -149
  219. package/lib/themes/dark.css.map +1 -1
  220. package/lib/themes/default.css +456 -182
  221. package/lib/themes/default.css.map +1 -1
  222. package/lib/types.d.ts +37 -0
  223. package/lib/types.js +0 -5
  224. package/lib/types.js.map +2 -2
  225. package/lib/utils/api.d.ts +3 -2
  226. package/lib/utils/api.js +28 -12
  227. package/lib/utils/api.js.map +2 -2
  228. package/lib/utils/dom.d.ts +4 -0
  229. package/lib/utils/dom.js +11 -1
  230. package/lib/utils/dom.js.map +2 -2
  231. package/lib/utils/helper.d.ts +2 -0
  232. package/lib/utils/helper.js +11 -2
  233. package/lib/utils/helper.js.map +2 -2
  234. package/lib/utils/icon.js +3 -0
  235. package/lib/utils/icon.js.map +2 -2
  236. package/package.json +1 -1
  237. package/schema.json +3038 -790
  238. package/scss/_mixins.scss +1 -3
  239. package/scss/_properties.scss +25 -1
  240. package/scss/base/_normalize.scss +2 -0
  241. package/scss/components/_anchor-nav.scss +88 -29
  242. package/scss/components/_card.scss +8 -14
  243. package/scss/components/_collapse.scss +16 -1
  244. package/scss/components/_mapping.scss +6 -0
  245. package/scss/components/_nav.scss +1 -1
  246. package/scss/components/_picker-columns.scss +123 -0
  247. package/scss/components/_popover.scss +17 -0
  248. package/scss/components/_portlet.scss +51 -0
  249. package/scss/components/_status.scss +1 -1
  250. package/scss/components/_table.scss +26 -0
  251. package/scss/components/form/_checks.scss +0 -351
  252. package/scss/components/form/_fieldset.scss +5 -1
  253. package/scss/components/form/_selection.scss +354 -0
  254. package/scss/components/form/_transfer.scss +75 -18
  255. package/scss/themes/_common.scss +4 -0
  256. package/scss/themes/_cxd-variables.scss +4 -1
  257. package/scss/themes/cxd.scss +16 -12
  258. package/sdk/ang-ie11.css +457 -152
  259. package/sdk/ang.css +480 -154
  260. package/sdk/antd-ie11.css +456 -151
  261. package/sdk/antd.css +480 -154
  262. package/sdk/charts.js +13 -13
  263. package/sdk/color-picker.js +65 -69
  264. package/sdk/cropperjs.js +2 -2
  265. package/sdk/cxd-ie11.css +496 -194
  266. package/sdk/cxd.css +517 -190
  267. package/sdk/dark-ie11.css +457 -152
  268. package/sdk/dark.css +480 -154
  269. package/sdk/exceljs.js +1 -1
  270. package/sdk/helper.css.map +1 -1
  271. package/sdk/locale/de-DE.js +2 -0
  272. package/sdk/markdown.js +69 -69
  273. package/sdk/papaparse.js +1 -1
  274. package/sdk/renderers/Form/CityDB.js +1 -1
  275. package/sdk/rest.js +20 -28
  276. package/sdk/rich-text.js +62 -62
  277. package/sdk/sdk-ie11.css +496 -194
  278. package/sdk/sdk.css +517 -190
  279. package/sdk/sdk.js +1268 -1236
  280. package/sdk/thirds/hls.js/hls.js +1 -1
  281. package/sdk/thirds/mpegts.js/mpegts.js +1 -1
  282. package/sdk/tinymce.js +57 -57
  283. package/src/Schema.ts +14 -0
  284. package/src/components/AnchorNav.tsx +15 -4
  285. package/src/components/{AssociatedCheckboxes.tsx → AssociatedSelection.tsx} +41 -37
  286. package/src/components/Badge.tsx +3 -3
  287. package/src/components/{ChainedCheckboxes.tsx → ChainedSelection.tsx} +57 -40
  288. package/src/components/{ListCheckboxes.tsx → GroupedSelection.tsx} +26 -21
  289. package/src/components/Link.tsx +28 -37
  290. package/src/components/ModalManager.ts +1 -1
  291. package/src/components/PickerColumn.tsx +429 -0
  292. package/src/components/PickerContainer.tsx +128 -0
  293. package/src/components/Radios.tsx +3 -8
  294. package/src/components/SearchBox.tsx +4 -5
  295. package/src/components/Select.tsx +57 -5
  296. package/src/components/{Checkboxes.tsx → Selection.tsx} +75 -21
  297. package/src/components/{TableCheckboxes.tsx → TableSelection.tsx} +46 -25
  298. package/src/components/TabsTransfer.tsx +13 -7
  299. package/src/components/TabsTransferPicker.tsx +85 -0
  300. package/src/components/Transfer.tsx +71 -50
  301. package/src/components/TransferDropDown.tsx +117 -0
  302. package/src/components/TransferPicker.tsx +84 -0
  303. package/src/components/{TreeCheckboxes.tsx → TreeSelection.tsx} +33 -26
  304. package/src/components/WithRemoteConfig.tsx +7 -2
  305. package/src/components/condition-builder/Field.tsx +5 -5
  306. package/src/components/condition-builder/Func.tsx +3 -3
  307. package/src/components/condition-builder/InputSwitch.tsx +3 -3
  308. package/src/components/condition-builder/Item.tsx +5 -12
  309. package/src/components/index.tsx +13 -13
  310. package/src/envOverwrite.ts +0 -1
  311. package/src/factory.tsx +18 -3
  312. package/src/hooks/index.ts +5 -0
  313. package/src/hooks/use-set-state.ts +19 -0
  314. package/src/hooks/use-touch.ts +100 -0
  315. package/src/hooks/use-update-effect.ts +16 -0
  316. package/src/index.tsx +3 -0
  317. package/src/locale/de-DE.ts +2 -0
  318. package/src/locale/en-US.ts +2 -0
  319. package/src/locale/zh-CN.ts +4 -2
  320. package/src/renderers/Action.tsx +28 -2
  321. package/src/renderers/AnchorNav.tsx +4 -0
  322. package/src/renderers/Avatar.tsx +8 -4
  323. package/src/renderers/Breadcrumb.tsx +5 -1
  324. package/src/renderers/CRUD.tsx +33 -3
  325. package/src/renderers/Card.tsx +63 -34
  326. package/src/renderers/Chart.tsx +6 -2
  327. package/src/renderers/Collapse.tsx +4 -2
  328. package/src/renderers/DropDownButton.tsx +1 -1
  329. package/src/renderers/Form/InputCity.tsx +4 -8
  330. package/src/renderers/Form/InputFile.tsx +29 -20
  331. package/src/renderers/Form/InputImage.tsx +11 -3
  332. package/src/renderers/Form/Item.tsx +1 -1
  333. package/src/renderers/Form/Options.tsx +16 -2
  334. package/src/renderers/Form/Select.tsx +144 -21
  335. package/src/renderers/Form/TabsTransferPicker.tsx +123 -0
  336. package/src/renderers/Form/Transfer.tsx +3 -2
  337. package/src/renderers/Form/TransferPicker.tsx +123 -0
  338. package/src/renderers/Form/TreeSelect.tsx +25 -0
  339. package/src/renderers/Form/index.tsx +1 -1
  340. package/src/renderers/Form/wrapControl.tsx +26 -1
  341. package/src/renderers/IFrame.tsx +2 -4
  342. package/src/renderers/Json.tsx +9 -9
  343. package/src/renderers/Link.tsx +27 -13
  344. package/src/renderers/List.tsx +1 -1
  345. package/src/renderers/Mapping.tsx +27 -11
  346. package/src/renderers/Nav.tsx +108 -60
  347. package/src/renderers/Portlet.tsx +423 -0
  348. package/src/renderers/Property.tsx +3 -2
  349. package/src/renderers/SearchBox.tsx +23 -4
  350. package/src/renderers/Table/TableContent.tsx +40 -2
  351. package/src/renderers/Table/index.tsx +87 -41
  352. package/src/renderers/Tabs.tsx +9 -1
  353. package/src/renderers/WebComponent.tsx +2 -2
  354. package/src/store/crud.ts +3 -8
  355. package/src/store/form.ts +5 -10
  356. package/src/store/service.ts +5 -4
  357. package/src/types.ts +57 -0
  358. package/src/utils/api.ts +40 -20
  359. package/src/utils/dom.tsx +12 -0
  360. package/src/utils/helper.ts +8 -0
  361. package/src/utils/icon.tsx +4 -0
  362. package/dump.rdb +0 -0
  363. package/lib/components/AssociatedCheckboxes.d.ts +0 -762
  364. package/lib/components/AssociatedCheckboxes.js +0 -90
  365. package/lib/components/AssociatedCheckboxes.js.map +0 -13
  366. package/lib/components/ChainedCheckboxes.js.map +0 -13
  367. package/lib/components/Checkboxes.js +0 -101
  368. package/lib/components/Checkboxes.js.map +0 -13
  369. package/lib/components/ListCheckboxes.d.ts +0 -739
  370. package/lib/components/ListCheckboxes.js +0 -48
  371. package/lib/components/ListCheckboxes.js.map +0 -13
  372. package/lib/components/ListRadios.d.ts +0 -763
  373. package/lib/components/ListRadios.js +0 -86
  374. package/lib/components/ListRadios.js.map +0 -13
  375. package/lib/components/TableCheckboxes.js.map +0 -13
  376. package/lib/components/TreeCheckboxes.js.map +0 -13
  377. package/lib/components/TreeRadios.d.ts +0 -838
  378. package/lib/components/TreeRadios.js +0 -116
  379. package/lib/components/TreeRadios.js.map +0 -13
  380. package/src/components/ListRadios.tsx +0 -159
  381. package/src/components/TreeRadios.tsx +0 -202
@@ -1,4 +1,4 @@
1
- import {BaseCheckboxes, BaseCheckboxesProps} from './Checkboxes';
1
+ import {BaseSelection, BaseSelectionProps} from './Selection';
2
2
  import {themeable} from '../theme';
3
3
  import React from 'react';
4
4
  import {uncontrollable} from 'uncontrollable';
@@ -9,25 +9,25 @@ import Spinner from './Spinner';
9
9
  import {localeable} from '../locale';
10
10
  import {Icon} from './icons';
11
11
 
12
- export interface TreeCheckboxesProps extends BaseCheckboxesProps {
12
+ export interface TreeSelectionProps extends BaseSelectionProps {
13
13
  expand?: 'all' | 'first' | 'root' | 'none';
14
14
  }
15
15
 
16
- export interface TreeCheckboxesState {
16
+ export interface TreeSelectionState {
17
17
  expanded: Array<string>;
18
18
  }
19
19
 
20
- export class TreeCheckboxes extends BaseCheckboxes<
21
- TreeCheckboxesProps,
22
- TreeCheckboxesState
20
+ export class TreeSelection extends BaseSelection<
21
+ TreeSelectionProps,
22
+ TreeSelectionState
23
23
  > {
24
24
  valueArray: Array<Option>;
25
- state: TreeCheckboxesState = {
25
+ state: TreeSelectionState = {
26
26
  expanded: []
27
27
  };
28
28
 
29
29
  static defaultProps = {
30
- ...BaseCheckboxes.defaultProps,
30
+ ...BaseSelection.defaultProps,
31
31
  expand: 'first' as 'first'
32
32
  };
33
33
 
@@ -35,7 +35,7 @@ export class TreeCheckboxes extends BaseCheckboxes<
35
35
  this.syncExpanded();
36
36
  }
37
37
 
38
- componentDidUpdate(prevProps: TreeCheckboxesProps) {
38
+ componentDidUpdate(prevProps: TreeSelectionProps) {
39
39
  const props = this.props;
40
40
 
41
41
  if (
@@ -82,7 +82,9 @@ export class TreeCheckboxes extends BaseCheckboxes<
82
82
  option2value,
83
83
  options,
84
84
  onDeferLoad,
85
- disabled
85
+ disabled,
86
+ multiple,
87
+ clearable
86
88
  } = this.props;
87
89
 
88
90
  if (disabled || option.disabled) {
@@ -92,12 +94,13 @@ export class TreeCheckboxes extends BaseCheckboxes<
92
94
  return;
93
95
  }
94
96
 
95
- let valueArray = BaseCheckboxes.value2array(value, options, option2value);
97
+ let valueArray = BaseSelection.value2array(value, options, option2value);
96
98
 
97
99
  if (
98
100
  option.value === void 0 &&
99
101
  Array.isArray(option.children) &&
100
- option.children.length
102
+ option.children.length &&
103
+ multiple
101
104
  ) {
102
105
  const someCheckedFn = (child: Option) =>
103
106
  (Array.isArray(child.children) && child.children.length
@@ -124,10 +127,12 @@ export class TreeCheckboxes extends BaseCheckboxes<
124
127
  } else {
125
128
  let idx = valueArray.indexOf(option);
126
129
 
127
- if (~idx) {
130
+ if (~idx && (multiple || clearable)) {
128
131
  valueArray.splice(idx, 1);
129
- } else {
132
+ } else if (multiple) {
130
133
  valueArray.push(option);
134
+ } else {
135
+ valueArray = [option];
131
136
  }
132
137
  }
133
138
 
@@ -135,7 +140,7 @@ export class TreeCheckboxes extends BaseCheckboxes<
135
140
  ? valueArray.map(item => option2value(item))
136
141
  : valueArray;
137
142
 
138
- onChange && onChange(newValue);
143
+ onChange && onChange(multiple ? newValue : newValue[0]);
139
144
  }
140
145
 
141
146
  toggleCollapsed(option: Option, index: string) {
@@ -163,7 +168,8 @@ export class TreeCheckboxes extends BaseCheckboxes<
163
168
  disabled,
164
169
  classnames: cx,
165
170
  itemClassName,
166
- itemRender
171
+ itemRender,
172
+ multiple
167
173
  } = this.props;
168
174
  const id = indexes.join('-');
169
175
  const valueArray = this.valueArray;
@@ -204,7 +210,7 @@ export class TreeCheckboxes extends BaseCheckboxes<
204
210
  <div
205
211
  key={index}
206
212
  className={cx(
207
- 'TreeCheckboxes-item',
213
+ 'TreeSelection-item',
208
214
  disabled || option.disabled || (option.defer && option.loading)
209
215
  ? 'is-disabled'
210
216
  : '',
@@ -213,9 +219,10 @@ export class TreeCheckboxes extends BaseCheckboxes<
213
219
  >
214
220
  <div
215
221
  className={cx(
216
- 'TreeCheckboxes-itemInner',
222
+ 'TreeSelection-itemInner',
217
223
  itemClassName,
218
- option.className
224
+ option.className,
225
+ checked ? 'is-active' : ''
219
226
  )}
220
227
  onClick={() => this.toggleOption(option)}
221
228
  >
@@ -231,13 +238,13 @@ export class TreeCheckboxes extends BaseCheckboxes<
231
238
  </a>
232
239
  ) : null}
233
240
 
234
- <div className={cx('TreeCheckboxes-itemLabel')}>
241
+ <div className={cx('TreeSelection-itemLabel')}>
235
242
  {itemRender(option)}
236
243
  </div>
237
244
 
238
245
  {option.defer && option.loading ? <Spinner show size="sm" /> : null}
239
246
 
240
- {!option.defer || option.loaded ? (
247
+ {multiple && (!option.defer || option.loaded) ? (
241
248
  <Checkbox
242
249
  size="sm"
243
250
  checked={checked}
@@ -249,7 +256,7 @@ export class TreeCheckboxes extends BaseCheckboxes<
249
256
  ) : null}
250
257
  </div>
251
258
  {hasChildren ? (
252
- <div className={cx('TreeCheckboxes-sublist')}>
259
+ <div className={cx('TreeSelection-sublist')}>
253
260
  {option.children!.map((option, key) =>
254
261
  this.renderItem(option, key, indexes.concat(key))
255
262
  )}
@@ -270,7 +277,7 @@ export class TreeCheckboxes extends BaseCheckboxes<
270
277
  translate: __
271
278
  } = this.props;
272
279
 
273
- this.valueArray = BaseCheckboxes.value2array(value, options, option2value);
280
+ this.valueArray = BaseSelection.value2array(value, options, option2value);
274
281
  let body: Array<React.ReactNode> = [];
275
282
 
276
283
  if (Array.isArray(options) && options.length) {
@@ -278,11 +285,11 @@ export class TreeCheckboxes extends BaseCheckboxes<
278
285
  }
279
286
 
280
287
  return (
281
- <div className={cx('TreeCheckboxes', className)}>
288
+ <div className={cx('TreeSelection', className)}>
282
289
  {body && body.length ? (
283
290
  body
284
291
  ) : (
285
- <div className={cx('TreeCheckboxes-placeholder')}>
292
+ <div className={cx('TreeSelection-placeholder')}>
286
293
  {__(placeholder)}
287
294
  </div>
288
295
  )}
@@ -293,7 +300,7 @@ export class TreeCheckboxes extends BaseCheckboxes<
293
300
 
294
301
  export default themeable(
295
302
  localeable(
296
- uncontrollable(TreeCheckboxes, {
303
+ uncontrollable(TreeSelection, {
297
304
  value: 'onChange'
298
305
  })
299
306
  )
@@ -12,7 +12,12 @@ import {withStore} from './WithStore';
12
12
  import {EnvContext, RendererEnv} from '../env';
13
13
 
14
14
  import {flow, Instance, isAlive, types} from 'mobx-state-tree';
15
- import {buildApi, isEffectiveApi, normalizeApi} from '../utils/api';
15
+ import {
16
+ buildApi,
17
+ isEffectiveApi,
18
+ normalizeApi,
19
+ normalizeApiResponseData
20
+ } from '../utils/api';
16
21
  import {
17
22
  isPureVariable,
18
23
  resolveVariableAndFilter,
@@ -46,7 +51,7 @@ export const Store = types
46
51
  }
47
52
 
48
53
  if (ret.ok) {
49
- const data = ret.data || {};
54
+ const data = normalizeApiResponseData(ret.data);
50
55
  let options = config.adaptor
51
56
  ? config.adaptor(data, component.props)
52
57
  : data;
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import PopOverContainer from '../PopOverContainer';
3
- import ListRadios from '../ListRadios';
3
+ import ListSelection from '../GroupedSelection';
4
4
  import ResultBox from '../ResultBox';
5
5
  import {ClassNamesFn, ThemeProps, themeable} from '../../theme';
6
6
  import {Icon} from '../icons';
@@ -90,13 +90,13 @@ export class ConditionField extends React.Component<
90
90
  {searchable ? (
91
91
  <SearchBox mini={false} onSearch={this.onSearch} />
92
92
  ) : null}
93
- <ListRadios
93
+ <ListSelection
94
+ multiple={false}
94
95
  onClick={e => this.onPopClose(e, onClose)}
95
- showRadio={false}
96
96
  options={this.state.options}
97
- value={value}
97
+ value={[value]}
98
98
  option2value={option2value}
99
- onChange={onChange}
99
+ onChange={([value]: any) => onChange(value)}
100
100
  />
101
101
  </>
102
102
  )}
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import {Func, ExpressionFunc, Field, Funcs} from './types';
3
3
  import {ThemeProps, themeable} from '../../theme';
4
4
  import PopOverContainer from '../PopOverContainer';
5
- import ListRadios from '../ListRadios';
5
+ import GroupedSelection from '../GroupedSelection';
6
6
  import {autobind, findTree, noop} from '../../utils/helper';
7
7
  import ResultBox from '../ResultBox';
8
8
  import {Icon} from '../icons';
@@ -77,13 +77,13 @@ export class ConditionFunc extends React.Component<ConditionFuncProps> {
77
77
  <div className={cx('CBFunc')}>
78
78
  <PopOverContainer
79
79
  popOverRender={({onClose}) => (
80
- <ListRadios
80
+ <GroupedSelection
81
81
  onClick={onClose}
82
- showRadio={false}
83
82
  options={funcs!}
84
83
  value={(func as Func)?.type}
85
84
  option2value={option2value}
86
85
  onChange={this.handleFuncChange}
86
+ multiple={false}
87
87
  />
88
88
  )}
89
89
  >
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
2
  import PopOverContainer from '../PopOverContainer';
3
3
  import {Icon} from '../icons';
4
- import ListRadios from '../ListRadios';
4
+ import GroupedSelection from '../GroupedSelection';
5
5
  import {ClassNamesFn, themeable, ThemeProps} from '../../theme';
6
6
 
7
7
  export interface InputSwitchProps extends ThemeProps {
@@ -23,13 +23,13 @@ export function InputSwitch({
23
23
  return (
24
24
  <PopOverContainer
25
25
  popOverRender={({onClose}) => (
26
- <ListRadios
26
+ <GroupedSelection
27
27
  onClick={onClose}
28
28
  option2value={option2value}
29
29
  onChange={onChange}
30
30
  options={options}
31
31
  value={value}
32
- showRadio={false}
32
+ multiple={false}
33
33
  disabled={disabled}
34
34
  />
35
35
  )}
@@ -18,7 +18,7 @@ import {autobind, findTree, noop} from '../../utils/helper';
18
18
  import Expression from './Expression';
19
19
  import {Config, OperationMap} from './config';
20
20
  import PopOverContainer from '../PopOverContainer';
21
- import ListRadios from '../ListRadios';
21
+ import GroupedSelection from '../GroupedSelection';
22
22
  import ResultBox from '../ResultBox';
23
23
  import {localeable, LocaleProps} from '../../locale';
24
24
 
@@ -100,15 +100,8 @@ export class ConditionItem extends React.Component<ConditionItemProps> {
100
100
  }
101
101
 
102
102
  renderLeft() {
103
- const {
104
- value,
105
- fields,
106
- funcs,
107
- config,
108
- disabled,
109
- fieldClassName,
110
- searchable
111
- } = this.props;
103
+ const {value, fields, funcs, config, disabled, fieldClassName, searchable} =
104
+ this.props;
112
105
  return (
113
106
  <Expression
114
107
  config={config}
@@ -158,7 +151,7 @@ export class ConditionItem extends React.Component<ConditionItemProps> {
158
151
  return (
159
152
  <PopOverContainer
160
153
  popOverRender={({onClose}) => (
161
- <ListRadios
154
+ <GroupedSelection
162
155
  onClick={onClose}
163
156
  option2value={option2value}
164
157
  onChange={this.handleOperatorChange}
@@ -167,7 +160,7 @@ export class ConditionItem extends React.Component<ConditionItemProps> {
167
160
  value: operator
168
161
  }))}
169
162
  value={value.op}
170
- showRadio={false}
163
+ multiple={false}
171
164
  />
172
165
  )}
173
166
  >
@@ -10,7 +10,7 @@ import {default as ContextMenu, openContextMenus} from './ContextMenu';
10
10
  import AsideNav from './AsideNav';
11
11
  import Button from './Button';
12
12
  import Checkbox from './Checkbox';
13
- import Checkboxes from './Checkboxes';
13
+ import Checkboxes from './Selection';
14
14
  import Collapse from './Collapse';
15
15
  import DatePicker from './DatePicker';
16
16
  import DateRangePicker from './DateRangePicker';
@@ -41,19 +41,19 @@ import Tree from './Tree';
41
41
  import Alert2 from './Alert2';
42
42
  import Transfer from './Transfer';
43
43
  import TabsTransfer from './TabsTransfer';
44
- import ListCheckboxes from './ListCheckboxes';
45
- import TableCheckboxes from './TableCheckboxes';
46
- import TreeCheckboxes from './TreeCheckboxes';
47
- import ChainedCheckboxes from './ChainedCheckboxes';
48
44
  import ResultBox from './ResultBox';
49
45
  import InputBox from './InputBox';
50
- import ListRadios from './ListRadios';
51
- import TreeRadios from './TreeRadios';
52
46
  import ListGroup from './ListGroup';
53
47
  import NumberInput from './NumberInput';
54
48
  import ArrayInput from './ArrayInput';
55
49
  import SearchBox from './SearchBox';
56
50
  import AnchorNav from './AnchorNav';
51
+ import Selection from './Selection';
52
+ import GroupedSelection from './GroupedSelection';
53
+ import ChainedSelection from './ChainedSelection';
54
+ import TableSelection from './TableSelection';
55
+ import TreeSelection from './TreeSelection';
56
+ import AssociatedSelection from './AssociatedSelection';
57
57
 
58
58
  export {
59
59
  NotFound,
@@ -99,15 +99,15 @@ export {
99
99
  Tree,
100
100
  Transfer,
101
101
  TabsTransfer,
102
- ListCheckboxes,
103
- TableCheckboxes,
104
- TreeCheckboxes,
105
- ChainedCheckboxes,
102
+ Selection,
103
+ GroupedSelection,
104
+ ChainedSelection,
105
+ TableSelection,
106
+ TreeSelection,
107
+ AssociatedSelection,
106
108
  ResultBox,
107
109
  InputBox,
108
- ListRadios,
109
110
  SearchBox,
110
- TreeRadios,
111
111
  ListGroup,
112
112
  NumberInput,
113
113
  ArrayInput,
@@ -4,7 +4,6 @@
4
4
 
5
5
  import {SchemaNode, Schema} from './types';
6
6
  import {RendererProps, RendererConfig, addSchemaFilter} from './factory';
7
-
8
7
  const isMobile = (window as any).matchMedia?.('(max-width: 768px)').matches
9
8
  ? true
10
9
  : false;
package/src/factory.tsx CHANGED
@@ -4,7 +4,16 @@ import {getEnv, destroy} from 'mobx-state-tree';
4
4
  import {wrapFetcher} from './utils/api';
5
5
  import {normalizeLink} from './utils/normalizeLink';
6
6
  import {findIndex, promisify, qsparse, string2regExp} from './utils/helper';
7
- import {Api, fetcherResult, Payload, SchemaNode, Schema, Action} from './types';
7
+ import {
8
+ Api,
9
+ fetcherResult,
10
+ Payload,
11
+ SchemaNode,
12
+ Schema,
13
+ Action,
14
+ EventTrack,
15
+ PlainObject
16
+ } from './types';
8
17
  import {observer} from 'mobx-react';
9
18
  import Scoped from './Scoped';
10
19
  import {getTheme, ThemeInstance, ThemeProps} from './theme';
@@ -58,6 +67,10 @@ export interface RendererProps extends ThemeProps, LocaleProps {
58
67
  };
59
68
  defaultData?: object;
60
69
  className?: any;
70
+ /**
71
+ * 是否使用移动端交互
72
+ */
73
+ useMobileUI?: boolean;
61
74
  [propName: string]: any;
62
75
  }
63
76
 
@@ -320,6 +333,8 @@ const defaultOptions: RenderOptions = {
320
333
  copy(contents: string) {
321
334
  console.error('copy contents', contents);
322
335
  },
336
+ // 用于跟踪用户在界面中的各种操作
337
+ tracker(eventTrack: EventTrack, props: PlainObject) {},
323
338
  rendererResolver: resolveRenderer
324
339
  };
325
340
  let stores: {
@@ -345,7 +360,7 @@ export function render(
345
360
  ...defaultOptions,
346
361
  ...options,
347
362
  fetcher: options.fetcher
348
- ? wrapFetcher(options.fetcher)
363
+ ? wrapFetcher(options.fetcher, options.tracker)
349
364
  : defaultOptions.fetcher,
350
365
  confirm: promisify(
351
366
  options.confirm || defaultOptions.confirm || window.confirm
@@ -416,7 +431,7 @@ export function updateEnv(options: Partial<RenderOptions>, session = 'global') {
416
431
  };
417
432
 
418
433
  if (options.fetcher) {
419
- options.fetcher = wrapFetcher(options.fetcher) as any;
434
+ options.fetcher = wrapFetcher(options.fetcher, options.tracker) as any;
420
435
  }
421
436
 
422
437
  if (options.confirm) {
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @file 常用 hooks
3
+ */
4
+ export {default as useSetState} from './use-set-state';
5
+ export {default as useUpdateEffect} from './use-update-effect';
@@ -0,0 +1,19 @@
1
+ import {useCallback, useState} from 'react';
2
+ import isFunction from 'lodash/isFunction';
3
+
4
+ const useSetState = <T extends object>(
5
+ initialState: T = {} as T
6
+ ): [T, (patch: Partial<T> | ((prevState: T) => Partial<T>)) => void] => {
7
+ const [state, setState] = useState<T>(initialState);
8
+
9
+ const setMergeState = useCallback(patch => {
10
+ setState(prevState => ({
11
+ ...prevState,
12
+ ...(isFunction(patch) ? patch(prevState) : patch)
13
+ }));
14
+ }, []);
15
+
16
+ return [state, setMergeState];
17
+ };
18
+
19
+ export default useSetState;
@@ -0,0 +1,100 @@
1
+ import {useCallback, useRef} from 'react';
2
+
3
+ const MIN_DISTANCE = 10;
4
+
5
+ type Direction = '' | 'vertical' | 'horizontal';
6
+
7
+ function getDirection(x: number, y: number) {
8
+ if (x > y && x > MIN_DISTANCE) {
9
+ return 'horizontal';
10
+ }
11
+ if (y > x && y > MIN_DISTANCE) {
12
+ return 'vertical';
13
+ }
14
+ return '';
15
+ }
16
+
17
+ const INITIAL_STATE = {
18
+ startX: 0,
19
+ startY: 0,
20
+ deltaX: 0,
21
+ deltaY: 0,
22
+ offsetX: 0,
23
+ offsetY: 0,
24
+ direction: '' as Direction
25
+ };
26
+
27
+ type StateType = Partial<typeof INITIAL_STATE>;
28
+ type StateFunctionType = (value: StateType) => typeof INITIAL_STATE;
29
+
30
+ const useTouch = () => {
31
+ const refState = useRef(INITIAL_STATE);
32
+ const innerState = refState.current;
33
+
34
+ const update = (value: StateType | StateFunctionType) => {
35
+ if (typeof value === 'function') {
36
+ value = value(refState.current);
37
+ }
38
+ Object.entries(value).forEach(([k, v]) => {
39
+ //@ts-ignore
40
+ refState.current[k] = v;
41
+ });
42
+ };
43
+
44
+ const isVertical = useCallback(
45
+ () => innerState.direction === 'vertical',
46
+ [innerState.direction]
47
+ );
48
+ const isHorizontal = useCallback(
49
+ () => innerState.direction === 'horizontal',
50
+ [innerState.direction]
51
+ );
52
+
53
+ const reset = () => {
54
+ update({
55
+ deltaX: 0,
56
+ deltaY: 0,
57
+ offsetX: 0,
58
+ offsetY: 0,
59
+ direction: ''
60
+ });
61
+ };
62
+
63
+ const start = ((event: TouchEvent) => {
64
+ reset();
65
+ update({
66
+ startX: event.touches[0].clientX,
67
+ startY: event.touches[0].clientY
68
+ });
69
+ }) as EventListener;
70
+
71
+ const move = ((event: TouchEvent) => {
72
+ const touch = event.touches[0];
73
+
74
+ update(value => {
75
+ // Fix: Safari back will set clientX to negative number
76
+ const newState = {...value} as typeof innerState;
77
+
78
+ newState.deltaX = touch.clientX < 0 ? 0 : touch.clientX - newState.startX;
79
+ newState.deltaY = touch.clientY - newState.startY;
80
+ newState.offsetX = Math.abs(newState.deltaX);
81
+ newState.offsetY = Math.abs(newState.deltaY);
82
+
83
+ if (!newState.direction) {
84
+ newState.direction = getDirection(newState.offsetX, newState.offsetY);
85
+ }
86
+ return newState;
87
+ });
88
+ }) as EventListener;
89
+
90
+ return {
91
+ ...innerState,
92
+ move,
93
+ start,
94
+ reset,
95
+ isVertical,
96
+ isHorizontal
97
+ };
98
+ };
99
+
100
+ export default useTouch;
@@ -0,0 +1,16 @@
1
+ import {useEffect, useRef} from 'react';
2
+
3
+ const useUpdateEffect: typeof useEffect = (effect, deps) => {
4
+ const isMounted = useRef(false);
5
+
6
+ useEffect(() => {
7
+ if (!isMounted.current) {
8
+ isMounted.current = true;
9
+ } else {
10
+ return effect();
11
+ }
12
+ return undefined;
13
+ }, deps);
14
+ };
15
+
16
+ export default useUpdateEffect;
package/src/index.tsx CHANGED
@@ -111,12 +111,14 @@ import './renderers/Form/InputColor';
111
111
  import './renderers/Form/ChainedSelect';
112
112
  import './renderers/Form/NestedSelect';
113
113
  import './renderers/Form/Transfer';
114
+ import './renderers/Form/TransferPicker';
114
115
  import './renderers/Form/InputTable';
115
116
  import './renderers/Form/Picker';
116
117
  import './renderers/Form/IconPicker';
117
118
  import './renderers/Form/Formula';
118
119
  import './renderers/Form/FieldSet';
119
120
  import './renderers/Form/TabsTransfer';
121
+ import './renderers/Form/TabsTransferPicker';
120
122
  import './renderers/Form/Group';
121
123
  import './renderers/Form/InputGroup';
122
124
  import './renderers/Grid';
@@ -133,6 +135,7 @@ import './renderers/PaginationWrapper';
133
135
  import './renderers/Panel';
134
136
  import './renderers/Plain';
135
137
  import './renderers/Property';
138
+ import './renderers/Portlet';
136
139
  import './renderers/Spinner';
137
140
  import './renderers/Table/index';
138
141
  import './renderers/Tabs';
@@ -181,6 +181,7 @@ register('de-DE', {
181
181
  'Transfer.configError': 'Konfigurationsfehler',
182
182
  'Transfer.refreshIcon': 'Zum Aktualisieren klicken',
183
183
  'Transfer.searchKeyword': 'Stichwörter eingeben',
184
+ 'Transfer.available': 'Verfügbar',
184
185
  'Transfer.selectd': 'Ausgewählt',
185
186
  'Transfer.selectFromLeft': 'Von links auswählen',
186
187
  'Tree.addChild': 'Untergeordnetes Element hinzufügen',
@@ -222,6 +223,7 @@ register('de-DE', {
222
223
  'Wizard.saveAndNext': 'Speichern & Weiter',
223
224
  'year-to-year': '{{from}} - {{to}}',
224
225
  'Year.placeholder': 'Wählen Sie ein Jahr',
226
+ 'reload': 'Neu laden',
225
227
  'rotate': 'Drehen',
226
228
  'Editor.fullscreen': 'Schirmfüllend Modus',
227
229
  'Editor.exitFullscreen': 'Zurücktreten Schirmfüllend Modus',
@@ -182,6 +182,7 @@ register('en-US', {
182
182
  'Transfer.configError': 'Config error',
183
183
  'Transfer.refreshIcon': 'Click to refresh',
184
184
  'Transfer.searchKeyword': 'Enter keywords',
185
+ 'Transfer.available': 'Available',
185
186
  'Transfer.selectd': 'Selected',
186
187
  'Transfer.selectFromLeft': 'Select from the left',
187
188
  'Tree.addChild': 'Add child',
@@ -223,6 +224,7 @@ register('en-US', {
223
224
  'Wizard.saveAndNext': 'Save & Next',
224
225
  'year-to-year': '{{from}} - {{to}}',
225
226
  'Year.placeholder': 'Select a Year',
227
+ 'reload': 'Reload',
226
228
  'rotate': 'Rotate',
227
229
  'Editor.fullscreen': 'full screen',
228
230
  'Editor.exitFullscreen': 'exit fullscreen mode',
@@ -186,8 +186,9 @@ register('zh-CN', {
186
186
  'Transfer.configError': '配置错误,选项无法与左侧选项对应',
187
187
  'Transfer.refreshIcon': '点击刷新重新加载',
188
188
  'Transfer.searchKeyword': '请输入关键字',
189
- 'Transfer.selectd': '当前选择',
190
- 'Transfer.selectFromLeft': '请从左侧选择数据',
189
+ 'Transfer.available': '可选项',
190
+ 'Transfer.selectd': '已选项',
191
+ 'Transfer.selectFromLeft': '请选择左侧数据',
191
192
  'Tree.addChild': '添加子节点',
192
193
  'Tree.addRoot': '添加一级节点',
193
194
  'Tree.editNode': '编辑该节点',
@@ -227,6 +228,7 @@ register('zh-CN', {
227
228
  'Wizard.saveAndNext': '保存并下一步',
228
229
  'year-to-year': '{{from}} 年 - {{to}} 年',
229
230
  'Year.placeholder': '请选择年',
231
+ 'reload': '刷新',
230
232
  'rotate': '旋转',
231
233
  'Editor.fullscreen': '全屏',
232
234
  'Editor.exitFullscreen': '退出全屏',