amis-editor 4.1.0-beta.4 → 4.2.0-beta.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (218) hide show
  1. package/dist/component/Breadcrumb.d.ts +23 -2
  2. package/dist/component/ClassNameControl.d.ts +1 -1
  3. package/dist/component/Control/APIControl.d.ts +2 -2
  4. package/dist/component/Control/OptionControl.d.ts +3 -3
  5. package/dist/component/Control/PopoverEdit.d.ts +4 -4
  6. package/dist/component/Control/ValidationControl.d.ts +1 -1
  7. package/dist/component/Editor.d.ts +20 -1
  8. package/dist/component/IFramePreview.d.ts +2 -1
  9. package/dist/component/NodeWrapper.d.ts +1 -1
  10. package/dist/component/Panel/RenderersPanel.d.ts +1 -2
  11. package/dist/component/Preview.d.ts +3 -1
  12. package/dist/component/RegionWrapper.d.ts +4 -0
  13. package/dist/component/ScaffoldModal.d.ts +1 -1
  14. package/dist/component/VRenderer.d.ts +4 -0
  15. package/dist/component/base/InputComponentName.d.ts +1 -1
  16. package/dist/component/base/SearchCustomRendererPanel.d.ts +15 -0
  17. package/dist/component/base/SearchPanel.d.ts +83 -0
  18. package/dist/component/base/SearchRendererPanel.d.ts +2 -42
  19. package/dist/component/base/ShortcutKey.d.ts +23 -0
  20. package/dist/env.d.ts +1 -1
  21. package/dist/exports.min.js +1 -1
  22. package/dist/index.d.ts +5 -1
  23. package/dist/index.min.js +1 -1
  24. package/dist/manager.d.ts +16 -4
  25. package/dist/plugin/Alert.d.ts +1 -1
  26. package/dist/plugin/Button.d.ts +1 -1
  27. package/dist/plugin/Card.d.ts +1 -0
  28. package/dist/plugin/Cards.d.ts +2 -1
  29. package/dist/plugin/Carousel.d.ts +1 -0
  30. package/dist/plugin/Chart.d.ts +1 -0
  31. package/dist/plugin/Collapse.d.ts +1 -0
  32. package/dist/plugin/Custom.d.ts +3 -0
  33. package/dist/plugin/CustomRegion.d.ts +40 -0
  34. package/dist/plugin/Dialog.d.ts +1 -1
  35. package/dist/plugin/Drawer.d.ts +1 -1
  36. package/dist/plugin/DropDownButton.d.ts +1 -1
  37. package/dist/plugin/Each.d.ts +1 -1
  38. package/dist/plugin/Flex.d.ts +1 -0
  39. package/dist/plugin/Form/Control.d.ts +1 -0
  40. package/dist/plugin/Form/Form.d.ts +19 -3
  41. package/dist/plugin/Form/Formula.d.ts +3 -3
  42. package/dist/plugin/Form/InputURL.d.ts +1 -0
  43. package/dist/plugin/Form/Switch.d.ts +2 -0
  44. package/dist/plugin/Grid.d.ts +1 -0
  45. package/dist/plugin/HBox.d.ts +1 -0
  46. package/dist/plugin/IFrame.d.ts +3 -3
  47. package/dist/plugin/Json.d.ts +1 -0
  48. package/dist/plugin/List.d.ts +2 -1
  49. package/dist/plugin/Mapping.d.ts +1 -0
  50. package/dist/plugin/Markdown.d.ts +1 -0
  51. package/dist/plugin/Nav.d.ts +1 -0
  52. package/dist/plugin/Page.d.ts +1 -1
  53. package/dist/plugin/Panel/Outline.d.ts +8 -0
  54. package/dist/plugin/Progress.d.ts +1 -0
  55. package/dist/plugin/QRCode.d.ts +1 -0
  56. package/dist/plugin/Reset.d.ts +0 -1
  57. package/dist/plugin/Service.d.ts +1 -0
  58. package/dist/plugin/Sparkline.d.ts +1 -0
  59. package/dist/plugin/Status.d.ts +1 -0
  60. package/dist/plugin/Steps.d.ts +1 -0
  61. package/dist/plugin/Submit.d.ts +0 -1
  62. package/dist/plugin/Table.d.ts +1 -1
  63. package/dist/plugin/TableView.d.ts +1 -0
  64. package/dist/plugin/Tasks.d.ts +1 -0
  65. package/dist/plugin/TooltipWrapper.d.ts +1 -0
  66. package/dist/plugin/Video.d.ts +1 -0
  67. package/dist/plugin/WebComponent.d.ts +1 -0
  68. package/dist/plugin/Wizard.d.ts +11 -2
  69. package/dist/plugin/Wrapper.d.ts +1 -0
  70. package/dist/plugin.d.ts +8 -7
  71. package/dist/store/editor.d.ts +58 -22
  72. package/dist/store/node.d.ts +6 -0
  73. package/dist/style.css +1 -1
  74. package/dist/util.d.ts +1 -1
  75. package/package.json +9 -3
  76. package/src/component/schemaTpl.tsx +2157 -0
  77. package/src/plugin/Alert.tsx +87 -0
  78. package/src/plugin/AnchorNav.tsx +233 -0
  79. package/src/plugin/Audio.tsx +154 -0
  80. package/src/plugin/Avatar.tsx +77 -0
  81. package/src/plugin/Breadcrumb.tsx +107 -0
  82. package/src/plugin/Button.tsx +281 -0
  83. package/src/plugin/ButtonGroup.tsx +85 -0
  84. package/src/plugin/ButtonToolbar.tsx +87 -0
  85. package/src/plugin/CRUD.tsx +1835 -0
  86. package/src/plugin/Card.tsx +290 -0
  87. package/src/plugin/Cards.tsx +318 -0
  88. package/src/plugin/Carousel.tsx +377 -0
  89. package/src/plugin/Chart.tsx +218 -0
  90. package/src/plugin/CodeView.tsx +60 -0
  91. package/src/plugin/Collapse.tsx +136 -0
  92. package/src/plugin/CollapseGroup.tsx +167 -0
  93. package/src/plugin/Container.tsx +40 -0
  94. package/src/plugin/Custom.tsx +128 -0
  95. package/src/plugin/CustomRegion.tsx +156 -0
  96. package/src/plugin/Date.tsx +74 -0
  97. package/src/plugin/Datetime.tsx +68 -0
  98. package/src/plugin/Dialog.tsx +176 -0
  99. package/src/plugin/Divider.tsx +36 -0
  100. package/src/plugin/Drawer.tsx +214 -0
  101. package/src/plugin/DropDownButton.tsx +235 -0
  102. package/src/plugin/Each.tsx +150 -0
  103. package/src/plugin/ErrorRenderer.tsx +15 -0
  104. package/src/plugin/Flex.tsx +151 -0
  105. package/src/plugin/Form/ButtonGroupSelect.tsx +75 -0
  106. package/src/plugin/Form/ButtonToolbar.tsx +110 -0
  107. package/src/plugin/Form/ChainedSelect.tsx +70 -0
  108. package/src/plugin/Form/Checkbox.tsx +87 -0
  109. package/src/plugin/Form/Checkboxes.tsx +167 -0
  110. package/src/plugin/Form/CodeEditor.tsx +81 -0
  111. package/src/plugin/Form/Combo.tsx +582 -0
  112. package/src/plugin/Form/ConditionBuilder.tsx +315 -0
  113. package/src/plugin/Form/Control.tsx +139 -0
  114. package/src/plugin/Form/DiffEditor.tsx +111 -0
  115. package/src/plugin/Form/FieldSet.tsx +163 -0
  116. package/src/plugin/Form/Form.tsx +687 -0
  117. package/src/plugin/Form/Formula.tsx +79 -0
  118. package/src/plugin/Form/Group.tsx +295 -0
  119. package/src/plugin/Form/Hidden.tsx +44 -0
  120. package/src/plugin/Form/InputArray.tsx +228 -0
  121. package/src/plugin/Form/InputCity.tsx +93 -0
  122. package/src/plugin/Form/InputColor.tsx +123 -0
  123. package/src/plugin/Form/InputDate.tsx +175 -0
  124. package/src/plugin/Form/InputDateRange.tsx +225 -0
  125. package/src/plugin/Form/InputDateTime.tsx +183 -0
  126. package/src/plugin/Form/InputDateTimeRange.tsx +221 -0
  127. package/src/plugin/Form/InputEmail.tsx +33 -0
  128. package/src/plugin/Form/InputExcel.tsx +85 -0
  129. package/src/plugin/Form/InputFile.tsx +221 -0
  130. package/src/plugin/Form/InputGroup.tsx +96 -0
  131. package/src/plugin/Form/InputImage.tsx +266 -0
  132. package/src/plugin/Form/InputKV.tsx +72 -0
  133. package/src/plugin/Form/InputMonth.tsx +35 -0
  134. package/src/plugin/Form/InputMonthRange.tsx +195 -0
  135. package/src/plugin/Form/InputNumber.tsx +89 -0
  136. package/src/plugin/Form/InputPassword.tsx +33 -0
  137. package/src/plugin/Form/InputQuarter.tsx +35 -0
  138. package/src/plugin/Form/InputQuarterRange.tsx +195 -0
  139. package/src/plugin/Form/InputRange.tsx +121 -0
  140. package/src/plugin/Form/InputRating.tsx +78 -0
  141. package/src/plugin/Form/InputRepeat.tsx +57 -0
  142. package/src/plugin/Form/InputRichText.tsx +186 -0
  143. package/src/plugin/Form/InputSubForm.tsx +189 -0
  144. package/src/plugin/Form/InputTable.tsx +434 -0
  145. package/src/plugin/Form/InputTag.tsx +70 -0
  146. package/src/plugin/Form/InputText.tsx +186 -0
  147. package/src/plugin/Form/InputTime.tsx +85 -0
  148. package/src/plugin/Form/InputTree.tsx +229 -0
  149. package/src/plugin/Form/InputURL.tsx +34 -0
  150. package/src/plugin/Form/InputYear.tsx +35 -0
  151. package/src/plugin/Form/Item.tsx +327 -0
  152. package/src/plugin/Form/ListSelect.tsx +73 -0
  153. package/src/plugin/Form/LocationPicker.tsx +62 -0
  154. package/src/plugin/Form/MatrixCheckboxes.tsx +136 -0
  155. package/src/plugin/Form/NestedSelect.tsx +211 -0
  156. package/src/plugin/Form/Picker.tsx +209 -0
  157. package/src/plugin/Form/Radios.tsx +119 -0
  158. package/src/plugin/Form/Select.tsx +233 -0
  159. package/src/plugin/Form/Static.tsx +322 -0
  160. package/src/plugin/Form/Switch.tsx +107 -0
  161. package/src/plugin/Form/TabsTransfer.tsx +259 -0
  162. package/src/plugin/Form/Textarea.tsx +83 -0
  163. package/src/plugin/Form/Transfer.tsx +368 -0
  164. package/src/plugin/Form/TreeSelect.tsx +263 -0
  165. package/src/plugin/Form/UUID.tsx +48 -0
  166. package/src/plugin/Grid.tsx +798 -0
  167. package/src/plugin/HBox.tsx +727 -0
  168. package/src/plugin/IFrame.tsx +70 -0
  169. package/src/plugin/Image.tsx +314 -0
  170. package/src/plugin/Images.tsx +231 -0
  171. package/src/plugin/Json.tsx +69 -0
  172. package/src/plugin/Link.tsx +93 -0
  173. package/src/plugin/List.tsx +278 -0
  174. package/src/plugin/ListItem.tsx +229 -0
  175. package/src/plugin/Log.tsx +52 -0
  176. package/src/plugin/Mapping.tsx +149 -0
  177. package/src/plugin/Markdown.tsx +47 -0
  178. package/src/plugin/Nav.tsx +184 -0
  179. package/src/plugin/Operation.tsx +95 -0
  180. package/src/plugin/Others/Action.tsx +426 -0
  181. package/src/plugin/Others/BasicToolbar.tsx +585 -0
  182. package/src/plugin/Others/DataDebug.tsx +134 -0
  183. package/src/plugin/Others/TableCell.tsx +480 -0
  184. package/src/plugin/Others/Unknown.tsx +37 -0
  185. package/src/plugin/Page.tsx +306 -0
  186. package/src/plugin/Panel/AvailableRenderers.tsx +41 -0
  187. package/src/plugin/Panel/Code.tsx +44 -0
  188. package/src/plugin/Panel/Name.tsx +26 -0
  189. package/src/plugin/Panel/Outline.tsx +40 -0
  190. package/src/plugin/Panel.tsx +243 -0
  191. package/src/plugin/Plain.tsx +84 -0
  192. package/src/plugin/Progress.tsx +125 -0
  193. package/src/plugin/Property.tsx +139 -0
  194. package/src/plugin/QRCode.tsx +96 -0
  195. package/src/plugin/Reset.tsx +23 -0
  196. package/src/plugin/Service.tsx +162 -0
  197. package/src/plugin/Sparkline.tsx +40 -0
  198. package/src/plugin/Status.tsx +76 -0
  199. package/src/plugin/Steps.tsx +128 -0
  200. package/src/plugin/Submit.tsx +23 -0
  201. package/src/plugin/Table.tsx +428 -0
  202. package/src/plugin/TableView.tsx +709 -0
  203. package/src/plugin/Tabs.tsx +362 -0
  204. package/src/plugin/Tasks.tsx +274 -0
  205. package/src/plugin/Time.tsx +68 -0
  206. package/src/plugin/TooltipWrapper.tsx +193 -0
  207. package/src/plugin/Tpl.tsx +158 -0
  208. package/src/plugin/Video.tsx +158 -0
  209. package/src/plugin/WebComponent.tsx +53 -0
  210. package/src/plugin/Wizard.tsx +740 -0
  211. package/src/plugin/Wrapper.tsx +107 -0
  212. package/src/plugin.ts +1050 -0
  213. package/dist/150a58f3318ca7541ed9.png +0 -0
  214. package/dist/471adb97c322b226e589.png +0 -0
  215. package/dist/4de5f42360bc5946c3c2.png +0 -0
  216. package/dist/4e9968bba3855f088fed.png +0 -0
  217. package/dist/7f09c38ebc687fea847a.png +0 -0
  218. package/dist/c94073576487510314ea.png +0 -0
