@harbor/ui
Version:
Harbor shared UI components based on Clarity and Angular6
276 lines (275 loc) • 30.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, ViewChild, ChangeDetectionStrategy, ChangeDetectorRef } from "@angular/core";
import { forkJoin } from "rxjs";
import { TranslateService } from "@ngx-translate/core";
import { EndpointService } from "../service/endpoint.service";
import { ErrorHandler } from "../error-handler/index";
import { ConfirmationMessage } from "../confirmation-dialog/confirmation-message";
import { ConfirmationDialogComponent } from "../confirmation-dialog/confirmation-dialog.component";
import { CreateEditEndpointComponent } from "../create-edit-endpoint/create-edit-endpoint.component";
import { toPromise, CustomComparator } from "../utils";
import { operateChanges, OperateInfo, OperationState } from "../operation/operate";
import { OperationService } from "../operation/operation.service";
export class EndpointComponent {
/**
* @param {?} endpointService
* @param {?} errorHandler
* @param {?} translateService
* @param {?} operationService
* @param {?} ref
*/
constructor(endpointService, errorHandler, translateService, operationService, ref) {
this.endpointService = endpointService;
this.errorHandler = errorHandler;
this.translateService = translateService;
this.operationService = operationService;
this.ref = ref;
this.loading = false;
this.creationTimeComparator = new CustomComparator("creation_time", "date");
this.selectedRow = [];
this.forceRefreshView(1000);
}
/**
* @return {?}
*/
get initEndpoint() {
return {
endpoint: "",
name: "",
username: "",
password: "",
insecure: false,
type: 0
};
}
/**
* @return {?}
*/
ngOnInit() {
this.targetName = "";
this.retrieve();
}
/**
* @return {?}
*/
ngOnDestroy() {
if (this.subscription) {
this.subscription.unsubscribe();
}
}
/**
* @return {?}
*/
selectedChange() {
this.forceRefreshView(5000);
}
/**
* @return {?}
*/
retrieve() {
this.loading = true;
this.selectedRow = [];
toPromise(this.endpointService.getEndpoints(this.targetName))
.then(targets => {
this.targets = targets || [];
this.forceRefreshView(1000);
this.loading = false;
})
.catch(error => {
this.errorHandler.error(error);
this.loading = false;
});
}
/**
* @param {?} targetName
* @return {?}
*/
doSearchTargets(targetName) {
this.targetName = targetName;
this.retrieve();
}
/**
* @return {?}
*/
refreshTargets() {
this.retrieve();
}
/**
* @param {?} $event
* @return {?}
*/
reload($event) {
this.targetName = "";
this.retrieve();
}
/**
* @return {?}
*/
openModal() {
this.createEditEndpointComponent.openCreateEditTarget(true);
this.target = this.initEndpoint;
}
/**
* @param {?} targets
* @return {?}
*/
editTargets(targets) {
if (targets && targets.length === 1) {
/** @type {?} */
let target = targets[0];
/** @type {?} */
let editable = true;
if (!target.id) {
return;
}
/** @type {?} */
let id = target.id;
this.createEditEndpointComponent.openCreateEditTarget(editable, id);
}
}
/**
* @param {?} targets
* @return {?}
*/
deleteTargets(targets) {
if (targets && targets.length) {
/** @type {?} */
let targetNames = [];
targets.forEach(target => {
targetNames.push(target.name);
});
/** @type {?} */
let deletionMessage = new ConfirmationMessage('REPLICATION.DELETION_TITLE_TARGET', 'REPLICATION.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.reload(true);
this.forceRefreshView(2000);
});
}
}
}
/**
* @param {?} target
* @return {?}
*/
delOperate(target) {
/** @type {?} */
let operMessage = new OperateInfo();
operMessage.name = 'OPERATION.DELETE_REGISTRY';
operMessage.data["id"] = target.id;
operMessage.state = OperationState.progressing;
operMessage.data["name"] = target.name;
this.operationService.publishInfo(operMessage);
return toPromise(this.endpointService
.deleteEndpoint(target.id))
.then(response => {
this.translateService.get('BATCH.DELETED_SUCCESS')
.subscribe(res => {
operateChanges(operMessage, OperationState.success);
});
}).catch(error => {
if (error && error.status === 412) {
forkJoin(this.translateService.get('BATCH.DELETED_FAILURE'), this.translateService.get('DESTINATION.FAILED_TO_DELETE_TARGET_IN_USED')).subscribe(res => {
operateChanges(operMessage, OperationState.failure, res[1]);
});
}
else {
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);
}
}
EndpointComponent.decorators = [
{ type: Component, args: [{
selector: "hbr-endpoint",
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='{{\"REPLICATION.FILTER_TARGETS_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\">\n <clr-datagrid [clrDgLoading]=\"loading\" [(clrDgSelected)]=\"selectedRow\" (clrDgSelectedChange)=\"selectedChange()\">\n <clr-dg-action-bar>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" (click)=\"openModal()\"><clr-icon shape=\"plus\" size=\"16\"></clr-icon> {{'DESTINATION.NEW_ENDPOINT' | translate}}</button>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" [disabled]=\"!(selectedRow.length ===1)\" (click)=\"editTargets(selectedRow)\" ><clr-icon shape=\"pencil\" size=\"16\"></clr-icon> {{'DESTINATION.EDIT' | translate}}</button>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" [disabled]=\"!selectedRow.length\" (click)=\"deleteTargets(selectedRow)\"><clr-icon shape=\"times\" size=\"16\"></clr-icon> {{'DESTINATION.DELETE' | translate}}</button>\n </clr-dg-action-bar>\n <clr-dg-column [clrDgField]=\"'name'\">{{'DESTINATION.NAME' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'endpoint'\">{{'DESTINATION.URL' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'insecure'\">{{'CONFIG.VERIFY_REMOTE_CERT' | translate }}</clr-dg-column>\n <clr-dg-column [clrDgSortBy]=\"creationTimeComparator\">{{'DESTINATION.CREATION_TIME' | translate}}</clr-dg-column>\n <clr-dg-placeholder>{{'DESTINATION.PLACEHOLDER' | translate }}</clr-dg-placeholder>\n <clr-dg-row *clrDgItems=\"let t of targets\" [clrDgItem]='t'>\n <clr-dg-cell>{{t.name}}</clr-dg-cell>\n <clr-dg-cell>{{t.endpoint}}</clr-dg-cell>\n <clr-dg-cell>\n {{!t.insecure}}\n </clr-dg-cell>\n <clr-dg-cell>{{t.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 <hbr-create-edit-endpoint (reload)=\"reload($event)\"></hbr-create-edit-endpoint>\n</div>",
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}"]
}] }
];
/** @nocollapse */
EndpointComponent.ctorParameters = () => [
{ type: EndpointService },
{ type: ErrorHandler },
{ type: TranslateService },
{ type: OperationService },
{ type: ChangeDetectorRef }
];
EndpointComponent.propDecorators = {
createEditEndpointComponent: [{ type: ViewChild, args: [CreateEditEndpointComponent,] }],
confirmationDialogComponent: [{ type: ViewChild, args: ["confirmationDialog",] }]
};
if (false) {
/** @type {?} */
EndpointComponent.prototype.createEditEndpointComponent;
/** @type {?} */
EndpointComponent.prototype.confirmationDialogComponent;
/** @type {?} */
EndpointComponent.prototype.targets;
/** @type {?} */
EndpointComponent.prototype.target;
/** @type {?} */
EndpointComponent.prototype.targetName;
/** @type {?} */
EndpointComponent.prototype.subscription;
/** @type {?} */
EndpointComponent.prototype.loading;
/** @type {?} */
EndpointComponent.prototype.creationTimeComparator;
/** @type {?} */
EndpointComponent.prototype.timerHandler;
/** @type {?} */
EndpointComponent.prototype.selectedRow;
/** @type {?} */
EndpointComponent.prototype.endpointService;
/** @type {?} */
EndpointComponent.prototype.errorHandler;
/** @type {?} */
EndpointComponent.prototype.translateService;
/** @type {?} */
EndpointComponent.prototype.operationService;
/** @type {?} */
EndpointComponent.prototype.ref;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"endpoint.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/endpoint/endpoint.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    OnInit,\n    OnDestroy,\n    ViewChild,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef\n} from \"@angular/core\";\nimport { Subscription} from \"rxjs\";\nimport {forkJoin} from \"rxjs\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { Comparator } from \"@clr/angular\";\n\nimport { Endpoint } from \"../service/interface\";\nimport { EndpointService } from \"../service/endpoint.service\";\n\nimport { ErrorHandler } from \"../error-handler/index\";\n\nimport {ConfirmationMessage} from \"../confirmation-dialog/confirmation-message\";\nimport {ConfirmationAcknowledgement} from \"../confirmation-dialog/confirmation-state-message\";\nimport {ConfirmationDialogComponent} from \"../confirmation-dialog/confirmation-dialog.component\";\n\nimport {\n    ConfirmationTargets,\n    ConfirmationState,\n    ConfirmationButtons\n} from \"../shared/shared.const\";\n\nimport { CreateEditEndpointComponent } from \"../create-edit-endpoint/create-edit-endpoint.component\";\nimport { toPromise, CustomComparator } from \"../utils\";\n\nimport {operateChanges, OperateInfo, OperationState} from \"../operation/operate\";\nimport {OperationService} from \"../operation/operation.service\";\n\n@Component({\n    selector: \"hbr-endpoint\",\n    templateUrl: \"./endpoint.component.html\",\n    styleUrls: [\"./endpoint.component.scss\"],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class EndpointComponent implements OnInit, OnDestroy {\n    @ViewChild(CreateEditEndpointComponent)\n    createEditEndpointComponent: CreateEditEndpointComponent;\n\n    @ViewChild(\"confirmationDialog\")\n    confirmationDialogComponent: ConfirmationDialogComponent;\n\n    targets: Endpoint[];\n    target: Endpoint;\n\n    targetName: string;\n    subscription: Subscription;\n\n    loading: boolean = false;\n\n    creationTimeComparator: Comparator<Endpoint> = new CustomComparator<Endpoint>(\n        \"creation_time\",\n        \"date\"\n    );\n\n    timerHandler: any;\n    selectedRow: Endpoint[] = [];\n\n    get initEndpoint(): Endpoint {\n        return {\n            endpoint: \"\",\n            name: \"\",\n            username: \"\",\n            password: \"\",\n            insecure: false,\n            type: 0\n        };\n    }\n\n    constructor(private endpointService: EndpointService,\n                private errorHandler: ErrorHandler,\n                private translateService: TranslateService,\n                private operationService: OperationService,\n                private ref: ChangeDetectorRef) {\n        this.forceRefreshView(1000);\n    }\n\n    ngOnInit(): void {\n        this.targetName = \"\";\n        this.retrieve();\n    }\n\n    ngOnDestroy(): void {\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n        }\n    }\n\n    selectedChange(): void {\n        this.forceRefreshView(5000);\n    }\n\n    retrieve(): void {\n        this.loading = true;\n        this.selectedRow = [];\n        toPromise<Endpoint[]>(this.endpointService.getEndpoints(this.targetName))\n            .then(targets => {\n                this.targets = targets || [];\n                this.forceRefreshView(1000);\n                this.loading = false;\n            })\n            .catch(error => {\n                this.errorHandler.error(error);\n                this.loading = false;\n            });\n    }\n\n    doSearchTargets(targetName: string) {\n        this.targetName = targetName;\n        this.retrieve();\n    }\n\n    refreshTargets() {\n        this.retrieve();\n    }\n\n    reload($event: any) {\n        this.targetName = \"\";\n        this.retrieve();\n    }\n\n    openModal() {\n        this.createEditEndpointComponent.openCreateEditTarget(true);\n        this.target = this.initEndpoint;\n    }\n\n    editTargets(targets: Endpoint[]) {\n        if (targets && targets.length === 1) {\n            let target = targets[0];\n            let editable = true;\n            if (!target.id) {\n                return;\n            }\n            let id: number | string = target.id;\n            this.createEditEndpointComponent.openCreateEditTarget(editable, id);\n        }\n    }\n\n    deleteTargets(targets: Endpoint[]) {\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                'REPLICATION.DELETION_TITLE_TARGET',\n                'REPLICATION.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: Endpoint[] = 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.reload(true);\n                    this.forceRefreshView(2000);\n                });\n            }\n        }\n    }\n\n    delOperate(target: Endpoint) {\n        // init operation info\n        let operMessage = new OperateInfo();\n        operMessage.name = 'OPERATION.DELETE_REGISTRY';\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.endpointService\n            .deleteEndpoint(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                    if (error && error.status === 412) {\n                        forkJoin(this.translateService.get('BATCH.DELETED_FAILURE'),\n                            this.translateService.get('DESTINATION.FAILED_TO_DELETE_TARGET_IN_USED')).subscribe(res => {\n                            operateChanges(operMessage, OperationState.failure, res[1]);\n                        });\n                    } else {\n                        this.translateService.get('BATCH.DELETED_FAILURE').subscribe(res => {\n                            operateChanges(operMessage, OperationState.failure, res);\n                        });\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"]}