Skip to content
create-project.component.ts 5.78 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output, ViewChild} from '@angular/core';
wangqinghua's avatar
wangqinghua committed
import {FormBuilder, FormControl, FormGroup, Validators} from '@angular/forms';
import {NzMessageService, UploadFile} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed
import {opr_company_type, project_type} from '../../project.constants';
wangqinghua's avatar
wangqinghua committed
import {SystemService} from '../../../system/system.service';
import {ProjectService} from '../../project.service';
wangqinghua's avatar
wangqinghua committed
import {CompanyModalComponent} from '../company-modal/company-modal.component';
wangqinghua's avatar
wangqinghua committed
import {TeamPeopleComponent} from '../team-people/team-people.component';
import {TeamModalComponent} from '../team-modal/team-modal.component';
wangqinghua's avatar
wangqinghua committed
import {TrackInfoComponent} from '../track-info/track-info.component';
wangqinghua's avatar
wangqinghua committed
import {WorkService} from '../../../work/work.service';
wangqinghua's avatar
wangqinghua committed

@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'smart-create-project',
    templateUrl: './create-project.component.html',
wangqinghua's avatar
wangqinghua committed
    styles: [
        `
            :host ::ng-deep .ant-input-disabled{
                color: rgba(0,0,0,.65);
                background-color: #fff;
            }
        `
    ]
wangqinghua's avatar
wangqinghua committed
})
export class CreateProjectComponent implements OnInit {
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartCompanyModal') smartCompanyModal: CompanyModalComponent;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartTeamModal') smartTeamModal: TeamModalComponent;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartTrackInfo') smartTrackInfo: TrackInfoComponent;
wangqinghua's avatar
wangqinghua committed
    @Output() done = new EventEmitter<any>();
    tabNum = 0;    //tabs面板的序列号
    timeFormat = 'yyyy-MM-dd';
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    title;
    isVisible = false;
    isOkLoading = false;
    validateForm: FormGroup;
    fileList: UploadFile[] = [];
wangqinghua's avatar
wangqinghua committed
    fileId = [];
wangqinghua's avatar
wangqinghua committed
    opr_company_type = project_type;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    cID;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    constructor(private fb: FormBuilder, private systemSer: SystemService,
wangqinghua's avatar
wangqinghua committed
                private workSer:WorkService,
wangqinghua's avatar
wangqinghua committed
                private message: NzMessageService, private projectSer: ProjectService) {
    }
wangqinghua's avatar
wangqinghua committed

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

wangqinghua's avatar
wangqinghua committed
    initForm() {
        this.validateForm = this.fb.group({
            name: [null, [Validators.required, Validators.minLength(2), Validators.maxLength(50)]],
            officeName: [null],
            officePrincipal: [null],
            aPrincipal: [null],
wangqinghua's avatar
wangqinghua committed
            bprincipal: [null],
            bprincipalName: [null],
wangqinghua's avatar
wangqinghua committed
            amount: [null],
wangqinghua's avatar
wangqinghua committed
            type: [null],
wangqinghua's avatar
wangqinghua committed
            companyId: [null],
wangqinghua's avatar
wangqinghua committed
            companyName: [null],
wangqinghua's avatar
wangqinghua committed
            teamId: [null],
wangqinghua's avatar
wangqinghua committed
            principal: [null],
            startDate: [null],
            endDate: [null],
wangqinghua's avatar
wangqinghua committed
            status: [null],
wangqinghua's avatar
wangqinghua committed
        });
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

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

    showEditModal(data, title) {
        this.isVisible = true;
wangqinghua's avatar
wangqinghua committed
        data.type += '';
wangqinghua's avatar
wangqinghua committed
        this.title = title;
        this.cID = data.id;
        this.validateForm.patchValue(data);
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

    handleCancel() {
        this.isVisible = false;

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

wangqinghua's avatar
wangqinghua committed
    beforeUpload = (file: UploadFile): boolean => {
wangqinghua's avatar
wangqinghua committed
        this.fileList.push(file);
        let file1 = <any>file;
        const formData = new FormData();
        formData.append('file', file1);
        this.workSer.sysFileUpload(formData).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.fileId.push(res.data.id);
                }
            }
        );

wangqinghua's avatar
wangqinghua committed
        return false;
    };
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    handleOk(status) {
wangqinghua's avatar
wangqinghua committed
        for (let i in this.validateForm.controls) {
            this.validateForm.controls[i].markAsDirty();
            this.validateForm.controls[i].updateValueAndValidity();
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
        if (this.validateForm.invalid) {
            return false;
        }
        this.isOkLoading = true;
wangqinghua's avatar
wangqinghua committed
        this.validateForm.patchValue({
            startDate: new Date(this.validateForm.value.startDate).getTime(),
            endDate: new Date(this.validateForm.value.endDate).getTime(),
            status: status
        });
wangqinghua's avatar
wangqinghua committed
        if (this.title == '新增运维项目') {
            this.create();
        }
        if (this.title == '编辑运维项目') {
            this.update();
        }
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    create() {
wangqinghua's avatar
wangqinghua committed
        this.validateForm.addControl('fileId', new FormControl(this.fileId.join(',')));
wangqinghua's avatar
wangqinghua committed
        this.projectSer.addMaintainProject(this.validateForm.value).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.isVisible = false;
                    this.initForm();
                    this.done.emit();
                    this.message.success('新增运维项目成功');
                }
                this.isOkLoading = false;
            }
        );
    }

    update() {
        this.validateForm.addControl('id', new FormControl(this.cID));
        this.projectSer.updateMaintainProject(this.validateForm.value).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.isVisible = false;
                    this.initForm();
                    this.done.emit();
                    this.message.success('更新项目成功');
                }
                this.isOkLoading = false;
            }
        );
    }

    //tabs切换
    tabsChange(num) {
        this.tabNum = num;
    }
wangqinghua's avatar
wangqinghua committed

    //showProjectmodal
wangqinghua's avatar
wangqinghua committed
    showProjectmodal() {
        this.smartCompanyModal.showModal();
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    getCompany(e) {
        const d = {
wangqinghua's avatar
wangqinghua committed
            companyId: e.id,
            companyName: e.name
        };
        this.validateForm.patchValue(d);
    }

//    获取人员
    showSelectPeople() {
        if (!this.validateForm.value.companyId) {
            this.message.info('请选择乙方公司');
            return;
        }
        this.smartTeamModal.showModal(this.validateForm.value.companyId,'乙方维护组长');
    }

    setPeople(e) {
        const d = {
            bprincipalName: e.userName,
            bprincipal: e.id
wangqinghua's avatar
wangqinghua committed
        };
        this.validateForm.patchValue(d);
wangqinghua's avatar
wangqinghua committed
        console.log(e);
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed
}