UNPKG

@harbor/ui

Version:

Harbor shared UI components based on Clarity and Angular6

221 lines (220 loc) 21.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, Output, EventEmitter, Input, ViewChild, ChangeDetectionStrategy, ChangeDetectorRef } from "@angular/core"; import { toPromise, clone, compareValue } from "../utils"; import { LabelService } from "../service/label.service"; import { ErrorHandler } from "../error-handler/error-handler"; import { NgForm } from "@angular/forms"; import { Subject } from "rxjs"; import { debounceTime } from "rxjs/operators"; import { LabelColor } from "../shared/shared.const"; export class CreateEditLabelComponent { /** * @param {?} labelService * @param {?} errorHandler * @param {?} ref */ constructor(labelService, errorHandler, ref) { this.labelService = labelService; this.errorHandler = errorHandler; this.ref = ref; this.labelModel = this.initLabel(); this.labelId = 0; this.isLabelNameExist = false; this.nameChecker = new Subject(); this.reload = new EventEmitter(); } /** * @return {?} */ ngOnInit() { this.nameChecker.pipe(debounceTime(500)).subscribe((name) => { toPromise(this.labelService.getLabels(this.scope, this.projectId, name)) .then(targets => { this.isLabelNameExist = false; if (targets && targets.length) { if (targets.find((target) => { return target.name === name; })) { this.isLabelNameExist = true; } } }) .catch(error => { this.errorHandler.error(error); }); /** @type {?} */ let hnd = setInterval(() => this.ref.markForCheck(), 100); setTimeout(() => clearInterval(hnd), 5000); }); } /** * @return {?} */ ngOnDestroy() { this.nameChecker.unsubscribe(); } /** * @return {?} */ get labelColor() { return LabelColor; } /** * @return {?} */ initLabel() { return { name: "", description: "", color: "", scope: "", project_id: 0 }; } /** * @return {?} */ openModal() { this.labelModel = this.initLabel(); this.formShow = true; this.isLabelNameExist = false; this.labelId = 0; this.copeLabelModel = null; } /** * @param {?} labelId * @param {?} label * @return {?} */ editModel(labelId, label) { this.labelModel = clone(label[0]); this.formShow = true; this.labelId = labelId; this.copeLabelModel = clone(label[0]); } /** * @return {?} */ get hasChanged() { return !compareValue(this.copeLabelModel, this.labelModel); } /** * @return {?} */ get isValid() { return !(this.isLabelNameExist || !(this.currentForm && this.currentForm.valid) || !this.hasChanged || this.inProgress); } /** * @param {?} text * @return {?} */ existValid(text) { if (text) { this.nameChecker.next(text); } else { this.isLabelNameExist = false; } } /** * @return {?} */ onSubmit() { this.inProgress = true; if (this.labelId <= 0) { this.labelModel.scope = this.scope; this.labelModel.project_id = this.projectId; toPromise(this.labelService.createLabel(this.labelModel)) .then(res => { this.inProgress = false; this.reload.emit(); this.labelModel = this.initLabel(); this.formShow = false; }) .catch(err => { this.inProgress = false; this.errorHandler.error(err); }); } else { toPromise(this.labelService.updateLabel(this.labelId, this.labelModel)) .then(res => { this.inProgress = false; this.reload.emit(); this.labelModel = this.initLabel(); this.formShow = false; }) .catch(err => { this.inProgress = false; this.errorHandler.error(err); }); } } /** * @return {?} */ onCancel() { this.inProgress = false; this.labelModel = this.initLabel(); this.formShow = false; } } CreateEditLabelComponent.decorators = [ { type: Component, args: [{ selector: "hbr-create-edit-label", template: "<div>\n <form #labelForm=\"ngForm\" [hidden]=\"!formShow\">\n <section>\n <label>\n <label for=\"name\">{{'LABEL.LABEL_NAME' | translate}}</label>\n <label aria-haspopup=\"true\" role=\"tooltip\" [class.invalid]=\"isLabelNameExist\"\n class=\"tooltip tooltip-validation tooltip-md tooltip-bottom-left\">\n <input type=\"text\" id=\"name\" name=\"name\" required size=\"20\" autocomplete=\"off\"\n [(ngModel)]=\"labelModel.name\" #name=\"ngModel\" (keyup)=\"existValid(labelModel.name)\">\n <span class=\"tooltip-content\">\n {{'LABEL.NAME_ALREADY_EXISTS' | translate }}\n </span>\n </label>\n </label>\n <label>\n <label for=\"color\">{{'LABEL.COLOR' | translate}}</label>\n <clr-dropdown [clrCloseMenuOnItemClick]=\"false\" clrDropdownTrigger>\n <clr-icon shape=\"caret down\" class=\"btn btn-outline btnColor btn-sm\"></clr-icon>\n <clr-dropdown-menu *clrIfOpen>\n <label class=\"dropdown-item\" (click)=\"labelModel.color=i.color\" *ngFor=\"let i of labelColor\"\n [class.borderSty]=\"i.color == '#FFFFFF'\" [ngStyle]=\"{'background-color': i.color, 'color': i.textColor }\">Aa</label>\n </clr-dropdown-menu>\n </clr-dropdown>\n <input type=\"text\" id=\"color\" size=\"8\" name=\"color\" disabled [(ngModel)]=\"labelModel.color\" #color=\"ngModel\">\n </label>\n <label>\n <label for=\"description\">{{'LABEL.DESCRIPTION' | translate}}</label>\n <input type=\"text\" id=\"description\" name=\"description\" size=\"30\" [(ngModel)]=\"labelModel.description\"\n #description=\"ngModel\">\n </label>\n <label>\n <button type=\"button\" class=\"btn btn-sm btn-outline\" (click)=\"onCancel()\" [disabled]=\"inProgress\">{{\n 'BUTTON.CANCEL' | translate }}\n </button>\n <button type=\"submit\" class=\"btn btn-sm btn-primary\" (click)=\"onSubmit()\" [disabled]=\"!isValid\">{{\n 'BUTTON.OK' | translate }}\n </button>\n </label>\n </section>\n </form>\n</div>", changeDetection: ChangeDetectionStrategy.Default, styles: ["form{margin-bottom:-10px;padding-top:0;margin-top:20px;width:100%;background-color:#eee;border:1px solid #ccc}form section{padding:.5rem 0}form section>label{margin-left:20px}form .btnColor{margin:0!important;padding:0!important;width:26px;height:22px;min-width:26px}form .colorPanel span{margin:5px 4px;width:30px;height:24px;text-align:center;line-height:24px;font-size:12px;border:1px solid #a1a1a1}form .dropdown-menu{display:inline-block;width:166px;padding:6px}form .dropdown-menu .dropdown-item{display:inline-block;margin:2px 4px;padding:0;width:30px;height:24px;text-align:center;line-height:24px;border:0;color:#fff;font-size:12px}form .dropdown .dropdown-toggle.btn{padding:0!important}form .borderSty{border:1px solid #a1a1a1!important;line-height:22px}"] }] } ]; /** @nocollapse */ CreateEditLabelComponent.ctorParameters = () => [ { type: LabelService }, { type: ErrorHandler }, { type: ChangeDetectorRef } ]; CreateEditLabelComponent.propDecorators = { currentForm: [{ type: ViewChild, args: ["labelForm",] }], projectId: [{ type: Input }], scope: [{ type: Input }], reload: [{ type: Output }] }; if (false) { /** @type {?} */ CreateEditLabelComponent.prototype.formShow; /** @type {?} */ CreateEditLabelComponent.prototype.inProgress; /** @type {?} */ CreateEditLabelComponent.prototype.copeLabelModel; /** @type {?} */ CreateEditLabelComponent.prototype.labelModel; /** @type {?} */ CreateEditLabelComponent.prototype.labelId; /** @type {?} */ CreateEditLabelComponent.prototype.isLabelNameExist; /** @type {?} */ CreateEditLabelComponent.prototype.nameChecker; /** @type {?} */ CreateEditLabelComponent.prototype.labelForm; /** @type {?} */ CreateEditLabelComponent.prototype.currentForm; /** @type {?} */ CreateEditLabelComponent.prototype.projectId; /** @type {?} */ CreateEditLabelComponent.prototype.scope; /** @type {?} */ CreateEditLabelComponent.prototype.reload; /** @type {?} */ CreateEditLabelComponent.prototype.labelService; /** @type {?} */ CreateEditLabelComponent.prototype.errorHandler; /** @type {?} */ CreateEditLabelComponent.prototype.ref; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-edit-label.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/create-edit-label/create-edit-label.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) 2017 VMware, Inc. All Rights Reserved.\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//    http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\nimport {\n  Component,\n  Output,\n  EventEmitter,\n  OnDestroy,\n  Input,\n  OnInit,\n  ViewChild,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef\n} from \"@angular/core\";\n\nimport { Label } from \"../service/interface\";\n\nimport { toPromise, clone, compareValue } from \"../utils\";\n\nimport { LabelService } from \"../service/label.service\";\nimport { ErrorHandler } from \"../error-handler/error-handler\";\nimport { NgForm } from \"@angular/forms\";\nimport { Subject } from \"rxjs\";\nimport { debounceTime } from \"rxjs/operators\";\nimport { LabelColor } from \"../shared/shared.const\";\n\n@Component({\n  selector: \"hbr-create-edit-label\",\n  templateUrl: \"./create-edit-label.component.html\",\n  styleUrls: [\"./create-edit-label.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.Default\n})\nexport class CreateEditLabelComponent implements OnInit, OnDestroy {\n  formShow: boolean;\n  inProgress: boolean;\n  copeLabelModel: Label;\n  labelModel: Label = this.initLabel();\n  labelId = 0;\n\n  isLabelNameExist = false;\n\n  nameChecker = new Subject<string>();\n\n  labelForm: NgForm;\n  @ViewChild(\"labelForm\") currentForm: NgForm;\n\n  @Input() projectId: number;\n  @Input() scope: string;\n  @Output() reload = new EventEmitter();\n\n  constructor(\n    private labelService: LabelService,\n    private errorHandler: ErrorHandler,\n    private ref: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    this.nameChecker.pipe(debounceTime(500)).subscribe((name: string) => {\n      toPromise<Label[]>(\n        this.labelService.getLabels(this.scope, this.projectId, name)\n      )\n        .then(targets => {\n          this.isLabelNameExist = false;\n          if (targets && targets.length) {\n            if (targets.find((target) => {\n              return target.name === name;\n            })) {\n              this.isLabelNameExist = true;\n            }\n          }\n        })\n        .catch(error => {\n          this.errorHandler.error(error);\n        });\n      let hnd = setInterval(() => this.ref.markForCheck(), 100);\n      setTimeout(() => clearInterval(hnd), 5000);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.nameChecker.unsubscribe();\n  }\n\n  get labelColor() {\n    return LabelColor;\n  }\n\n  initLabel(): Label {\n    return {\n      name: \"\",\n      description: \"\",\n      color: \"\",\n      scope: \"\",\n      project_id: 0\n    };\n  }\n  openModal(): void {\n    this.labelModel = this.initLabel();\n    this.formShow = true;\n    this.isLabelNameExist = false;\n    this.labelId = 0;\n    this.copeLabelModel = null;\n  }\n\n  editModel(labelId: number, label: Label[]): void {\n    this.labelModel = clone(label[0]);\n    this.formShow = true;\n    this.labelId = labelId;\n    this.copeLabelModel = clone(label[0]);\n  }\n\n  public get hasChanged(): boolean {\n    return !compareValue(this.copeLabelModel, this.labelModel);\n  }\n\n  public get isValid(): boolean {\n    return !(\n      this.isLabelNameExist ||\n      !(this.currentForm && this.currentForm.valid) ||\n      !this.hasChanged ||\n      this.inProgress\n    );\n  }\n\n  existValid(text: string): void {\n    if (text) {\n      this.nameChecker.next(text);\n    } else {\n      this.isLabelNameExist = false;\n    }\n  }\n\n  onSubmit(): void {\n    this.inProgress = true;\n    if (this.labelId <= 0) {\n      this.labelModel.scope = this.scope;\n      this.labelModel.project_id = this.projectId;\n      toPromise<Label>(this.labelService.createLabel(this.labelModel))\n        .then(res => {\n          this.inProgress = false;\n          this.reload.emit();\n          this.labelModel = this.initLabel();\n          this.formShow = false;\n        })\n        .catch(err => {\n          this.inProgress = false;\n          this.errorHandler.error(err);\n        });\n    } else {\n      toPromise<Label>(\n        this.labelService.updateLabel(this.labelId, this.labelModel)\n      )\n        .then(res => {\n          this.inProgress = false;\n          this.reload.emit();\n          this.labelModel = this.initLabel();\n          this.formShow = false;\n        })\n        .catch(err => {\n          this.inProgress = false;\n          this.errorHandler.error(err);\n        });\n    }\n  }\n\n  onCancel(): void {\n    this.inProgress = false;\n    this.labelModel = this.initLabel();\n    this.formShow = false;\n  }\n}\n"]}