@harbor/ui
Version:
Harbor shared UI components based on Clarity and Angular6
221 lines (220 loc) • 21.9 kB
JavaScript
/**
* @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"]}