@@ -0,0 +1,480 @@
1
+ import {Button} from 'amis';
2
+ import React from 'react';
3
+ import {registerEditorPlugin} from '../../manager';
4
+ import {
5
+ BasePlugin,
6
+ BasicRendererInfo,
7
+ BaseEventContext,
8
+ RendererInfoResolveEventContext,
9
+ ReplaceEventContext,
10
+ PluginEvent
11
+ } from '../../plugin';
12
+ import {defaultValue, getSchemaTpl} from '../../component/schemaTpl';
13
+ import {getVariable} from 'amis-core';
14
+
15
+ export class TableCellPlugin extends BasePlugin {
16
+ panelTitle = '列配置';
17
+ panelIcon = 'fa fa-columns';
18
+ panelBodyCreator = (context: BaseEventContext) => {
19
+ return [
20
+ getSchemaTpl('tabs', [
21
+ {
22
+ title: '常规',
23
+ body: [
24
+ /*{
25
+ children: (
26
+ <Button
27
+ size="sm"
28
+ level="info"
29
+ className="m-b"
30
+ block
31
+ onClick={this.exchangeRenderer.bind(this, context.id)}
32
+ >
33
+ 更改渲染器类型
34
+ </Button>
35
+ )
36
+ },*/
37
+ {
38
+ name: 'label',
39
+ label: '列名称',
40
+ type: 'input-text'
41
+ },
42
+
43
+ {
44
+ name: 'name',
45
+ type: 'input-text',
46
+ label: '绑定字段名'
47
+ },
48
+
49
+ {
50
+ name: 'remark',
51
+ label: '提示',
52
+ type: 'input-text',
53
+ description: '显示一个提示图标,鼠标放上去会提示该内容。'
54
+ },
55
+
56
+ {
57
+ name: 'placeholder',
58
+ type: 'input-text',
59
+ label: '占位符',
60
+ value: '-',
61
+ description: '当没有值时用这个来替代展示'
62
+ },
63
+
64
+ {
65
+ name: 'sortable',
66
+ type: 'switch',
67
+ label: '是否可排序',
68
+ mode: 'inline',
69
+ className: 'w-full',
70
+ description: '开启后可以根据当前列排序(后端排序)。'
71
+ }
72
+ ]
73
+ },
74
+ {
75
+ title: '高级',
76
+ body: [
77
+ {
78
+ name: 'groupName',
79
+ label: '列分组名称',
80
+ type: 'input-text',
81
+ description:
82
+ '当多列的分组名称设置一致时,表格会在显示表头的上层显示超级表头,<a href="https://baidu.github.io/amis/crud/header-group" target="_blank">示例</a>'
83
+ },
84
+ {
85
+ name: 'quickEdit',
86
+ label: '启用快速编辑',
87
+ type: 'switch',
88
+ pipeIn: (value: any) => !!value,
89
+ mode: 'inline',
90
+ className: 'w-full'
91
+ },
92
+
93
+ {
94
+ visibleOn: 'data.quickEdit',
95
+ name: 'quickEdit.mode',
96
+ type: 'button-group-select',
97
+ value: 'popOver',
98
+ label: '快速编辑模式',
99
+ size: 'xs',
100
+ mode: 'inline',
101
+ className: 'w-full',
102
+ options: [
103
+ {
104
+ label: '下拉',
105
+ value: 'popOver'
106
+ },
107
+ {
108
+ label: '内嵌',
109
+ value: 'inline'
110
+ }
111
+ ]
112
+ },
113
+
114
+ {
115
+ visibleOn: 'data.quickEdit',
116
+ name: 'quickEdit.saveImmediately',
117
+ label: '是否立即保存',
118
+ type: 'switch',
119
+ mode: 'inline',
120
+ className: 'w-full',
121
+ description: '开启后修改即提交,而不是标记修改批量提交。',
122
+ descriptionClassName: 'help-block m-b-none',
123
+ pipeIn: (value: any) => !!value
124
+ },
125
+
126
+ getSchemaTpl('api', {
127
+ label: '立即保存接口',
128
+ description:
129
+ '是否单独给立即保存配置接口,如果不配置,则默认使用quickSaveItemApi。',
130
+ name: 'quickEdit.saveImmediately.api',
131
+ visibleOn: 'this.quickEdit && this.quickEdit.saveImmediately'
132
+ }),
133
+
134
+ {
135
+ visibleOn: 'data.quickEdit',
136
+ name: 'quickEdit',
137
+ asFormItem: true,
138
+ children: ({value, onChange, data}: any) => {
139
+ if (value === true) {
140
+ value = {};
141
+ } else if (typeof value === 'undefined') {
142
+ value = getVariable(data, 'quickEdit');
143
+ }
144
+
145
+ const originMode = value.mode;
146
+
147
+ value = {
148
+ type: 'input-text',
149
+ name: data.name,
150
+ ...value
151
+ };
152
+ delete value.mode;
153
+
154
+ // todo 多个快速编辑表单模式看来只能代码模式编辑了。
155
+
156
+ return (
157
+ <Button
158
+ level="info"
159
+ className="m-b"
160
+ size="sm"
161
+ block
162
+ onClick={() => {
163
+ this.manager.openSubEditor({
164
+ title: '配置快速编辑类型',
165
+ value: value,
166
+ slot: {
167
+ type: 'form',
168
+ mode: 'normal',
169
+ body: ['$$'],
170
+ wrapWithPanel: false
171
+ },
172
+ onChange: value =>
173
+ onChange(
174
+ {
175
+ ...value,
176
+ mode: originMode
177
+ },
178
+ 'quickEdit'
179
+ )
180
+ });
181
+ }}
182
+ >
183
+ 配置快速编辑
184
+ </Button>
185
+ );
186
+ }
187
+ },
188
+
189
+ {
190
+ name: 'popOver',
191
+ label: '启用查看更多展示',
192
+ type: 'switch',
193
+ pipeIn: (value: any) => !!value,
194
+ mode: 'inline',
195
+ className: 'w-full'
196
+ },
197
+
198
+ {
199
+ name: 'popOver.mode',
200
+ label: '查看更多弹出模式',
201
+ type: 'select',
202
+ visibleOn: 'data.popOver',
203
+ pipeIn: defaultValue('popOver'),
204
+ options: [
205
+ {
206
+ label: '默认',
207
+ value: 'popOver'
208
+ },
209
+
210
+ {
211
+ label: '弹框',
212
+ value: 'dialog'
213
+ },
214
+
215
+ {
216
+ label: '抽出式弹框',
217
+ value: 'drawer'
218
+ }
219
+ ]
220
+ },
221
+
222
+ {
223
+ name: 'popOver.position',
224
+ label: '查看更多弹出模式',
225
+ type: 'select',
226
+ visibleOn: 'data.popOver && data.popOver.mode === "popOver"',
227
+ pipeIn: defaultValue('center'),
228
+ options: [
229
+ {
230
+ label: '目标中部',
231
+ value: 'center'
232
+ },
233
+
234
+ {
235
+ label: '目标左上角',
236
+ value: 'left-top'
237
+ },
238
+
239
+ {
240
+ label: '目标右上角',
241
+ value: 'right-top'
242
+ },
243
+
244
+ {
245
+ label: '目标左下角',
246
+ value: 'left-bottom'
247
+ },
248
+
249
+ {
250
+ label: '目标右下角',
251
+ value: 'right-bottom'
252
+ },
253
+
254
+ {
255
+ label: '页面左上角',
256
+ value: 'fixed-left-top'
257
+ },
258
+
259
+ {
260
+ label: '页面右上角',
261
+ value: 'fixed-right-top'
262
+ },
263
+
264
+ {
265
+ label: '页面左下角',
266
+ value: 'fixed-left-bottom'
267
+ },
268
+
269
+ {
270
+ label: '页面右下角',
271
+ value: 'fixed-right-bottom'
272
+ }
273
+ ]
274
+ },
275
+
276
+ {
277
+ visibleOn: 'data.popOver',
278
+ name: 'popOver',
279
+ asFormItem: true,
280
+ children: ({value, onChange}: any) => {
281
+ value = {
282
+ type: 'panel',
283
+ title: '查看详情',
284
+ body: '内容详情',
285
+ ...value
286
+ };
287
+
288
+ return (
289
+ <Button
290
+ level="info"
291
+ className="m-b"
292
+ size="sm"
293
+ block
294
+ onClick={() => {
295
+ this.manager.openSubEditor({
296
+ title: '配置查看更多展示内容',
297
+ value: value,
298
+ onChange: value => onChange(value, 'popOver')
299
+ });
300
+ }}
301
+ >
302
+ 查看更多内容配置
303
+ </Button>
304
+ );
305
+ }
306
+ },
307
+
308
+ {
309
+ name: 'copyable',
310
+ label: '启用内容复制功能',
311
+ type: 'switch',
312
+ pipeIn: (value: any) => !!value,
313
+ mode: 'inline',
314
+ className: 'w-full'
315
+ },
316
+
317
+ {
318
+ visibleOn: 'data.copyable',
319
+ name: 'copyable.content',
320
+ type: 'textarea',
321
+ label: '复制内容模板',
322
+ description: '默认为当前字段值,可定制。'
323
+ }
324
+ ]
325
+ },
326
+ {
327
+ title: '外观',
328
+ body: [
329
+ {
330
+ name: 'fixed',
331
+ type: 'button-group-select',
332
+ label: '固定位置',
333
+ pipeIn: defaultValue(''),
334
+ size: 'xs',
335
+ mode: 'inline',
336
+ className: 'w-full',
337
+ options: [
338
+ {
339
+ value: '',
340
+ label: '不固定'
341
+ },
342
+
343
+ {
344
+ value: 'left',
345
+ label: '左侧'
346
+ },
347
+
348
+ {
349
+ value: 'right',
350
+ label: '右侧'
351
+ }
352
+ ]
353
+ },
354
+
355
+ {
356
+ name: 'toggled',
357
+ type: 'switch',
358
+ label: '默认展示',
359
+ mode: 'inline',
360
+ className: 'w-full',
361
+ pipeIn: defaultValue(true)
362
+ },
363
+
364
+ {
365
+ name: 'breakpoint',
366
+ type: 'button-group-select',
367
+ label: '触发底部显示条件',
368
+ visibleOn: 'data.tableFootableEnabled',
369
+ size: 'xs',
370
+ multiple: true,
371
+ options: [
372
+ {
373
+ label: '总是',
374
+ value: '*'
375
+ },
376
+ {
377
+ label: '手机端',
378
+ value: 'xs'
379
+ },
380
+ {
381
+ label: '平板',
382
+ value: 'sm'
383
+ },
384
+ {
385
+ label: 'PC小屏',
386
+ value: 'md'
387
+ },
388
+ {
389
+ label: 'PC大屏',
390
+ value: 'lg'
391
+ }
392
+ ],
393
+ pipeIn: (value: any) =>
394
+ value ? (typeof value === 'string' ? value : '*') : '',
395
+ pipeOut: (value: any) =>
396
+ typeof value === 'string' &&
397
+ ~value.indexOf('*') &&
398
+ /xs|sm|md|lg/.test(value)
399
+ ? value.replace(/\*\s*,\s*|\s*,\s*\*/g, '')
400
+ : value
401
+ },
402
+
403
+ {
404
+ type: 'switch',
405
+ name: 'className',
406
+ label: '内容强制换行',
407
+ mode: 'inline',
408
+ className: 'w-full',
409
+ pipeIn: (value: any) =>
410
+ typeof value === 'string' && /\word\-break\b/.test(value),
411
+ pipeOut: (value: any, originValue: any) =>
412
+ (value ? 'word-break ' : '') +
413
+ (originValue || '').replace(/\bword\-break\b/g, '').trim()
414
+ },
415
+
416
+ getSchemaTpl('className'),
417
+ getSchemaTpl('className', {
418
+ name: 'innerClassName',
419
+ label: '内部 CSS 类名'
420
+ }),
421
+
422
+ {
423
+ name: 'width',
424
+ type: 'input-number',
425
+ label: '列宽',
426
+ description: '固定列的宽度,不推荐设置。'
427
+ }
428
+ ]
429
+ }
430
+ ])
431
+ ];
432
+ };
433
+
434
+ // filterProps(props: any) {
435
+ // props = JSONPipeOut(props, true);
436
+ // return props;
437
+ // }
438
+
439
+ getRendererInfo({
440
+ renderer,
441
+ schema
442
+ }: RendererInfoResolveEventContext): BasicRendererInfo | void {
443
+ if (renderer.name === 'table-cell') {
444
+ return {
445
+ name: schema.label ? `<${schema.label}>列` : '匿名列',
446
+ $schema: '/schemas/TableColumn.json',
447
+ multifactor: true,
448
+ wrapperResolve: (dom: HTMLTableCellElement) => {
449
+ const siblings = [].slice.call(dom.parentElement!.children);
450
+ const index = siblings.indexOf(dom) + 1;
451
+ const table = dom.closest('table')!;
452
+
453
+ return [].slice.call(
454
+ table.querySelectorAll(
455
+ `th:nth-child(${index}):not([data-editor-id="${schema.id}"]),
456
+ td:nth-child(${index}):not([data-editor-id="${schema.id}"])`
457
+ )
458
+ );
459
+ }
460
+ // filterProps: this.filterProps
461
+ };
462
+ }
463
+ }
464
+
465
+ /*exchangeRenderer(id: string) {
466
+ this.manager.showReplacePanel(id, '展示');
467
+ }*/
468
+
469
+ beforeReplace(event: PluginEvent<ReplaceEventContext>) {
470
+ const context = event.context;
471
+
472
+ // 替换字段的时候保留 label 和 name 值。
473
+ if (context.info.plugin === this && context.data) {
474
+ context.data.label = context.data.label || context.schema.label;
475
+ context.data.name = context.data.name || context.schema.name;
476
+ }
477
+ }
478
+ }
479
+
480
+ registerEditorPlugin(TableCellPlugin);
@@ -0,0 +1,37 @@
1
+ import {registerEditorPlugin} from '../../manager';
2
+ import {
3
+ BasePlugin,
4
+ BasicRendererInfo,
5
+ PluginInterface,
6
+ RendererInfoResolveEventContext
7
+ } from '../../plugin';
8
+
9
+ export class UnkownRendererPlugin extends BasePlugin {
10
+ order = 9999;
11
+
12
+ getRendererInfo({
13
+ renderer,
14
+ schema,
15
+ path
16
+ }: RendererInfoResolveEventContext): BasicRendererInfo | void {
17
+ if (schema.$$id && renderer) {
18
+ // 有些就是不想做编辑器
19
+ if (/(^|\/)static\-field/.test(path)) {
20
+ return;
21
+ } else if (
22
+ renderer.name === 'card-item' ||
23
+ renderer.name === 'list-item-field'
24
+ ) {
25
+ return;
26
+ }
27
+
28
+ // 复制部分信息出去
29
+ return {
30
+ name: 'Unkown',
31
+ $schema: '/schemas/UnkownSchema.json'
32
+ };
33
+ }
34
+ }
35
+ }
36
+
37
+ registerEditorPlugin(UnkownRendererPlugin);