序号 | \n授权客服 | \n授权时间 | \n操作 | \n
\n {{ index + 1 }} \n | \n \n {{ item.authtousername }} \n | \n \n {{ dateFormat(null, item.authtime) }}\n | \n\n \n {{ item.iscancel != \"Y\" ? \"取消授权\" : \"授权\" }}\n \n \n 删除\n \n | \n
序号 | \n授权客服 | \n授权时间 | \n
\n {{ index + 1 }} \n | \n \n {{ item.authusername }} \n | \n \n {{ dateFormat(null, item.authtime) }}\n | \n
\n {{ userInfo.roleName }}\n
\n\n {{ userInfo.orgName }}\n
\n\n 修改密码\n
\n\r\n \r\n 本系统为非涉密信息系统,不得上传涉密敏感文件。
如违规上传涉密文件,文件上传人将承担相应泄密责任!\r\n
推送方式(可多选)
\n\n 您还没有选择标签!\n
\n查找不到相关数据
\n暂无数据
\n{{ isTips }}
\n{{ errorInfo }}
\n]* contenteditable=\\\"([^\\\"]+)\\\"[^>]*>\", 'i'));\n if (quoteRegMatch) { // 引用\n let nonQuoteMsg = getNonQuoteMsg(content);\n let atRegMatch = nonQuoteMsg.match(new RegExp(\"]* userid=\\\"([^\\\"]+)\\\"[^>]*>\", 'i'));\n if (atRegMatch) {\n return simpleMsgFun(nonQuoteMsg);\n } else {\n content = \"[引用消息]\" + nonQuoteMsg;\n }\n }\n let html = $('' + content + '');\n let isAt = null;\n html.find(\"span,img,a,audio,video\").each(function (index, element) {\n switch ($(this)[0].tagName) {\n case \"SPAN\":\n let userid = $(this).attr(\"userid\");\n if (userid) {\n if (userid === store.state.user.baseInfo.id) {\n isAt = \"personal\";\n } else if (userid === \"all\") {\n isAt = \"all\";\n }\n }\n if ($(this).hasClass(\"znkf-question-label\")) {\n $(this)[0].outerHTML = \"[问题]\"\n }\n break;\n case \"AUDIO\":\n $(this)[0].outerHTML = \"[语音]\"\n break;\n case \"VIDEO\":\n $(this)[0].outerHTML = \"[视频]\"\n break;\n case \"IMG\":\n if ($(this)[0].alt) {\n $(this)[0].outerHTML = \"[表情]\"\n } else {\n $(this)[0].outerHTML = \"[图片]\"\n }\n break;\n case \"A\":\n $(this)[0].outerHTML = \"[链接]\"\n break;\n default:\n break;\n }\n });\n return {\n simpleMsg: html[0].innerText,\n isAt: isAt\n };\n}\n\nexport const getTextOnly = (content) => {\n if(!content) {\n return '';\n }\n let quoteRegMatch = content.match(new RegExp(\"]* contenteditable=\\\"([^\\\"]+)\\\"[^>]*>\", 'i'));\n if (quoteRegMatch) { // 引用\n let nonQuoteMsg = getNonQuoteMsg(content);\n let atRegMatch = nonQuoteMsg.match(new RegExp(\"]* userid=\\\"([^\\\"]+)\\\"[^>]*>\", 'i'));\n if (atRegMatch) {\n return getText(nonQuoteMsg);\n } else {\n content = nonQuoteMsg;\n }\n }\n let html = $('' + content + '');\n html.find(\"span,img,a,audio,video\").each(function (index, element) {\n switch ($(this)[0].tagName) {\n case \"SPAN\":\n let userid = $(this).attr(\"userid\");\n if (userid) {\n $(this)[0].outerHTML = \"\"\n }\n break;\n case \"AUDIO\":\n case \"VIDEO\":\n case \"IMG\":\n $(this)[0].outerHTML = \"\"\n break;\n default:\n break;\n }\n });\n return html[0].innerText;\n}\n\nexport const getNonQuoteMsg = (content) => {\n let quoteStartNum = 0;\n for (let i = 0; content.indexOf('');\n if (quoteStartIndex < quoteEndIndex) {\n content = content.substring(11 + content.indexOf(''));\n }\n return content;\n}\n\nexport const htmlMessageHandle = (content,getImages) => {\n // 还原被转义的表情代码\n content = restoreEscapeCharacter(content);\n // 将表情代码转换为图片\n content = emojiCodeToImg(content);\n // 将原始地址替换为当前环境地址\n // content = replaceUrlAddress(content);\n // 处理a标签,新建页面转跳\n let contentObj = handleLinkJump(content);\n if(getImages) {\n return {\n content: contentObj.content,\n images: contentObj.images\n };\n }else {\n return contentObj.content;\n }\n}\n\n\n/**\n * 多行文本框转换空格和换行\n * isToHtml: true 将文本框原始内容转为html格式\n * import { transTextArea } from \"@/utils/publicUtils\";\n */\n export function transTextArea(content,isToHtml) {\n content = content || \"\";\n if(!content) {\n return content;\n }\n if(isToHtml) {\n //替换所有的换行符\n content = content.replace(/\\r\\n/g,\"
\")\n content = content.replace(/\\n/g,\"
\");\n //替换空格( 中文空格、英文空格都会被替换: \\s 仅替换英文空格: ( ) )\n content = content.replace(/\\s/g,\" \");\n }else {\n content = content.replace(/
/g,\"\\n\")\n content = content.replace(/
/g,\"\\n\");\n content = content.replace(/ /g,\" \");\n }\n return content;\n}\n\nexport function tryJSONParse (JsonString, type) {\n let result = type ==\"array\" ? []:{};\n try {\n result = JSON.parse(JsonString);\n } catch (error) {\n console.log(`JSON error : ${error},JsonString:${JsonString}`);\n }\n return result || (type ==\"array\" ? []:{});\n}\n\n/**\n * 根据文件名返回对应的文件类型\n * str: 可为 123.jpg .jpg jpg\n */\nexport function getFileType (str) {\n let result = '';\n if(typeof str === 'string') {\n let arr = str.split('.');\n let fileSuffix = arr[arr.length===2 ? 1 : 0];\n switch (fileSuffix) {\n case 'xls':\n case 'xlsx':\n result = 'excel';\n break;\n case 'ppt':\n case 'pptx':\n result = 'ppt';\n break;\n case 'doc':\n case 'docx':\n result = 'word';\n break;\n case 'png':\n case 'jpg':\n case 'jpeg':\n case 'gif':\n case 'webp':\n case 'bmp':\n case 'svgs':\n result = 'image';\n break;\n case 'txt':\n result = 'txt';\n break;\n case 'pdf':\n result = 'pdf';\n break;\n case 'zip':\n case 'rar':\n result = 'zip';\n break;\n case 'mp4':\n result = 'video';\n break;\n }\n }\n return result;\n}\n\n/**\n * 数组对象排序\n * [{id: \"!\", val: 212}, {id: \"3\", val: 12}].sort(this.arrObjSortFun(\"id\"))\n */\nexport const arrObjSortFun = (prop) => {\n return function (obj1, obj2) {\n var val1 = obj1[prop];\n var val2 = obj2[prop];\n if (!isNaN(Number(val1)) && !isNaN(Number(val2))) {\n val1 = Number(val1);\n val2 = Number(val2);\n }\n if (val1 > val2) {\n return 1;\n } else if (val1 < val2) {\n return -1;\n } else {\n return 0;\n }\n }\n}\n\nexport const arrObjSortTimeFun = (prop) => {\n return function (obj1, obj2) {\n var val1 = obj1[prop] ? new Date(obj1[prop]).getTime() : 0;\n var val2 = obj2[prop] ? new Date(obj2[prop]).getTime() : 0;\n if (!isNaN(Number(val1)) && !isNaN(Number(val2))) {\n val1 = Number(val1);\n val2 = Number(val2);\n }\n if (val1 > val2) {\n return 1;\n } else if (val1 < val2) {\n return -1;\n } else {\n return 0;\n }\n };\n}\n","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","/**\n * 过滤器文件_过滤方法说明:\n * setAdaptSize 根据屏幕大小动态设置字体等的值(数字)\n */\n\n\nimport Vue from \"vue\";\n/* 全局方法\n * @例子 0.85745 保留两位小数 85.75%\n * @使用 this.$options.filters.demo(value)\n * @ 标签模板使用value|demo\n */\nVue.filter('demo', (value) => {\n if (value) {\n value = 1\n } else {\n value = 22\n }\n return value\n});\n\n/**\n * 数字格式化 setNum\n * @描述 需要进行四舍五入\n * @例子 12354.254 保留两位小数 12,354.25\n * @使用 this.$options.filters.setNum(value,decimal,isAbs,noZeroFun)\n * @param value 原始数据\n * @param decimal 不带参数默认余两位小数\n * @param isAbs true,表示取绝对值 -- 这里一般和增幅搭配使用\n * @param noZeroFun true,表示不进行0格式化\n */\nVue.filter('setNum', (value, decimal, isAbs, noZeroFun) => {\n if (value === null || isNaN(value)) {\n return \"-\"; //无效数字\n }\n value = Number(value) ? Number(value) : 0;\n decimal = !decimal && decimal != 0 ? 2 : decimal;\n let decimalPow = Math.pow(10, decimal);\n let fixedNum = Math.round(value * decimalPow) / decimalPow;\n fixedNum = isAbs ? Math.abs(fixedNum) : Number(fixedNum);\n fixedNum = fixedNum.toLocaleString()\n return noZeroFun ? fixedNum : setZeroFun(fixedNum, decimal);\n});\n\n/**\n * 百分比转换 setPercent\n * @描述 需要进行四舍五入 - 2019-12-11改动: 转换为百分比的数值大于99.99的才直接截取,如99.9999 = 99.99%\n * @例子 0.85745 保留两位小数 85.75%\n * @使用 this.$options.filters.setPercent(value, decimal, isAbs, isSpeed, noUnit)\n * @param value 原始数据\n * @param decimal 不带参数默认余两位小数\n * @param isAbs true,表示取绝对值 -- 这里和增幅搭配使用 ,0显示“持平”\n * @param isSpeed true,表示返回“快、慢”\n * @param noUnit true表示不返回“%”\n */\nVue.filter('setPercent', (value, decimal, isAbs, isSpeed, noUnit) => {\n let isNegative = false; //是否未负数\n if (value === null || isNaN(value)) {\n return \"-\" + (noUnit ? \"\" : \"%\"); //无效数字\n }\n // value = Number(value) ? value * 100 : 0; //存在运算精度丢失问题 0.0023 转为 0.22999999....\n value = Number(value) ? floatMultiply(value, 100) : 0; //解决运算精度丢失问题\n decimal = !decimal && decimal != 0 ? 2 : decimal;\n let fixedNum = 0;\n let maxDecimal = decimal ? (decimal == 2 ? 99.99 : 99.9) : 99; // 判断值 -- 例如:保留两位小数超过99.99进行截取\n if (value < 0) { //初始值是否未负数\n value = Math.abs(value); //取绝对值进行运算,运算结果再变负数\n isNegative = true;\n }\n if (value >= maxDecimal) {\n // 使用字符串拼接的方式截取小数位数,而不是四舍五入:\n value = (value + \"\").split(\".\");\n fixedNum = value.length > 1 ? value[1].substr(0, decimal) : \"\";\n fixedNum = value[0] + (decimal ? \".\" + fixedNum : \"\");\n fixedNum = Number(fixedNum);\n } else {\n // 四舍五入\n let decimalPow = Math.pow(10, decimal);\n // let fixedNum = Number(value).toFixed(decimal); //注释toFixed - 有精度问题\n fixedNum = Math.round(value * decimalPow) / decimalPow; //百分比转换后再进行判断, 0.000001 --> 0.0001保留两位小数后也是0的情况\n }\n if (isNegative) { //初始值是否未负数\n fixedNum = fixedNum * -1;\n }\n let str = \"\";\n let unit = noUnit ? \"\" : \"%\";\n if (isAbs || isSpeed) {\n // 增幅、进度快慢\n if (isSpeed && fixedNum < 0) {\n str = \"慢\";\n } else if (isSpeed && fixedNum > 0) {\n str = \"快\";\n }\n fixedNum = Math.abs(fixedNum); //取绝对值\n fixedNum = setZeroFun(fixedNum, decimal);\n fixedNum = fixedNum ? str + fixedNum + unit : \"持平\";\n } else {\n // fixedNum = Number(fixedNum);\n fixedNum = setZeroFun(fixedNum, decimal);\n fixedNum = fixedNum + unit;\n }\n return fixedNum;\n});\n\n// Vue.filter('setFileSize', (value, decimal, noZeroFun) => {\n// if (value === null || isNaN(value)) {\n// return \"-\"; //无效数字\n// }\n// value = Number(value) ? Number(value) : 0;\n// if(value===0) {\n// return \"0 Bytes\";\n// }\n// let unitArr = new Array(\"Bytes\",\"KB\",\"MB\",\"GB\",\"TB\",\"PB\",\"EB\",\"ZB\",\"YB\");\n// let index=0;\n// let srcsize = parseFloat(value);\n// index = Math.floor( floatDivide( Math.log(srcsize) / Math.log(1024) ) );\n// let size = floatDivide( srcsize, Math.pow(1024,index) );\n// decimal = !decimal && decimal != 0 ? 2 : decimal;\n// let decimalPow = Math.pow(10, decimal);\n// let fixedNum = Math.round(size * decimalPow) / decimalPow;\n// fixedNum = fixedNum.toLocaleString()\n// return fixedNum + unitArr[index];\n// });\n\n/**\n * 格式化文件大小\n * this.$options.filters.setFileSize(value);\n * @param value 原始值\n */\n Vue.filter('setFileSize', (value) => {\n if( !value || value=='' ){\n return \"0 Bytes\";\n }\n let unitArr = new Array(\"Bytes\",\"KB\",\"MB\",\"GB\",\"TB\",\"PB\",\"EB\",\"ZB\",\"YB\");\n let index=0;\n let srcsize = parseFloat(value);\n index=Math.floor(Math.log(srcsize)/Math.log(1024));\n let size =srcsize/Math.pow(1024,index);\n size=size.toFixed(2); // 保留的小数位数\n return size+unitArr[index];\n});\n\n/*\n 接入方式\n 根据参数传入返回对应图标\n @使用 this.$options.filters.tableIconClass(value,type)\n 类型属性:name,icon\n\n*/\nVue.filter('tableIconClass', (value, type) => {\n let data = {\n label: '',\n icon: '',\n }\n switch (value) {\n case 'WEB_STAFF': {\n //座席web端\n data.label = '座席端'\n data.icon = 'iconfont iconyouceneirongkuang-zhinenghuifu';\n break;\n }\n case 'WEB_ROBOT': {\n //前端机器人\n data.label = '机器人'\n data.icon = 'iconfont iconjieruqudaotubiao-qiantai';\n break;\n }\n case 'WECHAT_MP':\n //微信公众号icon图标\n data.label = '公众号'\n data.icon = 'iconfont iconjieruqudaotubiao-weixin';\n break;\n case 'YZY_H5':\n //粤政易图标\n data.label = '粤政易'\n data.icon = 'icon-yzy';\n break;\n }\n\n switch (type) {\n case 'name':\n // 获取接入渠道名\n return data.label\n case 'icon':\n // 获取接入渠道图标\n return data.icon\n default:\n return ''\n }\n});\n\n/*\n 工单优先级\n 根据参数传入返回对应样式\n @使用 this.$options.filters.tablePriorityState(value,Class)\n\n*/\nVue.filter('tablePriorityState', (value, Class) => {\n switch (value) {\n case '1':\n //尚未处理\n value = !Class ? '四等级' : 'table-priority-state-1';\n break;\n case '2':\n //受理中\n value = !Class ? '三等级' : 'table-priority-state-2';\n break;\n case '3':\n //等待回复\n value = !Class ? '二等级' : 'table-priority-state-3';\n break;\n case '4':\n //已解决\n value = !Class ? '一等级' : 'table-priority-state-4';\n break;\n }\n return value\n});\n\n/*\n 工单状态\n 根据参数传入返回对应样式\n @使用 this.$options.filters.tableDisposeState(value,Class)\n\n*/\nVue.filter('tableDisposeState', (value, Class) => {\n switch (value) {\n case '1':\n //尚未处理\n value = !Class ? '尚未处理' : 'table-dispose-state-1';\n break;\n case '2':\n //受理中\n value = !Class ? '受理中' : 'table-dispose-state-2';\n break;\n case '3':\n //等待回复\n value = !Class ? '等待回复' : 'table-dispose-state-3';\n break;\n case '4':\n //已解决\n value = !Class ? '已解决' : 'table-dispose-state-4';\n break;\n }\n return value\n});\n\n\n/**\n * 根据屏幕大小动态设置字体等的值(数字) - 屏幕变化时要刷新才会更新\n * @param value 色值\n * @param type 属性类型\n * 1. \"height\" 屏幕高度\n * 3. \"\" 默认是屏幕宽度\n * 使用 this.$options.filters.setAdaptSize(value,type);\n */\nVue.filter('setAdaptSize', (value, type) => {\n let adaptSize = 0;\n switch (type) {\n case \"height\":\n adaptSize = document.body.clientHeight; //网页可见区域高\n break;\n default:\n adaptSize = document.body.clientWidth; //网页可见区域宽\n break;\n }\n return Math.min(adaptSize / 1920 * value, value); //取最小值,不要超过传进来的原始值\n});\n\n\n/**\n * 乘法 - js运算精度丢失问题\n * @param arg1 数1\n * @param arg2 数2\n */\nvar floatMultiply = (arg1, arg2) => {\n if (arg1 == null || arg2 == null) {\n return null;\n }\n let n1, n2;\n let r1, r2; // 小数位数\n try {\n r1 = arg1.toString().split(\".\")[1].length;\n } catch (e) {\n r1 = 0;\n }\n try {\n r2 = arg2.toString().split(\".\")[1].length;\n } catch (e) {\n r2 = 0;\n }\n n1 = Number(arg1.toString().replace(\".\", \"\"));\n n2 = Number(arg2.toString().replace(\".\", \"\"));\n return n1 * n2 / Math.pow(10, r1 + r2);\n}\n\n\n/**\n * 固定小数后的位数,如果不够则补0\n * @param {*} value 原数\n * @param {*} decimal 小数位数\n */\nvar setZeroFun = (value, decimal) => {\n if (decimal == 0) {\n return value;\n }\n value = value + \"\";\n let valArr = value.split(\".\");\n let newVal = valArr.length > 1 ? valArr[1] : \"\"\n for (let i = 1; i <= decimal; i++) {\n if (newVal.length < i) {\n newVal += \"0\";\n }\n }\n return valArr[0] + \".\" + newVal;\n}\n\n/**\n * 数组对象排序\n * this.$options.filters.ArrObjSort(key, type)\n * key 属性名\n * type 排序类型:默认从大到小, -1 表示倒叙,从小到大\n */\nVue.filter('ArrObjSort', (key, type) => {\n return (obj1, obj2) => {\n let val1 = obj1[key];\n let val2 = obj2[key];\n if (!isNaN(Number(val1)) && !isNaN(Number(val2))) {\n val1 = Number(val1);\n val2 = Number(val2);\n }\n if (val1 < val2) {\n return 1;\n } else if (val1 > val2) {\n return -1;\n } else {\n return 0;\n }\n }\n});\n\n/**\n * 判断一个对象是否存在于某个数据对象(根据某个属性比如id进行判断)\n * 比如 { id: 1 } 是否存在于 [ { id: 1 }, { id: 2 } ]中,存在则返回true,否则返回false\n * this.$options.filters.isExistObject(obj,arr,key)\n * obj 对象\n * arr 数组对象\n * key 属性名 默认为“id”\n */\nVue.filter('isExistObject', (obj, arr, key) => {\n key = key || \"id\";\n for (let i = 0; i < arr.length; i++) {\n if (obj[key] == arr[i][key]) {\n return true;\n }\n }\n return false;\n});\n/**\n * 判断对象是否需要转换'-'\n * 默认null转换为'-'\n * number为转换数字类型 传布尔值类型\n */\nVue.filter('nullOfStr', (num, number) => {\n let val = '';\n if (number) {\n val = num === null ? '-' : Number(num)\n } else {\n val = num === null ? '-' : num\n }\n return val;\n});\n/* 小于10的数字前加0\n 01、02、03....\n*/\nVue.filter('numAddZero', (num) => {\n let val = '';\n val = num < 10 ? '0' + num : num;\n return val;\n});\n\n\n\n/**\n * 金额拆分为字符数组\n * @使用 this.$options.filters.moneyFormatToArr(value);\n * @param value 原始数值\n * @param minLen 最小长度,默认为9位数\n * 1 ==> 空空空,空空空,空空1\n * 123 ===> 空空空,空空空,123\n * minLen 传6的情况:\n * 1 ==> 空空空,空空1\n * 123 ===> 空空空,123\n * @param decimal 保留的小数长度,默认不保留小数\n * decimal = 2的情况:\n * 1.2510 ==> 空空空,空空空,空空1.25\n */\nVue.filter('moneyFormatToArr', (value, num, minLen, decimal) => {\n let isNull = false;\n if ((!value && value !== 0) || isNaN(value)) {\n isNull = true; //无效数字\n }\n minLen = minLen || 9;\n num = num || 1;\n if (isNull) {\n value = \"-\";\n decimal = decimal || 0;\n } else {\n value = value || 0;\n value = floatDivide(value, Math.pow(10, num - 1)); // 金额转换\n // 小数位处理,默认取整\n decimal = decimal || 0;\n let decimalPow = Math.pow(10, decimal);\n value = Math.round(value * decimalPow) / decimalPow;\n value = setZeroFun(value, decimal);\n // 获取转换后的小数的长度,如果有小数则加上小数点的长度\n decimal = decimal ? decimal + 1 : 0;\n }\n // 千位转换\n value = setThousandNum(value);\n // 字符拆分\n value = value.split(\"\");\n for (let i = 0; i < value.length; i++) {\n let text = value[i];\n let type = text == \",\" || text == \".\" ? \"dot\" : \"num\";\n value[i] = {\n text: text,\n type: type\n };\n }\n // 不足位数的前面补空格\n let fixNum = 0;\n if (minLen == 9) {\n if (value.length < 11 + decimal && value.length > 7 + decimal) {\n fixNum = 11 + decimal - value.length;\n } else if (value.length <= 7 + decimal && value.length > 3 + decimal) {\n fixNum = 10 + decimal - value.length;\n } else if (value.length <= 3 + decimal) {\n fixNum = 9 + decimal - value.length;\n }\n } else if (minLen == 6) {\n if (value.length < 7 + decimal && value.length > 3 + decimal) {\n fixNum = 7 + decimal - value.length;\n } else if (value.length == 3 + decimal) {\n fixNum = 3;\n } else if (value.length < 3 + decimal) {\n fixNum = 6 + decimal - value.length;\n }\n } else if (minLen == 5) {\n let num1 = value.length / 3;\n let num2 = value.length % 3;\n if (num2) {\n fixNum = minLen + decimal - value.length + Math.floor(num1);\n } else {\n fixNum = minLen + decimal - value.length;\n }\n if (fixNum == 1) {\n value.unshift({\n text: \"\",\n type: \"num\"\n });\n } else if (fixNum == 2) {\n value.unshift({\n text: \"\",\n type: \"num\"\n }, {\n text: \"\",\n type: \"num\"\n }, {\n text: \",\",\n type: \"dot col-1\"\n });\n } else if (fixNum == 3) {\n value.unshift({\n text: \"\",\n type: \"num\"\n }, {\n text: \"\",\n type: \"num\"\n }, {\n text: \",\",\n type: \"dot col-1\"\n }, {\n text: \"\",\n type: \"num\"\n });\n } else if (fixNum == 4) {\n value.unshift({\n text: \"\",\n type: \"num\"\n }, {\n text: \"\",\n type: \"num\"\n }, {\n text: \",\",\n type: \"dot col-1\"\n }, {\n text: \"\",\n type: \"num\"\n }, {\n text: \"\",\n type: \"num\"\n });\n }\n return value;\n } else if (minLen == 4) {\n let num1 = value.length / 3;\n let num2 = value.length % 3;\n if (num2) {\n fixNum = minLen + decimal - value.length + Math.floor(num1);\n } else {\n fixNum = minLen + decimal - value.length;\n }\n if (fixNum == 1) {\n value.unshift({\n text: \"\",\n type: \"num\"\n }, {\n text: \",\",\n type: \"dot col-1\"\n });\n } else if (fixNum == 2) {\n value.unshift({\n text: \"\",\n type: \"num\"\n }, {\n text: \",\",\n type: \"dot col-1\"\n }, {\n text: \"\",\n type: \"num\"\n });\n } else if (fixNum == 3) {\n value.unshift({\n text: \"\",\n type: \"num\"\n }, {\n text: \",\",\n type: \"dot col-1\"\n }, {\n text: \"\",\n type: \"num\"\n }, {\n text: \"\",\n type: \"num\"\n });\n }\n return value;\n }\n for (let i = fixNum; i > 0; i--) {\n if (i % 3 == 0 || (i == 1 && !(minLen - i) % 3)) {\n value.unshift({\n text: \",\",\n type: \"dot col-1\"\n });\n }\n value.unshift({\n text: \"\",\n type: \"num\"\n });\n }\n return value;\n});\n\n/**\n * 根据数组对象的某个属性值找到指定的元素\n * this.$options.filters.getArrObjItemVal(arr,key,val,getKey,type)\n * arr 操作的数组\n * key 当前对象的属性名\n * val 当前对象属性名对应的属性值\n * getKey 返回指定的元素的属性名,参数type不为false的时候,getKey可传false\n * type 返回值类型\n * 1. 不传返回指定元素的具体属性值\n * 2. true返回整个元素\n * 3. index返回对应元素的索引\n * emptyStr 空值返回的字符串标识,默认返回空\n */\nVue.filter('getArrObjItemVal', (arr, key, val, getKey, type, emptyStr) => {\n if(!arr || !arr.length) return emptyStr || \"\";\n // 如果数据为字符串类型,则去获取字典数据\n if(typeof arr === \"string\") {\n const dictDatas = require(\"@/api/dict.json\")\n arr = dictDatas[arr] || []\n }else {\n arr = arr || [];\n }\n let indexVal = false; // 符合条件的index\n let data = arr.filter((item, index) => {\n if (item[key] == val && indexVal === false) {\n indexVal = index; // 返回第一个符合条件的元素的索引\n }\n return item[key] == val;\n })\n if (data.length) {\n switch (type) {\n case \"index\":\n return indexVal;\n break;\n case true:\n return data[0];\n break;\n default:\n return data[0][getKey];\n break;\n }\n } else {\n return emptyStr || \"\";\n }\n});\n\n/**\n * 根据屏幕大小动态设置字体等的值(数字) - 屏幕变化时要刷新才会更新\n * @param value 色值\n * @param type 属性类型\n * 1. \"height\" 屏幕高度\n * 3. \"\" 默认是屏幕宽度\n * 使用 this.$options.filters.setAdaptSize(value,type);\n */\nVue.filter('setAdaptSize', (value, type) => {\n let adaptSize = 0;\n switch (type) {\n case \"height\":\n adaptSize = document.body.clientHeight; //网页可见区域高\n break;\n default:\n adaptSize = document.body.clientWidth; //网页可见区域宽\n break;\n }\n return Math.min(adaptSize / 1920 * value, value); //取最小值,不要超过传进来的原始值\n});\n\n/**\n * 获取数组对象的某个属性的最大值\n * this.$options.filters.getArrObjMaxVal(arr,key)\n * arr 操作的数组\n * key 属性名\n *\n * 另外:数据获取最大值的写法:\n 因为sort方法会改变原数组,所以合并一个空数据获得一个新数组重新排序获取最大值:\n arr.concat([]).sort((a,b)=>{\n return b-a;\n })[0];\n */\nVue.filter('getArrObjMaxVal', (arr, key) => {\n arr = arr || [];\n let newArr = new Array();\n for (let i in arr) {\n newArr.push(arr[i][key]);\n }\n newArr.sort((a, b) => {\n return b - a;\n })\n let maxcnt = eval(newArr[0]);\n return maxcnt;\n});\n/*\n 表格分页变量转换\n 新旧接口返回的分页对象不一致,前端需要转换下\n*/\nVue.filter('pageInfoFun', (obj) => {\n return {\n size: obj.size || obj.pageSize,\n total: obj.total || obj.totalSize,\n current: obj.current || obj.pageNumber,\n currentCount: obj.currentCount || obj.currentSize,\n pages: obj.pages || obj.totalPage\n }\n});\n/*\n 获取日期\n*/\nVue.filter('getFormatDate', (date, type) => {\n let myDate = date || new Date();\n let yy = myDate.getFullYear();\n let mm = String(Number(myDate.getMonth() + 1) < 10 ? '0' + Number(myDate.getMonth() + 1) : Number(myDate.getMonth() + 1));\n let dd = String(myDate.getDate() < 10 ? '0' + myDate.getDate() : myDate.getDate());\n let hou = String(myDate.getHours() < 10 ? \"0\" + myDate.getHours() : myDate.getHours());\n let min = String(myDate.getMinutes() < 10 ? '0' + myDate.getMinutes() : myDate.getMinutes());\n let sec = String(myDate.getSeconds() < 10 ? '0' + myDate.getSeconds() : myDate.getSeconds());\n switch (type) {\n case 'all':\n return yy + '-' + mm + '-' + dd + ' ' + hou + \":\" + min + \":\" + sec;\n break;\n case 'date':\n return yy + '-' + mm + '-' + dd;\n break;\n case 'time':\n return hou + \":\" + min + \":\" + sec;\n break;\n }\n});\n\n/**\n * ==================================================================================================================\n * 可在filter里面复用的公共方法\n */\n\n//数字格式化 从右到左,每隔三位整数添加一个逗号 如 100,000,411.301025\nvar setThousandNum = (num) => {\n return (num || 0).toString().replace(/\\d+/, function (n) {\n let len = n.length;\n if (len % 3 === 0) {\n return n.replace(/(\\d{3})/g, ',$1').slice(1);\n } else {\n return n.slice(0, len % 3) + n.slice(len % 3).replace(/(\\d{3})/g, ',$1');\n }\n });\n}\n\n/**\n * 将科学计数法的数字转为字符串\n * 4.496794759834739e-9 ==> 0.000000004496794759834739\n * 4.496794759834739e+9 ==> 4496794759.834739\n * @param num\n */\nvar toNonExponential = (num) => {\n if (num == null) {\n return num;\n }\n if (typeof num == \"number\") {\n var m = num.toExponential().match(/\\d(?:\\.(\\d*))?e([+-]\\d+)/);\n return num.toFixed(Math.max(0, (m[1] || '').length - m[2]));\n } else {\n return num;\n }\n}\n\n/**\n * 乘法 - js运算精度丢失问题\n * @param arg1 数1\n * @param arg2 数2\n */\nvar floatMultiply = (arg1, arg2) => {\n if (arg1 == null || arg2 == null) {\n return null;\n }\n arg1 = toNonExponential(arg1);\n arg2 = toNonExponential(arg2);\n var n1, n2;\n var r1, r2; // 小数位数\n try {\n r1 = arg1.toString().split(\".\")[1].length;\n } catch (e) {\n r1 = 0;\n }\n try {\n r2 = arg2.toString().split(\".\")[1].length;\n } catch (e) {\n r2 = 0;\n }\n n1 = Number(arg1.toString().replace(\".\", \"\"));\n n2 = Number(arg2.toString().replace(\".\", \"\"));\n return n1 * n2 / Math.pow(10, r1 + r2);\n}\n\n/**\n * 除法 - js运算精度丢失问题\n * @param arg1 数1\n * @param arg2 数2\n */\nvar floatDivide = (arg1, arg2) => {\n if (arg1 == null) {\n return null;\n }\n if (arg2 == null || arg2 == 0) {\n return null;\n }\n arg1 = toNonExponential(arg1);\n arg2 = toNonExponential(arg2);\n var n1, n2;\n var r1, r2; // 小数位数\n try {\n r1 = arg1.toString().split(\".\")[1].length;\n } catch (e) {\n r1 = 0;\n }\n try {\n r2 = arg2.toString().split(\".\")[1].length;\n } catch (e) {\n r2 = 0;\n }\n n1 = Number(arg1.toString().replace(\".\", \"\"));\n n2 = Number(arg2.toString().replace(\".\", \"\"));\n return floatMultiply((n1 / n2), Math.pow(10, r2 - r1));\n // return (n1 / n2) * Math.pow(10, r2 - r1); // 直接乘法还是会出现精度问题\n}\n\n/**\n * 加法 - js运算精度丢失问题\n * @param arg1 数1\n * @param arg2 数2\n */\nvar floatAdd = (arg1, arg2) => {\n arg1 = toNonExponential(arg1);\n arg2 = toNonExponential(arg2);\n var r1, r2, m;\n try {\n r1 = arg1.toString().split(\".\")[1].length;\n } catch (e) {\n r1 = 0;\n }\n try {\n r2 = arg2.toString().split(\".\")[1].length;\n } catch (e) {\n r2 = 0;\n }\n m = Math.pow(10, Math.max(r1, r2));\n return (floatMultiply(arg1, m) + floatMultiply(arg2, m)) / m;\n}\n\n/**\n * 减法 - js运算精度丢失问题\n * @param arg1 数1\n * @param arg2 数2\n */\nvar floatSub = (arg1, arg2) => {\n arg1 = toNonExponential(arg1);\n arg2 = toNonExponential(arg2);\n var r1, r2, m, n;\n try {\n r1 = arg1.toString().split(\".\")[1].length;\n } catch (e) {\n r1 = 0;\n }\n try {\n r2 = arg2.toString().split(\".\")[1].length;\n } catch (e) {\n r2 = 0;\n }\n m = Math.pow(10, Math.max(r1, r2));\n // 动态控制精度长度\n n = (r1 >= r2) ? r1 : r2;\n return ((floatMultiply(arg1, m) - floatMultiply(arg2, m)) / m).toFixed(n);\n}\n\n\n/**\n * 根据群用户类型返回对应的图标以及名称\n * @param data\n * @param resultType 返回数据类型(icon:图标,name:角色名)\n * 使用 this.$options.filters.groupUserIcon(memberLevel,type, resultType);\n */\nVue.filter(\"groupUserIcon\", (data, resultType) => {\n let icon = \"\";\n let name = \"\";\n switch (data.memberLevel) {\n case \"LEVEL_MAIN\": {\n //群主\n name = \"群主\"\n icon = \"iconfont el-icon-user-solid col-28\";\n break;\n }\n case \"LEVEL_ADMIN\":\n //管理员\n name = \"管理员\"\n icon = \"iconfont el-icon-user-solid col-3\";\n break;\n case \"LEVEL_GENERAL\":\n //客服或普通用户\n if (data.type === \"STAFF\") {\n name = \"客服\"\n icon = \"iconfont el-icon-user-solid col-3\";\n }\n break;\n }\n\n switch (resultType) {\n case \"name\":\n // 返回名称\n return name\n case \"icon\":\n // 返回图标\n return icon\n default:\n return ''\n }\n});\n\n/**\n * 树组件删除指定元素、设置指定元素不可点(递归遍历)\n * this.$options.filters.getZtreeList(arr,key,list,type)\n * arr 操作的数组\n * key 当前对象的属性名\n * list 需要处理的值数组\n * type del 删除、dis 不可选择\n * :options=\"areaZtreeList | getZtreeList('id',['440001','440224'],'del')\"\n */\nVue.filter('getZtreeList', (arr, key, list, type) => {\n arr = arr || [];\n arr = JSON.parse(JSON.stringify(arr));\n //递归子级数据\n let loopFun = (item)=> {\n if (item.children && item.children.length) {\n for(let c=0;c< item.children.length;c++) {\n let child = item.children[c];\n //console.log(list.indexOf(child[key]))\n if(list.indexOf(child[key])>-1) {\n if(type==\"del\") {\n item.children.splice(c,1);\n c--;\n }else if(type==\"dis\") {\n child.isDisabled = true;\n }\n }else {\n loopFun(child);\n }\n }\n }\n }\n // 遍历第一层数据\n for(let i=0;i-1) {\n if(type==\"del\") {\n arr.splice(i,1);\n i--;\n }\n }else {\n loopFun(item);\n }\n }\n return arr;\n});\n\n /**\n * 根据某个对象值找到树组织的指定对象的值\n * this.$options.filters.getZtreeItemVal(arr,key,val,getKey)\n * arr 操作的数组\n * key 当前对象的属性名\n * val 当前对象属性名对应的属性值\n * getKey 返回指定的元素的属性名\n */\n Vue.filter('getZtreeItemVal', (arr, key, val, getKey) => {\n let newVal = \"\";\n arr = arr || [];\n //递归子级数据\n let loopFun = (item)=> {\n if (item.children && item.children.length) {\n for(let c=0;c< item.children.length;c++) {\n let child = item.children[c];\n if(child[key]==val) {\n newVal = getKey ? child[getKey] : child;\n break;\n }else {\n loopFun(child);\n }\n }\n }\n }\n // 遍历第一层数据\n for(let i=0;i \"\n});\nvar result = sprite.add(symbol);\nexport default symbol","import SpriteSymbol from \"../../../node_modules/svg-baker-runtime/browser-symbol.js\";\nimport sprite from \"../../../node_modules/svg-sprite-loader/runtime/browser-sprite.build.js\";\nvar symbol = new SpriteSymbol({\n \"id\": \"icon-wx\",\n \"use\": \"icon-wx-usage\",\n \"viewBox\": \"0 0 1024 1024\",\n \"content\": \" \"\n});\nvar result = sprite.add(symbol);\nexport default symbol","module.exports = \"\"","// extracted by mini-css-extract-plugin\nexport {};","module.exports = \"\"","module.exports = \"\"","import SpriteSymbol from \"../../../node_modules/svg-baker-runtime/browser-symbol.js\";\nimport sprite from \"../../../node_modules/svg-sprite-loader/runtime/browser-sprite.build.js\";\nvar symbol = new SpriteSymbol({\n \"id\": \"icon-txt\",\n \"use\": \"icon-txt-usage\",\n \"viewBox\": \"0 0 1024 1024\",\n \"content\": \" \"\n});\nvar result = sprite.add(symbol);\nexport default symbol","import SpriteSymbol from \"../../../node_modules/svg-baker-runtime/browser-symbol.js\";\nimport sprite from \"../../../node_modules/svg-sprite-loader/runtime/browser-sprite.build.js\";\nvar symbol = new SpriteSymbol({\n \"id\": \"icon-zip\",\n \"use\": \"icon-zip-usage\",\n \"viewBox\": \"0 0 1024 1024\",\n \"content\": \" \"\n});\nvar result = sprite.add(symbol);\nexport default symbol","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","// extracted by mini-css-extract-plugin\nexport {};","module.exports = \"\"","// extracted by mini-css-extract-plugin\nexport {};","module.exports = \"\"","var map = {\n\t\"./add.svg\": \"s8CR\",\n\t\"./excel.svg\": \"+u5+\",\n\t\"./qq.svg\": \"Z3/d\",\n\t\"./txt.svg\": \"tqCd\",\n\t\"./word.svg\": \"cho8\",\n\t\"./wx.svg\": \"s9pR\",\n\t\"./zip.svg\": \"uLDA\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"z9n+\";","// extracted by mini-css-extract-plugin\nexport {};","module.exports = \"\"","// extracted by mini-css-extract-plugin\nexport {};"],"sourceRoot":""}