UNPKG

@harbor/ui

Version:

Harbor shared UI components based on Clarity and Angular6

360 lines (359 loc) 38.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter, ViewChild, ChangeDetectionStrategy, ChangeDetectorRef } from "@angular/core"; import { forkJoin } from "rxjs"; import { TranslateService } from "@ngx-translate/core"; import { ReplicationService } from "../service/replication.service"; import { ConfirmationDialogComponent } from "../confirmation-dialog/confirmation-dialog.component"; import { ConfirmationMessage } from "../confirmation-dialog/confirmation-message"; import { ErrorHandler } from "../error-handler/error-handler"; import { toPromise, CustomComparator } from "../utils"; import { operateChanges, OperateInfo, OperationState } from "../operation/operate"; import { OperationService } from "../operation/operation.service"; export class ListReplicationRuleComponent { /** * @param {?} replicationService * @param {?} translateService * @param {?} errorHandler * @param {?} operationService * @param {?} ref */ constructor(replicationService, translateService, errorHandler, operationService, ref) { this.replicationService = replicationService; this.translateService = translateService; this.errorHandler = errorHandler; this.operationService = operationService; this.ref = ref; this.nullTime = "0001-01-01T00:00:00Z"; this.loading = false; this.reload = new EventEmitter(); this.selectOne = new EventEmitter(); this.editOne = new EventEmitter(); this.toggleOne = new EventEmitter(); this.hideJobs = new EventEmitter(); this.redirect = new EventEmitter(); this.openNewRule = new EventEmitter(); this.replicateManual = new EventEmitter(); this.projectScope = false; this.startTimeComparator = new CustomComparator("start_time", "date"); this.enabledComparator = new CustomComparator("enabled", "number"); setInterval(() => ref.markForCheck(), 500); } /** * @param {?} desc * @return {?} */ trancatedDescription(desc) { if (desc.length > 35) { return desc.substr(0, 35); } else { return desc; } } /** * @return {?} */ ngOnInit() { // Global scope if (!this.projectScope) { this.retrieveRules(); } } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { /** @type {?} */ let proIdChange = changes["projectId"]; if (proIdChange) { if (proIdChange.currentValue !== proIdChange.previousValue) { if (proIdChange.currentValue) { this.projectId = proIdChange.currentValue; this.projectScope = true; // Scope is project, not global list // Initially load the replication rule data this.retrieveRules(); } } } } /** * @param {?=} ruleName * @return {?} */ retrieveRules(ruleName = "") { this.loading = true; /*this.selectedRow = null;*/ toPromise(this.replicationService.getReplicationRules(this.projectId, ruleName)) .then(rules => { this.rules = rules || []; // job list hidden this.hideJobs.emit(); this.changedRules = this.rules; this.loading = false; }) .catch(error => { this.errorHandler.error(error); this.loading = false; }); } /** * @param {?} rule * @return {?} */ replicateRule(rule) { this.replicateManual.emit(rule); } /** * @param {?} rule * @return {?} */ hasDeletedLabel(rule) { if (rule.filters) { /** @type {?} */ let count = 0; rule.filters.forEach((data) => { if (data.kind === 'label' && data.value.deleted) { count++; } }); if (count === 0) { return 'enabled'; } else { return 'disabled'; } } return 'enabled'; } /** * @param {?} message * @return {?} */ deletionConfirm(message) { if (message && message.source === 4 /* POLICY */ && message.state === 1 /* CONFIRMED */) { this.deleteOpe(message.data); } } /** * @param {?} rule * @return {?} */ selectRule(rule) { this.selectedId = rule.id || ""; this.selectOne.emit(rule); } /** * @param {?} rule * @return {?} */ redirectTo(rule) { this.redirect.emit(rule); } /** * @return {?} */ openModal() { this.openNewRule.emit(); } /** * @param {?} rule * @return {?} */ editRule(rule) { this.editOne.emit(rule); } /** * @param {?} id * @return {?} */ jobList(id) { /** @type {?} */ let ruleData; this.canDeleteRule = true; /** @type {?} */ let count = 0; return toPromise(this.replicationService.getJobs(id)) .then(response => { ruleData = response.data; if (ruleData.length) { ruleData.forEach(job => { if (job.status === "pending" || job.status === "running" || job.status === "retrying") { count++; } }); } this.canDeleteRule = count > 0 ? false : true; }) .catch(error => this.errorHandler.error(error)); } /** * @param {?} rule * @return {?} */ deleteRule(rule) { if (rule) { /** @type {?} */ let deletionMessage = new ConfirmationMessage("REPLICATION.DELETION_TITLE", "REPLICATION.DELETION_SUMMARY", rule.name, rule, 4 /* POLICY */, 2 /* DELETE_CANCEL */); this.deletionConfirmDialog.open(deletionMessage); } } /** * @param {?} rule * @return {?} */ deleteOpe(rule) { if (rule) { /** @type {?} */ let promiseLists = []; Promise.all([this.jobList(rule.id)]).then(items => { promiseLists.push(this.delOperate(rule)); Promise.all(promiseLists).then(item => { this.selectedRow = null; this.reload.emit(true); /** @type {?} */ let hnd = setInterval(() => this.ref.markForCheck(), 200); setTimeout(() => clearInterval(hnd), 2000); }); }); } } /** * @param {?} rule * @return {?} */ delOperate(rule) { /** @type {?} */ let operMessage = new OperateInfo(); operMessage.name = 'OPERATION.DELETE_REPLICATION'; operMessage.data["id"] = +rule.id; operMessage.state = OperationState.progressing; operMessage.data["name"] = rule.name; this.operationService.publishInfo(operMessage); if (!this.canDeleteRule) { forkJoin(this.translateService.get('BATCH.DELETED_FAILURE'), this.translateService.get('REPLICATION.DELETION_SUMMARY_FAILURE')).subscribe(res => { operateChanges(operMessage, OperationState.failure, res[1]); }); return null; } return toPromise(this.replicationService .deleteReplicationRule(+rule.id)) .then(() => { 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('REPLICATION.FAILED_TO_DELETE_POLICY_ENABLED')).subscribe(res => { operateChanges(operMessage, OperationState.failure, res[1]); }); } else { this.translateService.get('BATCH.DELETED_FAILURE').subscribe(res => { operateChanges(operMessage, OperationState.failure, res); }); } }); } } ListReplicationRuleComponent.decorators = [ { type: Component, args: [{ selector: "hbr-list-replication-rule", template: "<div style=\"padding-bottom: 15px;\">\n<clr-datagrid [clrDgLoading]=\"loading\" [(clrDgSingleSelected)]=\"selectedRow\" [clDgRowSelection]=\"true\">\n <clr-dg-action-bar>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" *ngIf=\"isSystemAdmin\" (click)=\"openModal()\"><clr-icon shape=\"plus\" size=\"16\"></clr-icon>&nbsp;{{'REPLICATION.NEW_REPLICATION_RULE' | translate}}</button>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" *ngIf=\"isSystemAdmin\" [disabled]=\"!selectedRow\" (click)=\"editRule(selectedRow)\"><clr-icon shape=\"pencil\" size=\"16\"></clr-icon>&nbsp;{{'REPLICATION.EDIT_POLICY' | translate}}</button>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" *ngIf=\"isSystemAdmin\" [disabled]=\"!selectedRow\" (click)=\"deleteRule(selectedRow)\"><clr-icon shape=\"times\" size=\"16\"></clr-icon>&nbsp;{{'REPLICATION.DELETE_POLICY' | translate}}</button>\n <button type=\"button\" class=\"btn btn-sm btn-secondary\" *ngIf=\"isSystemAdmin\" [disabled]=\"!selectedRow\" (click)=\"replicateRule(selectedRow)\"><clr-icon shape=\"export\" size=\"16\"></clr-icon>&nbsp;{{'REPLICATION.REPLICATE' | translate}}</button>\n </clr-dg-action-bar>\n <clr-dg-column [clrDgField]=\"'name'\">{{'REPLICATION.NAME' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'status'\">{{'REPLICATION.STATUS' | translate}}</clr-dg-column>\n <clr-dg-column *ngIf=\"!projectScope\">{{'REPLICATION.PROJECT' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'description'\">{{'REPLICATION.DESCRIPTION' | translate}}</clr-dg-column>\n <clr-dg-column >{{'REPLICATION.DESTINATION_NAME' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'trigger'\">{{'REPLICATION.TRIGGER_MODE' | translate}}</clr-dg-column>\n <clr-dg-placeholder>{{'REPLICATION.PLACEHOLDER' | translate }}</clr-dg-placeholder>\n <clr-dg-row *clrDgItems=\"let p of changedRules\" [clrDgItem]=\"p\" (click)=\"selectRule(p)\" [style.backgroundColor]=\"(projectScope && withReplicationJob && selectedId === p.id) ? '#eee' : ''\">\n <clr-dg-cell>{{p.name}}</clr-dg-cell>\n <clr-dg-cell>\n <div [ngSwitch]=\"hasDeletedLabel(p)\">\n <clr-tooltip *ngSwitchCase=\"'disabled'\" class=\"tooltip-lg\">\n <clr-icon clrTooltipTrigger shape=\"exclamation-triangle\" style=\"vertical-align: text-bottom;\" class=\"is-warning\" size=\"22\"></clr-icon>Disabled\n <clr-tooltip-content clrPosition=\"top-right\" clrSize=\"xs\" *clrIfOpen>\n <span>{{'REPLICATION.RULE_DISABLED' | translate}}</span>\n </clr-tooltip-content>\n </clr-tooltip>\n <div *ngSwitchCase=\"'enabled'\" ><clr-icon shape=\"success-standard\" style=\"vertical-align: text-bottom;\" class=\"is-success\" size=\"18\"></clr-icon> Enabled</div>\n </div>\n </clr-dg-cell>\n <clr-dg-cell *ngIf=\"!projectScope\">\n <a href=\"javascript:void(0)\" (click)=\"$event.stopPropagation(); redirectTo(p)\">{{p.projects?.length>0 ? p.projects[0].name : ''}}</a>\n </clr-dg-cell>\n <clr-dg-cell>\n {{p.description ? trancatedDescription(p.description) : '-'}}\n <clr-tooltip>\n <clr-icon *ngIf=\"p.description && p.description.length > 35\" clrTooltipTrigger shape=\"ellipsis-horizontal\" size=\"18\"></clr-icon>\n <clr-tooltip-content clrPosition=\"bottom-right\" clrSize=\"md\" *clrIfOpen>\n <span>{{p.description}}</span>\n </clr-tooltip-content>\n </clr-tooltip>\n </clr-dg-cell>\n <clr-dg-cell>{{p.targets?.length>0 ? p.targets[0].name : ''}}</clr-dg-cell>\n <clr-dg-cell>{{p.trigger ? p.trigger.kind : ''}}</clr-dg-cell>\n </clr-dg-row>\n <clr-dg-footer>\n <span *ngIf=\"pagination.totalItems\">{{pagination.firstItem + 1}} - {{pagination.lastItem +1 }} {{'REPLICATION.OF' | translate}} </span>{{pagination.totalItems }} {{'REPLICATION.ITEMS' | translate}}\n <clr-dg-pagination #pagination [clrDgPageSize]=\"5\"></clr-dg-pagination>\n </clr-dg-footer>\n</clr-datagrid>\n<confirmation-dialog #deletionConfirmDialog (confirmAction)=\"deletionConfirm($event)\"></confirmation-dialog>\n</div>\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: [""] }] } ]; /** @nocollapse */ ListReplicationRuleComponent.ctorParameters = () => [ { type: ReplicationService }, { type: TranslateService }, { type: ErrorHandler }, { type: OperationService }, { type: ChangeDetectorRef } ]; ListReplicationRuleComponent.propDecorators = { projectId: [{ type: Input }], isSystemAdmin: [{ type: Input }], selectedId: [{ type: Input }], withReplicationJob: [{ type: Input }], loading: [{ type: Input }], reload: [{ type: Output }], selectOne: [{ type: Output }], editOne: [{ type: Output }], toggleOne: [{ type: Output }], hideJobs: [{ type: Output }], redirect: [{ type: Output }], openNewRule: [{ type: Output }], replicateManual: [{ type: Output }], toggleConfirmDialog: [{ type: ViewChild, args: ["toggleConfirmDialog",] }], deletionConfirmDialog: [{ type: ViewChild, args: ["deletionConfirmDialog",] }] }; if (false) { /** @type {?} */ ListReplicationRuleComponent.prototype.nullTime; /** @type {?} */ ListReplicationRuleComponent.prototype.projectId; /** @type {?} */ ListReplicationRuleComponent.prototype.isSystemAdmin; /** @type {?} */ ListReplicationRuleComponent.prototype.selectedId; /** @type {?} */ ListReplicationRuleComponent.prototype.withReplicationJob; /** @type {?} */ ListReplicationRuleComponent.prototype.loading; /** @type {?} */ ListReplicationRuleComponent.prototype.reload; /** @type {?} */ ListReplicationRuleComponent.prototype.selectOne; /** @type {?} */ ListReplicationRuleComponent.prototype.editOne; /** @type {?} */ ListReplicationRuleComponent.prototype.toggleOne; /** @type {?} */ ListReplicationRuleComponent.prototype.hideJobs; /** @type {?} */ ListReplicationRuleComponent.prototype.redirect; /** @type {?} */ ListReplicationRuleComponent.prototype.openNewRule; /** @type {?} */ ListReplicationRuleComponent.prototype.replicateManual; /** @type {?} */ ListReplicationRuleComponent.prototype.projectScope; /** @type {?} */ ListReplicationRuleComponent.prototype.rules; /** @type {?} */ ListReplicationRuleComponent.prototype.changedRules; /** @type {?} */ ListReplicationRuleComponent.prototype.ruleName; /** @type {?} */ ListReplicationRuleComponent.prototype.canDeleteRule; /** @type {?} */ ListReplicationRuleComponent.prototype.selectedRow; /** @type {?} */ ListReplicationRuleComponent.prototype.toggleConfirmDialog; /** @type {?} */ ListReplicationRuleComponent.prototype.deletionConfirmDialog; /** @type {?} */ ListReplicationRuleComponent.prototype.startTimeComparator; /** @type {?} */ ListReplicationRuleComponent.prototype.enabledComparator; /** @type {?} */ ListReplicationRuleComponent.prototype.replicationService; /** @type {?} */ ListReplicationRuleComponent.prototype.translateService; /** @type {?} */ ListReplicationRuleComponent.prototype.errorHandler; /** @type {?} */ ListReplicationRuleComponent.prototype.operationService; /** @type {?} */ ListReplicationRuleComponent.prototype.ref; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-replication-rule.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/list-replication-rule/list-replication-rule.component.ts"],"names":[],"mappings":";;;;AAaA,OAAO,EACH,SAAS,EACT,KAAK,EACL,MAAM,EAEN,YAAY,EACZ,SAAS,EACT,uBAAuB,EACvB,iBAAiB,EAIpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAC,MAAM,MAAM,CAAC;AAE/B,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,OAAO,EAAC,kBAAkB,EAAC,MAAM,gCAAgC,CAAC;AAMlE,OAAO,EAAC,2BAA2B,EAAC,MAAM,sDAAsD,CAAC;AACjG,OAAO,EAAC,mBAAmB,EAAC,MAAM,6CAA6C,CAAC;AAOhF,OAAO,EAAC,YAAY,EAAC,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EAAC,SAAS,EAAE,gBAAgB,EAAC,MAAM,UAAU,CAAC;AACrD,OAAO,EAAC,cAAc,EAAE,WAAW,EAAE,cAAc,EAAC,MAAM,sBAAsB,CAAC;AACjF,OAAO,EAAC,gBAAgB,EAAC,MAAM,gCAAgC,CAAC;AAShE,MAAM;;;;;;;;IAqCF,YAAoB,kBAAsC,EACtC,kBACA,cACA,kBACA;QAJA,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,qBAAgB,GAAhB,gBAAgB;QAChB,iBAAY,GAAZ,YAAY;QACZ,qBAAgB,GAAhB,gBAAgB;QAChB,QAAG,GAAH,GAAG;wBAxCZ,sBAAsB;uBAOd,KAAK;sBAEL,IAAI,YAAY,EAAW;yBACxB,IAAI,YAAY,EAAmB;uBACrC,IAAI,YAAY,EAAmB;yBACjC,IAAI,YAAY,EAAmB;wBACpC,IAAI,YAAY,EAAO;wBACvB,IAAI,YAAY,EAAmB;2BAChC,IAAI,YAAY,EAAO;+BACnB,IAAI,YAAY,EAAmB;4BAEhD,KAAK;mCAe+B,IAAI,gBAAgB,CAAkB,YAAY,EAAE,MAAM,CAAC;iCAC7D,IAAI,gBAAgB,CAAkB,SAAS,EAAE,QAAQ,CAAC;QAOvG,WAAW,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,YAAY,EAAE,EAAE,GAAG,CAAC,CAAC;KAC9C;;;;;IAED,oBAAoB,CAAC,IAAY;QAC7B,IAAI,IAAI,CAAC,MAAM,GAAG,EAAE,EAAE;YAClB,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;SAC7B;aAAM;YACH,OAAO,IAAI,CAAC;SACf;KACJ;;;;IAED,QAAQ;;QAEJ,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;KACJ;;;;;IAED,WAAW,CAAC,OAAsB;;QAC9B,IAAI,WAAW,GAAiB,OAAO,CAAC,WAAW,CAAC,CAAC;QACrD,IAAI,WAAW,EAAE;YACb,IAAI,WAAW,CAAC,YAAY,KAAK,WAAW,CAAC,aAAa,EAAE;gBACxD,IAAI,WAAW,CAAC,YAAY,EAAE;oBAC1B,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,YAAY,CAAC;oBAC1C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;;oBAEzB,IAAI,CAAC,aAAa,EAAE,CAAC;iBACxB;aACJ;SACJ;KACJ;;;;;IAED,aAAa,CAAC,QAAQ,GAAG,EAAE;QACvB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;;QAEpB,SAAS,CACL,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CACxE;aACI,IAAI,CAAC,KAAK,CAAC,EAAE;YACV,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;;YAEzB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;YACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;YAC/B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACxB,CAAC;aACD,KAAK,CAAC,KAAK,CAAC,EAAE;YACX,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YAC/B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACxB,CAAC,CAAC;KACV;;;;;IAED,aAAa,CAAC,IAAqB;QAC/B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACnC;;;;;IAED,eAAe,CAAC,IAAS;QACrB,IAAI,IAAI,CAAC,OAAO,EAAE;;YACd,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;gBAC/B,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;oBAC7C,KAAK,EAAG,CAAC;iBACZ;aACJ,CAAC,CAAC;YACH,IAAI,KAAK,KAAK,CAAC,EAAE;gBACb,OAAO,SAAS,CAAC;aACpB;iBAAM;gBAAE,OAAO,UAAU,CAAC;aAAE;SAChC;QACD,OAAO,SAAS,CAAC;KACpB;;;;;IAED,eAAe,CAAC,OAAoC;QAChD,IACI,OAAO;YACP,OAAO,CAAC,MAAM,mBAA+B;YAC7C,OAAO,CAAC,KAAK,sBAAgC,EAC/C;YACE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAChC;KACJ;;;;;IAED,UAAU,CAAC,IAAqB;QAC5B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KAC7B;;;;;IAED,UAAU,CAAC,IAAqB;QAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KAC5B;;;;IAED,SAAS;QACL,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;KAC3B;;;;;IAED,QAAQ,CAAC,IAAqB;QAC1B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KAC3B;;;;;IAED,OAAO,CAAC,EAAmB;;QACvB,IAAI,QAAQ,CAAuB;QACnC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;;QAC1B,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,OAAO,SAAS,CAAiB,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;aAChE,IAAI,CAAC,QAAQ,CAAC,EAAE;YACb,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC;YACzB,IAAI,QAAQ,CAAC,MAAM,EAAE;gBACjB,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;oBACnB,IACI,GAAG,CAAC,MAAM,KAAK,SAAS;wBACxB,GAAG,CAAC,MAAM,KAAK,SAAS;wBACxB,GAAG,CAAC,MAAM,KAAK,UAAU,EAC3B;wBACE,KAAK,EAAE,CAAC;qBACX;iBACJ,CAAC,CAAC;aACN;YACD,IAAI,CAAC,aAAa,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;SACjD,CAAC;aACD,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;KACvD;;;;;IAED,UAAU,CAAC,IAAqB;QAC5B,IAAI,IAAI,EAAE;;YACN,IAAI,eAAe,GAAG,IAAI,mBAAmB,CACzC,4BAA4B,EAC5B,8BAA8B,EAC9B,IAAI,CAAC,IAAI,EACT,IAAI,wCAGP,CAAC;YACF,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SACpD;KACJ;;;;;IAED,SAAS,CAAC,IAAqB;QAC3B,IAAI,IAAI,EAAE;;YACN,IAAI,YAAY,GAAU,EAAE,CAAC;YAC7B,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBAC9C,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;gBAEzC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;oBAClC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;oBACxB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;oBACvB,IAAI,GAAG,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,EAAE,GAAG,CAAC,CAAC;oBAC1D,UAAU,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;iBAC9C,CAAC,CAAC;aACN,CAAC,CAAC;SACN;KACJ;;;;;IAED,UAAU,CAAC,IAAqB;;QAE5B,IAAI,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;QACpC,WAAW,CAAC,IAAI,GAAG,8BAA8B,CAAC;QAClD,WAAW,CAAC,IAAI,SAAM,CAAC,IAAI,CAAC,EAAE,CAAC;QAC/B,WAAW,CAAC,KAAK,GAAG,cAAc,CAAC,WAAW,CAAC;QAC/C,WAAW,CAAC,IAAI,WAAQ,IAAI,CAAC,IAAI,CAAC;QAClC,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAE/C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,uBAAuB,CAAC,EACvD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,sCAAsC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACnF,cAAc,CAAC,WAAW,EAAE,cAAc,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;aAC/D,CAAC,CAAC;YACH,OAAO,IAAI,CAAC;SACf;QAED,OAAO,SAAS,CAAM,IAAI,CAAC,kBAAkB;aACxC,qBAAqB,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;aAChC,IAAI,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,uBAAuB,CAAC;iBAC7C,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,cAAc,CAAC,WAAW,EAAE,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;SAC9E,CAAC;aACD,KAAK,CAAC,KAAK,CAAC,EAAE;YACX,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,GAAG,EAAE;gBAC/B,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,uBAAuB,CAAC,EACvD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,6CAA6C,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAC1F,cAAc,CAAC,WAAW,EAAE,cAAc,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC/D,CAAC,CAAC;aACN;iBAAM;gBACH,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,uBAAuB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAC/D,cAAc,CAAC,WAAW,EAAE,cAAc,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;iBAC5D,CAAC,CAAC;aACN;SACJ,CAAC,CAAC;KACV;;;YAzOJ,SAAS,SAAC;gBACP,QAAQ,EAAE,2BAA2B;gBACrC,qwIAAqD;gBAErD,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAClD;;;;YAzBO,kBAAkB;YAFjB,gBAAgB;YAgBjB,YAAY;YAGZ,gBAAgB;YA1BpB,iBAAiB;;;wBAsChB,KAAK;4BACL,KAAK;yBACL,KAAK;iCACL,KAAK;sBAEL,KAAK;qBAEL,MAAM;wBACN,MAAM;sBACN,MAAM;wBACN,MAAM;uBACN,MAAM;uBACN,MAAM;0BACN,MAAM;8BACN,MAAM;kCAWN,SAAS,SAAC,qBAAqB;oCAG/B,SAAS,SAAC,uBAAuB","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    Input,\n    Output,\n    OnInit,\n    EventEmitter,\n    ViewChild,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    OnChanges,\n    SimpleChange,\n    SimpleChanges\n} from \"@angular/core\";\nimport { forkJoin} from \"rxjs\";\nimport { Comparator } from \"@clr/angular\";\nimport { TranslateService } from \"@ngx-translate/core\";\n\nimport {ReplicationService} from \"../service/replication.service\";\nimport {\n    ReplicationJob,\n    ReplicationJobItem,\n    ReplicationRule\n} from \"../service/interface\";\nimport {ConfirmationDialogComponent} from \"../confirmation-dialog/confirmation-dialog.component\";\nimport {ConfirmationMessage} from \"../confirmation-dialog/confirmation-message\";\nimport {ConfirmationAcknowledgement} from \"../confirmation-dialog/confirmation-state-message\";\nimport {\n    ConfirmationState,\n    ConfirmationTargets,\n    ConfirmationButtons\n} from \"../shared/shared.const\";\nimport {ErrorHandler} from \"../error-handler/error-handler\";\nimport {toPromise, CustomComparator} from \"../utils\";\nimport {operateChanges, OperateInfo, OperationState} from \"../operation/operate\";\nimport {OperationService} from \"../operation/operation.service\";\n\n\n@Component({\n    selector: \"hbr-list-replication-rule\",\n    templateUrl: \"./list-replication-rule.component.html\",\n    styleUrls: [\"./list-replication-rule.component.scss\"],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ListReplicationRuleComponent implements OnInit, OnChanges {\n    nullTime = \"0001-01-01T00:00:00Z\";\n\n    @Input() projectId: number;\n    @Input() isSystemAdmin: boolean;\n    @Input() selectedId: number | string;\n    @Input() withReplicationJob: boolean;\n\n    @Input() loading = false;\n\n    @Output() reload = new EventEmitter<boolean>();\n    @Output() selectOne = new EventEmitter<ReplicationRule>();\n    @Output() editOne = new EventEmitter<ReplicationRule>();\n    @Output() toggleOne = new EventEmitter<ReplicationRule>();\n    @Output() hideJobs = new EventEmitter<any>();\n    @Output() redirect = new EventEmitter<ReplicationRule>();\n    @Output() openNewRule = new EventEmitter<any>();\n    @Output() replicateManual = new EventEmitter<ReplicationRule>();\n\n    projectScope = false;\n\n    rules: ReplicationRule[];\n    changedRules: ReplicationRule[];\n    ruleName: string;\n    canDeleteRule: boolean;\n\n    selectedRow: ReplicationRule;\n\n    @ViewChild(\"toggleConfirmDialog\")\n    toggleConfirmDialog: ConfirmationDialogComponent;\n\n    @ViewChild(\"deletionConfirmDialog\")\n    deletionConfirmDialog: ConfirmationDialogComponent;\n\n    startTimeComparator: Comparator<ReplicationRule> = new CustomComparator<ReplicationRule>(\"start_time\", \"date\");\n    enabledComparator: Comparator<ReplicationRule> = new CustomComparator<ReplicationRule>(\"enabled\", \"number\");\n\n    constructor(private replicationService: ReplicationService,\n                private translateService: TranslateService,\n                private errorHandler: ErrorHandler,\n                private operationService: OperationService,\n                private ref: ChangeDetectorRef) {\n        setInterval(() => ref.markForCheck(), 500);\n    }\n\n    trancatedDescription(desc: string): string {\n        if (desc.length > 35) {\n            return desc.substr(0, 35);\n        } else {\n            return desc;\n        }\n    }\n\n    ngOnInit(): void {\n        // Global scope\n        if (!this.projectScope) {\n            this.retrieveRules();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        let proIdChange: SimpleChange = changes[\"projectId\"];\n        if (proIdChange) {\n            if (proIdChange.currentValue !== proIdChange.previousValue) {\n                if (proIdChange.currentValue) {\n                    this.projectId = proIdChange.currentValue;\n                    this.projectScope = true; // Scope is project, not global list\n                    // Initially load the replication rule data\n                    this.retrieveRules();\n                }\n            }\n        }\n    }\n\n    retrieveRules(ruleName = \"\"): void {\n        this.loading = true;\n        /*this.selectedRow = null;*/\n        toPromise<ReplicationRule[]>(\n            this.replicationService.getReplicationRules(this.projectId, ruleName)\n        )\n            .then(rules => {\n                this.rules = rules || [];\n                // job list hidden\n                this.hideJobs.emit();\n                this.changedRules = this.rules;\n                this.loading = false;\n            })\n            .catch(error => {\n                this.errorHandler.error(error);\n                this.loading = false;\n            });\n    }\n\n    replicateRule(rule: ReplicationRule): void {\n        this.replicateManual.emit(rule);\n    }\n\n    hasDeletedLabel(rule: any) {\n        if (rule.filters) {\n            let count = 0;\n            rule.filters.forEach((data: any) => {\n                if (data.kind === 'label' && data.value.deleted) {\n                    count ++;\n                }\n            });\n            if (count === 0) {\n                return 'enabled';\n            } else { return 'disabled'; }\n        }\n        return 'enabled';\n    }\n\n    deletionConfirm(message: ConfirmationAcknowledgement) {\n        if (\n            message &&\n            message.source === ConfirmationTargets.POLICY &&\n            message.state === ConfirmationState.CONFIRMED\n        ) {\n            this.deleteOpe(message.data);\n        }\n    }\n\n    selectRule(rule: ReplicationRule): void {\n        this.selectedId = rule.id || \"\";\n        this.selectOne.emit(rule);\n    }\n\n    redirectTo(rule: ReplicationRule): void {\n        this.redirect.emit(rule);\n    }\n\n    openModal(): void {\n        this.openNewRule.emit();\n    }\n\n    editRule(rule: ReplicationRule) {\n        this.editOne.emit(rule);\n    }\n\n    jobList(id: string | number): Promise<void> {\n        let ruleData: ReplicationJobItem[];\n        this.canDeleteRule = true;\n        let count = 0;\n        return toPromise<ReplicationJob>(this.replicationService.getJobs(id))\n            .then(response => {\n                ruleData = response.data;\n                if (ruleData.length) {\n                    ruleData.forEach(job => {\n                        if (\n                            job.status === \"pending\" ||\n                            job.status === \"running\" ||\n                            job.status === \"retrying\"\n                        ) {\n                            count++;\n                        }\n                    });\n                }\n                this.canDeleteRule = count > 0 ? false : true;\n            })\n            .catch(error => this.errorHandler.error(error));\n    }\n\n    deleteRule(rule: ReplicationRule) {\n        if (rule) {\n            let deletionMessage = new ConfirmationMessage(\n                \"REPLICATION.DELETION_TITLE\",\n                \"REPLICATION.DELETION_SUMMARY\",\n                rule.name,\n                rule,\n                ConfirmationTargets.POLICY,\n                ConfirmationButtons.DELETE_CANCEL\n            );\n            this.deletionConfirmDialog.open(deletionMessage);\n        }\n    }\n\n    deleteOpe(rule: ReplicationRule) {\n        if (rule) {\n            let promiseLists: any[] = [];\n            Promise.all([this.jobList(rule.id)]).then(items => {\n                promiseLists.push(this.delOperate(rule));\n\n                Promise.all(promiseLists).then(item => {\n                    this.selectedRow = null;\n                    this.reload.emit(true);\n                    let hnd = setInterval(() => this.ref.markForCheck(), 200);\n                    setTimeout(() => clearInterval(hnd), 2000);\n                });\n            });\n        }\n    }\n\n    delOperate(rule: ReplicationRule) {\n        // init operation info\n        let operMessage = new OperateInfo();\n        operMessage.name = 'OPERATION.DELETE_REPLICATION';\n        operMessage.data.id = +rule.id;\n        operMessage.state = OperationState.progressing;\n        operMessage.data.name = rule.name;\n        this.operationService.publishInfo(operMessage);\n\n        if (!this.canDeleteRule) {\n            forkJoin(this.translateService.get('BATCH.DELETED_FAILURE'),\n                this.translateService.get('REPLICATION.DELETION_SUMMARY_FAILURE')).subscribe(res => {\n                operateChanges(operMessage, OperationState.failure, res[1]);\n            });\n            return null;\n        }\n\n        return toPromise<any>(this.replicationService\n            .deleteReplicationRule(+rule.id))\n            .then(() => {\n                this.translateService.get('BATCH.DELETED_SUCCESS')\n                    .subscribe(res => operateChanges(operMessage, OperationState.success));\n            })\n            .catch(error => {\n                if (error && error.status === 412) {\n                    forkJoin(this.translateService.get('BATCH.DELETED_FAILURE'),\n                        this.translateService.get('REPLICATION.FAILED_TO_DELETE_POLICY_ENABLED')).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"]}