amis-editor 5.2.0-beta.1 → 5.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (563) hide show
  1. package/dist/6dbcbb49b6fd405190a9.png +0 -0
  2. package/dist/cebfe0bc5a1dbde02da1.svg +10 -0
  3. package/dist/compat.d.ts +30 -0
  4. package/dist/component/Breadcrumb.d.ts +33 -0
  5. package/dist/component/ClassNameControl.d.ts +31 -0
  6. package/dist/component/CommonConfigWrapper.d.ts +6 -0
  7. package/dist/component/ContainerWrapper.d.ts +12 -0
  8. package/dist/component/Editor.d.ts +97 -0
  9. package/dist/component/HighlightBox.d.ts +29 -0
  10. package/dist/component/IFrameBridge.d.ts +32 -0
  11. package/dist/component/IFramePreview.d.ts +38 -0
  12. package/dist/component/MiniEditor.d.ts +9 -0
  13. package/dist/component/NodeWrapper.d.ts +20 -0
  14. package/dist/component/Panel/AMisCodeEditor.d.ts +37 -0
  15. package/dist/component/Panel/AvailableRenderersPanel.d.ts +10 -0
  16. package/dist/component/Panel/CodeEditorPanel.d.ts +6 -0
  17. package/dist/component/Panel/ContextMenuPanel.d.ts +8 -0
  18. package/dist/component/Panel/DrawerPanel.d.ts +15 -0
  19. package/dist/component/Panel/DrawerRendererPanel.d.ts +15 -0
  20. package/dist/component/Panel/InsertSubRendererPanel.d.ts +11 -0
  21. package/dist/component/Panel/LeftPanels.d.ts +20 -0
  22. package/dist/component/Panel/Outline.d.ts +18 -0
  23. package/dist/component/Panel/RenderersPanel.d.ts +31 -0
  24. package/dist/component/Panel/RightPanels.d.ts +21 -0
  25. package/dist/component/Panel/TargetNamePanel.d.ts +7 -0
  26. package/dist/component/PopOverForm.d.ts +22 -0
  27. package/dist/component/Preview.d.ts +67 -0
  28. package/dist/component/RegionHLBox.d.ts +20 -0
  29. package/dist/component/RegionWrapper.d.ts +206 -0
  30. package/dist/component/RendererThumb.d.ts +22 -0
  31. package/dist/component/ScaffoldModal.d.ts +24 -0
  32. package/dist/component/SubEditor.d.ts +67 -0
  33. package/{lib → dist}/component/TableViewEditor.d.ts +2 -2
  34. package/dist/component/VRenderer.d.ts +191 -0
  35. package/dist/component/base/BackTop.d.ts +26 -0
  36. package/dist/component/base/ErrorRenderer.d.ts +4 -0
  37. package/{lib/component → dist/component/base}/InputComponentName.d.ts +0 -0
  38. package/dist/component/base/SearchCustomRendererPanel.d.ts +15 -0
  39. package/dist/component/base/SearchPanel.d.ts +83 -0
  40. package/dist/component/base/SearchRendererPanel.d.ts +19 -0
  41. package/dist/component/base/ShortcutKey.d.ts +23 -0
  42. package/dist/component/base/WidthDraggableBtn.d.ts +16 -0
  43. package/dist/component/base/WidthDraggableContainer.d.ts +2 -0
  44. package/dist/component/control/APIControl.d.ts +1158 -0
  45. package/dist/component/control/ActionAPIControl.d.ts +1158 -0
  46. package/{lib/renderer → dist/component/control}/BadgeControl.d.ts +12 -13
  47. package/dist/component/control/BaseControl.d.ts +248 -0
  48. package/{lib/renderer → dist/component/control}/DataBindingControl.d.ts +0 -0
  49. package/{lib/renderer → dist/component/control}/DataPickerControl.d.ts +1 -1
  50. package/{lib/renderer → dist/component/control}/DateShortCutControl.d.ts +1 -1
  51. package/dist/component/control/FormulaControl.d.ts +51 -0
  52. package/{lib/renderer → dist/component/control}/OptionControl.d.ts +0 -0
  53. package/{lib/renderer → dist/component/control}/PopoverEdit.d.ts +1 -1
  54. package/{lib/renderer → dist/component/control}/StatusControl.d.ts +0 -0
  55. package/{lib/renderer → dist/component/control}/SwitchMoreControl.d.ts +70 -68
  56. package/{lib/renderer → dist/component/control}/ValidationControl.d.ts +0 -0
  57. package/{lib/renderer → dist/component/control}/ValidationItem.d.ts +0 -0
  58. package/{lib/renderer → dist/component/control}/style-control/Background.d.ts +0 -0
  59. package/{lib/renderer → dist/component/control}/style-control/Border.d.ts +0 -0
  60. package/{lib/renderer → dist/component/control}/style-control/BoxModel.d.ts +0 -0
  61. package/{lib/renderer → dist/component/control}/style-control/BoxShadow.d.ts +0 -0
  62. package/{lib/renderer → dist/component/control}/style-control/Display.d.ts +0 -0
  63. package/{lib/renderer → dist/component/control}/style-control/Font.d.ts +0 -0
  64. package/{lib/renderer → dist/component/control}/style-control/font-family.d.ts +0 -0
  65. package/{lib/renderer → dist/component/control}/style-control/transformation.d.ts +0 -0
  66. package/{lib/renderer → dist/component/control}/style-control/types.d.ts +0 -0
  67. package/dist/component/schemaTpl.d.ts +27 -0
  68. package/{lib → dist/component}/validator.d.ts +0 -0
  69. package/dist/dnd/default.d.ts +47 -0
  70. package/dist/dnd/index.d.ts +119 -0
  71. package/dist/dnd/interface.d.ts +14 -0
  72. package/dist/dnd/position-h.d.ts +7 -0
  73. package/dist/env.d.ts +5 -0
  74. package/dist/event-action/action-config-panel.d.ts +8 -0
  75. package/dist/event-action/actions.d.ts +3 -0
  76. package/dist/event-action/comp-action-select.d.ts +11 -0
  77. package/dist/event-action/config.d.ts +13 -0
  78. package/dist/event-action/index.d.ts +459 -0
  79. package/dist/event-action/schema.d.ts +32 -0
  80. package/dist/exports.d.ts +8 -0
  81. package/dist/exports.min.js +1 -0
  82. package/dist/icons/index.d.ts +2 -0
  83. package/{lib → dist}/index.d.ts +50 -24
  84. package/dist/index.min.js +1 -0
  85. package/dist/manager.d.ts +502 -0
  86. package/dist/mocker.d.ts +1 -0
  87. package/{lib → dist}/plugin/Alert.d.ts +1 -1
  88. package/dist/plugin/AnchorNav.d.ts +67 -0
  89. package/{lib → dist}/plugin/Audio.d.ts +1 -1
  90. package/dist/plugin/Avatar.d.ts +18 -0
  91. package/{lib → dist}/plugin/Breadcrumb.d.ts +1 -1
  92. package/{lib → dist}/plugin/Button.d.ts +2 -2
  93. package/{lib → dist}/plugin/ButtonGroup.d.ts +2 -2
  94. package/{lib → dist}/plugin/ButtonToolbar.d.ts +1 -1
  95. package/{lib → dist}/plugin/CRUD.d.ts +2 -2
  96. package/{lib → dist}/plugin/Card.d.ts +1 -1
  97. package/{lib → dist}/plugin/Cards.d.ts +1 -1
  98. package/{lib → dist}/plugin/Carousel.d.ts +1 -1
  99. package/{lib → dist}/plugin/Chart.d.ts +2 -2
  100. package/{lib → dist}/plugin/CodeView.d.ts +1 -1
  101. package/{lib → dist}/plugin/Collapse.d.ts +1 -1
  102. package/{lib → dist}/plugin/CollapseGroup.d.ts +1 -1
  103. package/{lib → dist}/plugin/Container.d.ts +1 -1
  104. package/{lib → dist}/plugin/Custom.d.ts +1 -1
  105. package/{lib → dist}/plugin/CustomRegion.d.ts +1 -1
  106. package/{lib → dist}/plugin/Date.d.ts +1 -1
  107. package/{lib → dist}/plugin/Datetime.d.ts +1 -1
  108. package/{lib → dist}/plugin/Dialog.d.ts +1 -1
  109. package/{lib → dist}/plugin/Divider.d.ts +1 -1
  110. package/{lib → dist}/plugin/Drawer.d.ts +1 -1
  111. package/{lib → dist}/plugin/DropDownButton.d.ts +2 -3
  112. package/{lib → dist}/plugin/Each.d.ts +1 -1
  113. package/dist/plugin/ErrorRenderer.d.ts +7 -0
  114. package/{lib → dist}/plugin/Flex.d.ts +1 -1
  115. package/{lib → dist}/plugin/Form/ButtonGroupSelect.d.ts +2 -2
  116. package/{lib → dist}/plugin/Form/ButtonToolbar.d.ts +1 -1
  117. package/{lib → dist}/plugin/Form/ChainedSelect.d.ts +3 -6
  118. package/{lib → dist}/plugin/Form/Checkbox.d.ts +2 -2
  119. package/{lib → dist}/plugin/Form/Checkboxes.d.ts +2 -2
  120. package/{lib → dist}/plugin/Form/CodeEditor.d.ts +3 -3
  121. package/{lib → dist}/plugin/Form/Combo.d.ts +2 -2
  122. package/{lib → dist}/plugin/Form/ConditionBuilder.d.ts +1 -1
  123. package/{lib → dist}/plugin/Form/Control.d.ts +1 -1
  124. package/{lib → dist}/plugin/Form/DiffEditor.d.ts +3 -3
  125. package/{lib → dist}/plugin/Form/FieldSet.d.ts +1 -1
  126. package/{lib → dist}/plugin/Form/Form.d.ts +3 -3
  127. package/{lib → dist}/plugin/Form/Formula.d.ts +1 -1
  128. package/{lib → dist}/plugin/Form/Group.d.ts +1 -1
  129. package/{lib → dist}/plugin/Form/Hidden.d.ts +1 -1
  130. package/{lib → dist}/plugin/Form/InputArray.d.ts +1 -1
  131. package/dist/plugin/Form/InputCity.d.ts +19 -0
  132. package/{lib → dist}/plugin/Form/InputColor.d.ts +18 -20
  133. package/{lib → dist}/plugin/Form/InputDate.d.ts +2 -2
  134. package/{lib → dist}/plugin/Form/InputDateRange.d.ts +2 -2
  135. package/{lib → dist}/plugin/Form/InputDateTime.d.ts +0 -0
  136. package/{lib → dist}/plugin/Form/InputDateTimeRange.d.ts +0 -0
  137. package/{lib → dist}/plugin/Form/InputEmail.d.ts +0 -0
  138. package/{lib → dist}/plugin/Form/InputExcel.d.ts +2 -2
  139. package/{lib → dist}/plugin/Form/InputFile.d.ts +2 -2
  140. package/{lib → dist}/plugin/Form/InputGroup.d.ts +1 -1
  141. package/dist/plugin/Form/InputImage.d.ts +20 -0
  142. package/{lib → dist}/plugin/Form/InputKV.d.ts +2 -2
  143. package/{lib → dist}/plugin/Form/InputMonth.d.ts +0 -0
  144. package/{lib → dist}/plugin/Form/InputMonthRange.d.ts +0 -0
  145. package/dist/plugin/Form/InputNumber.d.ts +20 -0
  146. package/{lib → dist}/plugin/Form/InputPassword.d.ts +0 -0
  147. package/{lib → dist}/plugin/Form/InputQuarter.d.ts +0 -0
  148. package/{lib → dist}/plugin/Form/InputQuarterRange.d.ts +0 -0
  149. package/{lib → dist}/plugin/Form/InputRange.d.ts +3 -5
  150. package/{lib → dist}/plugin/Form/InputRating.d.ts +2 -2
  151. package/{lib → dist}/plugin/Form/InputRepeat.d.ts +1 -1
  152. package/{lib → dist}/plugin/Form/InputRichText.d.ts +1 -1
  153. package/{lib → dist}/plugin/Form/InputSubForm.d.ts +1 -2
  154. package/{lib → dist}/plugin/Form/InputTable.d.ts +1 -1
  155. package/dist/plugin/Form/InputTag.d.ts +21 -0
  156. package/{lib → dist}/plugin/Form/InputText.d.ts +1 -1
  157. package/{lib → dist}/plugin/Form/InputTime.d.ts +0 -0
  158. package/{lib → dist}/plugin/Form/InputTimeRange.d.ts +0 -0
  159. package/{lib → dist}/plugin/Form/InputTree.d.ts +2 -2
  160. package/{lib → dist}/plugin/Form/InputURL.d.ts +0 -0
  161. package/{lib → dist}/plugin/Form/InputYear.d.ts +0 -0
  162. package/{lib → dist}/plugin/Form/InputYearRange.d.ts +0 -0
  163. package/{lib → dist}/plugin/Form/Item.d.ts +2 -2
  164. package/{lib → dist}/plugin/Form/ListSelect.d.ts +2 -2
  165. package/{lib → dist}/plugin/Form/LocationPicker.d.ts +2 -3
  166. package/{lib → dist}/plugin/Form/MatrixCheckboxes.d.ts +2 -7
  167. package/{lib → dist}/plugin/Form/NestedSelect.d.ts +2 -5
  168. package/{lib → dist}/plugin/Form/Picker.d.ts +1 -1
  169. package/{lib → dist}/plugin/Form/Radios.d.ts +2 -2
  170. package/{lib → dist}/plugin/Form/Select.d.ts +2 -2
  171. package/{lib → dist}/plugin/Form/Static.d.ts +3 -4
  172. package/{lib → dist}/plugin/Form/Switch.d.ts +2 -2
  173. package/{lib → dist}/plugin/Form/TabsTransfer.d.ts +2 -2
  174. package/{lib → dist}/plugin/Form/Textarea.d.ts +3 -3
  175. package/{lib → dist}/plugin/Form/Transfer.d.ts +2 -2
  176. package/{lib → dist}/plugin/Form/TreeSelect.d.ts +2 -2
  177. package/{lib → dist}/plugin/Form/UUID.d.ts +1 -1
  178. package/{lib → dist}/plugin/Grid.d.ts +2 -2
  179. package/{lib → dist}/plugin/HBox.d.ts +2 -2
  180. package/{lib → dist}/plugin/IFrame.d.ts +2 -3
  181. package/{lib → dist}/plugin/Image.d.ts +1 -1
  182. package/{lib → dist}/plugin/Images.d.ts +1 -1
  183. package/{lib → dist}/plugin/Json.d.ts +1 -1
  184. package/{lib → dist}/plugin/Link.d.ts +1 -2
  185. package/{lib → dist}/plugin/List.d.ts +1 -1
  186. package/{lib → dist}/plugin/ListItem.d.ts +1 -1
  187. package/{lib → dist}/plugin/Log.d.ts +1 -1
  188. package/{lib → dist}/plugin/Mapping.d.ts +1 -1
  189. package/{lib → dist}/plugin/Markdown.d.ts +1 -1
  190. package/{lib → dist}/plugin/Nav.d.ts +1 -1
  191. package/{lib → dist}/plugin/Operation.d.ts +1 -1
  192. package/{lib → dist}/plugin/Others/Action.d.ts +1 -1
  193. package/dist/plugin/Others/BasicToolbar.d.ts +11 -0
  194. package/dist/plugin/Others/DataDebug.d.ts +19 -0
  195. package/{lib → dist}/plugin/Others/TableCell.d.ts +1 -1
  196. package/dist/plugin/Others/Unknown.d.ts +5 -0
  197. package/{lib → dist}/plugin/Page.d.ts +3 -3
  198. package/dist/plugin/Panel/AvailableRenderers.d.ts +8 -0
  199. package/dist/plugin/Panel/Code.d.ts +9 -0
  200. package/dist/plugin/Panel/Name.d.ts +8 -0
  201. package/dist/plugin/Panel/Outline.d.ts +8 -0
  202. package/{lib → dist}/plugin/Panel.d.ts +1 -1
  203. package/{lib → dist}/plugin/Plain.d.ts +1 -1
  204. package/{lib → dist}/plugin/Progress.d.ts +1 -1
  205. package/{lib → dist}/plugin/Property.d.ts +1 -1
  206. package/{lib → dist}/plugin/QRCode.d.ts +1 -1
  207. package/{lib → dist}/plugin/Reset.d.ts +0 -0
  208. package/{lib → dist}/plugin/Service.d.ts +1 -4
  209. package/{lib → dist}/plugin/Sparkline.d.ts +1 -1
  210. package/{lib → dist}/plugin/Status.d.ts +1 -1
  211. package/{lib → dist}/plugin/Steps.d.ts +1 -1
  212. package/{lib → dist}/plugin/Submit.d.ts +0 -0
  213. package/{lib → dist}/plugin/Table.d.ts +2 -5
  214. package/{lib → dist}/plugin/TableView.d.ts +1 -1
  215. package/{lib → dist}/plugin/Tabs.d.ts +1 -2
  216. package/{lib → dist}/plugin/Tasks.d.ts +1 -1
  217. package/{lib → dist}/plugin/Time.d.ts +1 -1
  218. package/{lib → dist}/plugin/TooltipWrapper.d.ts +1 -1
  219. package/{lib → dist}/plugin/Tpl.d.ts +1 -1
  220. package/{lib → dist}/plugin/Video.d.ts +1 -1
  221. package/{lib → dist}/plugin/WebComponent.d.ts +1 -1
  222. package/{lib → dist}/plugin/Wizard.d.ts +2 -2
  223. package/{lib → dist}/plugin/Wrapper.d.ts +1 -1
  224. package/dist/plugin.d.ts +637 -0
  225. package/dist/store/editor.d.ts +1048 -0
  226. package/dist/store/node.d.ts +281 -0
  227. package/dist/style.css +1 -0
  228. package/dist/util.d.ts +105 -0
  229. package/package.json +32 -31
  230. package/src/component/schemaTpl.tsx +2881 -0
  231. package/src/plugin/Alert.tsx +108 -0
  232. package/src/plugin/AnchorNav.tsx +234 -0
  233. package/src/plugin/Audio.tsx +148 -0
  234. package/src/plugin/Avatar.tsx +78 -0
  235. package/src/plugin/Breadcrumb.tsx +108 -0
  236. package/src/plugin/Button.tsx +350 -0
  237. package/src/plugin/ButtonGroup.tsx +146 -0
  238. package/src/plugin/ButtonToolbar.tsx +81 -0
  239. package/src/plugin/CRUD.tsx +1777 -0
  240. package/src/plugin/Card.tsx +291 -0
  241. package/src/plugin/Cards.tsx +312 -0
  242. package/src/plugin/Carousel.tsx +377 -0
  243. package/src/plugin/Chart.tsx +230 -0
  244. package/src/plugin/CodeView.tsx +60 -0
  245. package/src/plugin/Collapse.tsx +136 -0
  246. package/src/plugin/CollapseGroup.tsx +249 -0
  247. package/src/plugin/Container.tsx +93 -0
  248. package/src/plugin/Custom.tsx +122 -0
  249. package/src/plugin/CustomRegion.tsx +157 -0
  250. package/src/plugin/Date.tsx +74 -0
  251. package/src/plugin/Datetime.tsx +68 -0
  252. package/src/plugin/Dialog.tsx +207 -0
  253. package/src/plugin/Divider.tsx +36 -0
  254. package/src/plugin/Drawer.tsx +244 -0
  255. package/src/plugin/DropDownButton.tsx +251 -0
  256. package/src/plugin/Each.tsx +150 -0
  257. package/src/plugin/ErrorRenderer.tsx +15 -0
  258. package/src/plugin/Flex.tsx +209 -0
  259. package/src/plugin/Form/ButtonGroupSelect.tsx +163 -0
  260. package/src/plugin/Form/ButtonToolbar.tsx +117 -0
  261. package/src/plugin/Form/ChainedSelect.tsx +115 -0
  262. package/src/plugin/Form/Checkbox.tsx +176 -0
  263. package/src/plugin/Form/Checkboxes.tsx +234 -0
  264. package/src/plugin/Form/CodeEditor.tsx +210 -0
  265. package/src/plugin/Form/Combo.tsx +621 -0
  266. package/src/plugin/Form/ConditionBuilder.tsx +315 -0
  267. package/src/plugin/Form/Control.tsx +85 -0
  268. package/src/plugin/Form/DiffEditor.tsx +215 -0
  269. package/src/plugin/Form/FieldSet.tsx +158 -0
  270. package/src/plugin/Form/Form.tsx +894 -0
  271. package/src/plugin/Form/Formula.tsx +73 -0
  272. package/src/plugin/Form/Group.tsx +295 -0
  273. package/src/plugin/Form/Hidden.tsx +44 -0
  274. package/src/plugin/Form/InputArray.tsx +219 -0
  275. package/src/plugin/Form/InputCity.tsx +93 -0
  276. package/src/plugin/Form/InputColor.tsx +123 -0
  277. package/src/plugin/Form/InputDate.tsx +398 -0
  278. package/src/plugin/Form/InputDateRange.tsx +367 -0
  279. package/src/plugin/Form/InputDateTime.tsx +39 -0
  280. package/src/plugin/Form/InputDateTimeRange.tsx +41 -0
  281. package/src/plugin/Form/InputEmail.tsx +34 -0
  282. package/src/plugin/Form/InputExcel.tsx +128 -0
  283. package/src/plugin/Form/InputFile.tsx +395 -0
  284. package/src/plugin/Form/InputGroup.tsx +96 -0
  285. package/src/plugin/Form/InputImage.tsx +266 -0
  286. package/src/plugin/Form/InputKV.tsx +133 -0
  287. package/src/plugin/Form/InputMonth.tsx +37 -0
  288. package/src/plugin/Form/InputMonthRange.tsx +41 -0
  289. package/src/plugin/Form/InputNumber.tsx +89 -0
  290. package/src/plugin/Form/InputPassword.tsx +35 -0
  291. package/src/plugin/Form/InputQuarter.tsx +37 -0
  292. package/src/plugin/Form/InputQuarterRange.tsx +41 -0
  293. package/src/plugin/Form/InputRange.tsx +191 -0
  294. package/src/plugin/Form/InputRating.tsx +390 -0
  295. package/src/plugin/Form/InputRepeat.tsx +57 -0
  296. package/src/plugin/Form/InputRichText.tsx +185 -0
  297. package/src/plugin/Form/InputSubForm.tsx +189 -0
  298. package/src/plugin/Form/InputTable.tsx +418 -0
  299. package/src/plugin/Form/InputTag.tsx +70 -0
  300. package/src/plugin/Form/InputText.tsx +364 -0
  301. package/src/plugin/Form/InputTime.tsx +36 -0
  302. package/src/plugin/Form/InputTimeRange.tsx +41 -0
  303. package/src/plugin/Form/InputTree.tsx +379 -0
  304. package/src/plugin/Form/InputURL.tsx +36 -0
  305. package/src/plugin/Form/InputYear.tsx +37 -0
  306. package/src/plugin/Form/InputYearRange.tsx +41 -0
  307. package/src/plugin/Form/Item.tsx +326 -0
  308. package/src/plugin/Form/ListSelect.tsx +128 -0
  309. package/src/plugin/Form/LocationPicker.tsx +57 -0
  310. package/src/plugin/Form/MatrixCheckboxes.tsx +136 -0
  311. package/src/plugin/Form/NestedSelect.tsx +278 -0
  312. package/src/plugin/Form/Picker.tsx +206 -0
  313. package/src/plugin/Form/Radios.tsx +189 -0
  314. package/src/plugin/Form/Select.tsx +304 -0
  315. package/src/plugin/Form/Static.tsx +322 -0
  316. package/src/plugin/Form/Switch.tsx +219 -0
  317. package/src/plugin/Form/TabsTransfer.tsx +355 -0
  318. package/src/plugin/Form/Textarea.tsx +193 -0
  319. package/src/plugin/Form/Transfer.tsx +430 -0
  320. package/src/plugin/Form/TreeSelect.tsx +404 -0
  321. package/src/plugin/Form/UUID.tsx +48 -0
  322. package/src/plugin/Grid.tsx +826 -0
  323. package/src/plugin/HBox.tsx +728 -0
  324. package/src/plugin/IFrame.tsx +79 -0
  325. package/src/plugin/Image.tsx +309 -0
  326. package/src/plugin/Images.tsx +226 -0
  327. package/src/plugin/Json.tsx +69 -0
  328. package/src/plugin/Link.tsx +87 -0
  329. package/src/plugin/List.tsx +274 -0
  330. package/src/plugin/ListItem.tsx +230 -0
  331. package/src/plugin/Log.tsx +52 -0
  332. package/src/plugin/Mapping.tsx +149 -0
  333. package/src/plugin/Markdown.tsx +47 -0
  334. package/src/plugin/Nav.tsx +182 -0
  335. package/src/plugin/Operation.tsx +95 -0
  336. package/src/plugin/Others/Action.tsx +432 -0
  337. package/src/plugin/Others/BasicToolbar.tsx +588 -0
  338. package/src/plugin/Others/DataDebug.tsx +134 -0
  339. package/src/plugin/Others/TableCell.tsx +460 -0
  340. package/src/plugin/Others/Unknown.tsx +37 -0
  341. package/src/plugin/Page.tsx +392 -0
  342. package/src/plugin/Panel/AvailableRenderers.tsx +41 -0
  343. package/src/plugin/Panel/Code.tsx +44 -0
  344. package/src/plugin/Panel/Name.tsx +26 -0
  345. package/src/plugin/Panel/Outline.tsx +40 -0
  346. package/src/plugin/Panel.tsx +242 -0
  347. package/src/plugin/Plain.tsx +81 -0
  348. package/src/plugin/Progress.tsx +265 -0
  349. package/src/plugin/Property.tsx +139 -0
  350. package/src/plugin/QRCode.tsx +96 -0
  351. package/src/plugin/Reset.tsx +23 -0
  352. package/src/plugin/Service.tsx +166 -0
  353. package/src/plugin/Sparkline.tsx +40 -0
  354. package/src/plugin/Status.tsx +76 -0
  355. package/src/plugin/Steps.tsx +128 -0
  356. package/src/plugin/Submit.tsx +23 -0
  357. package/src/plugin/Table.tsx +457 -0
  358. package/src/plugin/TableView.tsx +815 -0
  359. package/src/plugin/Tabs.tsx +522 -0
  360. package/src/plugin/Tasks.tsx +274 -0
  361. package/src/plugin/Time.tsx +68 -0
  362. package/src/plugin/TooltipWrapper.tsx +289 -0
  363. package/src/plugin/Tpl.tsx +174 -0
  364. package/src/plugin/Video.tsx +147 -0
  365. package/src/plugin/WebComponent.tsx +53 -0
  366. package/src/plugin/Wizard.tsx +941 -0
  367. package/src/plugin/Wrapper.tsx +128 -0
  368. package/src/plugin.ts +1112 -0
  369. package/static/Code-hover.png +0 -0
  370. package/static/Code.png +0 -0
  371. package/static/Outline-hover.png +0 -0
  372. package/static/Outline.png +0 -0
  373. package/static/Renderers-hover.png +0 -0
  374. package/static/Renderers.png +0 -0
  375. package/static/empty.png +0 -0
  376. package/static/side_hide_left.svg +10 -0
  377. package/lib/component/BaseControl.d.ts +0 -1831
  378. package/lib/component/BaseControl.js +0 -366
  379. package/lib/component/InputComponentName.js +0 -44
  380. package/lib/component/TableViewEditor.js +0 -528
  381. package/lib/event-action/actions.d.ts +0 -3
  382. package/lib/event-action/actions.js +0 -188
  383. package/lib/event-action/schema.d.ts +0 -13
  384. package/lib/event-action/schema.js +0 -134
  385. package/lib/index.js +0 -181
  386. package/lib/plugin/Alert.js +0 -113
  387. package/lib/plugin/AnchorNav.d.ts +0 -48
  388. package/lib/plugin/AnchorNav.js +0 -297
  389. package/lib/plugin/Audio.js +0 -157
  390. package/lib/plugin/Avatar.d.ts +0 -27
  391. package/lib/plugin/Avatar.js +0 -305
  392. package/lib/plugin/Breadcrumb.js +0 -116
  393. package/lib/plugin/Button.js +0 -297
  394. package/lib/plugin/ButtonGroup.js +0 -139
  395. package/lib/plugin/ButtonToolbar.js +0 -89
  396. package/lib/plugin/CRUD.js +0 -1528
  397. package/lib/plugin/Card.js +0 -233
  398. package/lib/plugin/Cards.js +0 -254
  399. package/lib/plugin/Carousel.js +0 -358
  400. package/lib/plugin/Chart.js +0 -192
  401. package/lib/plugin/CodeView.js +0 -68
  402. package/lib/plugin/Collapse.js +0 -138
  403. package/lib/plugin/CollapseGroup.js +0 -237
  404. package/lib/plugin/Container.js +0 -100
  405. package/lib/plugin/Custom.js +0 -109
  406. package/lib/plugin/CustomRegion.js +0 -154
  407. package/lib/plugin/Date.js +0 -82
  408. package/lib/plugin/Datetime.js +0 -77
  409. package/lib/plugin/Dialog.js +0 -214
  410. package/lib/plugin/Divider.js +0 -49
  411. package/lib/plugin/Drawer.js +0 -240
  412. package/lib/plugin/DropDownButton.js +0 -229
  413. package/lib/plugin/Each.js +0 -131
  414. package/lib/plugin/Flex.js +0 -203
  415. package/lib/plugin/Form/ButtonGroupSelect.js +0 -161
  416. package/lib/plugin/Form/ButtonToolbar.js +0 -107
  417. package/lib/plugin/Form/ChainedSelect.js +0 -183
  418. package/lib/plugin/Form/Checkbox.js +0 -174
  419. package/lib/plugin/Form/Checkboxes.js +0 -213
  420. package/lib/plugin/Form/CodeEditor.js +0 -201
  421. package/lib/plugin/Form/Combo.js +0 -546
  422. package/lib/plugin/Form/ConditionBuilder.js +0 -302
  423. package/lib/plugin/Form/Control.js +0 -88
  424. package/lib/plugin/Form/DiffEditor.js +0 -204
  425. package/lib/plugin/Form/FieldSet.js +0 -152
  426. package/lib/plugin/Form/Form.js +0 -846
  427. package/lib/plugin/Form/Formula.js +0 -82
  428. package/lib/plugin/Form/Group.js +0 -252
  429. package/lib/plugin/Form/Hidden.js +0 -58
  430. package/lib/plugin/Form/InputArray.js +0 -181
  431. package/lib/plugin/Form/InputCity.d.ts +0 -23
  432. package/lib/plugin/Form/InputCity.js +0 -139
  433. package/lib/plugin/Form/InputColor.js +0 -295
  434. package/lib/plugin/Form/InputDate.js +0 -357
  435. package/lib/plugin/Form/InputDateRange.js +0 -350
  436. package/lib/plugin/Form/InputDateTime.js +0 -50
  437. package/lib/plugin/Form/InputDateTimeRange.js +0 -51
  438. package/lib/plugin/Form/InputEmail.js +0 -45
  439. package/lib/plugin/Form/InputExcel.js +0 -121
  440. package/lib/plugin/Form/InputFile.js +0 -354
  441. package/lib/plugin/Form/InputGroup.js +0 -100
  442. package/lib/plugin/Form/InputImage.d.ts +0 -24
  443. package/lib/plugin/Form/InputImage.js +0 -271
  444. package/lib/plugin/Form/InputKV.js +0 -129
  445. package/lib/plugin/Form/InputMonth.js +0 -48
  446. package/lib/plugin/Form/InputMonthRange.js +0 -51
  447. package/lib/plugin/Form/InputNumber.d.ts +0 -25
  448. package/lib/plugin/Form/InputNumber.js +0 -263
  449. package/lib/plugin/Form/InputPassword.js +0 -45
  450. package/lib/plugin/Form/InputQuarter.js +0 -48
  451. package/lib/plugin/Form/InputQuarterRange.js +0 -51
  452. package/lib/plugin/Form/InputRange.js +0 -292
  453. package/lib/plugin/Form/InputRating.js +0 -357
  454. package/lib/plugin/Form/InputRepeat.js +0 -65
  455. package/lib/plugin/Form/InputRichText.js +0 -193
  456. package/lib/plugin/Form/InputSubForm.js +0 -160
  457. package/lib/plugin/Form/InputTable.js +0 -400
  458. package/lib/plugin/Form/InputTag.d.ts +0 -25
  459. package/lib/plugin/Form/InputTag.js +0 -155
  460. package/lib/plugin/Form/InputText.js +0 -328
  461. package/lib/plugin/Form/InputTime.js +0 -48
  462. package/lib/plugin/Form/InputTimeRange.js +0 -51
  463. package/lib/plugin/Form/InputTree.js +0 -375
  464. package/lib/plugin/Form/InputURL.js +0 -46
  465. package/lib/plugin/Form/InputYear.js +0 -48
  466. package/lib/plugin/Form/InputYearRange.js +0 -51
  467. package/lib/plugin/Form/Item.js +0 -265
  468. package/lib/plugin/Form/ListSelect.js +0 -130
  469. package/lib/plugin/Form/LocationPicker.js +0 -74
  470. package/lib/plugin/Form/MatrixCheckboxes.js +0 -234
  471. package/lib/plugin/Form/NestedSelect.js +0 -328
  472. package/lib/plugin/Form/Picker.js +0 -169
  473. package/lib/plugin/Form/Radios.js +0 -189
  474. package/lib/plugin/Form/Select.js +0 -304
  475. package/lib/plugin/Form/Static.js +0 -312
  476. package/lib/plugin/Form/Switch.js +0 -219
  477. package/lib/plugin/Form/TabsTransfer.js +0 -348
  478. package/lib/plugin/Form/Textarea.js +0 -190
  479. package/lib/plugin/Form/Transfer.js +0 -414
  480. package/lib/plugin/Form/TreeSelect.js +0 -375
  481. package/lib/plugin/Form/UUID.js +0 -55
  482. package/lib/plugin/Grid.js +0 -680
  483. package/lib/plugin/HBox.js +0 -594
  484. package/lib/plugin/IFrame.js +0 -94
  485. package/lib/plugin/Image.js +0 -264
  486. package/lib/plugin/Images.js +0 -214
  487. package/lib/plugin/Json.js +0 -82
  488. package/lib/plugin/Link.js +0 -120
  489. package/lib/plugin/List.js +0 -220
  490. package/lib/plugin/ListItem.js +0 -195
  491. package/lib/plugin/Log.js +0 -62
  492. package/lib/plugin/Mapping.js +0 -149
  493. package/lib/plugin/Markdown.js +0 -58
  494. package/lib/plugin/Nav.js +0 -181
  495. package/lib/plugin/Operation.js +0 -84
  496. package/lib/plugin/Others/Action.js +0 -350
  497. package/lib/plugin/Others/TableCell.js +0 -393
  498. package/lib/plugin/Page.js +0 -363
  499. package/lib/plugin/Pagination.d.ts +0 -51
  500. package/lib/plugin/Pagination.js +0 -247
  501. package/lib/plugin/Panel.js +0 -222
  502. package/lib/plugin/Plain.js +0 -88
  503. package/lib/plugin/Progress.js +0 -258
  504. package/lib/plugin/Property.js +0 -147
  505. package/lib/plugin/QRCode.js +0 -107
  506. package/lib/plugin/Reset.js +0 -38
  507. package/lib/plugin/Service.js +0 -217
  508. package/lib/plugin/Sparkline.js +0 -50
  509. package/lib/plugin/Status.js +0 -86
  510. package/lib/plugin/Steps.js +0 -136
  511. package/lib/plugin/Submit.js +0 -38
  512. package/lib/plugin/Table.js +0 -594
  513. package/lib/plugin/TableView.js +0 -744
  514. package/lib/plugin/Tabs.js +0 -429
  515. package/lib/plugin/Tasks.js +0 -263
  516. package/lib/plugin/Time.js +0 -77
  517. package/lib/plugin/TooltipWrapper.js +0 -281
  518. package/lib/plugin/Tpl.js +0 -183
  519. package/lib/plugin/Video.js +0 -140
  520. package/lib/plugin/WebComponent.js +0 -70
  521. package/lib/plugin/Wizard.js +0 -799
  522. package/lib/plugin/Wrapper.js +0 -136
  523. package/lib/renderer/APIControl.d.ts +0 -7526
  524. package/lib/renderer/APIControl.js +0 -791
  525. package/lib/renderer/BadgeControl.js +0 -290
  526. package/lib/renderer/DataBindingControl.js +0 -91
  527. package/lib/renderer/DataMappingControl.d.ts +0 -11
  528. package/lib/renderer/DataMappingControl.js +0 -73
  529. package/lib/renderer/DataPickerControl.js +0 -83
  530. package/lib/renderer/DateShortCutControl.js +0 -254
  531. package/lib/renderer/FormulaControl.d.ts +0 -96
  532. package/lib/renderer/FormulaControl.js +0 -324
  533. package/lib/renderer/OptionControl.js +0 -672
  534. package/lib/renderer/RangePartsControl.d.ts +0 -91
  535. package/lib/renderer/RangePartsControl.js +0 -392
  536. package/lib/renderer/StatusControl.js +0 -171
  537. package/lib/renderer/SwitchMoreControl.js +0 -302
  538. package/lib/renderer/ValidationControl.js +0 -279
  539. package/lib/renderer/ValidationItem.js +0 -147
  540. package/lib/renderer/style-control/Background.js +0 -493
  541. package/lib/renderer/style-control/Border.js +0 -191
  542. package/lib/renderer/style-control/BoxModel.js +0 -73
  543. package/lib/renderer/style-control/BoxShadow.js +0 -125
  544. package/lib/renderer/style-control/Display.js +0 -233
  545. package/lib/renderer/style-control/Font.js +0 -239
  546. package/lib/renderer/style-control/font-family.js +0 -149
  547. package/lib/renderer/style-control/transformation.js +0 -84
  548. package/lib/tpl/api.d.ts +0 -1
  549. package/lib/tpl/api.js +0 -378
  550. package/lib/tpl/common.d.ts +0 -1
  551. package/lib/tpl/common.js +0 -808
  552. package/lib/tpl/horizontal.d.ts +0 -1
  553. package/lib/tpl/horizontal.js +0 -260
  554. package/lib/tpl/index.d.ts +0 -7
  555. package/lib/tpl/options.d.ts +0 -1
  556. package/lib/tpl/options.js +0 -265
  557. package/lib/tpl/style.d.ts +0 -15
  558. package/lib/tpl/style.js +0 -372
  559. package/lib/tpl/validations.d.ts +0 -1
  560. package/lib/tpl/validations.js +0 -568
  561. package/lib/util.d.ts +0 -24
  562. package/lib/util.js +0 -64
  563. package/lib/validator.js +0 -417
