amis-editor 4.1.0-beta.2 → 4.1.0-beta.20

Sign up to get free protection for your applications and to get access to all the features.
Files changed (195) hide show
  1. package/dist/component/Breadcrumb.d.ts +23 -2
  2. package/dist/component/Editor.d.ts +19 -0
  3. package/dist/component/Panel/RenderersPanel.d.ts +1 -2
  4. package/dist/component/RegionWrapper.d.ts +4 -0
  5. package/dist/component/VRenderer.d.ts +4 -0
  6. package/dist/component/base/SearchCustomRendererPanel.d.ts +15 -0
  7. package/dist/component/base/SearchPanel.d.ts +83 -0
  8. package/dist/component/base/SearchRendererPanel.d.ts +2 -42
  9. package/dist/exports.min.js +1 -1
  10. package/dist/index.d.ts +4 -1
  11. package/dist/index.min.js +1 -1
  12. package/dist/manager.d.ts +14 -3
  13. package/dist/plugin/Card.d.ts +1 -0
  14. package/dist/plugin/Cards.d.ts +1 -0
  15. package/dist/plugin/Carousel.d.ts +1 -0
  16. package/dist/plugin/Chart.d.ts +1 -0
  17. package/dist/plugin/Collapse.d.ts +1 -0
  18. package/dist/plugin/Custom.d.ts +3 -0
  19. package/dist/plugin/CustomRegion.d.ts +43 -0
  20. package/dist/plugin/Flex.d.ts +1 -0
  21. package/dist/plugin/Form/Control.d.ts +1 -0
  22. package/dist/plugin/Form/Form.d.ts +19 -3
  23. package/dist/plugin/Form/InputURL.d.ts +1 -0
  24. package/dist/plugin/Grid.d.ts +1 -0
  25. package/dist/plugin/HBox.d.ts +1 -0
  26. package/dist/plugin/Json.d.ts +1 -0
  27. package/dist/plugin/List.d.ts +1 -0
  28. package/dist/plugin/Mapping.d.ts +1 -0
  29. package/dist/plugin/Markdown.d.ts +1 -0
  30. package/dist/plugin/Nav.d.ts +1 -0
  31. package/dist/plugin/Panel/Outline.d.ts +8 -0
  32. package/dist/plugin/Progress.d.ts +1 -0
  33. package/dist/plugin/QRCode.d.ts +1 -0
  34. package/dist/plugin/Reset.d.ts +0 -1
  35. package/dist/plugin/Service.d.ts +1 -0
  36. package/dist/plugin/Sparkline.d.ts +1 -0
  37. package/dist/plugin/Status.d.ts +1 -0
  38. package/dist/plugin/Steps.d.ts +1 -0
  39. package/dist/plugin/Submit.d.ts +0 -1
  40. package/dist/plugin/TableView.d.ts +1 -0
  41. package/dist/plugin/Tasks.d.ts +1 -0
  42. package/dist/plugin/TooltipWrapper.d.ts +1 -0
  43. package/dist/plugin/Video.d.ts +1 -0
  44. package/dist/plugin/WebComponent.d.ts +1 -0
  45. package/dist/plugin/Wizard.d.ts +11 -2
  46. package/dist/plugin/Wrapper.d.ts +1 -0
  47. package/dist/plugin.d.ts +2 -2
  48. package/dist/store/editor.d.ts +20 -2
  49. package/dist/store/node.d.ts +6 -0
  50. package/dist/style.css +1 -1
  51. package/dist/util.d.ts +7 -2
  52. package/package.json +6 -3
  53. package/src/component/schemaTpl.tsx +2155 -0
  54. package/src/plugin/Alert.tsx +87 -0
  55. package/src/plugin/AnchorNav.tsx +233 -0
  56. package/src/plugin/Audio.tsx +161 -0
  57. package/src/plugin/Avatar.tsx +77 -0
  58. package/src/plugin/Breadcrumb.tsx +107 -0
  59. package/src/plugin/Button.tsx +283 -0
  60. package/src/plugin/ButtonGroup.tsx +88 -0
  61. package/src/plugin/ButtonToolbar.tsx +89 -0
  62. package/src/plugin/CRUD.tsx +1832 -0
  63. package/src/plugin/Card.tsx +290 -0
  64. package/src/plugin/Cards.tsx +315 -0
  65. package/src/plugin/Carousel.tsx +386 -0
  66. package/src/plugin/Chart.tsx +218 -0
  67. package/src/plugin/CodeView.tsx +60 -0
  68. package/src/plugin/Collapse.tsx +143 -0
  69. package/src/plugin/CollapseGroup.tsx +167 -0
  70. package/src/plugin/Container.tsx +44 -0
  71. package/src/plugin/Custom.tsx +128 -0
  72. package/src/plugin/CustomRegion.tsx +150 -0
  73. package/src/plugin/Date.tsx +81 -0
  74. package/src/plugin/Datetime.tsx +75 -0
  75. package/src/plugin/Dialog.tsx +178 -0
  76. package/src/plugin/Divider.tsx +36 -0
  77. package/src/plugin/Drawer.tsx +217 -0
  78. package/src/plugin/DropDownButton.tsx +234 -0
  79. package/src/plugin/Each.tsx +152 -0
  80. package/src/plugin/ErrorRenderer.tsx +15 -0
  81. package/src/plugin/Flex.tsx +156 -0
  82. package/src/plugin/Form/ButtonGroupSelect.tsx +86 -0
  83. package/src/plugin/Form/ButtonToolbar.tsx +121 -0
  84. package/src/plugin/Form/ChainedSelect.tsx +70 -0
  85. package/src/plugin/Form/Checkbox.tsx +87 -0
  86. package/src/plugin/Form/Checkboxes.tsx +167 -0
  87. package/src/plugin/Form/CodeEditor.tsx +91 -0
  88. package/src/plugin/Form/Combo.tsx +582 -0
  89. package/src/plugin/Form/ConditionBuilder.tsx +324 -0
  90. package/src/plugin/Form/Control.tsx +139 -0
  91. package/src/plugin/Form/DiffEditor.tsx +117 -0
  92. package/src/plugin/Form/FieldSet.tsx +175 -0
  93. package/src/plugin/Form/Form.tsx +692 -0
  94. package/src/plugin/Form/Formula.tsx +91 -0
  95. package/src/plugin/Form/Group.tsx +300 -0
  96. package/src/plugin/Form/Hidden.tsx +56 -0
  97. package/src/plugin/Form/InputArray.tsx +228 -0
  98. package/src/plugin/Form/InputCity.tsx +93 -0
  99. package/src/plugin/Form/InputColor.tsx +123 -0
  100. package/src/plugin/Form/InputDate.tsx +175 -0
  101. package/src/plugin/Form/InputDateRange.tsx +225 -0
  102. package/src/plugin/Form/InputDateTime.tsx +183 -0
  103. package/src/plugin/Form/InputDateTimeRange.tsx +221 -0
  104. package/src/plugin/Form/InputEmail.tsx +33 -0
  105. package/src/plugin/Form/InputExcel.tsx +85 -0
  106. package/src/plugin/Form/InputFile.tsx +228 -0
  107. package/src/plugin/Form/InputGroup.tsx +105 -0
  108. package/src/plugin/Form/InputImage.tsx +277 -0
  109. package/src/plugin/Form/InputKV.tsx +72 -0
  110. package/src/plugin/Form/InputMonth.tsx +35 -0
  111. package/src/plugin/Form/InputMonthRange.tsx +195 -0
  112. package/src/plugin/Form/InputNumber.tsx +97 -0
  113. package/src/plugin/Form/InputPassword.tsx +33 -0
  114. package/src/plugin/Form/InputQuarter.tsx +35 -0
  115. package/src/plugin/Form/InputQuarterRange.tsx +195 -0
  116. package/src/plugin/Form/InputRange.tsx +121 -0
  117. package/src/plugin/Form/InputRating.tsx +78 -0
  118. package/src/plugin/Form/InputRepeat.tsx +69 -0
  119. package/src/plugin/Form/InputRichText.tsx +197 -0
  120. package/src/plugin/Form/InputSubForm.tsx +198 -0
  121. package/src/plugin/Form/InputTable.tsx +434 -0
  122. package/src/plugin/Form/InputTag.tsx +81 -0
  123. package/src/plugin/Form/InputText.tsx +186 -0
  124. package/src/plugin/Form/InputTime.tsx +95 -0
  125. package/src/plugin/Form/InputTree.tsx +240 -0
  126. package/src/plugin/Form/InputURL.tsx +34 -0
  127. package/src/plugin/Form/InputYear.tsx +35 -0
  128. package/src/plugin/Form/Item.tsx +325 -0
  129. package/src/plugin/Form/ListSelect.tsx +84 -0
  130. package/src/plugin/Form/LocationPicker.tsx +75 -0
  131. package/src/plugin/Form/MatrixCheckboxes.tsx +147 -0
  132. package/src/plugin/Form/NestedSelect.tsx +222 -0
  133. package/src/plugin/Form/Picker.tsx +217 -0
  134. package/src/plugin/Form/Radios.tsx +130 -0
  135. package/src/plugin/Form/Select.tsx +216 -0
  136. package/src/plugin/Form/Static.tsx +335 -0
  137. package/src/plugin/Form/Switch.tsx +116 -0
  138. package/src/plugin/Form/TabsTransfer.tsx +270 -0
  139. package/src/plugin/Form/Textarea.tsx +94 -0
  140. package/src/plugin/Form/Transfer.tsx +379 -0
  141. package/src/plugin/Form/TreeSelect.tsx +263 -0
  142. package/src/plugin/Form/UUID.tsx +48 -0
  143. package/src/plugin/Grid.tsx +799 -0
  144. package/src/plugin/HBox.tsx +727 -0
  145. package/src/plugin/IFrame.tsx +72 -0
  146. package/src/plugin/Image.tsx +318 -0
  147. package/src/plugin/Images.tsx +238 -0
  148. package/src/plugin/Json.tsx +76 -0
  149. package/src/plugin/Link.tsx +95 -0
  150. package/src/plugin/List.tsx +278 -0
  151. package/src/plugin/ListItem.tsx +233 -0
  152. package/src/plugin/Log.tsx +52 -0
  153. package/src/plugin/Mapping.tsx +156 -0
  154. package/src/plugin/Markdown.tsx +47 -0
  155. package/src/plugin/Nav.tsx +186 -0
  156. package/src/plugin/Operation.tsx +97 -0
  157. package/src/plugin/Others/Action.tsx +428 -0
  158. package/src/plugin/Others/BasicToolbar.tsx +591 -0
  159. package/src/plugin/Others/DataDebug.tsx +134 -0
  160. package/src/plugin/Others/TableCell.tsx +480 -0
  161. package/src/plugin/Others/Unknown.tsx +37 -0
  162. package/src/plugin/Page.tsx +308 -0
  163. package/src/plugin/Panel/AvailableRenderers.tsx +41 -0
  164. package/src/plugin/Panel/Code.tsx +44 -0
  165. package/src/plugin/Panel/Name.tsx +26 -0
  166. package/src/plugin/Panel/Outline.tsx +40 -0
  167. package/src/plugin/Panel.tsx +243 -0
  168. package/src/plugin/Plain.tsx +91 -0
  169. package/src/plugin/Progress.tsx +132 -0
  170. package/src/plugin/Property.tsx +139 -0
  171. package/src/plugin/QRCode.tsx +98 -0
  172. package/src/plugin/Reset.tsx +23 -0
  173. package/src/plugin/Service.tsx +167 -0
  174. package/src/plugin/Sparkline.tsx +40 -0
  175. package/src/plugin/Status.tsx +78 -0
  176. package/src/plugin/Steps.tsx +140 -0
  177. package/src/plugin/Submit.tsx +23 -0
  178. package/src/plugin/Table.tsx +440 -0
  179. package/src/plugin/TableView.tsx +711 -0
  180. package/src/plugin/Tabs.tsx +364 -0
  181. package/src/plugin/Tasks.tsx +276 -0
  182. package/src/plugin/Time.tsx +75 -0
  183. package/src/plugin/TooltipWrapper.tsx +193 -0
  184. package/src/plugin/Tpl.tsx +162 -0
  185. package/src/plugin/Video.tsx +160 -0
  186. package/src/plugin/WebComponent.tsx +56 -0
  187. package/src/plugin/Wizard.tsx +743 -0
  188. package/src/plugin/Wrapper.tsx +107 -0
  189. package/src/plugin.ts +1046 -0
  190. package/dist/150a58f3318ca7541ed9.png +0 -0
  191. package/dist/471adb97c322b226e589.png +0 -0
  192. package/dist/4de5f42360bc5946c3c2.png +0 -0
  193. package/dist/4e9968bba3855f088fed.png +0 -0
  194. package/dist/7f09c38ebc687fea847a.png +0 -0
  195. package/dist/c94073576487510314ea.png +0 -0
