@wibetter/json-utils 5.2.3 → 5.2.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,2390 +1,2 @@
1
1
  /*! For license information please see index.js.LICENSE.txt */
2
- !(function (e, t) {
3
- 'object' == typeof exports && 'object' == typeof module
4
- ? (module.exports = t())
5
- : 'function' == typeof define && define.amd
6
- ? define([], t)
7
- : 'object' == typeof exports
8
- ? (exports.JSONUtils = t())
9
- : (e.JSONUtils = t());
10
- })(this, function () {
11
- return (function () {
12
- 'use strict';
13
- var e = {
14
- n: function (t) {
15
- var r =
16
- t && t.__esModule
17
- ? function () {
18
- return t.default;
19
- }
20
- : function () {
21
- return t;
22
- };
23
- return e.d(r, { a: r }), r;
24
- },
25
- d: function (t, r) {
26
- for (var i in r)
27
- e.o(r, i) &&
28
- !e.o(t, i) &&
29
- Object.defineProperty(t, i, { enumerable: !0, get: r[i] });
30
- },
31
- o: function (e, t) {
32
- return Object.prototype.hasOwnProperty.call(e, t);
33
- },
34
- r: function (e) {
35
- 'undefined' != typeof Symbol &&
36
- Symbol.toStringTag &&
37
- Object.defineProperty(e, Symbol.toStringTag, { value: 'Module' }),
38
- Object.defineProperty(e, '__esModule', { value: !0 });
39
- },
40
- },
41
- t = {};
42
- e.r(t),
43
- e.d(t, {
44
- DataSourceTypeList: function () {
45
- return x;
46
- },
47
- EventTypeDataList: function () {
48
- return S;
49
- },
50
- KeyWordList: function () {
51
- return ve;
52
- },
53
- TypeDataList: function () {
54
- return O;
55
- },
56
- dataRoute2dataPath: function () {
57
- return se;
58
- },
59
- dynamicDataAnalyzer: function () {
60
- return ce;
61
- },
62
- evalExpression: function () {
63
- return s;
64
- },
65
- getCurPosition: function () {
66
- return Q;
67
- },
68
- getDefaultOptionVal: function () {
69
- return ae;
70
- },
71
- getExpectType: function () {
72
- return z;
73
- },
74
- getJsonDataByKeyRoute: function () {
75
- return d;
76
- },
77
- getNextIndexRoute: function () {
78
- return ee;
79
- },
80
- getParentIndexRoute: function () {
81
- return G;
82
- },
83
- getParentIndexRoute_CurIndex: function () {
84
- return te;
85
- },
86
- getParentKeyRoute: function () {
87
- return fe;
88
- },
89
- getParentKeyRoute_CurKey: function () {
90
- return be;
91
- },
92
- getSchemaByIndexRoute: function () {
93
- return y;
94
- },
95
- getSchemaByKeyRoute: function () {
96
- return f;
97
- },
98
- hasProperties: function () {
99
- return u;
100
- },
101
- indexRoute2keyRoute: function () {
102
- return b;
103
- },
104
- isArray: function () {
105
- return k;
106
- },
107
- isBoolean: function () {
108
- return N;
109
- },
110
- isColor: function () {
111
- return M;
112
- },
113
- isContainerSchema: function () {
114
- return Y;
115
- },
116
- isDateStr: function () {
117
- return R;
118
- },
119
- isDateTimeStr: function () {
120
- return q;
121
- },
122
- isEmptySchema: function () {
123
- return W;
124
- },
125
- isEqual: function () {
126
- return p;
127
- },
128
- isFunction: function () {
129
- return _;
130
- },
131
- isNewSchemaData: function () {
132
- return X;
133
- },
134
- isNumber: function () {
135
- return D;
136
- },
137
- isObject: function () {
138
- return P;
139
- },
140
- isQuantity: function () {
141
- return I;
142
- },
143
- isSameParent: function () {
144
- return H;
145
- },
146
- isSelect: function () {
147
- return F;
148
- },
149
- isString: function () {
150
- return T;
151
- },
152
- isStructuredSchema: function () {
153
- return Z;
154
- },
155
- isTimeStr: function () {
156
- return E;
157
- },
158
- isURL: function () {
159
- return w;
160
- },
161
- json2schema: function () {
162
- return A;
163
- },
164
- json2treeData: function () {
165
- return de;
166
- },
167
- keyRoute2indexRoute: function () {
168
- return v;
169
- },
170
- metaElemAnalyzer: function () {
171
- return V;
172
- },
173
- moveBackward: function () {
174
- return ie;
175
- },
176
- moveForward: function () {
177
- return re;
178
- },
179
- objClone: function () {
180
- return o;
181
- },
182
- oldSchemaToNewSchema: function () {
183
- return $;
184
- },
185
- oldSchemaToNewSchemaV1: function () {
186
- return L;
187
- },
188
- registerExpectType: function () {
189
- return U;
190
- },
191
- schema2conditionValue: function () {
192
- return ye;
193
- },
194
- schema2json: function () {
195
- return pe;
196
- },
197
- schemaMetaList: function () {
198
- return ue;
199
- },
200
- truncate: function () {
201
- return c;
202
- },
203
- urlParse: function () {
204
- return l;
205
- },
206
- urlStringify: function () {
207
- return n;
208
- },
209
- });
210
- var r = require('lodash'),
211
- i = require('qs'),
212
- a = e.n(i);
213
- function l() {
214
- var e = {};
215
- return (
216
- location.search && (e = a().parse(location.search.substring(1))), e
217
- );
218
- }
219
- function n(e) {
220
- var t = '';
221
- return url && (t = a().stringify(e)), t;
222
- }
223
- function o(e) {
224
- return (0, r.cloneDeep)(e);
225
- }
226
- function p(e, t) {
227
- return (0, r.isEqual)(e, t);
228
- }
229
- function u(e) {
230
- var t = !1;
231
- return null != e && (t = !0), t;
232
- }
233
- function c(e, t) {
234
- return (0, r.truncate)(e, t);
235
- }
236
- function s(e, t) {
237
- var r = t || {};
238
- if (!e) return !1;
239
- var i = new Function('data', 'with(data) { return (' + e + ');}'),
240
- a = '';
241
- try {
242
- a = i(r);
243
- } catch (t) {
244
- return console.warn('表达式运算出错: ' + e + ',报错信息:', t), a;
245
- }
246
- return a;
247
- }
248
- function d(e, t, r) {
249
- var i = t;
250
- if ((r && (i = o(t)), e))
251
- for (var a = e.split('-'), l = 0, n = a.length; l < n; l++) {
252
- var p = a[l];
253
- p && (i = i && i[p]);
254
- }
255
- return i;
256
- }
257
- function y(e, t, r) {
258
- var i = t;
259
- if ((r && (i = o(t)), e))
260
- for (var a = e.split('-'), l = 0, n = a.length; l < n; l++) {
261
- var p = a[l];
262
- if (
263
- '0' !== p ||
264
- ('array' !== i.type &&
265
- 'radio' !== i.type &&
266
- 'select' !== i.type &&
267
- 'checkboxes' !== i.type) ||
268
- (!i.options && !i.items)
269
- ) {
270
- if (p) {
271
- var u = '0';
272
- i.propertyOrder
273
- ? (u = i.propertyOrder[p])
274
- : i.properties && (u = Object.keys(i.properties)[p]),
275
- (i = i.properties[u]);
276
- }
277
- } else i = i.options || i.items;
278
- }
279
- return i;
280
- }
281
- function f(e, t, r) {
282
- var i = t;
283
- if ((r && (i = o(t)), e && i))
284
- for (var a = e.split('-'), l = 0, n = a.length; l < n; l++) {
285
- var p = a[l];
286
- p && i.properties && (i = i.properties[p]);
287
- }
288
- return i;
289
- }
290
- function b(e, t) {
291
- for (
292
- var r = t, i = '', a = e.split('-'), l = 0, n = a.length;
293
- l < n;
294
- l++
295
- ) {
296
- var o = a[l];
297
- if ('0' === o && r.items)
298
- (r = r.items), (i = i ? i + '-items' : 'items');
299
- else if ('0' === o && r.options)
300
- (r = r.options), (i = i ? i + '-options' : 'options');
301
- else if (o) {
302
- var p = '0';
303
- r.propertyOrder
304
- ? (p = r.propertyOrder[o])
305
- : r.properties && (p = Object.keys(r.properties)[o]),
306
- (r = r.properties[p]),
307
- (i = i ? i + '-' + p : p);
308
- }
309
- }
310
- return i;
311
- }
312
- function v(e, t) {
313
- for (
314
- var r = t, i = '', a = e.split('-'), l = 0, n = a.length;
315
- l < n;
316
- l++
317
- ) {
318
- var o = a[l];
319
- if (o) {
320
- var p = -1;
321
- r.propertyOrder
322
- ? ((p = r.propertyOrder.indexOf(o)), (r = r.properties[o]))
323
- : r.properties
324
- ? ((p = Object.keys(r.properties).indexOf(o)),
325
- (r = r.properties[o]))
326
- : r.items
327
- ? ((p = 0), (r = r.items))
328
- : r.options && ((p = 0), (r = r.options)),
329
- (i = i ? i + '-' + p : p.toString());
330
- }
331
- }
332
- return i;
333
- }
334
- var m,
335
- h = {
336
- type: 'event',
337
- title: '事件',
338
- isContainer: !1,
339
- properties: {
340
- type: {
341
- default: 'emit',
342
- type: 'select',
343
- options: [
344
- { label: 'on', value: 'on' },
345
- { label: 'emit', value: 'emit' },
346
- ],
347
- title: '事件类型',
348
- },
349
- trigger: {
350
- type: 'input',
351
- default: 'eventName',
352
- title: '触发事件',
353
- description: '用于输入触发事件的名称',
354
- placeholder: '请输入触发事件的名称',
355
- },
356
- eventData: {
357
- title: '事件数据',
358
- type: 'json',
359
- default: '{}',
360
- description: '传递给触发事件的数据对象',
361
- },
362
- },
363
- propertyOrder: ['type', 'trigger', 'eventData'],
364
- },
365
- g = {
366
- type: 'datasource',
367
- title: '数据源',
368
- isContainer: !1,
369
- properties: {
370
- type: {
371
- default: 'local',
372
- type: 'select',
373
- options: [
374
- { label: '本地数据', value: 'local' },
375
- { label: '接口数据', value: 'remote' },
376
- ],
377
- title: '数据源类型',
378
- },
379
- data: {
380
- title: '本地json数据',
381
- placeholder: '请输入静态json数据',
382
- type: 'json',
383
- default: '{}',
384
- description: '用于设置本地的静态json数据',
385
- isRequired: !0,
386
- },
387
- filter: {
388
- title: '过滤器',
389
- type: 'codearea',
390
- default: '() => {}',
391
- description: '用于定义过滤当前数据的函数',
392
- isRequired: !0,
393
- },
394
- },
395
- propertyOrder: ['type', 'data', 'filter'],
396
- },
397
- C =
398
- (((m = { type: 'object' }).type = 'datasource'),
399
- (m.title = '数据源'),
400
- (m.isContainer = !1),
401
- (m.properties = {
402
- type: {
403
- type: 'select',
404
- default: 'remote',
405
- options: [
406
- { label: '本地数据', value: 'local' },
407
- { label: '接口数据', value: 'remote' },
408
- ],
409
- title: '数据源类型',
410
- },
411
- data: {
412
- type: 'url',
413
- title: '远程json数据',
414
- placeholder: '请输入远程json数据源地址',
415
- default: 'http://xxx',
416
- isRequired: !0,
417
- description: '用于设置获取元素数据的请求地址',
418
- },
419
- filter: {
420
- type: 'codearea',
421
- title: '过滤器',
422
- default: '() => {}',
423
- description: '用于定义过滤当前数据的函数',
424
- isRequired: !0,
425
- },
426
- }),
427
- (m.propertyOrder = ['type', 'data', 'filter']),
428
- m),
429
- j = {
430
- type: 'local',
431
- config: { dataName: '', body: {}, filter: 'return data;' },
432
- data: '{}',
433
- localFilter: 'return data;',
434
- },
435
- O = {
436
- jsonschema: {
437
- type: 'object',
438
- title: 'jsonSchemaObject',
439
- properties: {
440
- func: {
441
- type: 'object',
442
- title: '功能设置',
443
- properties: {
444
- a: {
445
- title: '单文本框',
446
- type: 'input',
447
- default: '',
448
- description: '',
449
- placeholder: '',
450
- isRequired: !1,
451
- },
452
- },
453
- propertyOrder: ['a'],
454
- },
455
- style: {
456
- type: 'object',
457
- title: '样式设置',
458
- properties: {
459
- b: {
460
- title: '单文本框',
461
- type: 'input',
462
- default: '',
463
- description: '',
464
- placeholder: '',
465
- },
466
- },
467
- propertyOrder: ['b'],
468
- },
469
- data: {
470
- type: 'data',
471
- title: '数据设置',
472
- properties: {
473
- c: {
474
- title: '单文本框',
475
- type: 'input',
476
- default: '',
477
- description: '',
478
- placeholder: '',
479
- isRequired: !1,
480
- },
481
- },
482
- propertyOrder: ['c'],
483
- },
484
- },
485
- propertyOrder: ['func', 'style', 'data'],
486
- },
487
- input: {
488
- title: '单文本框',
489
- type: 'input',
490
- default: '',
491
- description: '',
492
- placeholder: '',
493
- },
494
- boolean: {
495
- type: 'boolean',
496
- title: '布尔值',
497
- default: !1,
498
- description: '',
499
- },
500
- object: {
501
- type: 'object',
502
- title: '对象Object',
503
- description: '',
504
- properties: {
505
- a: {
506
- type: 'input',
507
- title: '单文本框',
508
- default: '',
509
- description: '',
510
- placeholder: '',
511
- },
512
- },
513
- propertyOrder: ['a'],
514
- },
515
- array: {
516
- type: 'array',
517
- title: '数组Array',
518
- description: '',
519
- items: {
520
- type: 'object',
521
- title: '数组项',
522
- description: '',
523
- properties: {
524
- name: {
525
- type: 'input',
526
- title: '名字',
527
- default: '',
528
- description: '',
529
- placeholder: '',
530
- },
531
- },
532
- propertyOrder: ['name'],
533
- },
534
- },
535
- 'empty-array': {
536
- type: 'array',
537
- title: '数组Array',
538
- description: '',
539
- default: [],
540
- items: {
541
- type: 'object',
542
- title: '数组项',
543
- description: '',
544
- properties: {},
545
- },
546
- },
547
- 'empty-object': {
548
- type: 'object',
549
- title: '对象Object',
550
- description: '',
551
- properties: {},
552
- },
553
- url: {
554
- type: 'url',
555
- title: '链接地址url',
556
- default: '',
557
- description: '',
558
- placeholder: '',
559
- },
560
- textarea: {
561
- type: 'textarea',
562
- title: '多行文本框',
563
- default: '',
564
- description: '',
565
- placeholder: '',
566
- },
567
- color: {
568
- type: 'color',
569
- title: '颜色color',
570
- default: '#ffffff',
571
- description: '',
572
- },
573
- image: {
574
- title: '图片',
575
- type: 'image',
576
- default: '',
577
- description: '上传图片',
578
- imgWidth: 200,
579
- imgHeight: 200,
580
- imgRatioReadOnly: !0,
581
- },
582
- number: {
583
- type: 'number',
584
- title: '数量number',
585
- default: 1,
586
- minimum: 0,
587
- maximum: 1e3,
588
- description: '',
589
- },
590
- 'input-image': {
591
- title: '图片地址',
592
- type: 'input-image',
593
- description: '',
594
- accept: '.jpeg,.jpg,.png',
595
- multiple: !0,
596
- },
597
- json: {
598
- title: 'json数据',
599
- type: 'json',
600
- default: '{}',
601
- description: '',
602
- },
603
- codearea: {
604
- type: 'codearea',
605
- title: '函数类型',
606
- placeholder: '请输入函数方法',
607
- default: 'function func() { console.log("hello, world!"); }',
608
- description: '用于定义函数方法',
609
- },
610
- htmlarea: {
611
- title: '富文本',
612
- type: 'htmlarea',
613
- placeholder: '请输入html代码片段',
614
- default: '<p>hello,world!</p>',
615
- description: '用于放置html代码片段',
616
- },
617
- 'text-editor': {
618
- type: 'text-editor',
619
- title: '富文本',
620
- default: '',
621
- description: '',
622
- placeholder: '',
623
- },
624
- date: {
625
- type: 'date',
626
- title: '日期Date',
627
- default: '',
628
- description: '',
629
- placeholder: '',
630
- },
631
- 'date-time': {
632
- type: 'date-time',
633
- title: '日期时间',
634
- default: '',
635
- description: '',
636
- placeholder: '',
637
- },
638
- time: {
639
- type: 'time',
640
- title: '时间Time',
641
- default: '',
642
- description: '',
643
- placeholder: '',
644
- },
645
- quantity: {
646
- type: 'quantity',
647
- title: '单位计量',
648
- isContainer: !1,
649
- properties: {
650
- unit: {
651
- type: 'number',
652
- title: '单位数值',
653
- default: 50,
654
- minimum: 0,
655
- maximum: 1e3,
656
- description: '',
657
- },
658
- quantity: {
659
- type: 'select',
660
- default: 'px',
661
- options: [
662
- { label: 'px', value: 'px' },
663
- { label: 'rem', value: 'rem' },
664
- { label: 'em', value: 'em' },
665
- { label: '%', value: '%' },
666
- ],
667
- title: '单位类型',
668
- },
669
- },
670
- propertyOrder: ['unit', 'quantity'],
671
- },
672
- 'box-style': {
673
- type: 'box-style',
674
- title: '盒子模型',
675
- isContainer: !1,
676
- properties: {
677
- unit: {
678
- title: '单位数值',
679
- type: 'input',
680
- default: '0',
681
- description: '',
682
- },
683
- quantity: {
684
- type: 'select',
685
- default: 'px',
686
- options: [
687
- { label: 'px', value: 'px' },
688
- { label: 'rem', value: 'rem' },
689
- { label: 'em', value: 'em' },
690
- { label: '%', value: '%' },
691
- ],
692
- title: '单位类型',
693
- },
694
- },
695
- propertyOrder: ['unit', 'quantity'],
696
- },
697
- 'padding-margin': {
698
- type: 'padding-margin',
699
- title: '边距设置',
700
- isContainer: !1,
701
- properties: {
702
- margin: {
703
- title: '外边距',
704
- type: 'input',
705
- default: '0',
706
- description: '',
707
- },
708
- padding: {
709
- title: '内边距',
710
- type: 'input',
711
- default: '0',
712
- description: '',
713
- },
714
- quantity: {
715
- type: 'select',
716
- default: 'px',
717
- options: [
718
- { label: 'px', value: 'px' },
719
- { label: 'rem', value: 'rem' },
720
- { label: 'em', value: 'em' },
721
- { label: '%', value: '%' },
722
- ],
723
- title: '单位类型',
724
- },
725
- },
726
- propertyOrder: ['margin', 'padding', 'quantity'],
727
- },
728
- radio: {
729
- type: 'radio',
730
- title: '单选',
731
- options: [
732
- { label: '选项a', value: 'a' },
733
- { label: '选项b', value: 'b' },
734
- { label: '选项c', value: 'c' },
735
- ],
736
- description: '',
737
- },
738
- select: {
739
- type: 'select',
740
- title: '下拉选择',
741
- options: [
742
- { label: '选项a', value: 'a' },
743
- { label: '选项b', value: 'b' },
744
- { label: '选项c', value: 'c' },
745
- ],
746
- description: '',
747
- },
748
- cascader: {
749
- type: 'cascader',
750
- title: '级联选择',
751
- options: [
752
- {
753
- value: 'zhejiang',
754
- label: 'Zhejiang',
755
- children: [
756
- {
757
- value: 'hangzhou',
758
- label: 'Hangzhou',
759
- children: [{ value: 'xihu', label: 'West Lake' }],
760
- },
761
- ],
762
- },
763
- {
764
- value: 'jiangsu',
765
- label: 'Jiangsu',
766
- children: [
767
- {
768
- value: 'nanjing',
769
- label: 'Nanjing',
770
- children: [{ value: 'zhonghuamen', label: 'Zhong Hua Men' }],
771
- },
772
- ],
773
- },
774
- ],
775
- default: 'a',
776
- description: '',
777
- showSearch: !0,
778
- allowClear: !0,
779
- },
780
- checkboxes: {
781
- type: 'checkboxes',
782
- title: '多选',
783
- options: [
784
- { label: '选项a', value: 'a' },
785
- { label: '选项b', value: 'b' },
786
- { label: '选项c', value: 'c' },
787
- ],
788
- default: ['a'],
789
- description: '',
790
- },
791
- 'dynamic-data': {
792
- type: 'dynamic-data',
793
- title: '动态数据源',
794
- isContainer: !1,
795
- properties: {
796
- type: {
797
- default: 'local',
798
- type: 'select',
799
- options: [
800
- { label: '本地数据', value: 'local' },
801
- { label: '接口数据', value: 'remote' },
802
- ],
803
- title: '数据类型',
804
- },
805
- config: {
806
- title: '接口配置',
807
- type: 'object',
808
- description: '用于存放接口的配置数据(url、请求参数等)',
809
- isRequired: !0,
810
- properties: {
811
- dataName: {
812
- default: 'local',
813
- type: 'select',
814
- options: [
815
- { label: '本地数据', value: 'local' },
816
- { label: '接口数据', value: 'remote' },
817
- ],
818
- title: '数据类型',
819
- },
820
- body: {
821
- type: 'object',
822
- title: '请求参数配置',
823
- description: '用于配置当前接口的请求参数数值',
824
- isRequired: !0,
825
- },
826
- filter: {
827
- title: '过滤器函数体',
828
- type: 'codearea',
829
- default: 'return data;',
830
- description: '用于定义过滤接口数据',
831
- isRequired: !0,
832
- },
833
- },
834
- propertyOrder: ['dataName', 'body', 'filter'],
835
- },
836
- data: {
837
- title: '数据内容',
838
- type: 'json',
839
- default: '{}',
840
- description: '用于存放DynamicData的数据内容',
841
- isRequired: !0,
842
- },
843
- localFilter: {
844
- title: '过滤器',
845
- type: 'codearea',
846
- default: 'return data;',
847
- description: '用于定义过滤本地数据',
848
- isRequired: !0,
849
- },
850
- },
851
- propertyOrder: ['type', 'config', 'data', 'localFilter'],
852
- },
853
- datasource: g,
854
- event: h,
855
- 'dynamic-config': {
856
- type: 'dynamic-config',
857
- title: '动态配置',
858
- description: '',
859
- isContainer: !1,
860
- properties: {
861
- type: {
862
- type: 'select',
863
- title: '数据来源',
864
- options: [
865
- { label: '模板直接设置', value: 'DevDefaults' },
866
- { label: 'mp后台配置', value: 'ContentStaticConfig' },
867
- { label: '内容Meta数据', value: 'Content' },
868
- { label: '全局配置数据', value: 'RuntimeConst' },
869
- { label: '资源中心配置', value: 'ResourceCenter' },
870
- ],
871
- default: 'DevDefaults',
872
- isConditionProp: !0,
873
- description:
874
- '目前支持的数据来源包括: 1)模版直接设置:在模版配置直接生效,支持直接输入或图片上传。 2)mp后台配置:选择mp后台配置后,属性会出现在mp后台中,支持属性描述的输入。 3)内容meta数据:支持内容meta数据的获取,页面meta数据。 4)全局配置数据:目前支持的全局配置包括:全局Tab配置及主题包配置。相关属性会挂载至:window.globalConst',
875
- },
876
- value: {
877
- title: '数据值',
878
- type: 'input',
879
- default: '',
880
- description: '',
881
- placeholder: '',
882
- onShow:
883
- 'type === "DevDefaults" || type === "Content" || type === "RuntimeConst"',
884
- },
885
- description: {
886
- title: '属性名称',
887
- type: 'input',
888
- default: '',
889
- description: '',
890
- placeholder: '',
891
- onShow:
892
- 'type === "ContentStaticConfig" || type === "ResourceCenter"',
893
- },
894
- valueType: {
895
- type: 'radio',
896
- title: '配置方式',
897
- options: [
898
- { label: '填写', value: 'string' },
899
- { label: '选择', value: 'select' },
900
- ],
901
- default: 'string',
902
- isConditionProp: !0,
903
- description: '在MP后台或资源中心配置时的交互方式,推荐使用"选择"',
904
- onShow:
905
- 'type === "ContentStaticConfig" || type === "ResourceCenter"',
906
- },
907
- range: {
908
- type: 'select',
909
- title: '可选项',
910
- multiple: !0,
911
- options: [],
912
- onShow:
913
- '(type === "ContentStaticConfig" || type === "ResourceCenter") && valueType === "select"',
914
- description: '这里会使用value中的配置选项作为options',
915
- },
916
- },
917
- propertyOrder: ['type', 'value', 'description', 'valueType', 'range'],
918
- showCodeViewBtn: !1,
919
- },
920
- 'dynamic-object': {
921
- type: 'dynamic-object',
922
- title: '动态配置',
923
- description: '',
924
- isContainer: !1,
925
- properties: {
926
- type: {
927
- type: 'select',
928
- title: '数据来源',
929
- options: [
930
- { label: '模板直接设置', value: 'DevDefaults' },
931
- { label: 'mp后台配置', value: 'ContentStaticConfig' },
932
- { label: '内容Meta数据', value: 'Content' },
933
- { label: '全局配置数据', value: 'RuntimeConst' },
934
- { label: '资源中心配置', value: 'ResourceCenter' },
935
- ],
936
- default: 'DevDefaults',
937
- isConditionProp: !0,
938
- description:
939
- '目前支持的数据来源包括: 1)模版直接设置: 在模版配置直接生效,支持直接输入或图片上传。 2)mp后台配置: 选择mp后台配置后,属性会出现在mp后台中,支持属性描述的输入。 3)内容meta数据: 支持内容meta数据的获取,页面meta数据。 4)全局配置数据: 目前支持的全局配置包括:全局Tab配置及主题包配置。相关属性会挂载至:window.globalConst',
940
- },
941
- value: {
942
- title: '数据值',
943
- type: 'input',
944
- default: '',
945
- description: '',
946
- placeholder: '',
947
- onShow: 'type === "Content" || type === "RuntimeConst"',
948
- },
949
- description: {
950
- title: '自定义配置名称',
951
- type: 'input',
952
- default: '主题包配置',
953
- description: '',
954
- placeholder: '',
955
- onShow:
956
- 'type === "ContentStaticConfig" || type === "ResourceCenter"',
957
- },
958
- attrs: {
959
- type: 'array',
960
- title: '属性列表',
961
- description: 'Tab需要配置的属性',
962
- items: {
963
- type: 'object',
964
- title: '数组项',
965
- description: '',
966
- properties: {
967
- attr: {
968
- type: 'input',
969
- title: '属性Key',
970
- default: '',
971
- description: '',
972
- placeholder: '',
973
- },
974
- description: {
975
- title: '描述',
976
- type: 'input',
977
- default: '',
978
- description: '',
979
- placeholder: '',
980
- },
981
- value: {
982
- title: '数值',
983
- typeOn:
984
- "type === 'image' ? 'input-image' : type === 'number' ? 'number' : 'input'",
985
- default: '',
986
- description: '',
987
- placeholder: '',
988
- },
989
- type: {
990
- type: 'select',
991
- title: '属性类型',
992
- options: [
993
- { label: '图片类型', value: 'image' },
994
- { label: '字符串', value: 'string' },
995
- { label: '数字', value: 'number' },
996
- ],
997
- default: 'string',
998
- description: '',
999
- },
1000
- },
1001
- propertyOrder: ['attr', 'description', 'type', 'value'],
1002
- },
1003
- 'minimum-child': 1,
1004
- showCodeViewBtn: !1,
1005
- onShow:
1006
- 'type === "DevDefaults" || type === "ContentStaticConfig" || type === "ResourceCenter"',
1007
- },
1008
- },
1009
- propertyOrder: ['type', 'description', 'attrs', 'value'],
1010
- showCodeViewBtn: !1,
1011
- showKey: !0,
1012
- },
1013
- 'dynamic-array': {
1014
- type: 'dynamic-array',
1015
- title: '动态数组',
1016
- description: '',
1017
- isContainer: !1,
1018
- properties: {
1019
- type: {
1020
- type: 'select',
1021
- title: '数据来源',
1022
- options: [
1023
- { label: '模板直接设置', value: 'DevDefaults' },
1024
- { label: 'mp后台配置', value: 'ContentStaticConfig' },
1025
- { label: '资源中心配置', value: 'ResourceCenter' },
1026
- ],
1027
- default: 'DevDefaults',
1028
- isConditionProp: !0,
1029
- description:
1030
- '目前支持的数据来源包括: 1)模版直接设置:在模版配置直接生效,支持直接输入或图片上传。 2)mp后台配置:选择mp后台配置后,属性会出现在mp后台中,支持属性描述的输入。 3)内容meta数据:支持内容meta数据的获取,页面meta数据。 4)全局配置数据:目前支持的全局配置包括:全局Tab配置及主题包配置。相关属性会挂载至:window.globalConst',
1031
- },
1032
- description: {
1033
- title: '自定义配置名称',
1034
- type: 'input',
1035
- default: 'Tab全局配置',
1036
- description: '',
1037
- placeholder: '',
1038
- onShow:
1039
- 'type === "ContentStaticConfig" || type === "ResourceCenter"',
1040
- },
1041
- tabNums: {
1042
- title: 'Tab配置数',
1043
- type: 'number',
1044
- default: 1,
1045
- description: '需要配置的Tab数量',
1046
- placeholder: '',
1047
- onShow:
1048
- "type === 'ContentStaticConfig' || type === 'ResourceCenter'",
1049
- },
1050
- attrs: {
1051
- type: 'array',
1052
- title: 'Tab属性',
1053
- description: 'Tab需要配置的属性',
1054
- items: {
1055
- type: 'object',
1056
- title: '数组项',
1057
- description: '',
1058
- properties: {
1059
- attr: {
1060
- type: 'input',
1061
- title: '属性Key',
1062
- default: '',
1063
- description: '',
1064
- placeholder: '',
1065
- },
1066
- description: {
1067
- title: '描述',
1068
- type: 'input',
1069
- default: '',
1070
- description: '',
1071
- placeholder: '',
1072
- },
1073
- },
1074
- propertyOrder: ['attr', 'description'],
1075
- },
1076
- 'minimum-child': 1,
1077
- onShow:
1078
- "type === 'ContentStaticConfig' || type === 'ResourceCenter'",
1079
- showCodeViewBtn: !1,
1080
- },
1081
- value: {
1082
- type: 'array',
1083
- title: 'Tab配置',
1084
- description: '',
1085
- items: {
1086
- type: 'object',
1087
- title: '数组项',
1088
- description: '',
1089
- properties: {
1090
- title: {
1091
- type: 'input',
1092
- title: '名称',
1093
- default: '',
1094
- description: '',
1095
- placeholder: '',
1096
- },
1097
- id: {
1098
- title: 'id',
1099
- type: 'input',
1100
- default: '',
1101
- description: '',
1102
- placeholder: '',
1103
- },
1104
- value: {
1105
- title: '数值',
1106
- type: 'input',
1107
- default: '',
1108
- description: '',
1109
- placeholder: '',
1110
- },
1111
- },
1112
- propertyOrder: ['title', 'value', 'id'],
1113
- },
1114
- 'minimum-child': 1,
1115
- onShow: "type === 'DevDefaults'",
1116
- showCodeViewBtn: !1,
1117
- },
1118
- },
1119
- propertyOrder: ['type', 'value', 'description', 'tabNums', 'attrs'],
1120
- showCodeViewBtn: !1,
1121
- showKey: !0,
1122
- },
1123
- 'sohu-source': {
1124
- type: 'sohu-source',
1125
- title: '数据源',
1126
- description: '',
1127
- isContainer: !1,
1128
- properties: {
1129
- mainConfig: {
1130
- type: 'object',
1131
- title: '主要配置',
1132
- description: '',
1133
- isContainer: !1,
1134
- properties: {
1135
- type: {
1136
- type: 'select',
1137
- title: '数据来源',
1138
- isConditionProp: !0,
1139
- options: [
1140
- {
1141
- label: '模板自定义数据源',
1142
- value: 'RuntimeDataSelfDefine',
1143
- },
1144
- { label: 'mp后台配置', value: 'ContentStaticConfig' },
1145
- {
1146
- label: '请求当前页面数据',
1147
- value: 'RuntimeDataSelfContent',
1148
- },
1149
- { label: '资源中心配置', value: 'ResourceCenter' },
1150
- ],
1151
- default: 'RuntimeDataSelfDefine',
1152
- description: '',
1153
- },
1154
- description: {
1155
- title: '数据源名称',
1156
- type: 'input',
1157
- description: '',
1158
- placeholder: '',
1159
- onShow: 'type === "ContentStaticConfig"',
1160
- },
1161
- dataType: {
1162
- type: 'radio',
1163
- title: '请求方式',
1164
- default: !1,
1165
- options: [
1166
- { label: '批量请求', value: 'FROMCIS' },
1167
- { label: '组件内部请求', value: 'FROMCOMPCIS' },
1168
- { label: '不请求', value: !1 },
1169
- ],
1170
- description: '',
1171
- },
1172
- CONTENTID: {
1173
- title: '数据源ID',
1174
- type: 'input',
1175
- description: '',
1176
- placeholder: '',
1177
- onShow: 'type === "RuntimeDataSelfDefine"',
1178
- },
1179
- CONTENTTYPE: {
1180
- type: 'select',
1181
- title: '数据源类型',
1182
- options: [
1183
- { label: 'channel', value: 'channel' },
1184
- { label: 'topic', value: 'topic' },
1185
- { label: 'block', value: 'block' },
1186
- ],
1187
- description: '',
1188
- onShow: 'type === "RuntimeDataSelfDefine"',
1189
- },
1190
- },
1191
- propertyOrder: [
1192
- 'type',
1193
- 'description',
1194
- 'dataType',
1195
- 'CONTENTID',
1196
- 'CONTENTTYPE',
1197
- ],
1198
- showCodeViewBtn: !1,
1199
- },
1200
- outConfig: {
1201
- type: 'object',
1202
- title: '出流配置',
1203
- description: '',
1204
- isContainer: !1,
1205
- properties: {
1206
- PRO: {
1207
- type: 'select',
1208
- title: '内容类型',
1209
- options: [
1210
- { label: '置顶+加精', value: '4' },
1211
- { label: '长效置顶', value: '5' },
1212
- ],
1213
- description: '',
1214
- },
1215
- FEEDTYPE: {
1216
- type: 'select',
1217
- title: '排序类型',
1218
- options: [
1219
- { label: '综合', value: 'XTOPIC_SYNTHETICAL' },
1220
- { label: '最新', value: 'XTOPIC_LATEST' },
1221
- { label: '相关', value: 'XTOPIC_RELATED' },
1222
- ],
1223
- description: '',
1224
- },
1225
- VIEW: {
1226
- type: 'select',
1227
- title: '数据裁剪',
1228
- options: [
1229
- { label: '相关推荐模式', value: 'articleFeedMode' },
1230
- { label: '文字链裁剪方式', value: 'textMode' },
1231
- { label: '短内容摘录方式', value: 'excerptMode' },
1232
- {
1233
- label: '互动(点赞/评论)裁剪方式',
1234
- value: 'interactMode',
1235
- },
1236
- { label: '评论文字链裁剪方式', value: 'commentTextMode' },
1237
- {
1238
- label: '摘录方式(无点赞)',
1239
- value: 'excerptCommentMode',
1240
- },
1241
- { label: '无限流卡片模式', value: 'dynamicFeedMode' },
1242
- { label: '时间线模式', value: 'timeLineMode' },
1243
- { label: '复合内容流模式', value: 'multiFeedMode' },
1244
- { label: '搜狐号推荐模式', value: 'recommendFeedMode' },
1245
- { label: '作者页内容流模式', value: 'operateFeedMode' },
1246
- { label: '标签内容流模式', value: 'tagsFeedMode' },
1247
- { label: '评论链裁剪方式', value: 'commentMode' },
1248
- { label: '标签摘录方式', value: 'excerptTagsMode' },
1249
- { label: '内容流模式', value: 'feedMode' },
1250
- ],
1251
- description: '',
1252
- },
1253
- CONTENTCONTEXT: {
1254
- type: 'select',
1255
- title: 'mKey参数',
1256
- options: [
1257
- {
1258
- label: '作者ID+栏目ID',
1259
- value: 'authorColumnId_${#authorColumnId}',
1260
- },
1261
- {
1262
- label: '账号ID',
1263
- value: 'accountId_${#contentData_account_id}',
1264
- },
1265
- { label: 'mkeyID', value: 'mid_${#mkeyConst_mid}' },
1266
- { label: 'mkey名称', value: 'mname_${#mkeyConst_mname}' },
1267
- {
1268
- label: '城市Code码',
1269
- value: 'cityCode_${#cityInfo_cityCode}',
1270
- },
1271
- {
1272
- label: '城市名称',
1273
- value: 'cityName_${#cityInfo_cityName}',
1274
- },
1275
- {
1276
- label: '焦点城市Code码',
1277
- value: 'focusCityCode_${#focusCityInfo_cityCode}',
1278
- },
1279
- ],
1280
- description: '',
1281
- },
1282
- CONTENTPARAMS: {
1283
- title: '动态参数',
1284
- type: 'json',
1285
- description: '请填写JSON格式的参数',
1286
- placeholder: '',
1287
- },
1288
- },
1289
- propertyOrder: [
1290
- 'PRO',
1291
- 'FEEDTYPE',
1292
- 'VIEW',
1293
- 'CONTENTCONTEXT',
1294
- 'CONTENTPARAMS',
1295
- ],
1296
- showCodeViewBtn: !1,
1297
- },
1298
- otherConfig: {
1299
- type: 'object',
1300
- title: '选配内容',
1301
- description: '',
1302
- isContainer: !1,
1303
- properties: {
1304
- SIZE: {
1305
- type: 'number',
1306
- title: '容量',
1307
- minimum: 0,
1308
- maximum: 1e3,
1309
- description: '该位置区块需要的内容条数',
1310
- },
1311
- TITLE: {
1312
- title: '标题',
1313
- type: 'input',
1314
- description: '',
1315
- placeholder: '',
1316
- },
1317
- URL: {
1318
- type: 'url',
1319
- title: '更多跳转链接',
1320
- description: '该区块下点击“更多或箭头图标”后的跳转链接',
1321
- placeholder: '',
1322
- },
1323
- CODE: {
1324
- title: 'Code参数',
1325
- type: 'input',
1326
- description: '',
1327
- placeholder: '',
1328
- onShow: !1,
1329
- },
1330
- },
1331
- propertyOrder: ['SIZE', 'TITLE', 'URL', 'CODE'],
1332
- showCodeViewBtn: !1,
1333
- },
1334
- },
1335
- propertyOrder: ['mainConfig', 'otherConfig', 'outConfig'],
1336
- showCodeViewBtn: !1,
1337
- },
1338
- 'sohu-event': {
1339
- type: 'sohu-event',
1340
- title: 'sohu组件事件',
1341
- showCodeViewBtn: !1,
1342
- isContainer: !1,
1343
- properties: {
1344
- globalEventMap: {
1345
- type: 'object',
1346
- title: '全局事件Map',
1347
- description: '',
1348
- properties: {
1349
- eventCode: {
1350
- type: 'input',
1351
- title: '事件名称',
1352
- default: '',
1353
- description: '',
1354
- placeholder: '',
1355
- readOnly: !0,
1356
- },
1357
- },
1358
- propertyOrder: ['eventCode'],
1359
- showCodeViewBtn: !1,
1360
- },
1361
- event: {
1362
- type: 'array',
1363
- title: '监听事件',
1364
- description: '当前组件监听事件列表',
1365
- default: [],
1366
- items: {
1367
- type: 'object',
1368
- title: '数组项',
1369
- description: '',
1370
- properties: {
1371
- name: {
1372
- type: 'input',
1373
- title: '事件',
1374
- default: '',
1375
- description: '',
1376
- placeholder: '',
1377
- },
1378
- code: {
1379
- title: '事件code',
1380
- type: 'input',
1381
- default: '',
1382
- description: '',
1383
- placeholder: '',
1384
- },
1385
- listenName: {
1386
- title: '事件名称',
1387
- type: 'input',
1388
- default: '',
1389
- description: '',
1390
- placeholder: '',
1391
- },
1392
- desc: {
1393
- title: '事件描述',
1394
- type: 'input',
1395
- default: '',
1396
- description: '',
1397
- placeholder: '',
1398
- },
1399
- },
1400
- propertyOrder: ['name', 'code', 'listenName', 'desc'],
1401
- },
1402
- showCodeViewBtn: !1,
1403
- },
1404
- },
1405
- propertyOrder: ['globalEventMap', 'event'],
1406
- },
1407
- 'sohu-ad': {
1408
- type: 'object',
1409
- title: '广告配置',
1410
- description: '',
1411
- properties: {
1412
- type: {
1413
- type: 'select',
1414
- title: '数据源类型',
1415
- isConditionProp: !0,
1416
- options: [
1417
- { label: '模板直接设置', value: 'DevDefaults' },
1418
- { label: '资源中心配置', value: 'ResourceCenter' },
1419
- ],
1420
- description: '',
1421
- },
1422
- value: {
1423
- type: 'object',
1424
- title: '广告规则',
1425
- description: '',
1426
- onShow: 'type === "DevDefaults"',
1427
- properties: {
1428
- id: {
1429
- title: '广告ID',
1430
- type: 'number',
1431
- description: '',
1432
- placeholder: '',
1433
- },
1434
- rule: {
1435
- type: 'radio',
1436
- title: '规则类型',
1437
- isConditionProp: !0,
1438
- options: [
1439
- { label: '固定位置', value: 1 },
1440
- { label: '隔几出几', value: 2 },
1441
- { label: '固定位置隔几出几', value: 3 },
1442
- ],
1443
- description: '',
1444
- },
1445
- fixArray: {
1446
- type: 'select',
1447
- title: '固定位置',
1448
- description: '',
1449
- multiple: !0,
1450
- onShow: 'rule === 1 || rule === 3',
1451
- options: [
1452
- { label: '1', value: 1 },
1453
- { label: '2', value: 2 },
1454
- { label: '3', value: 3 },
1455
- { label: '4', value: 4 },
1456
- { label: '5', value: 5 },
1457
- { label: '6', value: 6 },
1458
- { label: '7', value: 7 },
1459
- { label: '8', value: 8 },
1460
- { label: '9', value: 9 },
1461
- { label: '10', value: 10 },
1462
- { label: '11', value: 11 },
1463
- { label: '12', value: 12 },
1464
- { label: '13', value: 13 },
1465
- { label: '14', value: 14 },
1466
- { label: '15', value: 15 },
1467
- { label: '16', value: 16 },
1468
- { label: '17', value: 17 },
1469
- { label: '18', value: 18 },
1470
- { label: '19', value: 19 },
1471
- { label: '20', value: 20 },
1472
- { label: '21', value: 21 },
1473
- { label: '22', value: 22 },
1474
- { label: '23', value: 23 },
1475
- { label: '24', value: 24 },
1476
- { label: '25', value: 25 },
1477
- { label: '26', value: 26 },
1478
- { label: '27', value: 27 },
1479
- { label: '28', value: 28 },
1480
- { label: '29', value: 29 },
1481
- { label: '30', value: 30 },
1482
- { label: '31', value: 31 },
1483
- { label: '32', value: 32 },
1484
- { label: '33', value: 33 },
1485
- { label: '34', value: 34 },
1486
- { label: '35', value: 35 },
1487
- { label: '36', value: 36 },
1488
- { label: '37', value: 37 },
1489
- { label: '38', value: 38 },
1490
- { label: '39', value: 39 },
1491
- { label: '40', value: 40 },
1492
- { label: '41', value: 41 },
1493
- { label: '42', value: 42 },
1494
- { label: '43', value: 43 },
1495
- { label: '44', value: 44 },
1496
- { label: '45', value: 45 },
1497
- { label: '46', value: 46 },
1498
- { label: '47', value: 47 },
1499
- { label: '48', value: 48 },
1500
- { label: '49', value: 49 },
1501
- { label: '50', value: 50 },
1502
- ],
1503
- },
1504
- begin: {
1505
- type: 'number',
1506
- title: '开始位置',
1507
- minimum: '1',
1508
- maximum: '50',
1509
- description: '',
1510
- onShow: 'rule === 2 || rule === 3',
1511
- },
1512
- turn: {
1513
- type: 'number',
1514
- title: '间隔/隔',
1515
- minimum: '1',
1516
- maximum: '50',
1517
- description: '',
1518
- onShow: 'rule === 2 || rule === 3',
1519
- },
1520
- number: {
1521
- type: 'number',
1522
- title: '间隔/出',
1523
- minimum: '1',
1524
- maximum: '50',
1525
- description: '',
1526
- onShow: 'rule === 2 || rule === 3',
1527
- },
1528
- mergeType: {
1529
- type: 'radio',
1530
- title: '插入规则',
1531
- options: [
1532
- { label: '覆盖', value: 0 },
1533
- { label: '插入', value: 1 },
1534
- ],
1535
- description: '',
1536
- },
1537
- },
1538
- propertyOrder: [
1539
- 'id',
1540
- 'rule',
1541
- 'fixArray',
1542
- 'begin',
1543
- 'turn',
1544
- 'number',
1545
- 'mergeType',
1546
- ],
1547
- },
1548
- range: {
1549
- type: 'array',
1550
- title: '广告规则列表',
1551
- description: '',
1552
- onShow: 'type === "ResourceCenter"',
1553
- items: {
1554
- type: 'object',
1555
- title: '数组项',
1556
- description: '',
1557
- properties: {
1558
- rule: {
1559
- type: 'radio',
1560
- title: '规则类型',
1561
- isConditionProp: !0,
1562
- options: [
1563
- { label: '固定位置', value: 1 },
1564
- { label: '隔几出几', value: 2 },
1565
- { label: '固定位置隔几出几', value: 3 },
1566
- ],
1567
- description: '',
1568
- },
1569
- fixArray: {
1570
- type: 'select',
1571
- title: '固定位置',
1572
- description: '',
1573
- onShow: 'rule === 1 || rule === 3',
1574
- multiple: !0,
1575
- options: [
1576
- { label: '1', value: 1 },
1577
- { label: '2', value: 2 },
1578
- { label: '3', value: 3 },
1579
- { label: '4', value: 4 },
1580
- { label: '5', value: 5 },
1581
- { label: '6', value: 6 },
1582
- { label: '7', value: 7 },
1583
- { label: '8', value: 8 },
1584
- { label: '9', value: 9 },
1585
- { label: '10', value: 10 },
1586
- { label: '11', value: 11 },
1587
- { label: '12', value: 12 },
1588
- { label: '13', value: 13 },
1589
- { label: '14', value: 14 },
1590
- { label: '15', value: 15 },
1591
- { label: '16', value: 16 },
1592
- { label: '17', value: 17 },
1593
- { label: '18', value: 18 },
1594
- { label: '19', value: 19 },
1595
- { label: '20', value: 20 },
1596
- { label: '21', value: 21 },
1597
- { label: '22', value: 22 },
1598
- { label: '23', value: 23 },
1599
- { label: '24', value: 24 },
1600
- { label: '25', value: 25 },
1601
- { label: '26', value: 26 },
1602
- { label: '27', value: 27 },
1603
- { label: '28', value: 28 },
1604
- { label: '29', value: 29 },
1605
- { label: '30', value: 30 },
1606
- { label: '31', value: 31 },
1607
- { label: '32', value: 32 },
1608
- { label: '33', value: 33 },
1609
- { label: '34', value: 34 },
1610
- { label: '35', value: 35 },
1611
- { label: '36', value: 36 },
1612
- { label: '37', value: 37 },
1613
- { label: '38', value: 38 },
1614
- { label: '39', value: 39 },
1615
- { label: '40', value: 40 },
1616
- { label: '41', value: 41 },
1617
- { label: '42', value: 42 },
1618
- { label: '43', value: 43 },
1619
- { label: '44', value: 44 },
1620
- { label: '45', value: 45 },
1621
- { label: '46', value: 46 },
1622
- { label: '47', value: 47 },
1623
- { label: '48', value: 48 },
1624
- { label: '49', value: 49 },
1625
- { label: '50', value: 50 },
1626
- ],
1627
- },
1628
- begin: {
1629
- type: 'number',
1630
- title: '开始位置',
1631
- minimum: '1',
1632
- maximum: '50',
1633
- description: '',
1634
- onShow: 'rule === 2 || rule === 3',
1635
- },
1636
- turn: {
1637
- type: 'number',
1638
- title: '间隔/隔',
1639
- minimum: '1',
1640
- maximum: '50',
1641
- description: '',
1642
- onShow: 'rule === 2 || rule === 3',
1643
- },
1644
- number: {
1645
- type: 'number',
1646
- title: '间隔/出',
1647
- minimum: '1',
1648
- maximum: '50',
1649
- description: '',
1650
- onShow: 'rule === 2 || rule === 3',
1651
- },
1652
- mergeType: {
1653
- type: 'radio',
1654
- title: '插入规则',
1655
- options: [
1656
- { label: '覆盖', value: 0 },
1657
- { label: '插入', value: 1 },
1658
- ],
1659
- description: '',
1660
- },
1661
- },
1662
- propertyOrder: [
1663
- 'rule',
1664
- 'fixArray',
1665
- 'begin',
1666
- 'turn',
1667
- 'number',
1668
- 'mergeType',
1669
- ],
1670
- },
1671
- },
1672
- },
1673
- propertyOrder: ['type', 'value', 'range'],
1674
- },
1675
- },
1676
- S = {
1677
- on: {
1678
- type: 'event',
1679
- title: '事件',
1680
- isContainer: !1,
1681
- properties: {
1682
- type: {
1683
- default: 'on',
1684
- type: 'select',
1685
- options: [
1686
- { label: 'on', value: 'on' },
1687
- { label: 'emit', value: 'emit' },
1688
- ],
1689
- title: '事件类型',
1690
- },
1691
- register: {
1692
- type: 'input',
1693
- default: 'eventName',
1694
- title: '注册事件',
1695
- description: '用于输入注册事件的名称',
1696
- placeholder: '请输入注册事件的名称',
1697
- },
1698
- actionFunc: {
1699
- title: '执行函数',
1700
- type: 'codearea',
1701
- default: '() => {}',
1702
- description: '',
1703
- },
1704
- },
1705
- propertyOrder: ['type', 'register', 'actionFunc'],
1706
- },
1707
- emit: h,
1708
- },
1709
- x = { local: g, remote: C };
1710
- function w(e) {
1711
- return /^http[s]?:\/\/.*/.test(e);
1712
- }
1713
- function T(e) {
1714
- return 'String' === Object.prototype.toString.call(e).slice(8, -1);
1715
- }
1716
- function D(e) {
1717
- return (
1718
- 'number' == typeof e ||
1719
- '[object Number]' === Object.prototype.toString.call(e)
1720
- );
1721
- }
1722
- function N(e) {
1723
- return 'Boolean' === Object.prototype.toString.call(e).slice(8, -1);
1724
- }
1725
- function R(e) {
1726
- return /^\d{4}-\d{2}-\d{2}$/.test(e);
1727
- }
1728
- function q(e) {
1729
- return (
1730
- /^\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}$/.test(e) ||
1731
- /^\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2}$/.test(e)
1732
- );
1733
- }
1734
- function E(e) {
1735
- return /^\d{2}:\d{2}:\d{2}$/.test(e) || /^\d{2}:\d{2}$/.test(e);
1736
- }
1737
- function k(e) {
1738
- var t = !1;
1739
- return (
1740
- 'Array' === Object.prototype.toString.call(e).slice(8, -1) && (t = !0),
1741
- t
1742
- );
1743
- }
1744
- function F(e) {
1745
- if (!k(e)) return !1;
1746
- for (var t = 0, r = e.length; t < r; t++) if (!T(e[t])) return !1;
1747
- return !0;
1748
- }
1749
- function P(e) {
1750
- var t = !1;
1751
- return (
1752
- 'Object' === Object.prototype.toString.call(e).slice(8, -1) && (t = !0),
1753
- t
1754
- );
1755
- }
1756
- function I(e) {
1757
- var t = !1;
1758
- return O.quantity.properties.quantity.enum.indexOf(e) >= 0 && (t = !0), t;
1759
- }
1760
- function M(e) {
1761
- return /^#[0-9a-f]{6}$/.test(e) || /^#[0-9a-f]{3}$/.test(e);
1762
- }
1763
- function _(e) {
1764
- var t = !1;
1765
- return (
1766
- 'Function' === Object.prototype.toString.call(e).slice(8, -1) &&
1767
- (t = !0),
1768
- t
1769
- );
1770
- }
1771
- function A(e) {
1772
- var t;
1773
- return (
1774
- (t =
1775
- e && P(e)
1776
- ? (function (e) {
1777
- var t;
1778
- if (P(e)) {
1779
- var r = Object.keys(e);
1780
- e.data && e.filter && 2 === r.length
1781
- ? (t = k(e.data) || P(e.data) ? o(x.local) : o(x.remote))
1782
- : e.trigger && e.eventData && 2 === r.length
1783
- ? (t = o(S.emit))
1784
- : e.register && e.actionFunc && 2 === r.length
1785
- ? (t = o(S.on))
1786
- : e.quantity && I(e.quantity) && 2 === r.length
1787
- ? (t = o(O.quantity))
1788
- : ((t = o(O['empty-object'])),
1789
- Object.keys(e).map(function (r) {
1790
- var i = e[r];
1791
- t.properties[r] = A(i);
1792
- }));
1793
- }
1794
- return t;
1795
- })(e)
1796
- : e && k(e)
1797
- ? (function (e) {
1798
- var t;
1799
- if (e && k(e))
1800
- if (F(e)) {
1801
- (t = o(O.select)).items.enum = e;
1802
- var r = t.items.enumextra.length,
1803
- i = e.length;
1804
- if (i > r)
1805
- for (var a = r, l = i; a < l; a++)
1806
- t.items.enumextra.push('选项' + e(a));
1807
- } else {
1808
- t = o(O['empty-array']);
1809
- var n = A(e[0]);
1810
- t.items.properties = n.properties;
1811
- }
1812
- return t;
1813
- })(e)
1814
- : (function (e) {
1815
- var t = '';
1816
- if (N(e)) t = o(O.boolean);
1817
- else if (D(e)) t = o(O.number);
1818
- else if (w(e)) t = o(O.url);
1819
- else if (R(e)) t = o(O.date);
1820
- else if (q(e)) t = o(O['date-time']);
1821
- else if (E(e)) t = o(O.time);
1822
- else if (M(e)) t = o(O.color);
1823
- else
1824
- try {
1825
- t = D(JSON.parse(e)) ? o(O.input) : o(O.json);
1826
- } catch (r) {
1827
- t = e && e.length > 30 ? o(O.textarea) : o(O.input);
1828
- }
1829
- return t;
1830
- })(e)),
1831
- t
1832
- );
1833
- }
1834
- function B(e, t) {
1835
- var r = t || {};
1836
- return (
1837
- P(e) &&
1838
- 'object' === getExpectType(e.type) &&
1839
- e.properties &&
1840
- (e.propertyOrder ? e.propertyOrder : Object.keys(e.properties)).map(
1841
- function (t) {
1842
- var i = e.properties[t];
1843
- r = V(i, r);
1844
- },
1845
- ),
1846
- r
1847
- );
1848
- }
1849
- function V(e, t) {
1850
- var r = !t,
1851
- i = t || {};
1852
- if (e && '{}' !== JSON.stringify(e)) {
1853
- var a = e.type;
1854
- 'object' === a || 'func' === a || 'style' === a || 'data' === a
1855
- ? (!r && i.object ? (i.object += 1) : r || (i.object = 1),
1856
- (i = B(e, i)))
1857
- : 'array' === a
1858
- ? (!r && i.array ? (i.array += 1) : r || (i.array = 1),
1859
- (i = B((e = e.items), i)))
1860
- : !r && i[a]
1861
- ? (i[a] += 1)
1862
- : r || (i[a] = 1);
1863
- }
1864
- return i;
1865
- }
1866
- function L(e) {
1867
- var t = o(e);
1868
- if (
1869
- (!t.title && t.description && (t.title = t.description),
1870
- t.type || (t.type = t.format),
1871
- ('quantity' !== t.type &&
1872
- 'array' !== t.type &&
1873
- 'datasource' !== t.type &&
1874
- 'event' !== t.type &&
1875
- 'object' !== t.type) ||
1876
- !u(t.default) ||
1877
- delete t.default,
1878
- 'radio' === t.type &&
1879
- ((t.type = 'string'),
1880
- t.enum &&
1881
- t.enumextra &&
1882
- ((t.items = {
1883
- type: 'string',
1884
- enum: o(t.enum),
1885
- enumextra: o(t.enumextra),
1886
- }),
1887
- delete t.enum,
1888
- delete t.enumextra)),
1889
- 'quantity' === t.type)
1890
- ) {
1891
- var r = t.properties,
1892
- i = o(O.quantity);
1893
- if (r.quantity && P(r.quantity) && r.quantity.default) {
1894
- var a = r.quantity.default;
1895
- i.properties.quantity.default = 'percent' === a ? '%' : a;
1896
- }
1897
- t = i;
1898
- }
1899
- if ('datasource' === t.type) {
1900
- var l = t.properties,
1901
- n = l.type && l.type.default,
1902
- p = l.data && l.data.default,
1903
- c = l.filter && l.filter.default;
1904
- 'local' === n
1905
- ? ((t = o(x.local)).properties.data.default = p ? o(p) : '{}')
1906
- : ((t = o(x.remote)).properties.data.default = p
1907
- ? o(p)
1908
- : 'http://xxx'),
1909
- (t.properties.filter.default = c ? o(c) : '() => {}');
1910
- }
1911
- if ('event' === t.type) {
1912
- var s = t.properties,
1913
- d = s.type && s.type.default;
1914
- if ('in' === d || 'on' === d) {
1915
- var y = (s.filter && s.filter.default) || '() => {}';
1916
- (t = o(S.on)),
1917
- s.actionFunc &&
1918
- P(s.actionFunc) &&
1919
- (t.properties.actionFunc.default = s.actionFunc.default || o(y));
1920
- } else {
1921
- var f = (s.filter && s.filter.default) || '{}';
1922
- (t = o(S.emit)),
1923
- s.eventData &&
1924
- P(s.eventData) &&
1925
- (t.properties.eventData.default = s.eventData.default || o(f));
1926
- }
1927
- }
1928
- return (
1929
- t.properties &&
1930
- (t.propertyOrder || (t.propertyOrder = Object.keys(t.properties)),
1931
- t.propertyOrder.map(function (e) {
1932
- t.properties[e] = $(t.properties[e]);
1933
- })),
1934
- t.items && (t.items = $(t.items)),
1935
- t
1936
- );
1937
- }
1938
- function $(e) {
1939
- var t = o(e);
1940
- return (
1941
- t.required || delete t.required,
1942
- t.type && t.type && (t.type = t.type),
1943
- ('quantity' !== t.type &&
1944
- 'array' !== t.type &&
1945
- 'datasource' !== t.type &&
1946
- 'event' !== t.type &&
1947
- 'object' !== t.type) ||
1948
- !u(t.default) ||
1949
- delete t.default,
1950
- ('radio' !== t.type &&
1951
- 'checkboxes' !== t.type &&
1952
- 'select' !== t.type) ||
1953
- (t.items &&
1954
- t.items.enum &&
1955
- t.items.enumextra &&
1956
- ((t.options = []),
1957
- t.items.enum.forEach(function (e, r) {
1958
- t.options.push({ label: t.items.enumextra[r] || e, value: e });
1959
- }),
1960
- delete t.items)),
1961
- t.properties &&
1962
- (t.propertyOrder || (t.propertyOrder = Object.keys(t.properties)),
1963
- t.propertyOrder.map(function (e) {
1964
- t.properties[e] = $(t.properties[e]);
1965
- })),
1966
- 'array' === t.type && t.items && (t.items = $(t.items)),
1967
- t
1968
- );
1969
- }
1970
- require('mobx');
1971
- var J,
1972
- K =
1973
- (((J = {
1974
- array: 'array',
1975
- boolean: 'boolean',
1976
- 'box-style': 'object',
1977
- 'padding-margin': 'object',
1978
- codearea: 'string',
1979
- color: 'string',
1980
- datasource: 'object',
1981
- date: 'string',
1982
- 'date-time': 'string',
1983
- 'dynamic-data': 'object',
1984
- event: 'object',
1985
- 'func-body': 'string',
1986
- htmlarea: 'string',
1987
- image: 'string',
1988
- input: 'string',
1989
- json: 'string',
1990
- number: 'number',
1991
- 'input-image': 'string',
1992
- object: 'object',
1993
- quantity: 'object',
1994
- radio: 'string',
1995
- select: 'array',
1996
- }).select = 'string'),
1997
- (J.textarea = 'string'),
1998
- (J['text-editor'] = 'string'),
1999
- (J.time = 'string'),
2000
- (J.url = 'string'),
2001
- (J['dynamic-config'] = 'object'),
2002
- (J['dynamic-object'] = 'object'),
2003
- (J['dynamic-array'] = 'object'),
2004
- (J['sohu-source'] = 'object'),
2005
- (J['sohu-event'] = 'object'),
2006
- J);
2007
- function z(e) {
2008
- return K[e] || e;
2009
- }
2010
- function U(e, t) {
2011
- K[e]
2012
- ? console.warn('当前已经存在' + e + '(' + K[e] + '),暂时不支持覆盖。')
2013
- : (K[e] = t);
2014
- }
2015
- function W(e) {
2016
- var t = !0;
2017
- if (!e) return t;
2018
- var r = e.type;
2019
- return (
2020
- (('object' === r &&
2021
- e.properties &&
2022
- e.propertyOrder &&
2023
- e.propertyOrder.length > 0) ||
2024
- ('array' === r &&
2025
- e.items &&
2026
- e.items.properties &&
2027
- e.items.propertyOrder &&
2028
- e.items.propertyOrder.length > 0) ||
2029
- (e.type && 'array' !== e.type && 'object' !== e.type) ||
2030
- e.type) &&
2031
- (t = !1),
2032
- t
2033
- );
2034
- }
2035
- function X(e) {
2036
- var t = !1,
2037
- r = e.lastUpdateTime,
2038
- i = new Date('2024-10-05T00:01:00.691Z').getTime();
2039
- return r && new Date(r).getTime() >= i && (t = !0), t;
2040
- }
2041
- function Y(e) {
2042
- var t = !1,
2043
- r = z(e.type),
2044
- i = void 0 === e.isContainer || e.isContainer;
2045
- return 'object' === r && i && (t = !0), t;
2046
- }
2047
- function Z(e) {
2048
- var t = !0;
2049
- return (
2050
- 'object' === e.type && e.propertyOrder && e.properties
2051
- ? e.propertyOrder.map(function (r) {
2052
- var i = e.properties[r];
2053
- ('object' === e.type && i.propertyOrder && i.properties) ||
2054
- (t = !1);
2055
- })
2056
- : (t = !1),
2057
- t
2058
- );
2059
- }
2060
- function H(e, t) {
2061
- var r = e.split('-'),
2062
- i = t.split('-');
2063
- return r.pop(), i.pop(), r.join('-') === i.join('-');
2064
- }
2065
- function Q(e, t) {
2066
- for (
2067
- var r = e.split('-'),
2068
- i = t.split('-'),
2069
- a = 'before',
2070
- l = 0,
2071
- n = (r.length > i.length ? i : r).length;
2072
- l < n;
2073
- l += 1
2074
- )
2075
- Number(r[l]) > Number(i[l]) && (a = 'after');
2076
- return a;
2077
- }
2078
- function G(e) {
2079
- var t = e.split('-');
2080
- return t.pop(), t.join('-');
2081
- }
2082
- function ee(e) {
2083
- var t = e.split('-'),
2084
- r = t.pop(),
2085
- i = Number(r) + 1;
2086
- return t.push('' + i), t.join('-');
2087
- }
2088
- function te(e) {
2089
- var t = e.split('-'),
2090
- r = t.pop();
2091
- return [t.join('-'), r];
2092
- }
2093
- function re(e) {
2094
- var t = e.split('-'),
2095
- r = t.pop();
2096
- return t.push(Number(r) - 1), t.join('-');
2097
- }
2098
- function ie(e) {
2099
- var t = e.split('-'),
2100
- r = t.pop();
2101
- return t.push(Number(r) + 1), t.join('-');
2102
- }
2103
- function ae(e, t) {
2104
- var r = '',
2105
- i = !1;
2106
- if (!1 !== e.defaultActiveFirstOption && e.defaultActiveFirstOption)
2107
- return (
2108
- e.options && e.options[0] && ((r = e.options[0].value), (i = !0)),
2109
- (t || e.multiple) && (r = i ? [r] : []),
2110
- r
2111
- );
2112
- }
2113
- function le(e, t) {
2114
- var r,
2115
- i,
2116
- a = void 0,
2117
- l = t;
2118
- u(l) &&
2119
- u(e.default) &&
2120
- (typeof l != typeof e.default ||
2121
- ((r = l), (i = e.default), P(r) + '-' + k(r) != P(i) + '-' + k(i))) &&
2122
- (l = void 0);
2123
- var n = u(l) ? l : e.default;
2124
- switch (e.type) {
2125
- case 'select':
2126
- case 'radio':
2127
- a = null != n ? n : ae(e);
2128
- break;
2129
- case 'checkboxes':
2130
- a = null != n ? n : ae(e, !0);
2131
- break;
2132
- case 'color':
2133
- ('#fff' !== n && '#FFF' !== n) || (n = '#ffffff'),
2134
- (a = u(n) ? n : '#ffffff');
2135
- break;
2136
- case 'boolean':
2137
- a = !!u(n) && n;
2138
- break;
2139
- case 'number':
2140
- a = u(n) ? n : void 0;
2141
- break;
2142
- case 'json':
2143
- var o = '';
2144
- if (P(n) || k(n)) o = n;
2145
- else if (_(n) || '' === n) o = {};
2146
- else
2147
- try {
2148
- o = JSON.parse(n);
2149
- } catch (e) {
2150
- o = {};
2151
- }
2152
- a = o;
2153
- break;
2154
- default:
2155
- a =
2156
- 'input' === e.type && '0' === e.default
2157
- ? n || e.default
2158
- : u(n)
2159
- ? n
2160
- : void 0;
2161
- }
2162
- return a;
2163
- }
2164
- function ne(e, t) {
2165
- var r = {},
2166
- i = e.type;
2167
- if (P(e) && 'object' === z(e.type)) {
2168
- var a = e,
2169
- l = t;
2170
- u(l) &&
2171
- ((u(a.default) && typeof l != typeof e.default) || !P(l)) &&
2172
- (l = void 0);
2173
- var n = u(l) ? l : a.default;
2174
- 'dynamic-data' === i
2175
- ? ((r = o(j)),
2176
- n &&
2177
- P(n) &&
2178
- '{}' !== JSON.stringify(n) &&
2179
- (r = Object.assign(r, n)))
2180
- : 'datasource' === i
2181
- ? a.properties &&
2182
- a.properties.type &&
2183
- a.properties.type.default &&
2184
- 'local' === a.properties.type.default
2185
- ? ((r = { data: '{}', filter: '() => {}' }),
2186
- n && n.data && (r.data = n.data),
2187
- n && n.filter && (r.filter = n.filter),
2188
- 'http://xxx' === r.data && (r.data = '{}'))
2189
- : ((r = { data: 'http://xxx', filter: '() => {}' }),
2190
- n && n.data && (r.data = n.data),
2191
- n && n.filter && (r.filter = n.filter),
2192
- '{}' === r.data && (r.data = 'http://xxx'))
2193
- : 'event' === i
2194
- ? a.properties &&
2195
- a.properties.type &&
2196
- a.properties.type.default &&
2197
- 'emit' === a.properties.type.default
2198
- ? n && 'out' === n.type
2199
- ? (r = {
2200
- trigger: (n && n.filter) || 'eventName',
2201
- eventData: '{}',
2202
- })
2203
- : ((r = { trigger: 'eventName', eventData: '{}' }),
2204
- n && n.trigger && (r.trigger = n.trigger),
2205
- n && n.eventData && (r.eventData = n.eventData))
2206
- : n && 'in' === n.type
2207
- ? (r = {
2208
- register: 'eventName',
2209
- actionFunc: (n && n.filter) || '() => {}',
2210
- })
2211
- : ((r = { register: 'eventName', actionFunc: '() => {}' }),
2212
- n && n.register && (r.register = n.register),
2213
- n && n.actionFunc && (r.actionFunc = n.actionFunc))
2214
- : !1 === e.isContainer && n && P(n) && '{}' !== JSON.stringify(n)
2215
- ? (r = Object.assign(r, n))
2216
- : void 0 === l && a.default && P(a.default)
2217
- ? (r = a.default)
2218
- : e.properties &&
2219
- (e.propertyOrder
2220
- ? e.propertyOrder
2221
- : Object.keys(e.properties)
2222
- ).map(function (i) {
2223
- var a = e.properties[i],
2224
- l = t && t[i];
2225
- switch (z(a.type)) {
2226
- case 'array':
2227
- r[i] = oe(a, l);
2228
- break;
2229
- case 'object':
2230
- r[i] = ne(a, l);
2231
- break;
2232
- default:
2233
- r[i] = le(a, l);
2234
- }
2235
- });
2236
- }
2237
- return r;
2238
- }
2239
- function oe(e, t) {
2240
- var r = [];
2241
- if (e && 'array' === z(e.type)) {
2242
- var i = t;
2243
- u(i) &&
2244
- ((u(e.default) && typeof i != typeof e.default) || !k(i)) &&
2245
- (i = void 0);
2246
- var a = u(i) ? i : e.default;
2247
- if ('array' === z(e.type))
2248
- if (k(a))
2249
- a.map(function (t) {
2250
- r.push(ne(e.items, t));
2251
- });
2252
- else if (a) r = a;
2253
- else {
2254
- var l = ne(e.items, a);
2255
- r.push(l);
2256
- }
2257
- else r = u(a) ? a : [];
2258
- }
2259
- return r;
2260
- }
2261
- function pe(e, t) {
2262
- return 'object' === z(e.type)
2263
- ? ne(e, t)
2264
- : 'array' === z(e.type)
2265
- ? oe(e, t)
2266
- : le(e, t);
2267
- }
2268
- var ue = O;
2269
- function ce(e, t) {
2270
- var r = t || [];
2271
- if (e && '{}' !== JSON.stringify(e))
2272
- if (P(e))
2273
- if (
2274
- e.type &&
2275
- 'remote' === e.type &&
2276
- e.config &&
2277
- P(e.config) &&
2278
- e.config.dataName &&
2279
- u(e.localFilter) &&
2280
- u(e.data)
2281
- ) {
2282
- var i = e.config.body;
2283
- if (i && !P(i))
2284
- try {
2285
- i = JSON.parse(i);
2286
- } catch (e) {
2287
- i = {};
2288
- }
2289
- r.push({ id: e.config.id, dataName: e.config.dataName, body: i });
2290
- } else
2291
- Object.keys(e).map(function (t) {
2292
- ce(e[t], r);
2293
- });
2294
- else
2295
- k(e) &&
2296
- e.map(function (e) {
2297
- ce(e, r);
2298
- });
2299
- return r;
2300
- }
2301
- function se(e, t) {
2302
- var r = t || 'data';
2303
- return (
2304
- e.split('-').map(function (e) {
2305
- r = /^\d+$/.test(e) ? r + '[' + e + ']' : r + '.' + e;
2306
- }),
2307
- r
2308
- );
2309
- }
2310
- function de(e, t) {
2311
- var r = [];
2312
- return (
2313
- P(e)
2314
- ? Object.keys(e).map(function (i) {
2315
- var a = e[i],
2316
- l = t ? t + '-' + i : i;
2317
- P(a) || k(a)
2318
- ? r.push({ title: i, value: l, key: l, children: de(a, l) })
2319
- : r.push({ title: i, value: l, key: l });
2320
- })
2321
- : k(e) &&
2322
- e.map(function (e, i) {
2323
- var a = i.toString(),
2324
- l = t ? t + '-' + i : a;
2325
- P(e) || k(e)
2326
- ? r.push({ title: a, value: l, key: l, children: de(e, l) })
2327
- : r.push({ title: a, value: l, key: l });
2328
- }),
2329
- r
2330
- );
2331
- }
2332
- function ye(e, t) {
2333
- var r = '';
2334
- return (
2335
- 'object' === z(e.type) &&
2336
- e.properties &&
2337
- (e.propertyOrder ? e.propertyOrder : Object.keys(e.properties)).map(
2338
- function (i) {
2339
- var a = e.properties[i],
2340
- l = t[i];
2341
- ('array' === z(a.type) && 'object' === z(a.type)) ||
2342
- (l &&
2343
- a.isConditionProp &&
2344
- (r.indexOf('-') > 0 ? (r += '-' + l) : (r = l)));
2345
- },
2346
- ),
2347
- r
2348
- );
2349
- }
2350
- function fe(e) {
2351
- var t = e.split('-');
2352
- return t.pop(), t.join('-');
2353
- }
2354
- function be(e) {
2355
- var t = e.split('-'),
2356
- r = t.pop();
2357
- return [t.join('-'), r];
2358
- }
2359
- var ve = [
2360
- 'key',
2361
- 'enum',
2362
- 'enumextra',
2363
- 'items',
2364
- 'input',
2365
- 'boolean',
2366
- 'number',
2367
- 'color',
2368
- 'url',
2369
- 'textarea',
2370
- 'text-editor',
2371
- 'radio',
2372
- 'select',
2373
- 'checkboxes',
2374
- 'date',
2375
- 'date-time',
2376
- 'time',
2377
- 'json',
2378
- 'codearea',
2379
- 'htmlarea',
2380
- 'quantity',
2381
- 'box-style',
2382
- 'dynamic-data',
2383
- 'datasource',
2384
- 'event',
2385
- 'array',
2386
- 'object',
2387
- ];
2388
- return t;
2389
- })();
2390
- });
2
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.JSONUtils=t():e.JSONUtils=t()}(this,(function(){return function(){"use strict";var e={n:function(t){var r=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(r,{a:r}),r},d:function(t,r){for(var i in r)e.o(r,i)&&!e.o(t,i)&&Object.defineProperty(t,i,{enumerable:!0,get:r[i]})},o:function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r:function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}},t={};e.r(t),e.d(t,{DataSourceTypeList:function(){return x},EventTypeDataList:function(){return S},KeyWordList:function(){return ve},TypeDataList:function(){return O},dataRoute2dataPath:function(){return se},dynamicDataAnalyzer:function(){return ce},evalExpression:function(){return s},getCurPosition:function(){return Q},getDefaultOptionVal:function(){return ae},getExpectType:function(){return z},getJsonDataByKeyRoute:function(){return d},getNextIndexRoute:function(){return ee},getParentIndexRoute:function(){return G},getParentIndexRoute_CurIndex:function(){return te},getParentKeyRoute:function(){return fe},getParentKeyRoute_CurKey:function(){return be},getSchemaByIndexRoute:function(){return y},getSchemaByKeyRoute:function(){return f},hasProperties:function(){return u},indexRoute2keyRoute:function(){return b},isArray:function(){return k},isBoolean:function(){return N},isColor:function(){return M},isContainerSchema:function(){return Y},isDateStr:function(){return R},isDateTimeStr:function(){return q},isEmptySchema:function(){return W},isEqual:function(){return p},isFunction:function(){return _},isNewSchemaData:function(){return X},isNumber:function(){return D},isObject:function(){return P},isQuantity:function(){return I},isSameParent:function(){return H},isSelect:function(){return F},isString:function(){return T},isStructuredSchema:function(){return Z},isTimeStr:function(){return E},isURL:function(){return w},json2schema:function(){return A},json2treeData:function(){return de},keyRoute2indexRoute:function(){return v},metaElemAnalyzer:function(){return V},moveBackward:function(){return ie},moveForward:function(){return re},objClone:function(){return o},oldSchemaToNewSchema:function(){return $},oldSchemaToNewSchemaV1:function(){return L},registerExpectType:function(){return U},schema2conditionValue:function(){return ye},schema2json:function(){return pe},schemaMetaList:function(){return ue},truncate:function(){return c},urlParse:function(){return l},urlStringify:function(){return n}});var r=require("lodash"),i=require("qs"),a=e.n(i);function l(){var e={};return location.search&&(e=a().parse(location.search.substring(1))),e}function n(e){var t="";return url&&(t=a().stringify(e)),t}function o(e){return(0,r.cloneDeep)(e)}function p(e,t){return(0,r.isEqual)(e,t)}function u(e){var t=!1;return null!=e&&(t=!0),t}function c(e,t){return(0,r.truncate)(e,t)}function s(e,t){var r=t||{};if(!e)return!1;var i=new Function("data","with(data) { return ("+e+");}"),a="";try{a=i(r)}catch(t){return console.warn("表达式运算出错: "+e+",报错信息:",t),a}return a}function d(e,t,r){var i=t;if(r&&(i=o(t)),e)for(var a=e.split("-"),l=0,n=a.length;l<n;l++){var p=a[l];p&&(i=i&&i[p])}return i}function y(e,t,r){var i=t;if(r&&(i=o(t)),e)for(var a=e.split("-"),l=0,n=a.length;l<n;l++){var p=a[l];if("0"!==p||"array"!==i.type&&"radio"!==i.type&&"select"!==i.type&&"checkboxes"!==i.type||!i.options&&!i.items){if(p){var u="0";i.propertyOrder?u=i.propertyOrder[p]:i.properties&&(u=Object.keys(i.properties)[p]),i=i.properties[u]}}else i=i.options||i.items}return i}function f(e,t,r){var i=t;if(r&&(i=o(t)),e&&i)for(var a=e.split("-"),l=0,n=a.length;l<n;l++){var p=a[l];p&&i.properties&&(i=i.properties[p])}return i}function b(e,t){for(var r=t,i="",a=e.split("-"),l=0,n=a.length;l<n;l++){var o=a[l];if("0"===o&&r.items)r=r.items,i=i?i+"-items":"items";else if("0"===o&&r.options)r=r.options,i=i?i+"-options":"options";else if(o){var p="0";r.propertyOrder?p=r.propertyOrder[o]:r.properties&&(p=Object.keys(r.properties)[o]),r=r.properties[p],i=i?i+"-"+p:p}}return i}function v(e,t){for(var r=t,i="",a=e.split("-"),l=0,n=a.length;l<n;l++){var o=a[l];if(o){var p=-1;r.propertyOrder?(p=r.propertyOrder.indexOf(o),r=r.properties[o]):r.properties?(p=Object.keys(r.properties).indexOf(o),r=r.properties[o]):r.items?(p=0,r=r.items):r.options&&(p=0,r=r.options),i=i?i+"-"+p:p.toString()}}return i}var m,h={type:"event",title:"事件",isContainer:!1,properties:{type:{default:"emit",type:"select",options:[{label:"on",value:"on"},{label:"emit",value:"emit"}],title:"事件类型"},trigger:{type:"input",default:"eventName",title:"触发事件",description:"用于输入触发事件的名称",placeholder:"请输入触发事件的名称"},eventData:{title:"事件数据",type:"json",default:"{}",description:"传递给触发事件的数据对象"}},propertyOrder:["type","trigger","eventData"]},g={type:"datasource",title:"数据源",isContainer:!1,properties:{type:{default:"local",type:"select",options:[{label:"本地数据",value:"local"},{label:"接口数据",value:"remote"}],title:"数据源类型"},data:{title:"本地json数据",placeholder:"请输入静态json数据",type:"json",default:"{}",description:"用于设置本地的静态json数据",isRequired:!0},filter:{title:"过滤器",type:"codearea",default:"() => {}",description:"用于定义过滤当前数据的函数",isRequired:!0}},propertyOrder:["type","data","filter"]},C=((m={type:"object"}).type="datasource",m.title="数据源",m.isContainer=!1,m.properties={type:{type:"select",default:"remote",options:[{label:"本地数据",value:"local"},{label:"接口数据",value:"remote"}],title:"数据源类型"},data:{type:"url",title:"远程json数据",placeholder:"请输入远程json数据源地址",default:"http://xxx",isRequired:!0,description:"用于设置获取元素数据的请求地址"},filter:{type:"codearea",title:"过滤器",default:"() => {}",description:"用于定义过滤当前数据的函数",isRequired:!0}},m.propertyOrder=["type","data","filter"],m),j={type:"local",config:{dataName:"",body:{},filter:"return data;"},data:"{}",localFilter:"return data;"},O={jsonschema:{type:"object",title:"jsonSchemaObject",properties:{func:{type:"object",title:"功能设置",properties:{a:{title:"单文本框",type:"input",default:"",description:"",placeholder:"",isRequired:!1}},propertyOrder:["a"]},style:{type:"object",title:"样式设置",properties:{b:{title:"单文本框",type:"input",default:"",description:"",placeholder:""}},propertyOrder:["b"]},data:{type:"data",title:"数据设置",properties:{c:{title:"单文本框",type:"input",default:"",description:"",placeholder:"",isRequired:!1}},propertyOrder:["c"]}},propertyOrder:["func","style","data"]},input:{title:"单文本框",type:"input",default:"",description:"",placeholder:""},boolean:{type:"boolean",title:"布尔值",default:!1,description:""},object:{type:"object",title:"对象Object",description:"",properties:{a:{type:"input",title:"单文本框",default:"",description:"",placeholder:""}},propertyOrder:["a"]},array:{type:"array",title:"数组Array",description:"",items:{type:"object",title:"数组项",description:"",properties:{name:{type:"input",title:"名字",default:"",description:"",placeholder:""}},propertyOrder:["name"]}},"empty-array":{type:"array",title:"数组Array",description:"",default:[],items:{type:"object",title:"数组项",description:"",properties:{}}},"empty-object":{type:"object",title:"对象Object",description:"",properties:{}},url:{type:"url",title:"链接地址url",default:"",description:"",placeholder:""},textarea:{type:"textarea",title:"多行文本框",default:"",description:"",placeholder:""},color:{type:"color",title:"颜色color",default:"#ffffff",description:""},image:{title:"图片",type:"image",default:"",description:"上传图片",imgWidth:200,imgHeight:200,imgRatioReadOnly:!0},number:{type:"number",title:"数量number",default:1,minimum:0,maximum:1e3,description:""},"input-image":{title:"图片地址",type:"input-image",description:"",accept:".jpeg,.jpg,.png",multiple:!0},json:{title:"json数据",type:"json",default:"{}",description:""},codearea:{type:"codearea",title:"函数类型",placeholder:"请输入函数方法",default:'function func() { console.log("hello, world!"); }',description:"用于定义函数方法"},htmlarea:{title:"富文本",type:"htmlarea",placeholder:"请输入html代码片段",default:"<p>hello,world!</p>",description:"用于放置html代码片段"},"text-editor":{type:"text-editor",title:"富文本",default:"",description:"",placeholder:""},date:{type:"date",title:"日期Date",default:"",description:"",placeholder:""},"date-time":{type:"date-time",title:"日期时间",default:"",description:"",placeholder:""},time:{type:"time",title:"时间Time",default:"",description:"",placeholder:""},quantity:{type:"quantity",title:"单位计量",isContainer:!1,properties:{unit:{type:"number",title:"单位数值",default:50,minimum:0,maximum:1e3,description:""},quantity:{type:"select",default:"px",options:[{label:"px",value:"px"},{label:"rem",value:"rem"},{label:"em",value:"em"},{label:"%",value:"%"}],title:"单位类型"}},propertyOrder:["unit","quantity"]},"box-style":{type:"box-style",title:"盒子模型",isContainer:!1,properties:{unit:{title:"单位数值",type:"input",default:"0",description:""},quantity:{type:"select",default:"px",options:[{label:"px",value:"px"},{label:"rem",value:"rem"},{label:"em",value:"em"},{label:"%",value:"%"}],title:"单位类型"}},propertyOrder:["unit","quantity"]},"padding-margin":{type:"padding-margin",title:"边距设置",isContainer:!1,properties:{margin:{title:"外边距",type:"input",default:"0",description:""},padding:{title:"内边距",type:"input",default:"0",description:""},quantity:{type:"select",default:"px",options:[{label:"px",value:"px"},{label:"rem",value:"rem"},{label:"em",value:"em"},{label:"%",value:"%"}],title:"单位类型"}},propertyOrder:["margin","padding","quantity"]},radio:{type:"radio",title:"单选",options:[{label:"选项a",value:"a"},{label:"选项b",value:"b"},{label:"选项c",value:"c"}],description:""},select:{type:"select",title:"下拉选择",options:[{label:"选项a",value:"a"},{label:"选项b",value:"b"},{label:"选项c",value:"c"}],description:""},cascader:{type:"cascader",title:"级联选择",options:[{value:"zhejiang",label:"Zhejiang",children:[{value:"hangzhou",label:"Hangzhou",children:[{value:"xihu",label:"West Lake"}]}]},{value:"jiangsu",label:"Jiangsu",children:[{value:"nanjing",label:"Nanjing",children:[{value:"zhonghuamen",label:"Zhong Hua Men"}]}]}],default:"a",description:"",showSearch:!0,allowClear:!0},checkboxes:{type:"checkboxes",title:"多选",options:[{label:"选项a",value:"a"},{label:"选项b",value:"b"},{label:"选项c",value:"c"}],default:["a"],description:""},"dynamic-data":{type:"dynamic-data",title:"动态数据源",isContainer:!1,properties:{type:{default:"local",type:"select",options:[{label:"本地数据",value:"local"},{label:"接口数据",value:"remote"}],title:"数据类型"},config:{title:"接口配置",type:"object",description:"用于存放接口的配置数据(url、请求参数等)",isRequired:!0,properties:{dataName:{default:"local",type:"select",options:[{label:"本地数据",value:"local"},{label:"接口数据",value:"remote"}],title:"数据类型"},body:{type:"object",title:"请求参数配置",description:"用于配置当前接口的请求参数数值",isRequired:!0},filter:{title:"过滤器函数体",type:"codearea",default:"return data;",description:"用于定义过滤接口数据",isRequired:!0}},propertyOrder:["dataName","body","filter"]},data:{title:"数据内容",type:"json",default:"{}",description:"用于存放DynamicData的数据内容",isRequired:!0},localFilter:{title:"过滤器",type:"codearea",default:"return data;",description:"用于定义过滤本地数据",isRequired:!0}},propertyOrder:["type","config","data","localFilter"]},datasource:g,event:h,"dynamic-config":{type:"dynamic-config",title:"动态配置",description:"",isContainer:!1,properties:{type:{type:"select",title:"数据来源",options:[{label:"模板直接设置",value:"DevDefaults"},{label:"mp后台配置",value:"ContentStaticConfig"},{label:"内容Meta数据",value:"Content"},{label:"全局配置数据",value:"RuntimeConst"},{label:"资源中心配置",value:"ResourceCenter"}],default:"DevDefaults",isConditionProp:!0,description:"目前支持的数据来源包括: 1)模版直接设置:在模版配置直接生效,支持直接输入或图片上传。 2)mp后台配置:选择mp后台配置后,属性会出现在mp后台中,支持属性描述的输入。 3)内容meta数据:支持内容meta数据的获取,页面meta数据。 4)全局配置数据:目前支持的全局配置包括:全局Tab配置及主题包配置。相关属性会挂载至:window.globalConst"},value:{title:"数据值",type:"input",default:"",description:"",placeholder:"",onShow:'type === "DevDefaults" || type === "Content" || type === "RuntimeConst"'},description:{title:"属性名称",type:"input",default:"",description:"",placeholder:"",onShow:'type === "ContentStaticConfig" || type === "ResourceCenter"'},valueType:{type:"radio",title:"配置方式",options:[{label:"填写",value:"string"},{label:"选择",value:"select"}],default:"string",isConditionProp:!0,description:'在MP后台或资源中心配置时的交互方式,推荐使用"选择"',onShow:'type === "ContentStaticConfig" || type === "ResourceCenter"'},range:{type:"select",title:"可选项",multiple:!0,options:[],onShow:'(type === "ContentStaticConfig" || type === "ResourceCenter") && valueType === "select"',description:"这里会使用value中的配置选项作为options"}},propertyOrder:["type","value","description","valueType","range"],showCodeViewBtn:!1},"dynamic-object":{type:"dynamic-object",title:"动态配置",description:"",isContainer:!1,properties:{type:{type:"select",title:"数据来源",options:[{label:"模板直接设置",value:"DevDefaults"},{label:"mp后台配置",value:"ContentStaticConfig"},{label:"内容Meta数据",value:"Content"},{label:"全局配置数据",value:"RuntimeConst"},{label:"资源中心配置",value:"ResourceCenter"}],default:"DevDefaults",isConditionProp:!0,description:"目前支持的数据来源包括: 1)模版直接设置: 在模版配置直接生效,支持直接输入或图片上传。 2)mp后台配置: 选择mp后台配置后,属性会出现在mp后台中,支持属性描述的输入。 3)内容meta数据: 支持内容meta数据的获取,页面meta数据。 4)全局配置数据: 目前支持的全局配置包括:全局Tab配置及主题包配置。相关属性会挂载至:window.globalConst"},value:{title:"数据值",type:"input",default:"",description:"",placeholder:"",onShow:'type === "Content" || type === "RuntimeConst"'},description:{title:"自定义配置名称",type:"input",default:"主题包配置",description:"",placeholder:"",onShow:'type === "ContentStaticConfig" || type === "ResourceCenter"'},attrs:{type:"array",title:"属性列表",description:"Tab需要配置的属性",items:{type:"object",title:"数组项",description:"",properties:{attr:{type:"input",title:"属性Key",default:"",description:"",placeholder:""},description:{title:"描述",type:"input",default:"",description:"",placeholder:""},value:{title:"数值",typeOn:"type === 'image' ? 'input-image' : type === 'number' ? 'number' : 'input'",default:"",description:"",placeholder:""},type:{type:"select",title:"属性类型",options:[{label:"图片类型",value:"image"},{label:"字符串",value:"string"},{label:"数字",value:"number"}],default:"string",description:""}},propertyOrder:["attr","description","type","value"]},"minimum-child":1,showCodeViewBtn:!1,onShow:'type === "DevDefaults" || type === "ContentStaticConfig" || type === "ResourceCenter"'}},propertyOrder:["type","description","attrs","value"],showCodeViewBtn:!1,showKey:!0},"dynamic-array":{type:"dynamic-array",title:"动态数组",description:"",isContainer:!1,properties:{type:{type:"select",title:"数据来源",options:[{label:"模板直接设置",value:"DevDefaults"},{label:"mp后台配置",value:"ContentStaticConfig"},{label:"资源中心配置",value:"ResourceCenter"}],default:"DevDefaults",isConditionProp:!0,description:"目前支持的数据来源包括: 1)模版直接设置:在模版配置直接生效,支持直接输入或图片上传。 2)mp后台配置:选择mp后台配置后,属性会出现在mp后台中,支持属性描述的输入。 3)内容meta数据:支持内容meta数据的获取,页面meta数据。 4)全局配置数据:目前支持的全局配置包括:全局Tab配置及主题包配置。相关属性会挂载至:window.globalConst"},description:{title:"自定义配置名称",type:"input",default:"Tab全局配置",description:"",placeholder:"",onShow:'type === "ContentStaticConfig" || type === "ResourceCenter"'},tabNums:{title:"Tab配置数",type:"number",default:1,description:"需要配置的Tab数量",placeholder:"",onShow:"type === 'ContentStaticConfig' || type === 'ResourceCenter'"},attrs:{type:"array",title:"Tab属性",description:"Tab需要配置的属性",items:{type:"object",title:"数组项",description:"",properties:{attr:{type:"input",title:"属性Key",default:"",description:"",placeholder:""},description:{title:"描述",type:"input",default:"",description:"",placeholder:""},tipText:{title:"提示说明",type:"textarea",default:"",description:"",placeholder:""}},propertyOrder:["attr","description","tipText"]},"minimum-child":1,onShow:"type === 'ContentStaticConfig' || type === 'ResourceCenter'",showCodeViewBtn:!1},value:{type:"array",title:"Tab配置",description:"",items:{type:"object",title:"数组项",description:"",properties:{title:{type:"input",title:"名称",default:"",description:"",placeholder:""},id:{title:"id",type:"input",default:"",description:"",placeholder:""},value:{title:"数值",type:"input",default:"",description:"",placeholder:""}},propertyOrder:["title","value","id"]},"minimum-child":1,onShow:"type === 'DevDefaults'",showCodeViewBtn:!1}},propertyOrder:["type","value","description","tabNums","attrs"],showCodeViewBtn:!1,showKey:!0},"sohu-source":{type:"sohu-source",title:"数据源",description:"",isContainer:!1,properties:{mainConfig:{type:"object",title:"主要配置",description:"",isContainer:!1,properties:{type:{type:"select",title:"数据来源",isConditionProp:!0,options:[{label:"模板自定义数据源",value:"RuntimeDataSelfDefine"},{label:"mp后台配置",value:"ContentStaticConfig"},{label:"请求当前页面数据",value:"RuntimeDataSelfContent"},{label:"资源中心配置",value:"ResourceCenter"}],default:"RuntimeDataSelfDefine",description:""},description:{title:"数据源名称",type:"input",description:"",placeholder:"",onShow:'type === "ContentStaticConfig"'},dataType:{type:"radio",title:"请求方式",default:!1,options:[{label:"批量请求",value:"FROMCIS"},{label:"组件内部请求",value:"FROMCOMPCIS"},{label:"不请求",value:!1}],description:""},CONTENTID:{title:"数据源ID",type:"input",description:"",placeholder:"",onShow:'type === "RuntimeDataSelfDefine"'},CONTENTTYPE:{type:"select",title:"数据源类型",options:[{label:"channel",value:"channel"},{label:"topic",value:"topic"},{label:"block",value:"block"}],description:"",onShow:'type === "RuntimeDataSelfDefine"'}},propertyOrder:["type","description","dataType","CONTENTID","CONTENTTYPE"],showCodeViewBtn:!1},outConfig:{type:"object",title:"出流配置",description:"",isContainer:!1,properties:{PRO:{type:"select",title:"内容类型",options:[{label:"置顶+加精",value:"4"},{label:"长效置顶",value:"5"}],description:""},FEEDTYPE:{type:"select",title:"排序类型",options:[{label:"综合",value:"XTOPIC_SYNTHETICAL"},{label:"最新",value:"XTOPIC_LATEST"},{label:"相关",value:"XTOPIC_RELATED"}],description:""},VIEW:{type:"select",title:"数据裁剪",options:[{label:"相关推荐模式",value:"articleFeedMode"},{label:"文字链裁剪方式",value:"textMode"},{label:"短内容摘录方式",value:"excerptMode"},{label:"互动(点赞/评论)裁剪方式",value:"interactMode"},{label:"评论文字链裁剪方式",value:"commentTextMode"},{label:"摘录方式(无点赞)",value:"excerptCommentMode"},{label:"无限流卡片模式",value:"dynamicFeedMode"},{label:"时间线模式",value:"timeLineMode"},{label:"复合内容流模式",value:"multiFeedMode"},{label:"搜狐号推荐模式",value:"recommendFeedMode"},{label:"作者页内容流模式",value:"operateFeedMode"},{label:"标签内容流模式",value:"tagsFeedMode"},{label:"评论链裁剪方式",value:"commentMode"},{label:"标签摘录方式",value:"excerptTagsMode"},{label:"内容流模式",value:"feedMode"}],description:""},CONTENTCONTEXT:{type:"select",title:"mKey参数",options:[{label:"作者ID+栏目ID",value:"authorColumnId_${#authorColumnId}"},{label:"账号ID",value:"accountId_${#contentData_account_id}"},{label:"mkeyID",value:"mid_${#mkeyConst_mid}"},{label:"mkey名称",value:"mname_${#mkeyConst_mname}"},{label:"城市Code码",value:"cityCode_${#cityInfo_cityCode}"},{label:"城市名称",value:"cityName_${#cityInfo_cityName}"},{label:"焦点城市Code码",value:"focusCityCode_${#focusCityInfo_cityCode}"}],description:""},CONTENTPARAMS:{title:"动态参数",type:"json",description:"请填写JSON格式的参数",placeholder:""}},propertyOrder:["PRO","FEEDTYPE","VIEW","CONTENTCONTEXT","CONTENTPARAMS"],showCodeViewBtn:!1},otherConfig:{type:"object",title:"选配内容",description:"",isContainer:!1,properties:{SIZE:{type:"number",title:"容量",minimum:0,maximum:1e3,description:"该位置区块需要的内容条数"},TITLE:{title:"标题",type:"input",description:"",placeholder:""},URL:{type:"url",title:"更多跳转链接",description:"该区块下点击“更多或箭头图标”后的跳转链接",placeholder:""},CODE:{title:"Code参数",type:"input",description:"",placeholder:"",onShow:!1}},propertyOrder:["SIZE","TITLE","URL","CODE"],showCodeViewBtn:!1}},propertyOrder:["mainConfig","otherConfig","outConfig"],showCodeViewBtn:!1},"sohu-event":{type:"sohu-event",title:"sohu组件事件",showCodeViewBtn:!1,isContainer:!1,properties:{globalEventMap:{type:"object",title:"全局事件Map",description:"",properties:{eventCode:{type:"input",title:"事件名称",default:"",description:"",placeholder:"",readOnly:!0}},propertyOrder:["eventCode"],showCodeViewBtn:!1},event:{type:"array",title:"监听事件",description:"当前组件监听事件列表",default:[],items:{type:"object",title:"数组项",description:"",properties:{name:{type:"input",title:"事件",default:"",description:"",placeholder:""},code:{title:"事件code",type:"input",default:"",description:"",placeholder:""},listenName:{title:"事件名称",type:"input",default:"",description:"",placeholder:""},desc:{title:"事件描述",type:"input",default:"",description:"",placeholder:""}},propertyOrder:["name","code","listenName","desc"]},showCodeViewBtn:!1}},propertyOrder:["globalEventMap","event"]},"sohu-ad":{type:"object",title:"广告配置",description:"",properties:{type:{type:"select",title:"数据源类型",isConditionProp:!0,options:[{label:"模板直接设置",value:"DevDefaults"},{label:"资源中心配置",value:"ResourceCenter"}],description:""},value:{type:"object",title:"广告规则",description:"",onShow:'type === "DevDefaults"',properties:{id:{title:"广告ID",type:"number",description:"",placeholder:""},rule:{type:"radio",title:"规则类型",isConditionProp:!0,options:[{label:"固定位置",value:1},{label:"隔几出几",value:2},{label:"固定位置隔几出几",value:3}],description:""},fixArray:{type:"select",title:"固定位置",description:"",multiple:!0,onShow:"rule === 1 || rule === 3",options:[{label:"1",value:1},{label:"2",value:2},{label:"3",value:3},{label:"4",value:4},{label:"5",value:5},{label:"6",value:6},{label:"7",value:7},{label:"8",value:8},{label:"9",value:9},{label:"10",value:10},{label:"11",value:11},{label:"12",value:12},{label:"13",value:13},{label:"14",value:14},{label:"15",value:15},{label:"16",value:16},{label:"17",value:17},{label:"18",value:18},{label:"19",value:19},{label:"20",value:20},{label:"21",value:21},{label:"22",value:22},{label:"23",value:23},{label:"24",value:24},{label:"25",value:25},{label:"26",value:26},{label:"27",value:27},{label:"28",value:28},{label:"29",value:29},{label:"30",value:30},{label:"31",value:31},{label:"32",value:32},{label:"33",value:33},{label:"34",value:34},{label:"35",value:35},{label:"36",value:36},{label:"37",value:37},{label:"38",value:38},{label:"39",value:39},{label:"40",value:40},{label:"41",value:41},{label:"42",value:42},{label:"43",value:43},{label:"44",value:44},{label:"45",value:45},{label:"46",value:46},{label:"47",value:47},{label:"48",value:48},{label:"49",value:49},{label:"50",value:50}]},begin:{type:"number",title:"开始位置",minimum:"1",maximum:"50",description:"",onShow:"rule === 2 || rule === 3"},turn:{type:"number",title:"间隔/隔",minimum:"1",maximum:"50",description:"",onShow:"rule === 2 || rule === 3"},number:{type:"number",title:"间隔/出",minimum:"1",maximum:"50",description:"",onShow:"rule === 2 || rule === 3"},mergeType:{type:"radio",title:"插入规则",options:[{label:"覆盖",value:0},{label:"插入",value:1}],description:""}},propertyOrder:["id","rule","fixArray","begin","turn","number","mergeType"]},range:{type:"array",title:"广告规则列表",description:"",onShow:'type === "ResourceCenter"',items:{type:"object",title:"数组项",description:"",properties:{rule:{type:"radio",title:"规则类型",isConditionProp:!0,options:[{label:"固定位置",value:1},{label:"隔几出几",value:2},{label:"固定位置隔几出几",value:3}],description:""},fixArray:{type:"select",title:"固定位置",description:"",onShow:"rule === 1 || rule === 3",multiple:!0,options:[{label:"1",value:1},{label:"2",value:2},{label:"3",value:3},{label:"4",value:4},{label:"5",value:5},{label:"6",value:6},{label:"7",value:7},{label:"8",value:8},{label:"9",value:9},{label:"10",value:10},{label:"11",value:11},{label:"12",value:12},{label:"13",value:13},{label:"14",value:14},{label:"15",value:15},{label:"16",value:16},{label:"17",value:17},{label:"18",value:18},{label:"19",value:19},{label:"20",value:20},{label:"21",value:21},{label:"22",value:22},{label:"23",value:23},{label:"24",value:24},{label:"25",value:25},{label:"26",value:26},{label:"27",value:27},{label:"28",value:28},{label:"29",value:29},{label:"30",value:30},{label:"31",value:31},{label:"32",value:32},{label:"33",value:33},{label:"34",value:34},{label:"35",value:35},{label:"36",value:36},{label:"37",value:37},{label:"38",value:38},{label:"39",value:39},{label:"40",value:40},{label:"41",value:41},{label:"42",value:42},{label:"43",value:43},{label:"44",value:44},{label:"45",value:45},{label:"46",value:46},{label:"47",value:47},{label:"48",value:48},{label:"49",value:49},{label:"50",value:50}]},begin:{type:"number",title:"开始位置",minimum:"1",maximum:"50",description:"",onShow:"rule === 2 || rule === 3"},turn:{type:"number",title:"间隔/隔",minimum:"1",maximum:"50",description:"",onShow:"rule === 2 || rule === 3"},number:{type:"number",title:"间隔/出",minimum:"1",maximum:"50",description:"",onShow:"rule === 2 || rule === 3"},mergeType:{type:"radio",title:"插入规则",options:[{label:"覆盖",value:0},{label:"插入",value:1}],description:""}},propertyOrder:["rule","fixArray","begin","turn","number","mergeType"]}}},propertyOrder:["type","value","range"]}},S={on:{type:"event",title:"事件",isContainer:!1,properties:{type:{default:"on",type:"select",options:[{label:"on",value:"on"},{label:"emit",value:"emit"}],title:"事件类型"},register:{type:"input",default:"eventName",title:"注册事件",description:"用于输入注册事件的名称",placeholder:"请输入注册事件的名称"},actionFunc:{title:"执行函数",type:"codearea",default:"() => {}",description:""}},propertyOrder:["type","register","actionFunc"]},emit:h},x={local:g,remote:C};function w(e){return/^http[s]?:\/\/.*/.test(e)}function T(e){return"String"===Object.prototype.toString.call(e).slice(8,-1)}function D(e){return"number"==typeof e||"[object Number]"===Object.prototype.toString.call(e)}function N(e){return"Boolean"===Object.prototype.toString.call(e).slice(8,-1)}function R(e){return/^\d{4}-\d{2}-\d{2}$/.test(e)}function q(e){return/^\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}$/.test(e)||/^\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2}$/.test(e)}function E(e){return/^\d{2}:\d{2}:\d{2}$/.test(e)||/^\d{2}:\d{2}$/.test(e)}function k(e){var t=!1;return"Array"===Object.prototype.toString.call(e).slice(8,-1)&&(t=!0),t}function F(e){if(!k(e))return!1;for(var t=0,r=e.length;t<r;t++)if(!T(e[t]))return!1;return!0}function P(e){var t=!1;return"Object"===Object.prototype.toString.call(e).slice(8,-1)&&(t=!0),t}function I(e){var t=!1;return O.quantity.properties.quantity.enum.indexOf(e)>=0&&(t=!0),t}function M(e){return/^#[0-9a-f]{6}$/.test(e)||/^#[0-9a-f]{3}$/.test(e)}function _(e){var t=!1;return"Function"===Object.prototype.toString.call(e).slice(8,-1)&&(t=!0),t}function A(e){var t;return t=e&&P(e)?function(e){var t;if(P(e)){var r=Object.keys(e);e.data&&e.filter&&2===r.length?t=k(e.data)||P(e.data)?o(x.local):o(x.remote):e.trigger&&e.eventData&&2===r.length?t=o(S.emit):e.register&&e.actionFunc&&2===r.length?t=o(S.on):e.quantity&&I(e.quantity)&&2===r.length?t=o(O.quantity):(t=o(O["empty-object"]),Object.keys(e).map((function(r){var i=e[r];t.properties[r]=A(i)})))}return t}(e):e&&k(e)?function(e){var t;if(e&&k(e))if(F(e)){(t=o(O.select)).items.enum=e;var r=t.items.enumextra.length,i=e.length;if(i>r)for(var a=r,l=i;a<l;a++)t.items.enumextra.push("选项"+e(a))}else{t=o(O["empty-array"]);var n=A(e[0]);t.items.properties=n.properties}return t}(e):function(e){var t="";if(N(e))t=o(O.boolean);else if(D(e))t=o(O.number);else if(w(e))t=o(O.url);else if(R(e))t=o(O.date);else if(q(e))t=o(O["date-time"]);else if(E(e))t=o(O.time);else if(M(e))t=o(O.color);else try{t=D(JSON.parse(e))?o(O.input):o(O.json)}catch(r){t=e&&e.length>30?o(O.textarea):o(O.input)}return t}(e),t}function B(e,t){var r=t||{};return P(e)&&"object"===getExpectType(e.type)&&e.properties&&(e.propertyOrder?e.propertyOrder:Object.keys(e.properties)).map((function(t){var i=e.properties[t];r=V(i,r)})),r}function V(e,t){var r=!t,i=t||{};if(e&&"{}"!==JSON.stringify(e)){var a=e.type;"object"===a||"func"===a||"style"===a||"data"===a?(!r&&i.object?i.object+=1:r||(i.object=1),i=B(e,i)):"array"===a?(!r&&i.array?i.array+=1:r||(i.array=1),i=B(e=e.items,i)):!r&&i[a]?i[a]+=1:r||(i[a]=1)}return i}function L(e){var t=o(e);if(!t.title&&t.description&&(t.title=t.description),t.type||(t.type=t.format),"quantity"!==t.type&&"array"!==t.type&&"datasource"!==t.type&&"event"!==t.type&&"object"!==t.type||!u(t.default)||delete t.default,"radio"===t.type&&(t.type="string",t.enum&&t.enumextra&&(t.items={type:"string",enum:o(t.enum),enumextra:o(t.enumextra)},delete t.enum,delete t.enumextra)),"quantity"===t.type){var r=t.properties,i=o(O.quantity);if(r.quantity&&P(r.quantity)&&r.quantity.default){var a=r.quantity.default;i.properties.quantity.default="percent"===a?"%":a}t=i}if("datasource"===t.type){var l=t.properties,n=l.type&&l.type.default,p=l.data&&l.data.default,c=l.filter&&l.filter.default;"local"===n?(t=o(x.local)).properties.data.default=p?o(p):"{}":(t=o(x.remote)).properties.data.default=p?o(p):"http://xxx",t.properties.filter.default=c?o(c):"() => {}"}if("event"===t.type){var s=t.properties,d=s.type&&s.type.default;if("in"===d||"on"===d){var y=s.filter&&s.filter.default||"() => {}";t=o(S.on),s.actionFunc&&P(s.actionFunc)&&(t.properties.actionFunc.default=s.actionFunc.default||o(y))}else{var f=s.filter&&s.filter.default||"{}";t=o(S.emit),s.eventData&&P(s.eventData)&&(t.properties.eventData.default=s.eventData.default||o(f))}}return t.properties&&(t.propertyOrder||(t.propertyOrder=Object.keys(t.properties)),t.propertyOrder.map((function(e){t.properties[e]=$(t.properties[e])}))),t.items&&(t.items=$(t.items)),t}function $(e){var t=o(e);return t.required||delete t.required,t.type&&t.type&&(t.type=t.type),"quantity"!==t.type&&"array"!==t.type&&"datasource"!==t.type&&"event"!==t.type&&"object"!==t.type||!u(t.default)||delete t.default,"radio"!==t.type&&"checkboxes"!==t.type&&"select"!==t.type||t.items&&t.items.enum&&t.items.enumextra&&(t.options=[],t.items.enum.forEach((function(e,r){t.options.push({label:t.items.enumextra[r]||e,value:e})})),delete t.items),t.properties&&(t.propertyOrder||(t.propertyOrder=Object.keys(t.properties)),t.propertyOrder.map((function(e){t.properties[e]=$(t.properties[e])}))),"array"===t.type&&t.items&&(t.items=$(t.items)),t}require("mobx");var J,K=((J={array:"array",boolean:"boolean","box-style":"object","padding-margin":"object",codearea:"string",color:"string",datasource:"object",date:"string","date-time":"string","dynamic-data":"object",event:"object","func-body":"string",htmlarea:"string",image:"string",input:"string",json:"string",number:"number","input-image":"string",object:"object",quantity:"object",radio:"string",select:"array"}).select="string",J.textarea="string",J["text-editor"]="string",J.time="string",J.url="string",J["dynamic-config"]="object",J["dynamic-object"]="object",J["dynamic-array"]="object",J["sohu-source"]="object",J["sohu-event"]="object",J);function z(e){return K[e]||e}function U(e,t){K[e]?console.warn("当前已经存在"+e+"("+K[e]+"),暂时不支持覆盖。"):K[e]=t}function W(e){var t=!0;if(!e)return t;var r=e.type;return("object"===r&&e.properties&&e.propertyOrder&&e.propertyOrder.length>0||"array"===r&&e.items&&e.items.properties&&e.items.propertyOrder&&e.items.propertyOrder.length>0||e.type&&"array"!==e.type&&"object"!==e.type||e.type)&&(t=!1),t}function X(e){var t=!1,r=e.lastUpdateTime,i=new Date("2024-10-05T00:01:00.691Z").getTime();return r&&new Date(r).getTime()>=i&&(t=!0),t}function Y(e){var t=!1,r=z(e.type),i=void 0===e.isContainer||e.isContainer;return"object"===r&&i&&(t=!0),t}function Z(e){var t=!0;return"object"===e.type&&e.propertyOrder&&e.properties?e.propertyOrder.map((function(r){var i=e.properties[r];"object"===e.type&&i.propertyOrder&&i.properties||(t=!1)})):t=!1,t}function H(e,t){var r=e.split("-"),i=t.split("-");return r.pop(),i.pop(),r.join("-")===i.join("-")}function Q(e,t){for(var r=e.split("-"),i=t.split("-"),a="before",l=0,n=(r.length>i.length?i:r).length;l<n;l+=1)Number(r[l])>Number(i[l])&&(a="after");return a}function G(e){var t=e.split("-");return t.pop(),t.join("-")}function ee(e){var t=e.split("-"),r=t.pop(),i=Number(r)+1;return t.push(""+i),t.join("-")}function te(e){var t=e.split("-"),r=t.pop();return[t.join("-"),r]}function re(e){var t=e.split("-"),r=t.pop();return t.push(Number(r)-1),t.join("-")}function ie(e){var t=e.split("-"),r=t.pop();return t.push(Number(r)+1),t.join("-")}function ae(e,t){var r="",i=!1;if(!1!==e.defaultActiveFirstOption&&e.defaultActiveFirstOption)return e.options&&e.options[0]&&(r=e.options[0].value,i=!0),(t||e.multiple)&&(r=i?[r]:[]),r}function le(e,t){var r,i,a=void 0,l=t;u(l)&&u(e.default)&&(typeof l!=typeof e.default||(r=l,i=e.default,P(r)+"-"+k(r)!=P(i)+"-"+k(i)))&&(l=void 0);var n=u(l)?l:e.default;switch(e.type){case"select":case"radio":a=null!=n?n:ae(e);break;case"checkboxes":a=null!=n?n:ae(e,!0);break;case"color":"#fff"!==n&&"#FFF"!==n||(n="#ffffff"),a=u(n)?n:"#ffffff";break;case"boolean":a=!!u(n)&&n;break;case"number":a=u(n)?n:void 0;break;case"json":var o="";if(P(n)||k(n))o=n;else if(_(n)||""===n)o={};else try{o=JSON.parse(n)}catch(e){o={}}a=o;break;default:a="input"===e.type&&"0"===e.default?n||e.default:u(n)?n:void 0}return a}function ne(e,t){var r={},i=e.type;if(P(e)&&"object"===z(e.type)){var a=e,l=t;u(l)&&(u(a.default)&&typeof l!=typeof e.default||!P(l))&&(l=void 0);var n=u(l)?l:a.default;"dynamic-data"===i?(r=o(j),n&&P(n)&&"{}"!==JSON.stringify(n)&&(r=Object.assign(r,n))):"datasource"===i?a.properties&&a.properties.type&&a.properties.type.default&&"local"===a.properties.type.default?(r={data:"{}",filter:"() => {}"},n&&n.data&&(r.data=n.data),n&&n.filter&&(r.filter=n.filter),"http://xxx"===r.data&&(r.data="{}")):(r={data:"http://xxx",filter:"() => {}"},n&&n.data&&(r.data=n.data),n&&n.filter&&(r.filter=n.filter),"{}"===r.data&&(r.data="http://xxx")):"event"===i?a.properties&&a.properties.type&&a.properties.type.default&&"emit"===a.properties.type.default?n&&"out"===n.type?r={trigger:n&&n.filter||"eventName",eventData:"{}"}:(r={trigger:"eventName",eventData:"{}"},n&&n.trigger&&(r.trigger=n.trigger),n&&n.eventData&&(r.eventData=n.eventData)):n&&"in"===n.type?r={register:"eventName",actionFunc:n&&n.filter||"() => {}"}:(r={register:"eventName",actionFunc:"() => {}"},n&&n.register&&(r.register=n.register),n&&n.actionFunc&&(r.actionFunc=n.actionFunc)):!1===e.isContainer&&n&&P(n)&&"{}"!==JSON.stringify(n)?r=Object.assign(r,n):void 0===l&&a.default&&P(a.default)?r=a.default:e.properties&&(e.propertyOrder?e.propertyOrder:Object.keys(e.properties)).map((function(i){var a=e.properties[i],l=t&&t[i];switch(z(a.type)){case"array":r[i]=oe(a,l);break;case"object":r[i]=ne(a,l);break;default:r[i]=le(a,l)}}))}return r}function oe(e,t){var r=[];if(e&&"array"===z(e.type)){var i=t;u(i)&&(u(e.default)&&typeof i!=typeof e.default||!k(i))&&(i=void 0);var a=u(i)?i:e.default;if("array"===z(e.type))if(k(a))a.map((function(t){r.push(ne(e.items,t))}));else if(a)r=a;else{var l=ne(e.items,a);r.push(l)}else r=u(a)?a:[]}return r}function pe(e,t){return"object"===z(e.type)?ne(e,t):"array"===z(e.type)?oe(e,t):le(e,t)}var ue=O;function ce(e,t){var r=t||[];if(e&&"{}"!==JSON.stringify(e))if(P(e))if(e.type&&"remote"===e.type&&e.config&&P(e.config)&&e.config.dataName&&u(e.localFilter)&&u(e.data)){var i=e.config.body;if(i&&!P(i))try{i=JSON.parse(i)}catch(e){i={}}r.push({id:e.config.id,dataName:e.config.dataName,body:i})}else Object.keys(e).map((function(t){ce(e[t],r)}));else k(e)&&e.map((function(e){ce(e,r)}));return r}function se(e,t){var r=t||"data";return e.split("-").map((function(e){r=/^\d+$/.test(e)?r+"["+e+"]":r+"."+e})),r}function de(e,t){var r=[];return P(e)?Object.keys(e).map((function(i){var a=e[i],l=t?t+"-"+i:i;P(a)||k(a)?r.push({title:i,value:l,key:l,children:de(a,l)}):r.push({title:i,value:l,key:l})})):k(e)&&e.map((function(e,i){var a=i.toString(),l=t?t+"-"+i:a;P(e)||k(e)?r.push({title:a,value:l,key:l,children:de(e,l)}):r.push({title:a,value:l,key:l})})),r}function ye(e,t){var r="";return"object"===z(e.type)&&e.properties&&(e.propertyOrder?e.propertyOrder:Object.keys(e.properties)).map((function(i){var a=e.properties[i],l=t[i];"array"===z(a.type)&&"object"===z(a.type)||l&&a.isConditionProp&&(r.indexOf("-")>0?r+="-"+l:r=l)})),r}function fe(e){var t=e.split("-");return t.pop(),t.join("-")}function be(e){var t=e.split("-"),r=t.pop();return[t.join("-"),r]}var ve=["key","enum","enumextra","items","input","boolean","number","color","url","textarea","text-editor","radio","select","checkboxes","date","date-time","time","json","codearea","htmlarea","quantity","box-style","dynamic-data","datasource","event","array","object"];return t}()}));