Skip to content
common.service.ts 6.39 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Injectable, OnInit} from "@angular/core";
wangqinghua's avatar
wangqinghua committed
import {NzModalService} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed
import {SERVER_API_URL, SERVER_API_URL_COMS} from '../../app.constants';
wangqinghua's avatar
wangqinghua committed
import {DatePipe} from '@angular/common';
wangqinghua's avatar
wangqinghua committed
@Injectable()
wangqinghua's avatar
wangqinghua committed
export class CommonService implements OnInit {
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    constructor(private modalSer:NzModalService,private datePipe:DatePipe) {
wangqinghua's avatar
wangqinghua committed
        // 定义发射事件
    }

    ngOnInit() {

    }

    exists(list, parentId,myId){
        for(let i=0; i<list.length; i++){
            if(list[i][myId] == parentId){
                return true;
            }
        }
        return false;
    }

wangqinghua's avatar
wangqinghua committed
    /**
     * list一层数组转为树形结构的数组
     * @param myId   父级ID
     * @param pId   子级ID
     * @param list
     * @returns {any[]}
     */
wangqinghua's avatar
wangqinghua committed
    listToTree(myId,pId,list){
        const  nodes = [];
        for(let i=0; i<list.length; i++){
            list[i].checked = false;
            const row = list[i];
            if ( !this.exists(list, row[pId],myId) ){
                nodes.push(row);
            }
        }

        const toDo = [];
        for(let i=0; i<nodes.length; i++){
            toDo.push(nodes[i]);
        }
        while(toDo.length){
            const node = toDo.shift(); // the parent node
            for(let i=0; i<list.length; i++){
                const row = list[i];
                if (row[pId] == node[myId]){
                    if (node.children){
                        node.children.push(row);
                    } else {
                        node.children = [row];
                    }
                    toDo.push(row);
                }
            }
        }
        return nodes;
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    /**
     * JSON格式数据转化为字符串 接口调用
     * @param data  json格式的数据
     * @returns {string}
     */
wangqinghua's avatar
wangqinghua committed
    toQuery(data){
        let str = '';
wangqinghua's avatar
wangqinghua committed
        for (let key in data) {
wangqinghua's avatar
wangqinghua committed
            if (data.hasOwnProperty(key)) {
                const value = data[key];
                str += key + '=' + value + '&';
            }
        }
        str = str.substring(0, str.length - 1);
        return str;
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    /**
     * 删除确认函数
     * @param title  提示语
     * @param callback  回调函数
     */
    confirmThing(title,content,callback){
wangqinghua's avatar
wangqinghua committed
        this.modalSer.confirm({
wangqinghua's avatar
wangqinghua committed
            nzTitle: title,
            nzContent: '<b style="color: red;">'+content+'</b>',
wangqinghua's avatar
wangqinghua committed
            nzOkText: '确定',
            nzOkType: 'danger',
            nzOnOk: callback,
            nzCancelText: '取消',
            nzOnCancel: () => console.log('Cancel'),
        })
    }
wangqinghua's avatar
wangqinghua committed

    /**
     * 下载文件
     * @param url 文件URL
     */
    downloadFile(title,data: Response) {
wangqinghua's avatar
wangqinghua committed
        const blob = new Blob([data], {type:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;"});
wangqinghua's avatar
wangqinghua committed
        const url= window.URL.createObjectURL(blob);
        let link = document.createElement("a");
        link.setAttribute("href", url);
        link.setAttribute("download", title);
        document.body.appendChild(link);
        link.click();
        document.body.removeChild(link);
    }
wangqinghua's avatar
wangqinghua committed

    /**
     * 部分区域全屏
     * @param element  全屏区域
     * @param method  全屏方法
     * @returns {any}
     */
    showInFullScreen(element, method){
        let usablePrefixMethod;
        ['webkit', 'moz', 'ms', 'o', ''].forEach( (prefix)=> {
                if (usablePrefixMethod) {
                    return
                }
                if (prefix === '') {
                    // 无前缀,方法首字母小写
                    // method = method.slice(0, 1).toLowerCase() + method.slice(1)
                }
                let typePrefixMethod = typeof element[prefix + method];
                if (typePrefixMethod + '' !== 'undefined') {
                    if (typePrefixMethod === 'function') {
                        usablePrefixMethod = element[prefix + method]()
                    } else {
                        usablePrefixMethod = element[prefix + method]
                    }
                }
            }
        )
        return usablePrefixMethod;
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    /**
     * 根据type 查询时间段
     * @param timeType  0 最近一小时 1 今天 2 昨天(最近一天) 3 最近三天 4 最近一周 5 最近一个月
     */
    getTimeByType(timeType){
        const nowDate = new Date().getTime();
        let day1, day2; //当作变量使用
        let obj = {startTime:'',endTime:''};
        switch (timeType) {
            case'0':{   //最近一小时
                day1 = nowDate - 1 * 60 * 60 * 1000;
                obj.startTime = this.datePipe.transform(day1, 'yyyy-MM-dd HH:mm:ss');
                obj.endTime = this.datePipe.transform(nowDate, 'yyyy-MM-dd HH:mm:ss');
                break;
            }
            case'1': {   //今天
                obj.startTime = this.datePipe.transform(nowDate, 'yyyy-MM-dd') + ' 00:00:00';
                obj.endTime = this.datePipe.transform(nowDate, 'yyyy-MM-dd') + ' 23:59:59';
                break;
            }
            case'2': {   //昨天
                day1 = nowDate - 1 * 24 * 60 * 60 * 1000;
                obj.startTime = this.datePipe.transform(day1, 'yyyy-MM-dd') + ' 00:00:00';
                obj.endTime = this.datePipe.transform(day1, 'yyyy-MM-dd') + ' 23:59:59';
                break;
            }
            case'3': {   //最近三天
                day1 = nowDate - 3 * 24 * 60 * 60 * 1000;
                day2 = nowDate;
                obj.startTime = this.datePipe.transform(day1, 'yyyy-MM-dd') + ' 00:00:00';
                obj.endTime = this.datePipe.transform(day2, 'yyyy-MM-dd') + ' 23:59:59';
                break;
            }
            case'4': {  //最近一周
                day1 = nowDate - 7 * 24 * 60 * 60 * 1000;
                day2 = nowDate;
                obj.startTime = this.datePipe.transform(day1, 'yyyy-MM-dd') + ' 00:00:00';
                obj.endTime = this.datePipe.transform(day2, 'yyyy-MM-dd') + ' 23:59:59';
                break;
            }
            case'5': {  //最近一个月
                day1 = nowDate - 30 * 24 * 60 * 60 * 1000;
                day2 = nowDate;
                obj.startTime = this.datePipe.transform(day1, 'yyyy-MM-dd') + ' 00:00:00';
                obj.endTime = this.datePipe.transform(day2, 'yyyy-MM-dd') + ' 23:59:59';
                break;
            }
            case'6': {
                break;
            }
        }
        console.log(obj);
        return obj;
    }
}