@@ -0,0 +1,941 @@
1
+ import {registerEditorPlugin} from '../manager';
2
+ import {
3
+ BaseEventContext,
4
+ BasePlugin,
5
+ BasicToolbarItem,
6
+ RendererInfo,
7
+ VRendererConfig
8
+ } from '../plugin';
9
+ import {defaultValue, getSchemaTpl} from '../component/schemaTpl';
10
+ import React from 'react';
11
+ import {VRenderer} from '../component/VRenderer';
12
+ import {mapReactElement} from '../component/factory';
13
+ import {RegionWrapper as Region} from '../component/RegionWrapper';
14
+ import {getComboWrapper} from '../event-action/schema';
15
+
16
+ import {getEventControlConfig} from '../util';
17
+ import {RendererAction, RendererEvent} from '../event-action';
18
+
19
+ export class WizardPlugin extends BasePlugin {
20
+ // 关联渲染器名字
21
+ rendererName = 'wizard';
22
+ $schema = '/schemas/WizardSchema.json';
23
+
24
+ name = '向导';
25
+ isBaseComponent = true;
26
+ description =
27
+ '表单向导,可以将复杂的多个表单项拆分成多个步骤,一步一步指引用户完成填写。';
28
+ docLink = '/amis/zh-CN/components/wizard';
29
+ tags = ['功能'];
30
+ icon = 'fa fa-list-ol';
31
+
32
+ scaffold = {
33
+ type: 'wizard',
34
+ steps: [
35
+ {
36
+ title: '第一步',
37
+ body: [
38
+ {
39
+ type: 'input-text',
40
+ label: '文本',
41
+ name: 'var1'
42
+ }
43
+ ]
44
+ },
45
+
46
+ {
47
+ title: '第二步',
48
+ body: [
49
+ {
50
+ type: 'input-text',
51
+ label: '文本2',
52
+ name: 'var2'
53
+ }
54
+ ]
55
+ }
56
+ ]
57
+ };
58
+
59
+ previewSchema = {
60
+ type: 'wizard',
61
+ className: 'text-left m-b-none',
62
+ steps: [
63
+ {
64
+ title: '第一步',
65
+ body: [
66
+ {
67
+ type: 'input-text',
68
+ label: '文本',
69
+ name: 'var1'
70
+ }
71
+ ]
72
+ },
73
+
74
+ {
75
+ title: '第二步',
76
+ body: []
77
+ }
78
+ ]
79
+ };
80
+
81
+ // 事件定义
82
+ events: RendererEvent[] = [
83
+ {
84
+ eventName: 'inited',
85
+ eventLabel: '初始化完成',
86
+ description: '远程初始化接口请求成功时触发',
87
+ dataSchema: [
88
+ {
89
+ type: 'object',
90
+ properties: {
91
+ 'event.data': {
92
+ type: 'object',
93
+ title: 'initApi 远程请求返回的初始化数据'
94
+ }
95
+ }
96
+ }
97
+ ]
98
+ },
99
+ {
100
+ eventName: 'finished',
101
+ eventLabel: '点击完成',
102
+ description: '最终提交时触发',
103
+ dataSchema: [
104
+ {
105
+ type: 'object',
106
+ properties: {
107
+ 'event.data': {
108
+ type: 'object',
109
+ title: '提交的表单数据'
110
+ }
111
+ }
112
+ }
113
+ ]
114
+ },
115
+ {
116
+ eventName: 'stepChange',
117
+ eventLabel: '步骤切换',
118
+ description: '切换步骤时触发',
119
+ dataSchema: [
120
+ {
121
+ type: 'object',
122
+ properties: {
123
+ 'event.data.step': {
124
+ type: 'string',
125
+ title: '步骤索引'
126
+ }
127
+ }
128
+ }
129
+ ]
130
+ },
131
+ {
132
+ eventName: 'change',
133
+ eventLabel: '数值变化',
134
+ description: '表单值变化时触发',
135
+ dataSchema: [
136
+ {
137
+ type: 'object',
138
+ properties: {
139
+ 'event.data': {
140
+ type: 'object',
141
+ title: '当前表单数据'
142
+ }
143
+ }
144
+ }
145
+ ]
146
+ },
147
+ {
148
+ eventName: 'submitSucc',
149
+ eventLabel: '提交成功',
150
+ description: '最终提交成功时触发',
151
+ dataSchema: [
152
+ {
153
+ type: 'object',
154
+ properties: {
155
+ 'event.data': {
156
+ type: 'object',
157
+ title: '提交成功后返回的数据'
158
+ }
159
+ }
160
+ }
161
+ ]
162
+ },
163
+ {
164
+ eventName: 'submitFail',
165
+ eventLabel: '提交失败',
166
+ description: '最终提交失败时触发',
167
+ dataSchema: [
168
+ {
169
+ type: 'object',
170
+ properties: {
171
+ 'event.data.error': {
172
+ type: 'object',
173
+ title: '提交失败后返回的错误信息'
174
+ }
175
+ }
176
+ }
177
+ ]
178
+ },
179
+ {
180
+ eventName: 'stepSubmitSucc',
181
+ eventLabel: '步骤提交成功',
182
+ description: '单个步骤提交成功'
183
+ },
184
+ {
185
+ eventName: 'stepSubmitFail',
186
+ eventLabel: '步骤提交失败',
187
+ description: '单个步骤提交失败',
188
+ dataSchema: [
189
+ {
190
+ type: 'object',
191
+ properties: {
192
+ 'event.data.error': {
193
+ type: 'object',
194
+ title: '单个步骤提交失败后返回的错误信息'
195
+ }
196
+ }
197
+ }
198
+ ]
199
+ }
200
+ ];
201
+
202
+ // 动作定义
203
+ actions: RendererAction[] = [
204
+ {
205
+ actionType: 'submit',
206
+ actionLabel: '全部提交',
207
+ description: '提交全部数据'
208
+ },
209
+ {
210
+ actionType: 'stepSubmit',
211
+ actionLabel: '分步提交',
212
+ description: '提交当前步骤数据',
213
+ desc: (info: any) => {
214
+ return (
215
+ <div>
216
+ <span className="variable-right">{info?.__rendererLabel}</span>
217
+ 提交当前步骤数据
218
+ </div>
219
+ );
220
+ }
221
+ },
222
+ {
223
+ actionType: 'prev',
224
+ actionLabel: '上一步',
225
+ description: '返回上一步'
226
+ },
227
+ {
228
+ actionType: 'next',
229
+ actionLabel: '下一步',
230
+ description: '提交当前步骤数据'
231
+ },
232
+ {
233
+ actionType: 'goto-step',
234
+ actionLabel: '定位步骤',
235
+ description: '切换到指定步骤',
236
+ config: ['step'],
237
+ desc: (info: any) => {
238
+ return (
239
+ <div>
240
+ <span className="variable-right">{info?.__rendererLabel}</span>
241
+ 切换到第
242
+ <span className="variable-left variable-right">
243
+ {info?.args?.step}
244
+ </span>
245
+
246
+ </div>
247
+ );
248
+ },
249
+ schema: getComboWrapper([
250
+ {
251
+ type: 'input-formula',
252
+ variables: '${variables}',
253
+ evalMode: false,
254
+ required: true,
255
+ variableMode: 'tabs',
256
+ label: '目标步骤',
257
+ size: 'lg',
258
+ name: 'step',
259
+ mode: 'horizontal'
260
+ }
261
+ ])
262
+ },
263
+ {
264
+ actionType: 'reload',
265
+ actionLabel: '重新加载',
266
+ description: '触发组件数据刷新并重新渲染'
267
+ },
268
+ {
269
+ actionType: 'setValue',
270
+ actionLabel: '更新数据',
271
+ description: '触发组件数据更新'
272
+ }
273
+ ];
274
+
275
+ panelTitle = '向导';
276
+ panelBodyCreator = (context: BaseEventContext) => {
277
+ return [
278
+ getSchemaTpl('tabs', [
279
+ {
280
+ title: '常规',
281
+ body: [
282
+ {
283
+ name: 'steps',
284
+ label: '步骤设置',
285
+ type: 'combo',
286
+ multiple: true,
287
+ multiLine: true,
288
+ addButtonText: '新增一步',
289
+ scaffold: {
290
+ title: '标题',
291
+ items: [
292
+ {
293
+ type: 'input-text',
294
+ name: 'var1',
295
+ label: '文本'
296
+ }
297
+ ]
298
+ },
299
+ items: [
300
+ {
301
+ name: 'title',
302
+ type: 'input-text',
303
+ label: '标题',
304
+ pipeIn: (value: any, data: any) => value || data.label
305
+ },
306
+
307
+ {
308
+ type: 'fieldSet',
309
+ title: '其他设置',
310
+ collapsed: true,
311
+ collapsable: true,
312
+ className: 'fieldset m-b-none',
313
+ body: [
314
+ {
315
+ name: 'mode',
316
+ label: '展示模式',
317
+ type: 'button-group-select',
318
+ size: 'xs',
319
+ mode: 'inline',
320
+ className: 'w-full',
321
+ value: 'normal',
322
+ options: [
323
+ {
324
+ label: '默认',
325
+ value: 'normal'
326
+ },
327
+ {
328
+ label: '左右摆放',
329
+ value: 'horizontal'
330
+ },
331
+ {
332
+ label: '内联',
333
+ value: 'inline'
334
+ }
335
+ ]
336
+ },
337
+
338
+ getSchemaTpl('horizontal', {
339
+ visibleOn: 'data.mode == "horizontal"'
340
+ }),
341
+
342
+ getSchemaTpl('api', {
343
+ label: '保存接口',
344
+ description:
345
+ '如果接口返回了 <code>step</code> 变量,且数值是数字类型,比如 <code>3</code>,提交完后回跳到第 3 步'
346
+ }),
347
+
348
+ getSchemaTpl('switch', {
349
+ label: '采用异步方式?',
350
+ name: 'asyncApi',
351
+ visibleOn: 'data.api',
352
+ labelRemark: {
353
+ trigger: 'click',
354
+ rootClose: true,
355
+ title: '什么是异步方式?',
356
+ content:
357
+ '异步方式主要用来解决请求超时问题,启用异步方式后,程序会在请求完后,定时轮询请求额外的接口用来咨询操作是否完成。所以接口可以快速的返回,而不需要等待流程真正完成。',
358
+ placement: 'left'
359
+ },
360
+ pipeIn: (value: any) => value != null,
361
+ pipeOut: (value: any) => (value ? '' : undefined)
362
+ }),
363
+
364
+ getSchemaTpl('api', {
365
+ name: 'asyncApi',
366
+ label: '异步检测接口',
367
+ visibleOn: 'data.asyncApi != null',
368
+ description:
369
+ '设置此属性后,表单提交发送保存接口后,还会继续轮训请求该接口,直到返回 finished 属性为 true 才 结束'
370
+ }),
371
+
372
+ {
373
+ type: 'divider'
374
+ },
375
+
376
+ getSchemaTpl('api', {
377
+ name: 'initApi',
378
+ label: '初始化接口',
379
+ description: '用来初始化表单数据'
380
+ }),
381
+
382
+ getSchemaTpl('switch', {
383
+ label: '采用异步方式?',
384
+ name: 'initAsyncApi',
385
+ visibleOn: 'data.initApi',
386
+ labelRemark: {
387
+ trigger: 'click',
388
+ rootClose: true,
389
+ title: '什么是异步方式?',
390
+ content:
391
+ '异步方式主要用来解决请求超时问题,启用异步方式后,程序会在请求完后,定时轮询请求额外的接口用来咨询操作是否完成。所以接口可以快速的返回,而不需要等待流程真正完成。',
392
+ placement: 'left'
393
+ },
394
+ pipeIn: (value: any) => value != null,
395
+ pipeOut: (value: any) => (value ? '' : undefined)
396
+ }),
397
+
398
+ getSchemaTpl('api', {
399
+ name: 'initAsyncApi',
400
+ label: '异步检测接口',
401
+ visibleOn: 'data.initAsyncApi != null',
402
+ description:
403
+ '设置此属性后,表单请求 initApi 后,还会继续轮训请求该接口,直到返回 finished 属性为 true 才 结束'
404
+ }),
405
+
406
+ getSchemaTpl('initFetch'),
407
+
408
+ {
409
+ label: '是否可被点开',
410
+ type: 'input-text',
411
+ name: 'jumpableOn',
412
+ description:
413
+ '用表达式来决定,当前步骤是否可被点开。额外可用变量:currentStep 表示当前步骤。'
414
+ }
415
+ ]
416
+ }
417
+ ]
418
+ },
419
+ {
420
+ type: 'input-text',
421
+ name: 'startStep',
422
+ label: '起始默认值',
423
+ description:
424
+ '从第几步开始。可支持模版,但是只有在组件创建时渲染模版并设置当前步数,在之后组件被刷新时,当前step不会根据startStep改变'
425
+ }
426
+ ]
427
+ },
428
+
429
+ {
430
+ title: '接口',
431
+ body: [
432
+ getSchemaTpl('api', {
433
+ name: 'initApi',
434
+ label: '初始化接口',
435
+ description:
436
+ '用来初始化向导数据,当接口中返回 <code>step</code> 字段时,可以控制默认跳转到第几步,注意数值一定得是数字类型。当返回 <code>submiting</code> 并且当前步骤中存在异步保存接口时,可以让 wizard 初始进入异步提交状态。'
437
+ }),
438
+
439
+ getSchemaTpl('switch', {
440
+ label: '采用异步方式?',
441
+ name: 'initAsyncApi',
442
+ visibleOn: 'data.initApi',
443
+ labelRemark: {
444
+ trigger: 'click',
445
+ rootClose: true,
446
+ title: '什么是异步方式?',
447
+ content:
448
+ '异步方式主要用来解决请求超时问题,启用异步方式后,程序会在请求完后,定时轮询请求额外的接口用来咨询操作是否完成。所以接口可以快速的返回,而不需要等待流程真正完成。',
449
+ placement: 'left'
450
+ },
451
+
452
+ pipeIn: (value: any) => value != null,
453
+ pipeOut: (value: any) => (value ? '' : undefined)
454
+ }),
455
+
456
+ getSchemaTpl('api', {
457
+ name: 'initAsyncApi',
458
+ label: '异步检测接口',
459
+ visibleOn: 'data.initAsyncApi != null',
460
+ description:
461
+ '设置此属性后,表单请求 initApi 后,还会继续轮训请求该接口,直到返回 finished 属性为 true 才 结束'
462
+ }),
463
+
464
+ {
465
+ name: 'initFetch',
466
+ type: 'radios',
467
+ label: '是否初始拉取',
468
+ inline: true,
469
+ onChange: () => {},
470
+ options: [
471
+ {
472
+ label: '是',
473
+ value: true
474
+ },
475
+
476
+ {
477
+ label: '否',
478
+ value: false
479
+ },
480
+
481
+ {
482
+ label: '表达式',
483
+ value: ''
484
+ }
485
+ ]
486
+ },
487
+
488
+ {
489
+ name: 'initFetch',
490
+ autoComplete: false,
491
+ visibleOn: 'typeof this.initFetch !== "boolean"',
492
+ type: 'input-text',
493
+ placeholder: '',
494
+ className: 'm-t-n-sm'
495
+ },
496
+
497
+ {
498
+ type: 'divider'
499
+ },
500
+
501
+ getSchemaTpl('api', {
502
+ label: '保存接口',
503
+ description:
504
+ '用来保存表单数据, 最后一步点击完成触发,<code>如果最后一步中已经设置保存接口,则此处设置无效。</code>'
505
+ }),
506
+
507
+ getSchemaTpl('switch', {
508
+ label: '采用异步方式?',
509
+ name: 'asyncApi',
510
+ visibleOn: 'data.api',
511
+ labelRemark: {
512
+ trigger: 'click',
513
+ rootClose: true,
514
+ title: '什么是异步方式?',
515
+ content:
516
+ '异步方式主要用来解决请求超时问题,启用异步方式后,程序会在请求完后,定时轮询请求额外的接口用来咨询操作是否完成。所以接口可以快速的返回,而不需要等待流程真正完成。',
517
+ placement: 'left'
518
+ },
519
+ pipeIn: (value: any) => value != null,
520
+ pipeOut: (value: any) => (value ? '' : undefined)
521
+ }),
522
+
523
+ getSchemaTpl('api', {
524
+ name: 'asyncApi',
525
+ label: '异步检测接口',
526
+ visibleOn: 'data.asyncApi != null',
527
+ description:
528
+ '设置此属性后,表单提交发送保存接口后,还会继续轮训请求该接口,直到返回 finished 属性为 true 才 结束'
529
+ })
530
+ ]
531
+ },
532
+
533
+ {
534
+ title: '外观',
535
+ body: [
536
+ {
537
+ name: 'mode',
538
+ label: '展示模式',
539
+ type: 'button-group-select',
540
+ size: 'sm',
541
+ mode: 'inline',
542
+ className: 'w-full',
543
+ value: 'horizontal',
544
+ options: [
545
+ {
546
+ label: '水平',
547
+ value: 'horizontal'
548
+ },
549
+
550
+ {
551
+ label: '垂直',
552
+ value: 'vertical'
553
+ }
554
+ ]
555
+ },
556
+
557
+ {
558
+ name: 'actionPrevLabel',
559
+ label: '上一步按钮名称',
560
+ type: 'input-text',
561
+ pipeIn: defaultValue('上一步')
562
+ },
563
+
564
+ {
565
+ name: 'actionNextLabel',
566
+ label: '下一步按钮名称',
567
+ type: 'input-text',
568
+ pipeIn: defaultValue('下一步')
569
+ },
570
+
571
+ {
572
+ name: 'actionNextSaveLabel',
573
+ label: '保存并下一步按钮名称',
574
+ type: 'input-text',
575
+ pipeIn: defaultValue('保存并下一步')
576
+ },
577
+
578
+ {
579
+ name: 'actionFinishLabel',
580
+ label: '完成按钮名称',
581
+ type: 'input-text',
582
+ pipeIn: defaultValue('完成')
583
+ },
584
+
585
+ // {
586
+ // type: 'alert',
587
+ // level: 'info',
588
+ // body: `温馨提示:操作按钮每个步骤可以单独配置,请在右侧切换到需要单独配置的步骤后,点击下方的【自定义按钮】定制。`
589
+ // },
590
+
591
+ getSchemaTpl('className'),
592
+ getSchemaTpl('className', {
593
+ name: 'actionClassName',
594
+ label: '按钮 CSS 类名'
595
+ })
596
+ ]
597
+ },
598
+
599
+ {
600
+ title: '其他',
601
+ body: [
602
+ getSchemaTpl('ref'),
603
+ getSchemaTpl('name'),
604
+ getSchemaTpl('reload'),
605
+
606
+ {
607
+ label: '跳转',
608
+ name: 'redirect',
609
+ type: 'input-text',
610
+ description: '当设置此值后,表单提交完后跳转到目标地址。'
611
+ },
612
+
613
+ getSchemaTpl('visible')
614
+ ]
615
+ },
616
+
617
+ {
618
+ title: '事件',
619
+ className: 'p-none',
620
+ body: [
621
+ getSchemaTpl('eventControl', {
622
+ name: 'onEvent',
623
+ ...getEventControlConfig(this.manager, context)
624
+ })
625
+ ]
626
+ }
627
+ ])
628
+ ];
629
+ };
630
+
631
+ /**
632
+ * 补充切换的 toolbar
633
+ * @param context
634
+ * @param toolbars
635
+ */
636
+ buildEditorToolbar(
637
+ context: BaseEventContext,
638
+ toolbars: Array<BasicToolbarItem>
639
+ ) {
640
+ if (
641
+ context.info.plugin === this &&
642
+ context.info.renderer.name === this.rendererName &&
643
+ !context.info.hostId
644
+ ) {
645
+ const node = context.node;
646
+
647
+ toolbars.push({
648
+ level: 'secondary',
649
+ icon: 'fa fa-chevron-left',
650
+ tooltip: '上个步骤',
651
+ onClick: () => {
652
+ const control = node.getComponent();
653
+
654
+ if (control?.gotoStep) {
655
+ const currentIndex = control.state.currentStep;
656
+ control.gotoStep(currentIndex - 1);
657
+ }
658
+ }
659
+ });
660
+
661
+ toolbars.push({
662
+ level: 'secondary',
663
+ icon: 'fa fa-chevron-right',
664
+ tooltip: '下个步骤',
665
+ onClick: () => {
666
+ const control = node.getComponent();
667
+
668
+ if (control?.gotoStep) {
669
+ const currentIndex = control.state.currentStep;
670
+ control.gotoStep(currentIndex + 1);
671
+ }
672
+ }
673
+ });
674
+ }
675
+ }
676
+
677
+ filterProps(props: any) {
678
+ props.affixFooter = false;
679
+
680
+ return props;
681
+ }
682
+
683
+ patchContainers = ['steps.body'];
684
+ vRendererConfig: VRendererConfig = {
685
+ regions: {
686
+ body: {
687
+ key: 'body',
688
+ label: '表单集合',
689
+ wrapperResolve: (dom: HTMLElement) => dom
690
+ },
691
+ actions: {
692
+ label: '按钮组',
693
+ key: 'actions',
694
+ preferTag: '按钮',
695
+ wrapperResolve: (dom: HTMLElement) => dom
696
+ }
697
+ },
698
+ panelTitle: '步骤',
699
+ panelBodyCreator: (context: BaseEventContext) => {
700
+ return getSchemaTpl('tabs', [
701
+ {
702
+ title: '常规',
703
+ body: [
704
+ {
705
+ name: 'title',
706
+ type: 'input-text',
707
+ label: '标题',
708
+ pipeIn: (value: any, data: any) => value || data.label
709
+ },
710
+ getSchemaTpl('api', {
711
+ label: '保存接口',
712
+ description:
713
+ '如果接口返回了 <code>step</code> 变量,且数值是数字类型,比如 <code>3</code>,提交完后回跳到第 3 步'
714
+ }),
715
+
716
+ getSchemaTpl('switch', {
717
+ label: '采用异步方式?',
718
+ name: 'asyncApi',
719
+ visibleOn: 'data.api',
720
+ labelRemark: {
721
+ trigger: 'click',
722
+ rootClose: true,
723
+ title: '什么是异步方式?',
724
+ content:
725
+ '异步方式主要用来解决请求超时问题,启用异步方式后,程序会在请求完后,定时轮询请求额外的接口用来咨询操作是否完成。所以接口可以快速的返回,而不需要等待流程真正完成。',
726
+ placement: 'left'
727
+ },
728
+ pipeIn: (value: any) => value != null,
729
+ pipeOut: (value: any) => (value ? '' : undefined)
730
+ }),
731
+
732
+ getSchemaTpl('api', {
733
+ name: 'asyncApi',
734
+ label: '异步检测接口',
735
+ visibleOn: 'data.asyncApi != null',
736
+ description:
737
+ '设置此属性后,表单提交发送保存接口后,还会继续轮训请求该接口,直到返回 finished 属性为 true 才 结束'
738
+ }),
739
+ {
740
+ type: 'divider'
741
+ },
742
+ getSchemaTpl('api', {
743
+ name: 'initApi',
744
+ label: '初始化接口',
745
+ description: '用来初始化表单数据'
746
+ }),
747
+
748
+ getSchemaTpl('switch', {
749
+ label: '采用异步方式?',
750
+ name: 'initAsyncApi',
751
+ visibleOn: 'data.initApi',
752
+ labelRemark: {
753
+ trigger: 'click',
754
+ rootClose: true,
755
+ title: '什么是异步方式?',
756
+ content:
757
+ '异步方式主要用来解决请求超时问题,启用异步方式后,程序会在请求完后,定时轮询请求额外的接口用来咨询操作是否完成。所以接口可以快速的返回,而不需要等待流程真正完成。',
758
+ placement: 'left'
759
+ },
760
+ pipeIn: (value: any) => value != null,
761
+ pipeOut: (value: any) => (value ? '' : undefined)
762
+ }),
763
+
764
+ getSchemaTpl('api', {
765
+ name: 'initAsyncApi',
766
+ label: '异步检测接口',
767
+ visibleOn: 'data.initAsyncApi != null',
768
+ description:
769
+ '设置此属性后,表单请求 initApi 后,还会继续轮训请求该接口,直到返回 finished 属性为 true 才 结束'
770
+ }),
771
+ getSchemaTpl('initFetch')
772
+ ]
773
+ },
774
+ {
775
+ title: '外观',
776
+ body: [
777
+ {
778
+ name: 'mode',
779
+ label: '展示模式',
780
+ type: 'button-group-select',
781
+ size: 'xs',
782
+ mode: 'inline',
783
+ className: 'w-full',
784
+ value: 'normal',
785
+ options: [
786
+ {
787
+ label: '默认',
788
+ value: 'normal'
789
+ },
790
+ {
791
+ label: '左右摆放',
792
+ value: 'horizontal'
793
+ },
794
+ {
795
+ label: '内联',
796
+ value: 'inline'
797
+ }
798
+ ]
799
+ },
800
+ getSchemaTpl('horizontal', {
801
+ visibleOn: 'data.mode == "horizontal"'
802
+ })
803
+ // getSchemaTpl('className', {
804
+ // name: 'tabClassName',
805
+ // label: '选项卡成员 CSS 类名'
806
+ // })
807
+ ]
808
+ },
809
+ {
810
+ title: '其他',
811
+ body: [
812
+ {
813
+ label: '是否可被点开',
814
+ type: 'input-text',
815
+ name: 'jumpableOn',
816
+ description:
817
+ '用表达式来决定,当前步骤是否可被点开。额外可用变量:currentStep 表示当前步骤。'
818
+ }
819
+ ]
820
+ }
821
+ ]);
822
+ }
823
+ };
824
+
825
+ wizardWrapperResolve = (dom: HTMLElement) =>
826
+ [].slice.call(
827
+ dom.querySelectorAll('[role="wizard-body"],[role="wizard-footer"]')
828
+ );
829
+ overrides = {
830
+ renderWizard: function (this: any) {
831
+ const info: RendererInfo = this.props.$$editor;
832
+ const steps = this.props.steps;
833
+ const currentStep = this.state.currentStep;
834
+ const dom = this.super();
835
+
836
+ if (!info || !steps?.[currentStep - 1]) {
837
+ return dom;
838
+ }
839
+
840
+ const index = currentStep - 1;
841
+ const step = steps[index];
842
+ const id = step.$$id;
843
+ const plugin: WizardPlugin = info.plugin as any;
844
+
845
+ return mapReactElement(dom, (child: JSX.Element) => {
846
+ if (/Wizard-step\b/.test(child.props.className)) {
847
+ return (
848
+ <VRenderer
849
+ key={id}
850
+ type={info.type}
851
+ plugin={info.plugin}
852
+ renderer={info.renderer}
853
+ $schema="/schemas/WizardStepSchema.json"
854
+ hostId={info.id}
855
+ memberIndex={index}
856
+ name={step.title || `步骤${index + 1}`}
857
+ id={id}
858
+ draggable={false}
859
+ wrapperResolve={plugin.wizardWrapperResolve}
860
+ schemaPath={`${info.schemaPath}/steps/${index}`}
861
+ path={`${this.props.$path}/${index}`} // 好像没啥用
862
+ data={this.props.data} // 好像没啥用
863
+ >
864
+ {mapReactElement(child, (child2: any, index: number) => {
865
+ if (child2.props.schema?.body && child2.props.schema.$$id) {
866
+ const region = plugin.vRendererConfig?.regions?.body;
867
+
868
+ if (!region) {
869
+ return child2;
870
+ }
871
+
872
+ const schema = {
873
+ ...child2.props.schema
874
+ };
875
+ delete schema.$$id;
876
+ return (
877
+ <Region
878
+ key={region.key}
879
+ preferTag={region.preferTag}
880
+ name={region.key}
881
+ label={region.label}
882
+ regionConfig={region}
883
+ placeholder={region.placeholder}
884
+ editorStore={plugin.manager.store}
885
+ manager={plugin.manager}
886
+ children={React.cloneElement(child2, {
887
+ schema: schema
888
+ })}
889
+ wrapperResolve={region.wrapperResolve}
890
+ rendererName={info.renderer.name}
891
+ />
892
+ );
893
+ }
894
+
895
+ return child2;
896
+ })}
897
+ </VRenderer>
898
+ );
899
+ }
900
+
901
+ return child;
902
+ });
903
+ },
904
+
905
+ renderFooter: function (this: any) {
906
+ const info: RendererInfo = this.props.$$editor;
907
+ const steps = this.props.steps;
908
+ const currentStep = this.state.currentStep;
909
+ const dom = this.super();
910
+
911
+ if (!info || !steps?.[currentStep - 1]) {
912
+ return dom;
913
+ }
914
+
915
+ const plugin: WizardPlugin = info.plugin as any;
916
+ const region = plugin.vRendererConfig?.regions?.actions;
917
+
918
+ if (!region) {
919
+ return dom;
920
+ }
921
+
922
+ return (
923
+ <Region
924
+ key={region.key}
925
+ preferTag={region.preferTag}
926
+ name={region.key}
927
+ label={region.label}
928
+ regionConfig={region}
929
+ placeholder={region.placeholder}
930
+ editorStore={plugin.manager.store}
931
+ manager={plugin.manager}
932
+ children={dom}
933
+ wrapperResolve={region.wrapperResolve}
934
+ rendererName={info.renderer.name}
935
+ />
936
+ );
937
+ }
938
+ };
939
+ }
940
+
941
+ registerEditorPlugin(WizardPlugin);