index.js 11 KB
Newer Older
liuxin committed
1 2
export default class Utils {
    static toDepthObject(obj) {
fukai committed
3
        var target = {};
liuxin committed
4
        for (var key in obj) {
fukai committed
5 6
            var keyArr = key.split("_"); //以下划线或分割
            var tempobj = target;
liuxin committed
7 8
            for (var i = 0; i < keyArr.length - 1; i++) {
                if (tempobj[keyArr[i]])
fukai committed
9
                    tempobj = tempobj[keyArr[i]];
liuxin committed
10
                else {
fukai committed
11 12
                    tempobj[keyArr[i]] = {};
                    tempobj = tempobj[keyArr[i]];
liuxin committed
13
                }
fukai committed
14 15
            }
            //给叶子元素赋值
liuxin committed
16
            tempobj[keyArr[keyArr.length - 1]] = obj[key];
fukai committed
17 18 19
        }
        return target;
    }
liuxin committed
20 21 22 23 24
    static flatObject(obj, target, pkey) {
        target = target || {};
        for (var key in obj) {
            var nkey = pkey ? pkey + "_" + key : key;
            if (!obj[key])
25
                target[nkey] = obj[key];
liuxin committed
26
            else if (obj[key] instanceof Array)
27
                target[nkey] = obj[key];
liuxin committed
28 29 30
            else if (obj[key] instanceof Date)
                target[nkey] = obj[key];
            else if (typeof obj[key] == "object")
潘际乾 committed
31 32 33 34 35 36 37 38 39
                /**
                 * IStream类型 
                 * { 
                 *   empty: true
                 *   keepsort: false
                 *   rows: []
                 * }
                */
                if (Object.keys(obj[key]).length === 3 && obj[key].hasOwnProperty("empty") && obj[key].hasOwnProperty("keepsort") && obj[key].hasOwnProperty("rows")) {
40 41 42 43
                    target[nkey] = obj[key];
                } else {
                    Utils.flatObject(obj[key], target, nkey); //递归赋值
                }
liuxin committed
44 45 46 47
            else
                target[nkey] = obj[key];
        }
        return target;
fukai committed
48
    }
liuxin committed
49
    static copyValueFromVO(model, vo) {
fukai committed
50
        var target = model;
liuxin committed
51
        for (var key in vo) {
fukai committed
52 53
            var keyArr = key.split("_"); //以下划线或分割
            var tempobj = target;
liuxin committed
54 55
            for (var i = 0; i < keyArr.length - 1; i++) {
                if (tempobj[keyArr[i]])
fukai committed
56
                    tempobj = tempobj[keyArr[i]];
liuxin committed
57
                else {
fukai committed
58 59
                    tempobj = null;
                    break;
liuxin committed
60
                }
fukai committed
61 62
            }
            //给叶子元素赋值
liuxin committed
63
            if (tempobj) {
fukai committed
64
                let leafProp = keyArr[keyArr.length - 1];
fukai committed
65 66 67
                if (tempobj.hasOwnProperty(leafProp)
                    || "pageId" == leafProp  //对pageId开放判断。
                )
liuxin committed
68
                    tempobj[leafProp] = vo[key];
fukai committed
69 70 71 72
            }
        }
        return target;
    }
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153

