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,815 @@
1
+ /**
2
+ * @file table view 组件的可视化编辑
3
+ */
4
+
5
+ import React from 'react';
6
+ import {registerEditorPlugin} from '../manager';
7
+ import {
8
+ BaseEventContext,
9
+ BasePlugin,
10
+ BasicPanelItem,
11
+ BasicToolbarItem,
12
+ BuildPanelEventContext,
13
+ RegionConfig,
14
+ RendererInfo,
15
+ VRendererConfig
16
+ } from '../plugin';
17
+ import {defaultValue, getSchemaTpl} from '../component/schemaTpl';
18
+ import {VRenderer} from '../component/VRenderer';
19
+ import {TableViewEditor} from '../component/TableViewEditor';
20
+ import {TableViewSchema} from 'amis/lib/renderers/TableView';
21
+ import {JSONGetById} from '../util';
22
+
23
+ /**
24
+ * 尚未实现的功能:
25
+ * * 按列删除,需要将一些 colspan 减一
26
+ * * 水平/垂直拆分单元格,增加周围节点的 colspan 和 rowspan
27
+ */
28
+
29
+ // td 节点模板
30
+ const TD_TEMPLATE = {
31
+ body: {
32
+ type: 'tpl',
33
+ tpl: '---'
34
+ }
35
+ } as {body: {type: 'tpl'}};
36
+
37
+ /**
38
+ * 遍历表格,算出每个单元格在最终渲染时的实际行和列,后续许多操作都需要以这个作为依据
39
+ * 比如插入列的时候,不能根据单元格在数组的位置,而是要根据单元格实际渲染时所属列
40
+ */
41
+ function getCellRealPosition(table: TableViewSchema) {
42
+ if (!table) {
43
+ return {
44
+ trs: []
45
+ };
46
+ }
47
+ // 记录有哪些行列被合并了,这样后续计算的时候就要跳过这些行列
48
+ const spannedCell: boolean[][] = [];
49
+ const trs = table.trs || [];
50
+
51
+ let currentRow = 0; // 当前渲染的实际行
52
+ for (const tr of trs) {
53
+ const tds = tr.tds || [];
54
+
55
+ let currentCol = 0; // 当前渲染的实际列
56
+ for (const td of tds) {
57
+ // 跳过被合并的行
58
+ while (spannedCell[currentRow] && spannedCell[currentRow][currentCol]) {
59
+ currentCol = currentCol + 1;
60
+ }
61
+ const rowspan = td.rowspan || 1;
62
+ const colspan = td.colspan || 1;
63
+ // 标记后续行合并情况
64
+ if (rowspan > 1 || colspan > 1) {
65
+ for (let i = 0; i < rowspan; i++) {
66
+ const spanRow = currentRow + i;
67
+ if (!spannedCell[spanRow]) {
68
+ spannedCell[spanRow] = [];
69
+ }
70
+ for (let j = 0; j < colspan; j++) {
71
+ const spanCol = currentCol + j;
72
+ spannedCell[spanRow][spanCol] = true;
73
+ }
74
+ }
75
+ }
76
+ (td as any).$$row = currentRow;
77
+ (td as any).$$col = currentCol;
78
+ currentCol = currentCol + 1;
79
+ }
80
+
81
+ currentRow = currentRow + 1;
82
+ }
83
+ return table;
84
+ }
85
+
86
+ export class TableViewPlugin extends BasePlugin {
87
+ // 关联渲染器名字
88
+ rendererName = 'table-view';
89
+ $schema = '/schemas/TableViewSchema.json';
90
+
91
+ // 组件名称
92
+ name = '表格视图';
93
+ isBaseComponent = true;
94
+ icon = 'fa fa-columns';
95
+ description = '表格类型的展现';
96
+ docLink = '/amis/zh-CN/components/table-view';
97
+ tags = ['容器'];
98
+ scaffold = {
99
+ type: 'table-view',
100
+ trs: [
101
+ {
102
+ background: '#F7F7F7',
103
+ tds: [
104
+ {
105
+ body: {
106
+ type: 'tpl',
107
+ tpl: '地区'
108
+ }
109
+ },
110
+ {
111
+ body: {
112
+ type: 'tpl',
113
+ tpl: '城市'
114
+ }
115
+ },
116
+ {
117
+ body: {
118
+ type: 'tpl',
119
+ tpl: '销量'
120
+ }
121
+ }
122
+ ]
123
+ },
124
+ {
125
+ tds: [
126
+ {
127
+ rowspan: 2,
128
+ body: {
129
+ type: 'tpl',
130
+ tpl: '华北'
131
+ }
132
+ },
133
+ {
134
+ body: {
135
+ type: 'tpl',
136
+ tpl: '北京'
137
+ }
138
+ },
139
+ {
140
+ body: {
141
+ type: 'tpl',
142
+ tpl: '${beijing}'
143
+ }
144
+ }
145
+ ]
146
+ },
147
+ {
148
+ tds: [
149
+ {
150
+ body: {
151
+ type: 'tpl',
152
+ tpl: '天津'
153
+ }
154
+ },
155
+ {
156
+ body: {
157
+ type: 'tpl',
158
+ tpl: '${tianjing}'
159
+ }
160
+ }
161
+ ]
162
+ }
163
+ ]
164
+ };
165
+ previewSchema = {
166
+ ...this.scaffold
167
+ };
168
+
169
+ regions: Array<RegionConfig> = [
170
+ {
171
+ key: 'body',
172
+ label: '内容区',
173
+ renderMethod: 'renderTdBody',
174
+ preferTag: '展示'
175
+ }
176
+ ];
177
+
178
+ panelTitle = '表格视图';
179
+ panelBody = [
180
+ getSchemaTpl('tabs', [
181
+ {
182
+ title: '属性',
183
+ className: 'p-none',
184
+ body: [
185
+ getSchemaTpl('collapseGroup', [
186
+ {
187
+ title: '常用',
188
+ body: [
189
+ {
190
+ label: '标题',
191
+ name: 'caption',
192
+ type: 'input-text'
193
+ },
194
+ {
195
+ label: '标题位置',
196
+ name: 'captionSide',
197
+ type: 'button-group-select',
198
+ size: 'sm',
199
+ mode: 'row',
200
+ className: 'ae-buttonGroupSelect--justify',
201
+ visibleOn: 'this.caption',
202
+ options: [
203
+ {label: '顶部', value: 'top'},
204
+ {label: '底部', value: 'bottom'}
205
+ ]
206
+ },
207
+ {
208
+ type: 'input-text',
209
+ label: '视图宽度',
210
+ name: 'width',
211
+ clearable: true
212
+ },
213
+ {
214
+ type: 'input-text',
215
+ label: '单元格默认内间距',
216
+ name: 'padding',
217
+ clearable: true
218
+ },
219
+ {
220
+ label: '显示边框',
221
+ name: 'border',
222
+ type: 'switch',
223
+ mode: 'row',
224
+ inputClassName: 'inline-flex justify-between flex-row-reverse'
225
+ },
226
+ {
227
+ label: '边框颜色',
228
+ type: 'input-color',
229
+ name: 'borderColor',
230
+ visibleOn: 'this.border',
231
+ pipeIn: defaultValue('#eceff8')
232
+ }
233
+ ]
234
+ }
235
+ ])
236
+ ]
237
+ },
238
+ {
239
+ title: '外观',
240
+ className: 'p-none',
241
+ body: getSchemaTpl('collapseGroup', [
242
+ ...getSchemaTpl('style:common'),
243
+ {
244
+ title: 'CSS 类名',
245
+ body: [getSchemaTpl('className')]
246
+ }
247
+ ])
248
+ },
249
+ {
250
+ title: '状态',
251
+ body: [getSchemaTpl('visible')]
252
+ }
253
+ ])
254
+ ];
255
+
256
+ fieldWrapperResolve = (dom: HTMLElement) => dom;
257
+
258
+ overrides = {
259
+ renderTd(this: any, td: any, colIndex: number, rowIndex: number) {
260
+ const dom = this.super(td, colIndex, rowIndex);
261
+ const info: RendererInfo = this.props.$$editor;
262
+
263
+ if (!info || !td.$$id) {
264
+ return dom;
265
+ }
266
+
267
+ const plugin = info.plugin as TableViewPlugin;
268
+ const id = td.$$id;
269
+ return (
270
+ <VRenderer
271
+ type={info.type}
272
+ plugin={info.plugin}
273
+ renderer={info.renderer}
274
+ key={id}
275
+ $schema="/schemas/TdObject.json"
276
+ hostId={info.id}
277
+ memberIndex={colIndex} // TODO: colIndex 其实不对,需要增加 schema filter 功能来让插件能
278
+ name={`${`单元格 ${rowIndex + 1},${colIndex + 1}`}`}
279
+ id={id}
280
+ draggable={false}
281
+ wrapperResolve={plugin.fieldWrapperResolve}
282
+ schemaPath={`${info.schemaPath}/td`}
283
+ path={`${this.props.$path}/tr/${rowIndex}/td/${colIndex}`}
284
+ data={this.props.data}
285
+ children={dom}
286
+ />
287
+ );
288
+ },
289
+ renderTr(this: any, tr: any, rowIndex: number) {
290
+ const dom = this.super(tr, rowIndex);
291
+ const info: RendererInfo = this.props.$$editor;
292
+
293
+ if (!info || !tr.$$id) {
294
+ return dom;
295
+ }
296
+
297
+ const plugin = info.plugin as TableViewPlugin;
298
+ const id = tr.$$id;
299
+ return (
300
+ <VRenderer
301
+ type={info.type}
302
+ plugin={info.plugin}
303
+ renderer={info.renderer}
304
+ key={id}
305
+ $schema="/schemas/TrObject.json"
306
+ hostId={info.id}
307
+ memberIndex={rowIndex}
308
+ name={`${`行 ${rowIndex + 1}`}`}
309
+ id={id}
310
+ draggable={false}
311
+ wrapperResolve={plugin.fieldWrapperResolve}
312
+ schemaPath={`${info.schemaPath}/tr`}
313
+ path={`${this.props.$path}/tr/${rowIndex}`}
314
+ data={this.props.data}
315
+ children={dom}
316
+ />
317
+ );
318
+ }
319
+ };
320
+
321
+ tdVRendererConfig: VRendererConfig = {
322
+ panelTitle: '单元格',
323
+ panelBodyCreator: (context: BaseEventContext) => {
324
+ return [
325
+ getSchemaTpl('tabs', [
326
+ {
327
+ title: '属性',
328
+ className: 'p-none',
329
+ body: [
330
+ getSchemaTpl('collapseGroup', [
331
+ {
332
+ title: '显示',
333
+ body: [
334
+ {
335
+ label: '背景色',
336
+ type: 'input-color',
337
+ name: 'background'
338
+ },
339
+ {
340
+ label: '文字颜色',
341
+ type: 'input-color',
342
+ name: 'color'
343
+ },
344
+ {
345
+ label: '文字加粗',
346
+ name: 'bold',
347
+ type: 'switch',
348
+ mode: 'row',
349
+ inputClassName:
350
+ 'inline-flex justify-between flex-row-reverse'
351
+ }
352
+ ]
353
+ },
354
+ {
355
+ title: '布局',
356
+ body: [
357
+ {
358
+ type: 'input-text',
359
+ label: '单元格宽度',
360
+ name: 'width',
361
+ clearable: true
362
+ },
363
+ {
364
+ type: 'input-number',
365
+ name: 'padding',
366
+ label: '单元格内边距'
367
+ },
368
+ {
369
+ label: '水平对齐',
370
+ name: 'align',
371
+ type: 'button-group-select',
372
+ size: 'sm',
373
+ mode: 'row',
374
+ className: 'ae-buttonGroupSelect--justify',
375
+ options: [
376
+ {
377
+ label: '',
378
+ value: 'left',
379
+ icon: 'fa fa-align-left'
380
+ },
381
+ {
382
+ label: '',
383
+ value: 'center',
384
+ icon: 'fa fa-align-center'
385
+ },
386
+ {
387
+ label: '',
388
+ value: 'right',
389
+ icon: 'fa fa-align-right'
390
+ },
391
+ {
392
+ label: '',
393
+ value: 'justify',
394
+ icon: 'fa fa-align-justify'
395
+ }
396
+ ]
397
+ },
398
+ {
399
+ label: '垂直对齐',
400
+ name: 'valign',
401
+ type: 'button-group-select',
402
+ size: 'sm',
403
+ mode: 'row',
404
+ className: 'ae-buttonGroupSelect--justify',
405
+ options: [
406
+ {
407
+ label: '顶部',
408
+ value: 'top'
409
+ },
410
+ {
411
+ label: '居中',
412
+ value: 'middle'
413
+ },
414
+ {
415
+ label: '底部',
416
+ value: 'bottom'
417
+ },
418
+ {
419
+ label: '基线对齐',
420
+ value: 'baseline'
421
+ }
422
+ ]
423
+ },
424
+ {
425
+ type: 'input-number',
426
+ name: 'colspan',
427
+ label: '水平合并列数'
428
+ },
429
+ {
430
+ type: 'input-number',
431
+ name: 'rowspan',
432
+ label: '垂直合并列数'
433
+ }
434
+ ]
435
+ }
436
+ ])
437
+ ]
438
+ },
439
+ {
440
+ title: '外观',
441
+ className: 'p-none',
442
+ body: getSchemaTpl('collapseGroup', getSchemaTpl('style:common'))
443
+ }
444
+ ])
445
+ ];
446
+ }
447
+ };
448
+
449
+ trVRendererConfig: VRendererConfig = {
450
+ panelTitle: ' 行',
451
+ panelBodyCreator: (context: BaseEventContext) => {
452
+ return [
453
+ getSchemaTpl('tabs', [
454
+ {
455
+ title: '属性',
456
+ body: [
457
+ {
458
+ label: '行高度',
459
+ type: 'input-number',
460
+ name: 'height'
461
+ },
462
+ {
463
+ label: '行背景色',
464
+ type: 'input-color',
465
+ name: 'background'
466
+ }
467
+ ]
468
+ },
469
+ {
470
+ title: '外观',
471
+ className: 'p-none',
472
+ body: getSchemaTpl('collapseGroup', getSchemaTpl('style:common'))
473
+ }
474
+ ])
475
+ ];
476
+ }
477
+ };
478
+
479
+ renderRenderer(props: any) {
480
+ const $$editor = props.$$editor;
481
+ const renderer = $$editor.renderer;
482
+ const schema = props.$schema;
483
+ getCellRealPosition(schema);
484
+ return (
485
+ <TableViewEditor schema={schema} manager={this.manager}>
486
+ <renderer.component {...props} />
487
+ </TableViewEditor>
488
+ );
489
+ }
490
+
491
+ // 根据路径判断是选中单元格还是行
492
+ buildEditorPanel(
493
+ context: BuildPanelEventContext,
494
+ panels: Array<BasicPanelItem>
495
+ ) {
496
+ super.buildEditorPanel(context, panels);
497
+ const store = this.manager.store;
498
+ if (context.info.schemaPath.endsWith('/td')) {
499
+ panels.push({
500
+ key: 'td',
501
+ order: 100,
502
+ icon: this.tdVRendererConfig.panelIcon || 'fa fa-tablet',
503
+ title: this.tdVRendererConfig.panelTitle || '格子',
504
+ render: this.manager.makeSchemaFormRender({
505
+ controls: this.tdVRendererConfig.panelControlsCreator
506
+ ? this.tdVRendererConfig.panelControlsCreator(context)
507
+ : this.tdVRendererConfig.panelControls!,
508
+ body: this.tdVRendererConfig.panelBodyCreator
509
+ ? this.tdVRendererConfig.panelBodyCreator(context)
510
+ : this.tdVRendererConfig.panelBody!,
511
+ panelById: store.activeId
512
+ })
513
+ });
514
+ } else if (context.info.schemaPath.endsWith('/tr')) {
515
+ panels.push({
516
+ key: 'tr',
517
+ order: 100,
518
+ icon: this.trVRendererConfig.panelIcon || 'fa fa-tablet',
519
+ title: this.trVRendererConfig.panelTitle || '格子',
520
+ render: this.manager.makeSchemaFormRender({
521
+ controls: this.trVRendererConfig.panelControlsCreator
522
+ ? this.trVRendererConfig.panelControlsCreator(context)
523
+ : this.trVRendererConfig.panelControls!,
524
+ body: this.trVRendererConfig.panelBodyCreator
525
+ ? this.trVRendererConfig.panelBodyCreator(context)
526
+ : this.trVRendererConfig.panelBody!,
527
+ panelById: store.activeId
528
+ })
529
+ });
530
+ }
531
+ }
532
+
533
+ /**
534
+ * 插入行,需要处理前面有 rowspan 的情况
535
+ *
536
+ * +---+---+---+
537
+ * | a | b | c |
538
+ * + +---+---+
539
+ * | | d | e |
540
+ * + +---+---+
541
+ * | | f | g |
542
+ * +---+---+---+
543
+ *
544
+ * 比如在 d 位置的前面插入行,需要将 a 的 rowspan 加一,然后再插入两个单元格
545
+ */
546
+ insertRow(tdId: string, position: 'above' | 'below') {
547
+ const store = this.manager.store;
548
+ const paths = store.getNodePathById(tdId);
549
+ const tableId = paths[paths.length - 3].id;
550
+ const table = store.getSchema(tableId);
551
+ getCellRealPosition(table);
552
+
553
+ const td = JSONGetById(table, tdId);
554
+
555
+ if (!td) {
556
+ console.warn('找不到对应的 td id');
557
+ return;
558
+ }
559
+
560
+ let insertRow = td.$$row;
561
+ if (position === 'below') {
562
+ insertRow = insertRow + 1;
563
+ }
564
+
565
+ // 通过第一行来确认表格一共多少列
566
+ const firstRow = table.trs[0];
567
+ const firstRowLastTd = firstRow.tds[firstRow.tds.length - 1];
568
+ if (!firstRowLastTd) {
569
+ console.warn('第一列没内容');
570
+ return;
571
+ }
572
+ let colSize = firstRowLastTd.$$col + (firstRowLastTd.colspan || 1);
573
+ let insertIndex = table.trs.length;
574
+ for (let trIndex = 0; trIndex < table.trs.length; trIndex++) {
575
+ for (const td of table.trs[trIndex].tds || []) {
576
+ const tdRow = td.$$row;
577
+ const rowspan = td.rowspan || 1;
578
+ const colspan = td.colspan || 1;
579
+ // 如果覆盖到要插入的行,则增加 rowspan,并在这个插入的行中减去对应
580
+ if (rowspan > 1) {
581
+ const isOverlapping = tdRow + rowspan > insertRow;
582
+ if (isOverlapping) {
583
+ td.rowspan = rowspan + 1;
584
+ colSize = colSize - colspan;
585
+ }
586
+ }
587
+ if (tdRow === insertRow) {
588
+ insertIndex = trIndex;
589
+ break;
590
+ }
591
+ }
592
+ }
593
+
594
+ const insertTds = [];
595
+ for (let i = 0; i < colSize; i++) {
596
+ insertTds.push(TD_TEMPLATE);
597
+ }
598
+ table.trs.splice(insertIndex, 0, {tds: insertTds});
599
+ this.manager.store.changeValueById(tableId, table);
600
+ }
601
+
602
+ /**
603
+ * 插入列
604
+ *
605
+ * +---+---+---+
606
+ * | a | b |
607
+ * + +---+
608
+ * | | c |
609
+ * +---+---+---+
610
+ * | d | e | f |
611
+ * +---+---+---+
612
+ *
613
+ * 比如在 c 位置左侧插入列,应该将 a 的 colspan 加一,然后在最后一行增加一个单元格
614
+ */
615
+ insertCol(tdId: string, position: 'left' | 'right') {
616
+ const store = this.manager.store;
617
+ const paths = store.getNodePathById(tdId);
618
+ const tableId = paths[paths.length - 3].id;
619
+ const table = store.getSchema(tableId);
620
+ getCellRealPosition(table);
621
+ const td = JSONGetById(table, tdId);
622
+ if (!td) {
623
+ console.warn('找不到对应的 td id');
624
+ return;
625
+ }
626
+
627
+ let insertCol = td.$$col;
628
+ if (position === 'right') {
629
+ insertCol = insertCol + 1;
630
+ }
631
+
632
+ for (const tr of table.trs || []) {
633
+ const tds = tr.tds || [];
634
+ let isInserted = false;
635
+ for (let tdIndex = 0; tdIndex < tds.length; tdIndex++) {
636
+ const td = tds[tdIndex];
637
+ const tdColspan = td.colspan || 1;
638
+ const tdCol = td.$$col;
639
+ // 如果要插入的行被覆盖了,则对节点加一并跳过插入
640
+ if (tdColspan > 1) {
641
+ const isOverlapping = tdCol + tdColspan > insertCol;
642
+ if (isOverlapping) {
643
+ td.colspan = tdColspan + 1;
644
+ isInserted = true;
645
+ break;
646
+ }
647
+ }
648
+ if (insertCol <= tdCol) {
649
+ tds.splice(tdIndex, 0, TD_TEMPLATE);
650
+ isInserted = true;
651
+ break;
652
+ }
653
+ }
654
+ // 如果没找到对应的节点,那可能是插入到最后一条或者这一列节点数量不够,此时就要插入到最后
655
+ if (!isInserted) {
656
+ tds.push(TD_TEMPLATE);
657
+ }
658
+ }
659
+ this.manager.store.changeValueById(tableId, table);
660
+ }
661
+
662
+ /**
663
+ * 拆分有跨行或跨列的单元格
664
+ *
665
+ * +---+---+---+
666
+ * | a | b |
667
+ * + +---+
668
+ * | | c |
669
+ * +---+---+---+
670
+ * | d | e | f |
671
+ * +---+---+---+
672
+ *
673
+ * 比如拆分 a,最后要变成
674
+ *
675
+ * +---+---+---+
676
+ * | a | g | b |
677
+ * +---+---+---+
678
+ * | h | i | c |
679
+ * +---+---+---+
680
+ * | d | e | f |
681
+ * +---+---+---+
682
+ *
683
+ * 因此要新增 g、h、i 三个单元格
684
+ */
685
+ splitCell(tdId: string) {
686
+ const store = this.manager.store;
687
+ const paths = store.getNodePathById(tdId);
688
+ const tableId = paths[paths.length - 3].id;
689
+ const table = store.getSchema(tableId);
690
+ getCellRealPosition(table);
691
+ const td = JSONGetById(table, tdId);
692
+ if (!td) {
693
+ console.warn('找不到对应的 td id');
694
+ return;
695
+ }
696
+
697
+ const rowspan = td.rowspan || 1;
698
+ const colspan = td.colspan || 1;
699
+
700
+ // 将这个单元格的跨行和跨列都设置为 1
701
+ td.colspan = 1;
702
+ td.rowspan = 1;
703
+
704
+ // 算出需要补充哪些单元格及位置
705
+ const tdRow = td.$$row;
706
+ const tdCol = td.$$col;
707
+ const insertTds = [];
708
+ for (var i = 0; i < rowspan; i++) {
709
+ for (var j = 0; j < colspan; j++) {
710
+ // 跳过第一个,也就是这个单元格自己的位置
711
+ if (i === 0 && j === 0) {
712
+ continue;
713
+ }
714
+ insertTds.push({row: tdRow + i, col: tdCol + j});
715
+ }
716
+ }
717
+
718
+ // 需要将列大的放前面,主要是因为后面需要反向遍历才能动态删数据
719
+ insertTds.sort((a: any, b: any) => {
720
+ return b.col - a.col;
721
+ });
722
+
723
+ for (const tr of table.trs) {
724
+ for (let tdIndex = 0; tdIndex < tr.tds.length; tdIndex++) {
725
+ const td = tr.tds[tdIndex];
726
+ const currentRow = td.$$row;
727
+ const currentCol = td.$$col;
728
+ let insertIndex = insertTds.length;
729
+ while (insertIndex--) {
730
+ const insertTd = insertTds[insertIndex];
731
+ if (currentRow === insertTd.row) {
732
+ if (insertTd.col <= currentCol) {
733
+ tr.tds.splice(tdIndex, 0, TD_TEMPLATE);
734
+ } else {
735
+ tr.tds.push(TD_TEMPLATE);
736
+ }
737
+ insertTds.splice(insertIndex, 1);
738
+ }
739
+ }
740
+ }
741
+ }
742
+
743
+ // 如果前面有单元格找不到位置,那意味着是下面这种情况,这个单元格跨两行且是最后一行
744
+ // 这时 table.tr 其实只有一行数据,需要在添加一行数据
745
+ // +---+---+
746
+ // | a |
747
+ // + +
748
+ // | |
749
+ // +---+---+
750
+ if (insertTds.length) {
751
+ const newTds = [];
752
+ for (var i = 0; i < insertTds.length; i++) {
753
+ newTds.push(TD_TEMPLATE);
754
+ }
755
+ table.trs.push({tds: newTds});
756
+ }
757
+
758
+ this.manager.store.changeValueById(tableId, table);
759
+ }
760
+
761
+ buildEditorToolbar(
762
+ {schema, info}: BaseEventContext,
763
+ toolbars: Array<BasicToolbarItem>
764
+ ) {
765
+ if (info.schemaPath.endsWith('/td')) {
766
+ const tdId = schema.$$id;
767
+ toolbars.push({
768
+ icon: 'fa fa-chevron-left',
769
+ order: 100,
770
+ tooltip: '左侧新增列',
771
+ onClick: () => {
772
+ this.insertCol(tdId, 'left');
773
+ }
774
+ });
775
+ toolbars.push({
776
+ icon: 'fa fa-chevron-down',
777
+ order: 100,
778
+ tooltip: '下方新增行',
779
+ onClick: () => {
780
+ this.insertRow(tdId, 'below');
781
+ }
782
+ });
783
+ toolbars.push({
784
+ icon: 'fa fa-chevron-up',
785
+ order: 100,
786
+ tooltip: '上方新增行',
787
+ onClick: () => {
788
+ this.insertRow(tdId, 'above');
789
+ }
790
+ });
791
+ toolbars.push({
792
+ icon: 'fa fa-chevron-right',
793
+ order: 100,
794
+ tooltip: '右侧新增列',
795
+ onClick: () => {
796
+ this.insertCol(tdId, 'right');
797
+ }
798
+ });
799
+ const colspan = schema.colspan || 1;
800
+ const rowspan = schema.rowspan || 1;
801
+ if (colspan > 1 || rowspan > 1) {
802
+ toolbars.push({
803
+ icon: 'fa fa-columns',
804
+ order: 100,
805
+ tooltip: '拆分单元格',
806
+ onClick: () => {
807
+ this.splitCell(tdId);
808
+ }
809
+ });
810
+ }
811
+ }
812
+ }
813
+ }
814
+
815
+ registerEditorPlugin(TableViewPlugin);