@wibetter/json-utils 5.2.8 → 5.2.10

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