    static showXml(str){
        var text = str
    
        //去掉多余的空格
        text = '\n' + text.replace(/(<\w+)(\s.*?>)/g,function($0, name, props)
        {
            return name + ' ' + props.replace(/\s+(\w+=)/g," $1");
        }).replace(/>\s*?</g,">\n<");
    
        //把注释编码
        text = text.replace(/\n/g,'\r').replace(/<!--(.+?)-->/g,function($0, text)
        {
            var ret = '<!--' + escape(text) + '-->';
            return ret;
        }).replace(/\r/g,'\n');
    
        //调整格式
        var rgx = /\n(<(([^\?]).+?)(?:\s|\s*?>|\s*?(\/)>)(?:.*?(?:(?:(\/)>)|(?:<(\/)\2>)))?)/mg;
        var nodeStack = [];
        var output = text.replace(rgx,function($0,all,name,isBegin,isCloseFull1,isCloseFull2 ,isFull1,isFull2){
            var isClosed = (isCloseFull1 == '/') || (isCloseFull2 == '/' ) || (isFull1 == '/') || (isFull2 == '/');
            var prefix = '';
            if(isBegin == '!')
            {
                prefix = Utils.getPrefix(nodeStack.length);
            }
            else 
            {
                if(isBegin != '/')
                {
                    prefix = Utils.getPrefix(nodeStack.length);
                    if(!isClosed)
                    {
                        nodeStack.push(name);
                    }
                }
                else
                {
                    nodeStack.pop();
                    prefix = Utils.getPrefix(nodeStack.length);
                }
    
            }
                var ret =  '\n' + prefix + all;
                return ret;
        });
    
        var prefixSpace = -1;
        var outputText = output.substring(1);
    
        //把注释还原并解码,调格式
        outputText = outputText.replace(/\n/g,'\r').replace(/(\s*)<!--(.+?)-->/g,function($0, prefix,  text)
        {
            if(prefix.charAt(0) == '\r')
                prefix = prefix.substring(1);
            text = unescape(text).replace(/\r/g,'\n');
            var ret = '\n' + prefix + '<!--' + text.replace(/^\s*/mg, prefix ) + '-->';
            return ret;
        });
        //alert(outputText);
        
        outputText=	outputText.replace(/\s+$/g,'').replace(/\r/g,'\r\n');
        
        
        return outputText
        
    
    }
    
    static getPrefix(prefixIndex)
    {
        var span = '    ';
        var output = [];
        for(var i = 0 ; i < prefixIndex; ++i)
        {
            output.push(span);
        }
       
        return output.join('');
    }
154

潘际乾 committed
155 156 157 158 159 160
    /**
     * 执行checkAll之后根据返回的错误信息定位
     * @param {Object} fieldErrors 错误信息
     * @param {Array} formFields 表单字段
     * @returns El-Tab实例
     */
潘际乾 committed
161
    static positioningErrorMsg(fieldErrors, formFields) {
162 163 164
        if (Object.keys(fieldErrors).length === 0) {
            return null;
        }
潘际乾 committed
165
        let firstErrorItem = null
166
        // 顺序
潘际乾 committed
167 168
        for (let i = 0; i < formFields.length; i++) {
            const field = formFields[i];
169 170 171 172 173 174
            const fieldError = fieldErrors[field.prop];
            if (fieldError) {
                field.validateState  = 'error';
                field.validateMessage = fieldError;
                if (!firstErrorItem) {
                    firstErrorItem = field
潘际乾 committed
175
                }
176
            }                
潘际乾 committed
177
        }
178
        let firstErrorTab = null, collapsePanel = null
潘际乾 committed
179 180 181
        if (firstErrorItem) {
            let parentVC = firstErrorItem
            while(!firstErrorTab) {
182
                const vcName = parentVC.$options.componentName
潘际乾 committed
183 184 185 186 187 188 189 190
                // 没有Tabs的表单
                if (vcName === "ElForm") {
                    break;
                }
                if (vcName === "ElTabPane") {
                    firstErrorTab = parentVC
                    break;
                }
191 192 193
                if (vcName === "ElCollapseItem") {
                    collapsePanel = parentVC;
                }
潘际乾 committed
194 195 196 197
                parentVC = parentVC.$parent;
            }
            if (firstErrorTab) {
                const tabs = firstErrorTab.$parent
潘际乾 committed
198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251
                tabs.currentName = firstErrorTab.name
            }
            if (collapsePanel && collapsePanel.collapse.activeNames.indexOf(collapsePanel.name) < 0) {
                collapsePanel.collapse.activeNames.push(collapsePanel.name)
            }
            setTimeout(() => {
                // 滚动到指定节点
                firstErrorItem.$el.scrollIntoView({
                    // 值有start,center,end,nearest,当前显示在视图区域中间
                    block: 'center', 
                    // 值有auto、instant,smooth,缓动动画(当前是慢速的)
                    behavior: 'smooth' 
                })
            }, 0)
        }
        return firstErrorTab;
    }

