UNPKG

@harbor/ui

Version:

Harbor shared UI components based on Clarity and Angular6

234 lines (233 loc) 25.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, ViewChild, ChangeDetectionStrategy, ChangeDetectorRef, Input } from "@angular/core"; import { LabelService } from "../service/label.service"; import { toPromise } from "../utils"; import { ErrorHandler } from "../error-handler/error-handler"; import { CreateEditLabelComponent } from "../create-edit-label/create-edit-label.component"; import { ConfirmationMessage } from "../confirmation-dialog/confirmation-message"; import { TranslateService } from "@ngx-translate/core"; import { ConfirmationDialogComponent } from "../confirmation-dialog/confirmation-dialog.component"; import { operateChanges, OperateInfo, OperationState } from "../operation/operate"; import { OperationService } from "../operation/operation.service"; export class LabelComponent { /** * @param {?} labelService * @param {?} errorHandler * @param {?} translateService * @param {?} operationService * @param {?} ref */ constructor(labelService, errorHandler, translateService, operationService, ref) { this.labelService = labelService; this.errorHandler = errorHandler; this.translateService = translateService; this.operationService = operationService; this.ref = ref; this.selectedRow = []; this.projectId = 0; } /** * @return {?} */ ngOnInit() { this.retrieve(this.scope); } /** * @param {?} scope * @param {?=} name * @return {?} */ retrieve(scope, name = "") { this.loading = true; this.selectedRow = []; this.targetName = ""; toPromise(this.labelService.getLabels(scope, this.projectId, name)) .then(targets => { this.targets = targets || []; this.loading = false; this.forceRefreshView(2000); }) .catch(error => { this.errorHandler.error(error); this.loading = false; }); } /** * @return {?} */ openModal() { this.createEditLabel.openModal(); } /** * @return {?} */ reload() { this.retrieve(this.scope); } /** * @param {?} targetName * @return {?} */ doSearchTargets(targetName) { this.retrieve(this.scope, targetName); } /** * @return {?} */ refreshTargets() { this.retrieve(this.scope); } /** * @return {?} */ selectedChange() { // this.forceRefreshView(5000); } /** * @param {?} label * @return {?} */ editLabel(label) { this.createEditLabel.editModel(label[0]["id"], label); } /** * @param {?} targets * @return {?} */ deleteLabels(targets) { if (targets && targets.length) { /** @type {?} */ let targetNames = []; targets.forEach(target => { targetNames.push(target.name); }); /** @type {?} */ let deletionMessage = new ConfirmationMessage('LABEL.DELETION_TITLE_TARGET', 'LABEL.DELETION_SUMMARY_TARGET', targetNames.join(', ') || '', targets, 6 /* TARGET */, 2 /* DELETE_CANCEL */); this.confirmationDialogComponent.open(deletionMessage); } } /** * @param {?} message * @return {?} */ confirmDeletion(message) { if (message && message.source === 6 /* TARGET */ && message.state === 1 /* CONFIRMED */) { /** @type {?} */ let targetLists = message.data; if (targetLists && targetLists.length) { /** @type {?} */ let promiseLists = []; targetLists.forEach(target => { promiseLists.push(this.delOperate(target)); }); Promise.all(promiseLists).then((item) => { this.selectedRow = []; this.retrieve(this.scope); }); } } } /** * @param {?} target * @return {?} */ delOperate(target) { /** @type {?} */ let operMessage = new OperateInfo(); operMessage.name = 'OPERATION.DELETE_LABEL'; operMessage.data["id"] = target["id"]; operMessage.state = OperationState.progressing; operMessage.data["name"] = target.name; this.operationService.publishInfo(operMessage); return toPromise(this.labelService .deleteLabel(target["id"])) .then(response => { this.translateService.get('BATCH.DELETED_SUCCESS') .subscribe(res => { operateChanges(operMessage, OperationState.success); }); }).catch(error => { this.translateService.get('BATCH.DELETED_FAILURE').subscribe(res => { operateChanges(operMessage, OperationState.failure, res); }); }); } /** * @param {?} duration * @return {?} */ forceRefreshView(duration) { // Reset timer if (this.timerHandler) { clearInterval(this.timerHandler); } this.timerHandler = setInterval(() => this.ref.markForCheck(), 100); setTimeout(() => { if (this.timerHandler) { clearInterval(this.timerHandler); this.timerHandler = null; } }, duration); } } LabelComponent.decorators = [ { type: Component, args: [{ selector: "hbr-label", template: "<div>\n <div class=\"row\" style=\"position:relative;\">\n <div>\n <div class=\"row flex-items-xs-between rightPos\">\n <div class=\"flex-items-xs-middle option-right\">\n <hbr-filter [withDivider]=\"true\" filterPlaceholder='{{\"LABEL.FILTER_LABEL_PLACEHOLDER\" | translate}}' (filterEvt)=\"doSearchTargets($event)\" [currentValue]=\"targetName\"></hbr-filter>\n <span class=\"refresh-btn\" (click)=\"refreshTargets()\">\n <clr-icon shape=\"refresh\"></clr-icon>\n </span>\n </div>\n </div>\n </div>\n <div class=\"col-lg-12 col-md-12 col-sm-12 col-xs-12 btnGroup\">\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" (click)=\"openModal()\"><clr-icon shape=\"plus\" size=\"16\"></clr-icon>&nbsp;{{'LABEL.NEW_LABEL' | translate}}</button>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" [disabled]=\"!(selectedRow.length == 1)\" (click)=\"editLabel(selectedRow)\"><clr-icon shape=\"pencil\" size=\"16\"></clr-icon>&nbsp;{{'LABEL.EDIT' | translate}}</button>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" [disabled]=\"!selectedRow.length\" (click)=\"deleteLabels(selectedRow)\"><clr-icon shape=\"times\" size=\"16\"></clr-icon>&nbsp;{{'LABEL.DELETE' | translate}}</button> \n <hbr-create-edit-label [scope]=\"scope\" [projectId]=\"projectId\" (reload)=\"reload()\"></hbr-create-edit-label>\n </div>\n <div class=\"col-lg-12 col-md-12 col-sm-12 col-xs-12 content-mt\">\n <clr-datagrid [clrDgLoading]=\"loading\" [(clrDgSelected)]=\"selectedRow\" (clrDgSelectedChange)=\"selectedChange()\">\n <clr-dg-column [clrDgField]=\"'name'\">{{'LABEL.LABEL' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'endpoint'\">{{'LABEL.DESCRIPTION' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'insecure'\">{{'LABEL.CREATION_TIME' | translate }}</clr-dg-column>\n <clr-dg-placeholder>{{'LABEL.PLACEHOLDER' | translate }}</clr-dg-placeholder>\n <clr-dg-row *clrDgItems=\"let label of targets\" [clrDgItem]='label'>\n <clr-dg-cell>\n <hbr-label-piece [label]=\"label\"></hbr-label-piece>\n </clr-dg-cell>\n <clr-dg-cell>{{label.description}}</clr-dg-cell>\n <clr-dg-cell>{{label.creation_time | date: 'short'}}</clr-dg-cell>\n </clr-dg-row>\n <clr-dg-footer>\n <span *ngIf=\"pagination.totalItems\">{{pagination.firstItem + 1}} - {{pagination.lastItem + 1}} {{'DESTINATION.OF' | translate}}</span>\n {{pagination.totalItems}} {{'DESTINATION.ITEMS' | translate}}\n <clr-dg-pagination #pagination [clrDgPageSize]=\"15\"></clr-dg-pagination>\n </clr-dg-footer>\n </clr-datagrid>\n </div>\n </div>\n <confirmation-dialog #confirmationDialog (confirmAction)=\"confirmDeletion($event)\"></confirmation-dialog>\n</div>\n\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: [".option-left{padding-left:16px;margin-top:-6px}.option-right{padding-right:16px}.refresh-btn{cursor:pointer}.refresh-btn:hover{color:#007cbb}.rightPos{position:absolute;z-index:100;right:35px;margin-top:4px;height:24px}.content-mt{margin-top:-12px}"] }] } ]; /** @nocollapse */ LabelComponent.ctorParameters = () => [ { type: LabelService }, { type: ErrorHandler }, { type: TranslateService }, { type: OperationService }, { type: ChangeDetectorRef } ]; LabelComponent.propDecorators = { scope: [{ type: Input }], projectId: [{ type: Input }], hasProjectAdminRole: [{ type: Input }], createEditLabel: [{ type: ViewChild, args: [CreateEditLabelComponent,] }], confirmationDialogComponent: [{ type: ViewChild, args: ["confirmationDialog",] }] }; if (false) { /** @type {?} */ LabelComponent.prototype.timerHandler; /** @type {?} */ LabelComponent.prototype.loading; /** @type {?} */ LabelComponent.prototype.targets; /** @type {?} */ LabelComponent.prototype.targetName; /** @type {?} */ LabelComponent.prototype.selectedRow; /** @type {?} */ LabelComponent.prototype.scope; /** @type {?} */ LabelComponent.prototype.projectId; /** @type {?} */ LabelComponent.prototype.hasProjectAdminRole; /** @type {?} */ LabelComponent.prototype.createEditLabel; /** @type {?} */ LabelComponent.prototype.confirmationDialogComponent; /** @type {?} */ LabelComponent.prototype.labelService; /** @type {?} */ LabelComponent.prototype.errorHandler; /** @type {?} */ LabelComponent.prototype.translateService; /** @type {?} */ LabelComponent.prototype.operationService; /** @type {?} */ LabelComponent.prototype.ref; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"label.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/label/label.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright Project Harbor Authors\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    OnInit,\n    ViewChild,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Input\n} from \"@angular/core\";\nimport {Label} from \"../service/interface\";\nimport {LabelService} from \"../service/label.service\";\nimport {toPromise} from \"../utils\";\nimport {ErrorHandler} from \"../error-handler/error-handler\";\nimport {CreateEditLabelComponent} from \"../create-edit-label/create-edit-label.component\";\nimport {ConfirmationMessage} from \"../confirmation-dialog/confirmation-message\";\nimport {\n    ConfirmationButtons,\n    ConfirmationState,\n    ConfirmationTargets\n} from \"../shared/shared.const\";\nimport {ConfirmationAcknowledgement} from \"../confirmation-dialog/confirmation-state-message\";\nimport {TranslateService} from \"@ngx-translate/core\";\nimport {ConfirmationDialogComponent} from \"../confirmation-dialog/confirmation-dialog.component\";\nimport {operateChanges, OperateInfo, OperationState} from \"../operation/operate\";\nimport {OperationService} from \"../operation/operation.service\";\n\n@Component({\n    selector: \"hbr-label\",\n    templateUrl: \"./label.component.html\",\n    styleUrls: [\"./label.component.scss\"],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LabelComponent implements OnInit {\n    timerHandler: any;\n    loading: boolean;\n    targets: Label[];\n    targetName: string;\n    selectedRow: Label[] = [];\n\n    @Input() scope: string;\n    @Input() projectId = 0;\n    @Input() hasProjectAdminRole: boolean;\n\n    @ViewChild(CreateEditLabelComponent)\n    createEditLabel: CreateEditLabelComponent;\n    @ViewChild(\"confirmationDialog\")\n    confirmationDialogComponent: ConfirmationDialogComponent;\n\n    constructor(private labelService: LabelService,\n                private errorHandler: ErrorHandler,\n                private translateService: TranslateService,\n                private operationService: OperationService,\n                private ref: ChangeDetectorRef) {\n    }\n\n    ngOnInit(): void {\n        this.retrieve(this.scope);\n    }\n\n    retrieve(scope: string, name = \"\") {\n        this.loading = true;\n        this.selectedRow = [];\n        this.targetName = \"\";\n        toPromise<Label[]>(this.labelService.getLabels(scope, this.projectId, name))\n            .then(targets => {\n                this.targets = targets || [];\n                this.loading = false;\n                this.forceRefreshView(2000);\n            })\n            .catch(error => {\n                this.errorHandler.error(error);\n                this.loading = false;\n            });\n    }\n\n    openModal(): void {\n        this.createEditLabel.openModal();\n    }\n\n    reload(): void {\n        this.retrieve(this.scope);\n    }\n\n    doSearchTargets(targetName: string) {\n        this.retrieve(this.scope, targetName);\n    }\n\n    refreshTargets() {\n        this.retrieve(this.scope);\n    }\n\n    selectedChange(): void {\n        // this.forceRefreshView(5000);\n    }\n\n    editLabel(label: Label[]): void {\n        this.createEditLabel.editModel(label[0].id, label);\n    }\n\n    deleteLabels(targets: Label[]): void {\n        if (targets && targets.length) {\n            let targetNames: string[] = [];\n            targets.forEach(target => {\n                targetNames.push(target.name);\n            });\n            let deletionMessage = new ConfirmationMessage(\n                'LABEL.DELETION_TITLE_TARGET',\n                'LABEL.DELETION_SUMMARY_TARGET',\n                targetNames.join(', ') || '',\n                targets,\n                ConfirmationTargets.TARGET,\n                ConfirmationButtons.DELETE_CANCEL);\n            this.confirmationDialogComponent.open(deletionMessage);\n        }\n    }\n\n    confirmDeletion(message: ConfirmationAcknowledgement) {\n        if (message &&\n            message.source === ConfirmationTargets.TARGET &&\n            message.state === ConfirmationState.CONFIRMED) {\n            let targetLists: Label[] = message.data;\n            if (targetLists && targetLists.length) {\n                let promiseLists: any[] = [];\n                targetLists.forEach(target => {\n                    promiseLists.push(this.delOperate(target));\n                });\n                Promise.all(promiseLists).then((item) => {\n                    this.selectedRow = [];\n                    this.retrieve(this.scope);\n                });\n            }\n        }\n    }\n\n    delOperate(target: Label) {\n        // init operation info\n        let operMessage = new OperateInfo();\n        operMessage.name = 'OPERATION.DELETE_LABEL';\n        operMessage.data.id = target.id;\n        operMessage.state = OperationState.progressing;\n        operMessage.data.name = target.name;\n        this.operationService.publishInfo(operMessage);\n\n        return toPromise<number>(this.labelService\n            .deleteLabel(target.id))\n            .then(\n                response => {\n                    this.translateService.get('BATCH.DELETED_SUCCESS')\n                        .subscribe(res => {\n                            operateChanges(operMessage, OperationState.success);\n                        });\n                }).catch(\n                error => {\n                    this.translateService.get('BATCH.DELETED_FAILURE').subscribe(res => {\n                        operateChanges(operMessage, OperationState.failure, res);\n                    });\n                });\n    }\n\n    // Forcely refresh the view\n    forceRefreshView(duration: number): void {\n        // Reset timer\n        if (this.timerHandler) {\n            clearInterval(this.timerHandler);\n        }\n        this.timerHandler = setInterval(() => this.ref.markForCheck(), 100);\n        setTimeout(() => {\n            if (this.timerHandler) {\n                clearInterval(this.timerHandler);\n                this.timerHandler = null;\n            }\n        }, duration);\n    }\n}\n"]}