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,291 @@
1
+ import {Button} from 'amis-ui';
2
+ import React from 'react';
3
+ import {registerEditorPlugin} from '../manager';
4
+ import {
5
+ BaseEventContext,
6
+ BasePlugin,
7
+ InsertEventContext,
8
+ PluginEvent,
9
+ RegionConfig,
10
+ RendererInfo,
11
+ VRendererConfig
12
+ } from '../plugin';
13
+ import {defaultValue, getSchemaTpl} from '../component/schemaTpl';
14
+ import flatten from 'lodash/flatten';
15
+ import {VRenderer} from '../component/VRenderer';
16
+
17
+ export class CardPlugin extends BasePlugin {
18
+ // 关联渲染器名字
19
+ rendererName = 'card';
20
+ $schema = '/schemas/CardSchema.json';
21
+
22
+ // 组件名称
23
+ name = '卡片';
24
+ isBaseComponent = true;
25
+ description = '展示单个卡片。';
26
+ docLink = '/amis/zh-CN/components/card';
27
+ tags = ['展示'];
28
+ icon = '';
29
+ scaffold = {
30
+ type: 'card',
31
+ header: {
32
+ title: '标题',
33
+ subTitle: '副标题'
34
+ },
35
+ body: '内容',
36
+ actions: [
37
+ {
38
+ type: 'button',
39
+ label: '按钮',
40
+ actionType: 'dialog',
41
+ dialog: {
42
+ title: '标题',
43
+ body: '内容'
44
+ }
45
+ }
46
+ ]
47
+ };
48
+ previewSchema = {
49
+ ...this.scaffold
50
+ };
51
+
52
+ regions: Array<RegionConfig> = [
53
+ {
54
+ key: 'body',
55
+ label: '内容区',
56
+ renderMethod: 'renderBody',
57
+ preferTag: '展示'
58
+ },
59
+
60
+ {
61
+ key: 'actions',
62
+ label: '按钮组',
63
+ renderMethod: 'renderActions',
64
+ wrapperResolve: (dom: HTMLElement) => dom,
65
+ preferTag: '按钮'
66
+ }
67
+ ];
68
+
69
+ panelTitle = '卡片';
70
+ panelBodyCreator = (context: BaseEventContext) => {
71
+ return [
72
+ getSchemaTpl('tabs', [
73
+ {
74
+ title: '常规',
75
+ body: flatten([
76
+ {
77
+ children: (
78
+ <Button
79
+ size="sm"
80
+ className="m-b-sm"
81
+ level="info"
82
+ block
83
+ onClick={() =>
84
+ // this.manager.showInsertPanel('actions', context.id)
85
+ this.manager.showRendererPanel(
86
+ '按钮',
87
+ '请从左侧组件面板中点击添加按钮元素'
88
+ )
89
+ }
90
+ >
91
+ 新增按钮
92
+ </Button>
93
+ )
94
+ },
95
+ {
96
+ children: (
97
+ <div>
98
+ <Button
99
+ block
100
+ level="primary"
101
+ size="sm"
102
+ onClick={() =>
103
+ // this.manager.showInsertPanel('body', context.id)
104
+ this.manager.showRendererPanel(
105
+ '展示',
106
+ '请从左侧组件面板中点击添加内容元素'
107
+ )
108
+ }
109
+ >
110
+ 新增内容
111
+ </Button>
112
+ </div>
113
+ )
114
+ },
115
+ {
116
+ type: 'divider'
117
+ },
118
+ {
119
+ name: 'header.title',
120
+ type: 'input-text',
121
+ label: '标题',
122
+ description: '支持模板语法如: <code>\\${xxx}</code>'
123
+ },
124
+ {
125
+ name: 'header.subTitle',
126
+ type: 'input-text',
127
+ label: '副标题',
128
+ description: '支持模板语法如: <code>\\${xxx}</code>'
129
+ },
130
+ {
131
+ name: 'header.avatar',
132
+ type: 'input-text',
133
+ label: '图片地址',
134
+ description: '支持模板语法如: <code>\\${xxx}</code>'
135
+ },
136
+ {
137
+ name: 'header.desc',
138
+ type: 'textarea',
139
+ label: '描述',
140
+ description: '支持模板语法如: <code>\\${xxx}</code>'
141
+ },
142
+ {
143
+ name: 'header.highlight',
144
+ type: 'input-text',
145
+ label: '是否高亮表达式',
146
+ description: '如: <code>this.isOwner</code>'
147
+ }
148
+ ])
149
+ },
150
+ {
151
+ title: '外观',
152
+ body: [
153
+ {
154
+ type: 'input-range',
155
+ name: 'actionsCount',
156
+ pipeIn: defaultValue(4),
157
+ min: 1,
158
+ max: 10,
159
+ step: 1,
160
+ label: '卡片一行最多能放按钮个数'
161
+ },
162
+ getSchemaTpl('className', {
163
+ name: 'titleClassName',
164
+ label: '标题 CSS 类名'
165
+ }),
166
+ getSchemaTpl('className', {
167
+ name: 'highlightClassName',
168
+ label: '高亮 CSS 类名'
169
+ }),
170
+ getSchemaTpl('className', {
171
+ name: 'subTitleClassName',
172
+ label: '副标题 CSS 类名'
173
+ }),
174
+ getSchemaTpl('className', {
175
+ name: 'descClassName',
176
+ label: '描述 CSS 类名'
177
+ }),
178
+ getSchemaTpl('className', {
179
+ name: 'avatarClassName',
180
+ label: '图片外层 CSS 类名'
181
+ }),
182
+ getSchemaTpl('className', {
183
+ name: 'imageClassName',
184
+ label: '图片 CSS 类名'
185
+ }),
186
+ getSchemaTpl('className', {
187
+ name: 'bodyClassName',
188
+ label: '内容区 CSS 类名'
189
+ }),
190
+ getSchemaTpl('className')
191
+ ]
192
+ },
193
+ {
194
+ title: '显隐',
195
+ body: [getSchemaTpl('ref'), getSchemaTpl('visible')]
196
+ }
197
+ ])
198
+ ];
199
+ };
200
+
201
+ /*exchangeRenderer(id: string) {
202
+ this.manager.showReplacePanel(id, '展示');
203
+ }*/
204
+
205
+ fieldWrapperResolve = (dom: HTMLElement) => dom;
206
+ overrides = {
207
+ renderFeild: function (
208
+ this: any,
209
+ region: string,
210
+ field: any,
211
+ index: any,
212
+ props: any
213
+ ) {
214
+ const dom = this.super(region, field, index, props);
215
+ const info: RendererInfo = this.props.$$editor;
216
+
217
+ if (!info || !field.$$id) {
218
+ return dom;
219
+ }
220
+
221
+ const plugin = info.plugin as CardPlugin;
222
+ const id = field.$$id;
223
+ return (
224
+ <VRenderer
225
+ type={info.type}
226
+ plugin={info.plugin}
227
+ renderer={info.renderer}
228
+ multifactor
229
+ key={id}
230
+ $schema="/schemas/CardBodyField.json"
231
+ hostId={info.id}
232
+ memberIndex={index}
233
+ name={`${`字段${index + 1}`}`}
234
+ id={id}
235
+ draggable={false}
236
+ wrapperResolve={plugin.fieldWrapperResolve}
237
+ schemaPath={`${info.schemaPath}/body/${index}`}
238
+ path={`${this.props.$path}/${index}`} // 好像没啥用
239
+ data={this.props.data} // 好像没啥用
240
+ >
241
+ {dom}
242
+ </VRenderer>
243
+ );
244
+ }
245
+ };
246
+
247
+ vRendererConfig: VRendererConfig = {
248
+ panelTitle: '字段',
249
+ panelBodyCreator: (context: BaseEventContext) => {
250
+ return [
251
+ getSchemaTpl('label'),
252
+ getSchemaTpl('className', {
253
+ name: 'labelClassName',
254
+ label: 'Label CSS 类名',
255
+ visibleOn: 'this.label'
256
+ })
257
+ /*{
258
+ children: (
259
+ <Button
260
+ size="sm"
261
+ level="info"
262
+ className="m-b"
263
+ block
264
+ onClick={this.exchangeRenderer.bind(this, context.id)}
265
+ >
266
+ 更改渲染器类型
267
+ </Button>
268
+ )
269
+ }*/
270
+ ];
271
+ }
272
+ };
273
+
274
+ // 自动插入 label
275
+ beforeInsert(event: PluginEvent<InsertEventContext>) {
276
+ const context = event.context;
277
+
278
+ if (
279
+ (context.info.plugin === this ||
280
+ context.node.sameIdChild?.info.plugin === this) &&
281
+ context.region === 'body'
282
+ ) {
283
+ context.data = {
284
+ ...context.data,
285
+ label: context.data.label ?? context.subRenderer?.name ?? '列名称'
286
+ };
287
+ }
288
+ }
289
+ }
290
+
291
+ registerEditorPlugin(CardPlugin);
@@ -0,0 +1,312 @@
1
+ import {Button, resolveVariable} from 'amis';
2
+ import React from 'react';
3
+ import {registerEditorPlugin} from '../manager';
4
+ import {
5
+ BaseEventContext,
6
+ BasePlugin,
7
+ BasicPanelItem,
8
+ BasicRendererInfo,
9
+ BasicToolbarItem,
10
+ ContextMenuEventContext,
11
+ ContextMenuItem,
12
+ PluginInterface,
13
+ RegionConfig,
14
+ RendererInfo,
15
+ RendererInfoResolveEventContext
16
+ } from '../plugin';
17
+ import {defaultValue, getSchemaTpl} from '../component/schemaTpl';
18
+ import {diff, JSONPipeOut, repeatArray} from '../util';
19
+
20
+ export class CardsPlugin extends BasePlugin {
21
+ // 关联渲染器名字
22
+ rendererName = 'cards';
23
+ $schema = '/schemas/CardsSchema.json';
24
+
25
+ // 组件名称
26
+ name = '卡片列表';
27
+ isBaseComponent = true;
28
+ description =
29
+ '功能类似于表格,但是用一个个小卡片来展示数据。当前组件需要配置数据源,不自带数据拉取,请优先使用 「CRUD」 组件。';
30
+ docLink = '/amis/zh-CN/components/cards';
31
+ tags = ['展示'];
32
+ icon = 'fa fa-window-maximize';
33
+ scaffold = {
34
+ type: 'cards',
35
+ data: {
36
+ items: [
37
+ {a: 1, b: 2},
38
+ {a: 3, b: 4}
39
+ ]
40
+ },
41
+ columnsCount: 2,
42
+ card: {
43
+ type: 'card',
44
+ className: 'm-b-none',
45
+ header: {
46
+ title: '标题',
47
+ subTitle: '副标题'
48
+ },
49
+ body: [
50
+ {
51
+ name: 'a',
52
+ label: 'A'
53
+ },
54
+ {
55
+ name: 'b',
56
+ label: 'B'
57
+ }
58
+ ],
59
+ actions: [
60
+ {
61
+ label: '详情',
62
+ type: 'button'
63
+ }
64
+ ]
65
+ }
66
+ };
67
+ previewSchema = {
68
+ ...this.scaffold,
69
+ className: 'text-left '
70
+ };
71
+
72
+ panelTitle = '卡片集';
73
+ panelBodyCreator = (context: BaseEventContext) => {
74
+ const isCRUDBody = context.schema.type === 'crud';
75
+ return [
76
+ getSchemaTpl('tabs', [
77
+ {
78
+ title: '常规',
79
+ body: [
80
+ {
81
+ children: (
82
+ <div className="m-b">
83
+ <Button
84
+ level="success"
85
+ size="sm"
86
+ block
87
+ onClick={this.editDetail.bind(this, context.id)}
88
+ >
89
+ 配置单项信息
90
+ </Button>
91
+ </div>
92
+ )
93
+ },
94
+
95
+ {
96
+ type: 'divider'
97
+ },
98
+ {
99
+ name: 'title',
100
+ type: 'input-text',
101
+ label: '标题'
102
+ },
103
+ {
104
+ name: 'href',
105
+ type: 'input-text',
106
+ label: '打开外部链接'
107
+ },
108
+ isCRUDBody
109
+ ? null
110
+ : {
111
+ name: 'source',
112
+ type: 'input-text',
113
+ label: '数据源',
114
+ pipeIn: defaultValue('${items}'),
115
+ description: '绑定当前环境变量',
116
+ test: !isCRUDBody
117
+ },
118
+ {
119
+ name: 'placeholder',
120
+ value: '暂无数据',
121
+ type: 'input-text',
122
+ label: '无数据提示'
123
+ }
124
+ ]
125
+ },
126
+ {
127
+ title: '外观',
128
+ body: [
129
+ getSchemaTpl('switch', {
130
+ name: 'showHeader',
131
+ label: '是否显示头部',
132
+ pipeIn: defaultValue(true)
133
+ }),
134
+
135
+ getSchemaTpl('switch', {
136
+ name: 'showFooter',
137
+ label: '是否显示底部',
138
+ pipeIn: defaultValue(true)
139
+ }),
140
+
141
+ getSchemaTpl('className', {
142
+ label: 'CSS 类名'
143
+ }),
144
+ getSchemaTpl('className', {
145
+ name: 'headerClassName',
146
+ label: '头部 CSS 类名'
147
+ }),
148
+ getSchemaTpl('className', {
149
+ name: 'footerClassName',
150
+ label: '底部 CSS 类名'
151
+ }),
152
+ getSchemaTpl('className', {
153
+ name: 'itemsClassName',
154
+ label: '内容 CSS 类名'
155
+ }),
156
+ getSchemaTpl('className', {
157
+ pipeIn: defaultValue('Grid-col--sm6 Grid-col--md4 Grid-col--lg3'),
158
+ name: 'itemClassName',
159
+ label: '卡片 CSS 类名'
160
+ }),
161
+ {
162
+ name: 'columnsCount',
163
+ type: 'input-range',
164
+ visibleOn: '!this.leftFixed',
165
+ min: 0,
166
+ max: 12,
167
+ step: 1,
168
+ label: '每行显示个数',
169
+ description: '不设置时,由卡片 CSS 类名决定'
170
+ },
171
+ getSchemaTpl('switch', {
172
+ name: 'masonryLayout',
173
+ label: '启用瀑布流'
174
+ })
175
+ ]
176
+ },
177
+ {
178
+ title: '显隐',
179
+ body: [getSchemaTpl('ref'), getSchemaTpl('visible')]
180
+ }
181
+ ])
182
+ ];
183
+ };
184
+
185
+ editDetail(id: string) {
186
+ const manager = this.manager;
187
+ const store = manager.store;
188
+ const node = store.getNodeById(id);
189
+ const value = store.getValueOf(id);
190
+
191
+ node &&
192
+ value &&
193
+ this.manager.openSubEditor({
194
+ title: '配置成员渲染器',
195
+ value: {
196
+ type: 'card',
197
+ ...value.card
198
+ },
199
+ slot: {
200
+ type: 'container',
201
+ body: '$$'
202
+ },
203
+ typeMutable: false,
204
+ onChange: newValue => {
205
+ newValue = {...value, card: newValue};
206
+ manager.panelChangeValue(newValue, diff(value, newValue));
207
+ },
208
+ data: {
209
+ item: 'mocked data',
210
+ index: 0
211
+ }
212
+ });
213
+ }
214
+
215
+ buildEditorToolbar(
216
+ {id, info, schema}: BaseEventContext,
217
+ toolbars: Array<BasicToolbarItem>
218
+ ) {
219
+ if (
220
+ info.renderer.name === 'cards' ||
221
+ (info.renderer.name === 'crud' && schema.mode === 'cards')
222
+ ) {
223
+ toolbars.push({
224
+ icon: 'fa fa-expand',
225
+ order: 100,
226
+ tooltip: '配置成员渲染器',
227
+ onClick: this.editDetail.bind(this, id)
228
+ });
229
+ }
230
+ }
231
+
232
+ buildEditorContextMenu(
233
+ {id, schema, region, info, selections}: ContextMenuEventContext,
234
+ menus: Array<ContextMenuItem>
235
+ ) {
236
+ if (selections.length || info?.plugin !== this) {
237
+ return;
238
+ }
239
+ if (
240
+ info.renderer.name === 'cards' ||
241
+ (info.renderer.name === 'crud' && schema.mode === 'cards')
242
+ ) {
243
+ menus.push('|', {
244
+ label: '配置成员渲染器',
245
+ onSelect: this.editDetail.bind(this, id)
246
+ });
247
+ }
248
+ }
249
+
250
+ filterProps(props: any) {
251
+ const data = {
252
+ ...props.defaultData,
253
+ ...props.data
254
+ };
255
+ const arr = Array.isArray(props.value)
256
+ ? props.value
257
+ : typeof props.source === 'string'
258
+ ? resolveVariable(props.source, data)
259
+ : resolveVariable('items', data);
260
+
261
+ if (!Array.isArray(arr) || !arr.length) {
262
+ const mockedData: any = {
263
+ id: 666,
264
+ title: '假数据',
265
+ description: '假数据',
266
+ a: '假数据',
267
+ b: '假数据'
268
+ };
269
+
270
+ props.value = repeatArray(mockedData, 1).map((item, index) => ({
271
+ ...item,
272
+ id: index + 1
273
+ }));
274
+ }
275
+
276
+ const {$schema, ...rest} = props;
277
+
278
+ return {
279
+ ...JSONPipeOut(rest),
280
+ $schema
281
+ };
282
+ }
283
+
284
+ getRendererInfo(
285
+ context: RendererInfoResolveEventContext
286
+ ): BasicRendererInfo | void {
287
+ const plugin: PluginInterface = this;
288
+ const {renderer, schema} = context;
289
+ if (
290
+ !schema.$$id &&
291
+ schema.$$editor?.renderer.name === 'crud' &&
292
+ renderer.name === 'cards'
293
+ ) {
294
+ return {
295
+ ...({id: schema.$$editor.id} as any),
296
+ name: plugin.name!,
297
+ regions: plugin.regions,
298
+ patchContainers: plugin.patchContainers,
299
+ vRendererConfig: plugin.vRendererConfig,
300
+ wrapperProps: plugin.wrapperProps,
301
+ wrapperResolve: plugin.wrapperResolve,
302
+ filterProps: plugin.filterProps,
303
+ $schema: plugin.$schema,
304
+ renderRenderer: plugin.renderRenderer
305
+ };
306
+ }
307
+
308
+ return super.getRendererInfo(context);
309
+ }
310
+ }
311
+
312
+ registerEditorPlugin(CardsPlugin);