    /**
     * 表单自身的validate方法执行后,错误提示定位
     * @param {Array} formFields 表单字段
     * @returns El-Tab实例
     */
    static formValidateTips(formFields) {
        let firstErrorItem = null
        // 顺序
        for (let i = 0; i < formFields.length; i++) {
            const field = formFields[i];
            if (field.validateState === 'error') {
                firstErrorItem = field
                break;
            }                
        }
        let firstErrorTab = null, collapsePanel = null
        if (firstErrorItem) {
            let parentVC = firstErrorItem
            while(!firstErrorTab) {
                const vcName = parentVC.$options.componentName
                // 没有Tabs的表单
                if (vcName === "ElForm") {
                    break;
                }
                if (vcName === "ElTabPane") {
                    firstErrorTab = parentVC
                    break;
                }
                if (vcName === "ElCollapseItem") {
                    collapsePanel = parentVC;
                }
                parentVC = parentVC.$parent;
            }
            if (firstErrorTab) {
                const tabs = firstErrorTab.$parent
                tabs.currentName = firstErrorTab.name
潘际乾 committed
252
            }
253 254 255
            if (collapsePanel && collapsePanel.collapse.activeNames.indexOf(collapsePanel.name) < 0) {
                collapsePanel.collapse.activeNames.push(collapsePanel.name)
            }
潘际乾 committed
256 257 258 259 260 261 262 263 264 265
            setTimeout(() => {
                // 滚动到指定节点
                firstErrorItem.$el.scrollIntoView({
                    // 值有start,center,end,nearest,当前显示在视图区域中间
                    block: 'center', 
                    // 值有auto、instant,smooth,缓动动画(当前是慢速的)
                    behavior: 'smooth' 
                })
            }, 0)
        }
266
        return firstErrorTab;
潘际乾 committed
267
    }
fukai committed
268 269 270 271 272 273

    static defaultFunction(rule, value, callback){
        this.executeNotify().then(res => {
            if (res.respCode == SUCCESS){
                const data = res.data;
                Utils.copyValueFromVO(this.model, data)
274 275 276
                if (typeof callback === "function") {
                    callback()
                }
fukai committed
277 278 279
            }
        })
    }
潘际乾 committed
280 281 282 283

    static reflectCheck(key){
        return async function(rule, value, callback){
            //调用具体的check
284
            const res = await this.executeCheck(key)
285 286 287 288 289 290 291
            // if (res.respCode == SUCCESS){
                
            // }
            if (Object.hasOwnProperty.call(res.fieldErrors, key)) {
                callback(new Error(res.fieldErrors[key]))
            } else {
                callback();
潘际乾 committed
292 293 294
            }
        }
    }
295 296

    static generateUUID() {
zhujiazhan committed
297
        console.log(111);
298
        var d = new Date().getTime();
zhujiazhan committed
299
        console.log(2222);
300 301 302 303 304 305 306 307 308 309
        if (window.performance && typeof window.performance.now === "function") {
            d += performance.now(); //use high-precision timer if available
        }
        var uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
            var r = (d + Math.random() * 16) % 16 | 0;
            d = Math.floor(d / 16);
            return (c == 'x' ? r : (r & 0x3 | 0x8)).toString(16);
        });
        return uuid;
    }
liuxin committed
310 311 312 313 314 315 316 317 318 319

    static copyCustomFromModel(customModel, model){
        for(let key in customModel){
            if(typeof customModel[key] == "object"){
                this.copyCustomFromModel(customModel[key], model[key])
            }else{
                customModel[key] = model[key]
            }
        }
    }
李少勇 committed
320 321 322 323
    // 值分别为:Number、String、Boolean、Null、Undefined、Symbol、Object、Array、Function、Date
    static typeOf (data) {
      return Object.prototype.toString.call(data).slice(8, -1);
    }
fukai committed
324
}