@@ -0,0 +1,134 @@
1
+ import {registerEditorPlugin} from '../../manager';
2
+ import {BaseEventContext, BasePlugin, BasicToolbarItem} from '../../plugin';
3
+ import React from 'react';
4
+ import JsonView, {InteractionProps} from 'react-json-view';
5
+
6
+ /**
7
+ * 添加调试功能
8
+ */
9
+ export class DataDebugPlugin extends BasePlugin {
10
+ buildEditorToolbar(
11
+ {id, schema, node}: BaseEventContext,
12
+ toolbars: Array<BasicToolbarItem>
13
+ ) {
14
+ const comp = node.getComponent();
15
+ if (!comp || !comp.props.data || !comp.props.store) {
16
+ return;
17
+ }
18
+
19
+ // const renderers = getRenderers();
20
+ // const renderInfo = find(
21
+ // renderers,
22
+ // renderer => renderer.Renderer && comp instanceof renderer.Renderer
23
+ // ) as RendererConfig;
24
+
25
+ // if (!renderInfo || !renderInfo.storeType) {
26
+ // return;
27
+ // }
28
+ const store = comp.props.store;
29
+
30
+ toolbars.push({
31
+ icon: 'fa fa-bug',
32
+ order: -1000,
33
+ placement: 'bottom',
34
+ tooltip: '上下文数据',
35
+ onClick: () =>
36
+ this.openDebugForm(
37
+ comp.props.data,
38
+ store.updateData && store.data === comp.props.data
39
+ ? values => store.updateData(values)
40
+ : undefined
41
+ )
42
+ });
43
+ }
44
+
45
+ dataViewer = {
46
+ type: 'json',
47
+ name: 'ctx',
48
+ asFormItem: true,
49
+ className: 'm-b-none',
50
+ component: ({
51
+ value,
52
+ onChange,
53
+ readOnly
54
+ }: {
55
+ value: any;
56
+ onChange: (value: any) => void;
57
+ readOnly?: boolean;
58
+ }) => {
59
+ const [index, setIndex] = React.useState(0);
60
+ let start = value || {};
61
+ const stacks = [start];
62
+
63
+ while (Object.getPrototypeOf(start) !== Object.prototype) {
64
+ const superData = Object.getPrototypeOf(start);
65
+
66
+ if (Object.prototype.toString.call(superData) !== '[object Object]') {
67
+ break;
68
+ }
69
+
70
+ stacks.push(superData);
71
+ start = superData;
72
+ }
73
+
74
+ function emitChange(e: InteractionProps) {
75
+ const obj = Object.create(stacks[1] || Object.prototype);
76
+ Object.keys(e.updated_src).forEach(
77
+ key => (obj[key] = (e.updated_src as any)[key])
78
+ );
79
+ onChange(obj);
80
+ }
81
+
82
+ return (
83
+ <div className="aeDataChain">
84
+ <div className="aeDataChain-aside">
85
+ <ul>
86
+ {stacks.map((_, i) => (
87
+ <li
88
+ className={i === index ? 'is-active' : ''}
89
+ key={i}
90
+ onClick={() => setIndex(i)}
91
+ >
92
+ {i === 0 ? '当前' : i === 1 ? '上层' : `上${i}层`}
93
+ </li>
94
+ ))}
95
+ </ul>
96
+ </div>
97
+ <div className="aeDataChain-main">
98
+ <JsonView
99
+ name={false}
100
+ src={stacks[index]}
101
+ enableClipboard={false}
102
+ iconStyle="square"
103
+ onAdd={index === 0 && !readOnly ? emitChange : false}
104
+ onEdit={index === 0 && !readOnly ? emitChange : false}
105
+ onDelete={index === 0 && !readOnly ? emitChange : false}
106
+ collapsed={2}
107
+ />
108
+ </div>
109
+ </div>
110
+ );
111
+ }
112
+ };
113
+
114
+ async openDebugForm(data: any, callback?: (values: any) => void) {
115
+ const result = await this.manager.scaffold(
116
+ {
117
+ title: '上下文数据',
118
+ body: [
119
+ {
120
+ ...this.dataViewer,
121
+ readOnly: callback ? false : true
122
+ }
123
+ ]
124
+ },
125
+ {
126
+ ctx: data
127
+ }
128
+ );
129
+
130
+ callback?.((result as any).ctx);
131
+ }
132
+ }
133
+
134
+ registerEditorPlugin(DataDebugPlugin);
@@ -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/lib/utils/helper';
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);