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,728 @@
1
+ import {Button} from 'amis';
2
+ import React from 'react';
3
+ import {registerEditorPlugin} from '../manager';
4
+ import {
5
+ BaseEventContext,
6
+ BasePlugin,
7
+ ContextMenuEventContext,
8
+ ContextMenuItem,
9
+ PluginEvent,
10
+ RendererJSONSchemaResolveEventContext,
11
+ VRendererConfig,
12
+ ResizeMoveEventContext
13
+ } from '../plugin';
14
+ import {defaultValue, getSchemaTpl} from '../component/schemaTpl';
15
+ import {EditorNodeType} from '../store/node';
16
+ import {Schema} from 'amis/lib/types';
17
+ import {VRenderer} from '../component/VRenderer';
18
+ import {RegionWrapper as Region} from '../component/RegionWrapper';
19
+ import {JSONChangeInArray, JSONPipeIn, repeatArray} from '../util';
20
+ import {Icon} from '../icons/index';
21
+
22
+ export class HBoxPlugin extends BasePlugin {
23
+ // 关联渲染器名字
24
+ rendererName = 'hbox';
25
+ $schema = '/schemas/HBoxSchema.json';
26
+ disabledRendererPlugin = true; // 组件面板不显示
27
+
28
+ // 组件名称
29
+ name = 'HBox';
30
+ isBaseComponent = true;
31
+ icon = 'fa fa-columns';
32
+ description =
33
+ '用来实现左右排版布局,默认平均分配,可以通过 columnClassName 配置某列的宽度。';
34
+ docLink = '/amis/zh-CN/components/hbox';
35
+ tags = ['容器'];
36
+ scaffold = {
37
+ type: 'hbox',
38
+ gap: 'base',
39
+ columns: [
40
+ {
41
+ body: []
42
+ },
43
+ {
44
+ body: []
45
+ }
46
+ ]
47
+ };
48
+ previewSchema = {
49
+ type: 'hbox',
50
+ columns: [
51
+ {
52
+ type: 'tpl',
53
+ tpl: '固定宽度<br />w-xs',
54
+ columnClassName: 'bg-primary w-xs'
55
+ },
56
+ {
57
+ type: 'tpl',
58
+ tpl: '自动填满',
59
+ columnClassName: 'bg-success'
60
+ }
61
+ ]
62
+ };
63
+
64
+ panelTitle = 'HBox';
65
+ panelBodyCreator = (context: BaseEventContext) => [
66
+ getSchemaTpl('tabs', [
67
+ {
68
+ title: '常规',
69
+ body: [
70
+ getSchemaTpl('fieldSet', {
71
+ title: '插入',
72
+ collapsable: false,
73
+ body: [
74
+ {
75
+ type: 'wrapper',
76
+ size: 'none',
77
+ className: 'grid grid-cols-2 gap-4 mb-4',
78
+ body: [
79
+ {
80
+ children: (
81
+ <Button
82
+ size="sm"
83
+ onClick={() => this.insertRowAfter(context.node)}
84
+ >
85
+ <Icon className="icon" icon="arrow-to-bottom" />
86
+ <span>下方插入新行</span>
87
+ </Button>
88
+ )
89
+ },
90
+ {
91
+ children: (
92
+ <Button
93
+ size="sm"
94
+ onClick={() => this.insertRowBefore(context.node)}
95
+ >
96
+ <Icon className="icon" icon="top-arrow-to-top" />
97
+ <span>上方插入新行</span>
98
+ </Button>
99
+ )
100
+ }
101
+ ]
102
+ },
103
+
104
+ {
105
+ label: '列数',
106
+ name: 'columns',
107
+ type: 'select',
108
+ pipeIn: (value: any) =>
109
+ Array.isArray(value) ? value.length : undefined,
110
+ pipeOut: (value: any, origin: any) => {
111
+ if (Array.isArray(origin)) {
112
+ if (origin.length > value) {
113
+ origin = origin.concat();
114
+ origin.splice(value - 1, origin.length - value);
115
+ } else {
116
+ origin = origin.concat(
117
+ repeatArray(
118
+ {
119
+ body: []
120
+ },
121
+ value - origin.length
122
+ )
123
+ );
124
+ }
125
+ }
126
+
127
+ return origin;
128
+ },
129
+ options: repeatArray(null, 12).map((_, index) => ({
130
+ label: `${index + 1}`,
131
+ value: index + 1
132
+ }))
133
+ }
134
+ ]
135
+ }),
136
+
137
+ {
138
+ type: 'list-select',
139
+ name: 'gap',
140
+ label: '列间距',
141
+ size: 'sm',
142
+ clearable: true,
143
+ tiled: true,
144
+ options: [
145
+ {
146
+ label: '极小',
147
+ value: 'xs'
148
+ },
149
+ {
150
+ label: '小',
151
+ value: 'sm'
152
+ },
153
+ {
154
+ label: '正常',
155
+ value: 'base'
156
+ },
157
+ {
158
+ label: '中',
159
+ value: 'md'
160
+ },
161
+ {
162
+ label: '大',
163
+ value: 'lg'
164
+ }
165
+ ]
166
+ },
167
+
168
+ {
169
+ name: 'columns',
170
+ label: '列集合',
171
+ type: 'combo',
172
+ scaffold: {
173
+ body: []
174
+ },
175
+ minLength: 1,
176
+ multiple: true,
177
+ // draggable: true,
178
+ draggableTip: '',
179
+ items: [
180
+ {
181
+ type: 'tpl',
182
+ tpl: '<span class="label label-default">列${index | plus}</span>',
183
+ columnClassName: 'no-grow v-middle'
184
+ },
185
+ getSchemaTpl('className', {
186
+ name: 'columnClassName',
187
+ labelRemark: '',
188
+ label: ''
189
+ })
190
+ ]
191
+ },
192
+ getSchemaTpl('fieldSet', {
193
+ title: '水平对齐',
194
+ collapsable: false,
195
+ body: [
196
+ {
197
+ type: 'button-group-select',
198
+ name: 'align',
199
+ size: 'sm',
200
+ label: false,
201
+ tiled: true,
202
+ pipeIn: defaultValue('left'),
203
+ options: [
204
+ {
205
+ value: 'left',
206
+ label: '左对齐'
207
+ },
208
+ {
209
+ value: 'center',
210
+ label: '中间对齐'
211
+ },
212
+ {
213
+ value: 'right',
214
+ label: '右对齐'
215
+ },
216
+ {
217
+ value: 'between',
218
+ label: '两端对齐'
219
+ }
220
+ ]
221
+ }
222
+ ]
223
+ }),
224
+
225
+ getSchemaTpl('fieldSet', {
226
+ title: '垂直对齐',
227
+ collapsable: false,
228
+ body: [
229
+ {
230
+ type: 'button-group-select',
231
+ name: 'valign',
232
+ size: 'sm',
233
+ label: false,
234
+ tiled: true,
235
+ pipeIn: defaultValue('top'),
236
+ options: [
237
+ {
238
+ value: 'top',
239
+ label: '顶部对齐'
240
+ },
241
+ {
242
+ value: 'middle',
243
+ label: '中间对齐'
244
+ },
245
+ {
246
+ value: 'bottom',
247
+ label: '底部对齐'
248
+ },
249
+ {
250
+ value: 'between',
251
+ label: '两端对齐'
252
+ }
253
+ ]
254
+ }
255
+ ]
256
+ })
257
+ ]
258
+ },
259
+ {
260
+ title: '外观',
261
+ body: [
262
+ getSchemaTpl('className'),
263
+ getSchemaTpl('subFormItemMode'),
264
+ getSchemaTpl('subFormHorizontalMode'),
265
+ getSchemaTpl('subFormHorizontal')
266
+ ]
267
+ },
268
+ {
269
+ title: '显隐',
270
+ body: [getSchemaTpl('visible')]
271
+ }
272
+ ])
273
+ ];
274
+
275
+ vRendererConfig: VRendererConfig = {
276
+ regions: {
277
+ body: {
278
+ key: 'body',
279
+ label: '内容区',
280
+ placeholder: '列',
281
+ wrapperResolve: (dom: HTMLElement) => dom
282
+ }
283
+ },
284
+ panelTitle: '列',
285
+ panelBodyCreator: (context: BaseEventContext) => {
286
+ return [
287
+ getSchemaTpl('tabs', [
288
+ {
289
+ title: '常规',
290
+ body: [
291
+ getSchemaTpl('fieldSet', {
292
+ title: '插入',
293
+ collapsable: false,
294
+ body: [
295
+ {
296
+ type: 'wrapper',
297
+ size: 'none',
298
+ className: 'grid grid-cols-2 gap-4',
299
+ body: [
300
+ {
301
+ children: (
302
+ <Button
303
+ size="sm"
304
+ onClick={() =>
305
+ this.insertRowAfter(context.node.host)
306
+ }
307
+ >
308
+ <Icon className="icon" icon="arrow-to-bottom" />
309
+ <span>下方插入新行</span>
310
+ </Button>
311
+ )
312
+ },
313
+ {
314
+ children: (
315
+ <Button
316
+ size="sm"
317
+ onClick={() =>
318
+ this.insertRowBefore(context.node.host)
319
+ }
320
+ >
321
+ <Icon className="icon" icon="top-arrow-to-top" />
322
+ <span>上方插入新行</span>
323
+ </Button>
324
+ )
325
+ },
326
+ {
327
+ children: (
328
+ <Button
329
+ size="sm"
330
+ onClick={() => this.insertColumnBefore(context)}
331
+ >
332
+ <Icon className="icon" icon="left-arrow-to-left" />
333
+ <span>左侧插入新列</span>
334
+ </Button>
335
+ )
336
+ },
337
+ {
338
+ children: (
339
+ <Button
340
+ size="sm"
341
+ onClick={() => this.insertColumnAfter(context)}
342
+ >
343
+ <Icon className="icon" icon="arrow-to-right" />
344
+ <span>右侧插入新列</span>
345
+ </Button>
346
+ )
347
+ }
348
+ ]
349
+ }
350
+ ]
351
+ }),
352
+
353
+ getSchemaTpl('fieldSet', {
354
+ title: '宽度设置',
355
+ collapsable: false,
356
+ body: [
357
+ {
358
+ type: 'button-group-select',
359
+ name: 'width',
360
+ size: 'sm',
361
+ label: false,
362
+ pipeIn: (value: any) =>
363
+ value && value !== 'auto' ? 'manual' : value || '',
364
+ pipeOut: (value: any) =>
365
+ value === 'manual' ? '20%' : value,
366
+ options: [
367
+ {
368
+ value: '',
369
+ label: '适配宽度'
370
+ },
371
+ {
372
+ value: 'auto',
373
+ label: '适配内容'
374
+ },
375
+ {
376
+ value: 'manual',
377
+ label: '手动'
378
+ }
379
+ ],
380
+ description:
381
+ '<% if (this.width && this.width !== "auto") {%>请按住高亮框右侧方块拖动调整宽度<%}%>'
382
+ }
383
+ ]
384
+ }),
385
+
386
+ getSchemaTpl('fieldSet', {
387
+ title: '垂直对齐',
388
+ collapsable: false,
389
+ body: [
390
+ {
391
+ type: 'button-group-select',
392
+ name: 'valign',
393
+ size: 'sm',
394
+ label: false,
395
+ tiled: true,
396
+ clearable: true,
397
+ options: [
398
+ {
399
+ value: 'top',
400
+ label: '顶部对齐'
401
+ },
402
+ {
403
+ value: 'middle',
404
+ label: '中间对齐'
405
+ },
406
+ {
407
+ value: 'bottom',
408
+ label: '底部对齐'
409
+ },
410
+ {
411
+ value: 'between',
412
+ label: '两端对齐'
413
+ }
414
+ ]
415
+ }
416
+ ]
417
+ })
418
+ ]
419
+ },
420
+ {
421
+ title: '外观',
422
+ body: [
423
+ getSchemaTpl('className', {
424
+ name: 'columnClassName',
425
+ label: '列 CSS 类名',
426
+ description: '可以添加宽度类样式调整宽度,默认宽度为平均分配。'
427
+ })
428
+ ]
429
+ }
430
+ ])
431
+ ];
432
+ }
433
+ };
434
+
435
+ vWrapperResolve = (dom: HTMLElement) => dom;
436
+ overrides = {
437
+ renderColumn: function (this: any, node: Schema, index: number) {
438
+ const dom = this.super(node, index);
439
+ const info = this.props.$$editor;
440
+
441
+ if (info && node.$$id) {
442
+ const plugin: HBoxPlugin = info.plugin as any;
443
+ const region = plugin.vRendererConfig?.regions?.body;
444
+ if (!region) {
445
+ return dom;
446
+ }
447
+
448
+ return (
449
+ <VRenderer
450
+ key={node.$$id}
451
+ type={info.type}
452
+ plugin={info.plugin}
453
+ renderer={info.renderer}
454
+ $schema="" // /schemas/GridColumn.json
455
+ hostId={info.id}
456
+ memberIndex={index}
457
+ name={`第${index + 1}列`}
458
+ id={node.$$id}
459
+ draggable={false}
460
+ schemaPath={`${info.schemaPath}/hbox/${index}`}
461
+ wrapperResolve={plugin.vWrapperResolve}
462
+ path={`${this.props.$path}/${index}`} // 好像没啥用
463
+ data={this.props.data} // 好像没啥用
464
+ widthMutable
465
+ >
466
+ {region ? (
467
+ <Region
468
+ key={region.key}
469
+ preferTag={region.preferTag}
470
+ name={region.key}
471
+ label={region.label}
472
+ regionConfig={region}
473
+ placeholder={region.placeholder}
474
+ editorStore={plugin.manager.store}
475
+ manager={plugin.manager}
476
+ children={dom}
477
+ wrapperResolve={region.wrapperResolve}
478
+ rendererName={info.renderer.name}
479
+ />
480
+ ) : (
481
+ dom
482
+ )}
483
+ </VRenderer>
484
+ );
485
+ }
486
+ return dom;
487
+ }
488
+ };
489
+
490
+ // buildEditorPanel(context: BaseEventContext, panels: Array<BasicPanelItem>) {
491
+ // super.buildEditorPanel(context, panels);
492
+ // const parent = context.node.parent?.host as EditorNodeType;
493
+
494
+ // if (
495
+ // parent?.info?.plugin === this &&
496
+ // (this.vRendererConfig.panelControls ||
497
+ // this.vRendererConfig.panelControlsCreator)
498
+ // ) {
499
+ // panels.push({
500
+ // key: 'grid',
501
+ // order: 100,
502
+ // icon: this.vRendererConfig.panelIcon || 'fa fa-tablet',
503
+ // title: this.vRendererConfig.panelTitle || '格子',
504
+ // render: this.manager.makeSchemaFormRender({
505
+ // body: this.vRendererConfig.panelControlsCreator
506
+ // ? this.vRendererConfig.panelControlsCreator(context)
507
+ // : this.vRendererConfig.panelControls!
508
+ // })
509
+ // });
510
+ // }
511
+ // }
512
+
513
+ afterResolveJsonSchema(
514
+ event: PluginEvent<RendererJSONSchemaResolveEventContext>
515
+ ) {
516
+ const context = event.context;
517
+ const parent = context.node.parent?.host as EditorNodeType;
518
+
519
+ if (parent?.info?.plugin === this) {
520
+ event.setData('/schemas/HBoxColumn.json');
521
+ }
522
+ }
523
+
524
+ buildEditorContextMenu(
525
+ context: ContextMenuEventContext,
526
+ menus: Array<ContextMenuItem>
527
+ ) {
528
+ if (context.selections.length || context.info?.plugin !== this) {
529
+ return;
530
+ }
531
+
532
+ if (context.node.isVitualRenderer) {
533
+ menus.push('|');
534
+
535
+ menus.push({
536
+ label: '左侧插入一列',
537
+ onSelect: () => this.insertColumnBefore(context)
538
+ });
539
+
540
+ menus.push({
541
+ label: '右侧插入一列',
542
+ onSelect: () => this.insertColumnAfter(context)
543
+ });
544
+
545
+ menus.push('|');
546
+
547
+ menus.push({
548
+ label: '上方插入一行',
549
+ onSelect: () => this.insertRowBefore(context.node.host)
550
+ });
551
+
552
+ menus.push({
553
+ label: '下方插入一行',
554
+ onSelect: () => this.insertRowAfter(context.node.host)
555
+ });
556
+ } else {
557
+ menus.push('|');
558
+
559
+ menus.push({
560
+ label: '上方插入一行',
561
+ onSelect: () => this.insertRowBefore(context.node)
562
+ });
563
+
564
+ menus.push({
565
+ label: '下方插入一行',
566
+ onSelect: () => this.insertRowAfter(context.node)
567
+ });
568
+ }
569
+ }
570
+
571
+ onWidthChangeStart(
572
+ event: PluginEvent<
573
+ ResizeMoveEventContext,
574
+ {
575
+ onMove(e: MouseEvent): void;
576
+ onEnd(e: MouseEvent): void;
577
+ }
578
+ >
579
+ ) {
580
+ const context = event.context;
581
+ const node = context.node;
582
+ if (node.info?.plugin !== this) {
583
+ return;
584
+ }
585
+ const host = node.host;
586
+ if (!host || host.info?.plugin !== this) {
587
+ return;
588
+ }
589
+
590
+ const dom = context.dom;
591
+ const parent = dom.parentElement as HTMLElement;
592
+ if (!parent) {
593
+ return;
594
+ }
595
+ const resizer = context.resizer;
596
+ const frameRect = parent.getBoundingClientRect();
597
+ let columns = host.schema.columns;
598
+ const index = node.index;
599
+ let finalWidth = columns[index].width;
600
+ const rect = dom.getBoundingClientRect();
601
+
602
+ event.setData({
603
+ onMove: (e: MouseEvent) => {
604
+ const width = e.pageX - rect.left;
605
+ const percent = (finalWidth = `${Math.max(
606
+ 1,
607
+ Math.min(99, Math.round((100 * width) / frameRect.width))
608
+ )}%`);
609
+ columns = columns.concat();
610
+ columns[index] = {
611
+ ...columns[index],
612
+ width: percent
613
+ };
614
+ resizer.setAttribute('data-value', percent);
615
+
616
+ host.updateState({
617
+ columns
618
+ });
619
+ requestAnimationFrame(() => {
620
+ node.calculateHighlightBox();
621
+ });
622
+ },
623
+ onEnd: () => {
624
+ host.updateState({}, true);
625
+ resizer.removeAttribute('data-value');
626
+ node.updateSchema({
627
+ width: finalWidth
628
+ });
629
+ requestAnimationFrame(() => {
630
+ node.calculateHighlightBox();
631
+ });
632
+ }
633
+ });
634
+ }
635
+
636
+ insertRowAfter(node: EditorNodeType) {
637
+ if (node.info?.plugin !== this) {
638
+ return;
639
+ }
640
+ const store = this.manager.store;
641
+ const schema = store.schema;
642
+ const id = node.id;
643
+ store.traceableSetSchema(
644
+ JSONChangeInArray(schema, id, (arr: any[], node: any, index: number) => {
645
+ arr.splice(
646
+ index + 1,
647
+ 0,
648
+ JSONPipeIn({
649
+ type: 'hbox',
650
+ align: node.align,
651
+ valign: node.valign,
652
+ columns: node.columns.map((column: any) => ({
653
+ body: [],
654
+ width: column?.width
655
+ }))
656
+ })
657
+ );
658
+ })
659
+ );
660
+ }
661
+ insertRowBefore(node: EditorNodeType) {
662
+ if (node.info?.plugin !== this) {
663
+ return;
664
+ }
665
+ const store = this.manager.store;
666
+ const id = node.id;
667
+ const schema = store.schema;
668
+ store.traceableSetSchema(
669
+ JSONChangeInArray(schema, id, (arr: any[], node: any, index: number) => {
670
+ arr.splice(
671
+ index,
672
+ 0,
673
+ JSONPipeIn({
674
+ type: 'hbox',
675
+ align: node.align,
676
+ valign: node.valign,
677
+ columns: node.columns.map((column: any) => ({
678
+ body: [],
679
+ width: column?.width
680
+ }))
681
+ })
682
+ );
683
+ })
684
+ );
685
+ }
686
+ insertColumnBefore(context: BaseEventContext) {
687
+ const node = context.node;
688
+ if (node.info?.plugin !== this) {
689
+ return;
690
+ }
691
+ const store = this.manager.store;
692
+ const schema = store.schema;
693
+ const id = context.id;
694
+ store.traceableSetSchema(
695
+ JSONChangeInArray(schema, id, (arr: any[], node: any, index: number) => {
696
+ arr.splice(
697
+ index,
698
+ 0,
699
+ JSONPipeIn({
700
+ body: []
701
+ })
702
+ );
703
+ })
704
+ );
705
+ }
706
+ insertColumnAfter(context: BaseEventContext) {
707
+ const node = context.node;
708
+ if (node.info?.plugin !== this) {
709
+ return;
710
+ }
711
+ const id = context.id;
712
+ const store = this.manager.store;
713
+ const schema = store.schema;
714
+ store.traceableSetSchema(
715
+ JSONChangeInArray(schema, id, (arr: any[], node: any, index: number) => {
716
+ arr.splice(
717
+ index + 1,
718
+ 0,
719
+ JSONPipeIn({
720
+ body: []
721
+ })
722
+ );
723
+ })
724
+ );
725
+ }
726
+ }
727
+
728
+ registerEditorPlugin(HBoxPlugin);