Skip to content
icon.component.ts 3.58 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output} from '@angular/core';
import {NzMessageService, UploadFile} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed
import {TopologyService} from '../../topology.service';
wangqinghua's avatar
wangqinghua committed
import {FormBuilder, FormGroup, Validator, Validators} from '@angular/forms';
wangqinghua's avatar
wangqinghua committed
import {filter} from 'rxjs/operators';
wangqinghua's avatar
wangqinghua committed

@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'smart-icon',
    templateUrl: './icon.component.html',
    styles: []
wangqinghua's avatar
wangqinghua committed
})
export class IconComponent implements OnInit {
wangqinghua's avatar
wangqinghua committed
    @Output() done = new EventEmitter<any>();
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    isVisible = false;
wangqinghua's avatar
wangqinghua committed
    fileList: UploadFile[] = [];
wangqinghua's avatar
wangqinghua committed
    title;
    firstTypeId;  //分类ID
    iconId;   //图标ID

    options;  //一级分类list;
wangqinghua's avatar
wangqinghua committed

    constructor(private topologySer: TopologyService, private message: NzMessageService,
                private fb: FormBuilder) {
    }
wangqinghua's avatar
wangqinghua committed

    values;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    ngOnInit() {
        this.initForm();
wangqinghua's avatar
wangqinghua committed
        this.getList();
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    initForm() {
        this.fileList = [];
wangqinghua's avatar
wangqinghua committed
        this.firstTypeId = null;  //分类ID
        this.iconId = null;   //图标ID
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //一级分类
    getList(){
wangqinghua's avatar
wangqinghua committed
        this.topologySer.findTreeWithWeb().subscribe(
wangqinghua's avatar
wangqinghua committed
            (res)=>{
                if(res.errCode == 10000){
wangqinghua's avatar
wangqinghua committed
                    this.options = res.data;
wangqinghua's avatar
wangqinghua committed
                }else{
wangqinghua's avatar
wangqinghua committed
                    this.message.error(res.errMSg);
                }
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        )
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    beforeUpload = (file: UploadFile): boolean => {
wangqinghua's avatar
wangqinghua committed
        const isLt2M = file.size / 1024 < 300;
wangqinghua's avatar
wangqinghua committed
        if (!isLt2M) {
            this.message.error('图标必须小于300kb!');
wangqinghua's avatar
wangqinghua committed
        } else {
wangqinghua's avatar
wangqinghua committed
            this.fileList.push(file);
        }
        return false;
    };

wangqinghua's avatar
wangqinghua committed
    showAddModal(title) {
        this.title = title;
        this.isVisible = true;
    }

    showEditModal(title,id) {
        this.iconId = id;
        this.title = title;
wangqinghua's avatar
wangqinghua committed
        this.isVisible = true;
    }

wangqinghua's avatar
wangqinghua committed
    handleOk() {
        if (this.fileList.length == 0) {
            this.message.error('请选择图标');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
wangqinghua's avatar
wangqinghua committed

        if(this.title == "添加图标"){
            if (!this.firstTypeId) {
                this.message.error('请选择一级分类');
                return false;
            }else{
                this.create();
            }
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed

        if(this.title == "更换图标"){
            this.update();
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
    }

    create(){
wangqinghua's avatar
wangqinghua committed
        const formData = new FormData();
        this.fileList.forEach((file: any) => {
wangqinghua's avatar
wangqinghua committed
            formData.append('file', file);
wangqinghua's avatar
wangqinghua committed
        });
wangqinghua's avatar
wangqinghua committed
        formData.append('firstTypeId', this.firstTypeId);
wangqinghua's avatar
wangqinghua committed
        this.topologySer.iconUpload(formData).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
                    this.message.success('添加成功');
wangqinghua's avatar
wangqinghua committed
                    this.isVisible = false;
wangqinghua's avatar
wangqinghua committed
                    this.initForm();
wangqinghua's avatar
wangqinghua committed
                    this.done.emit();
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.error(res.errMsg);
                }
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    update(){
        const formData = new FormData();
        this.fileList.forEach((file: any) => {
            formData.append('file', file);
wangqinghua's avatar
wangqinghua committed
        });
wangqinghua's avatar
wangqinghua committed
        formData.append('id', this.iconId);

        this.topologySer.updateIcon(formData).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.message.success('添加成功');
                    this.isVisible = false;
                    this.initForm();
                    this.done.emit();
                } else {
                    this.message.error(res.errMsg);
                }
            }
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    handleCancel() {
wangqinghua's avatar
wangqinghua committed
        this.isVisible = false;
wangqinghua's avatar
wangqinghua committed
        this.initForm();
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
}