@wibetter/json-utils 5.2.10 → 5.3.1

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,2 +1,2433 @@
1
1
  /*! For license information please see index.js.LICENSE.txt */
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}()}));
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 c;
49
+ },
50
+ KeyWordList: function () {
51
+ return ve;
52
+ },
53
+ TypeDataList: function () {
54
+ return s;
55
+ },
56
+ dataRoute2dataPath: function () {
57
+ return de;
58
+ },
59
+ dynamicDataAnalyzer: function () {
60
+ return ce;
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 se;
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
+ s = {
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: 13 },
1073
+ { label: 'topic', value: 15 },
1074
+ { label: 'block', value: 14 },
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
+ c = {
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 s.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(c.emit))
1827
+ : e.register && e.actionFunc && 2 === r.length
1828
+ ? (t = N(c.on))
1829
+ : e.quantity && S(e.quantity) && 2 === r.length
1830
+ ? (t = N(s.quantity))
1831
+ : ((t = N(s['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(s.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(s['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(s.boolean);
1860
+ else if (b(e)) t = N(s.number);
1861
+ else if (y(e)) t = N(s.url);
1862
+ else if (v(e)) t = N(s.date);
1863
+ else if (h(e)) t = N(s['date-time']);
1864
+ else if (g(e)) t = N(s.time);
1865
+ else if (x(e)) t = N(s.color);
1866
+ else
1867
+ try {
1868
+ t = b(JSON.parse(e)) ? N(s.input) : N(s.json);
1869
+ } catch (r) {
1870
+ t = e && e.length > 30 ? N(s.textarea) : N(s.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(s.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(c.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(c.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 se = s;
2312
+ function ce(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
+ ce(e[t], r);
2336
+ });
2337
+ else
2338
+ C(e) &&
2339
+ e.map(function (e) {
2340
+ ce(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
+ });