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

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

    isVisible = false;
    title: string;
wangqinghua's avatar
wangqinghua committed
    validateForm:FormGroup;
wangqinghua's avatar
wangqinghua committed
    topoId;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    pageNum;
    pageCount;

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

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

    initForm(){
        this.validateForm = this.fb.group(
            {
                name:['',[Validators.required]],
wangqinghua's avatar
wangqinghua committed
                refreshRete:['',[Validators.required]],
                json:[''],
                users:[[]],
                userGroups:[[]]
wangqinghua's avatar
wangqinghua committed
            }
        )
wangqinghua's avatar
wangqinghua committed
    }

    showAddMOodal() {
        this.isVisible = true;
        this.title = '添加拓扑图';
    }

wangqinghua's avatar
wangqinghua committed
    showEditModal(id) {
wangqinghua's avatar
wangqinghua committed
        this.title = '编辑拓扑图';
        this.isVisible = true;
wangqinghua's avatar
wangqinghua committed
        this.topoId = id;
        this.topologySer.findItem(id).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                   this.validateForm.patchValue(res.data);
                }else{
                    this.message.create('error',`${res.errMsg}`);
                }
            }
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    handleOk(){
wangqinghua's avatar
wangqinghua committed
        for(let i  in this.validateForm.controls){
wangqinghua's avatar
wangqinghua committed
            this.validateForm.controls[i].markAsDirty();
            this.validateForm.controls[i].updateValueAndValidity();
        }
        if(this.validateForm.invalid){
            return false;
        }
        if(this.title == "添加拓扑图"){
            this.create();
        }
        if(this.title == "编辑拓扑图"){
            this.update();
        }
    }

wangqinghua's avatar
wangqinghua committed
    create(){
        this.topologySer.create(this.validateForm.value).subscribe(
            (res)=>{
                if(res.errCode == 10000){
                    this.initForm();
                    this.message.create('success', `创建成功`);
                    this.isVisible = false;
                    this.done.emit();
                }else{
                    this.message.create('error', `${res.errMsg}`);
                }
            }
        )
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    update(){
        this.validateForm.addControl('id',new FormControl(this.topoId));
        this.topologySer.update(this.validateForm.value).subscribe(
            (res)=>{
                if(res.errCode == 10000){
                    this.initForm();
                    this.message.create('success', `编辑成功`);
                    this.done.emit();
                    this.isVisible = false;
                }else{
                    this.message.create('error', `${res.errMsg}`);
                }
            }
        )
    }
wangqinghua's avatar
wangqinghua committed

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

}