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