UNPKG

@harbor/ui

Version:

Harbor shared UI components based on Clarity and Angular6

234 lines (233 loc) 22 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, ViewChild, Input } from '@angular/core'; import { TranslateService } from '@ngx-translate/core'; import { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component'; import { ConfirmationMessage } from '../confirmation-dialog/confirmation-message'; import { ConfigurationService, SystemInfoService } from '../service/index'; import { toPromise, compareValue, isEmptyObject, clone } from '../utils'; import { ErrorHandler } from '../error-handler/index'; import { SystemSettingsComponent, VulnerabilityConfigComponent, GcComponent } from './index'; import { Configuration } from './config'; export class RegistryConfigComponent { /** * @param {?} configService * @param {?} errorHandler * @param {?} translate * @param {?} systemInfoService */ constructor(configService, errorHandler, translate, systemInfoService) { this.configService = configService; this.errorHandler = errorHandler; this.translate = translate; this.systemInfoService = systemInfoService; this.config = new Configuration(); this.onGoing = false; this.hasAdminRole = false; } /** * @return {?} */ get shouldDisable() { return !this.isValid() || !this.hasChanges() || this.onGoing; } /** * @return {?} */ get hasCAFile() { return this.systemInfo && this.systemInfo.has_ca_root; } /** * @return {?} */ get withClair() { return this.systemInfo && this.systemInfo.with_clair; } /** * @return {?} */ get withAdmiral() { return this.systemInfo && this.systemInfo.with_admiral; } /** * @return {?} */ ngOnInit() { this.loadSystemInfo(); // Initialize this.load(); } /** * @return {?} */ isValid() { return this.systemSettings && this.systemSettings.isValid && this.vulnerabilityCfg && this.vulnerabilityCfg.isValid; } /** * @return {?} */ hasChanges() { return !isEmptyObject(this.getChanges()); } /** * @return {?} */ loadSystemInfo() { toPromise(this.systemInfoService.getSystemInfo()) .then((info) => this.systemInfo = info) .catch(error => this.errorHandler.error(error)); } /** * @return {?} */ load() { this.onGoing = true; toPromise(this.configService.getConfigurations()) .then((config) => { this.configCopy = clone(config); this.config = config; this.onGoing = false; }) .catch(error => { this.errorHandler.error(error); this.onGoing = false; }); } /** * @return {?} */ save() { /** @type {?} */ let changes = this.getChanges(); if (isEmptyObject(changes)) { // Guard code, do nothing return; } this.onGoing = true; toPromise(this.configService.saveConfigurations(changes)) .then(() => { this.onGoing = false; this.translate.get("CONFIG.SAVE_SUCCESS").subscribe((res) => { this.errorHandler.info(res); }); // Reload to fetch all the updates this.load(); // Reload all system info // this.loadSystemInfo(); }) .catch(error => { this.onGoing = false; this.errorHandler.error(error); }); } /** * @return {?} */ cancel() { /** @type {?} */ let msg = new ConfirmationMessage("CONFIG.CONFIRM_TITLE", "CONFIG.CONFIRM_SUMMARY", "", {}, 9 /* CONFIG */); this.confirmationDlg.open(msg); } /** * @param {?} ack * @return {?} */ confirmCancel(ack) { if (ack && ack.source === 9 /* CONFIG */ && ack.state === 1 /* CONFIRMED */) { this.reset(); } } /** * @return {?} */ reset() { /** @type {?} */ let changes = this.getChanges(); for (let prop of Object.keys(changes)) { this.config[prop] = clone(this.configCopy[prop]); } } /** * @return {?} */ getChanges() { /** @type {?} */ let changes = {}; if (!this.config || !this.configCopy) { return changes; } for (let prop of Object.keys(this.config)) { /** @type {?} */ let field = this.configCopy[prop]; if (field && field.editable) { if (!compareValue(field.value, this.config[prop].value)) { changes[prop] = this.config[prop].value; // Number if (typeof field.value === "number") { changes[prop] = +changes[prop]; } // Trim string value if (typeof field.value === "string") { changes[prop] = ('' + changes[prop]).trim(); } } } } return changes; } } RegistryConfigComponent.decorators = [ { type: Component, args: [{ selector: 'hbr-registry-config', template: "<clr-tabs>\n <clr-tab>\n <button id=\"config-system\" clrTabLink>{{'CONFIG.SYSTEM' | translate}}</button>\n <clr-tab-content id=\"system_settings\" *clrIfActive>\n <system-settings #systemSettings [(systemSettings)]=\"config\" [showSubTitle]=\"true\" [hasAdminRole]=\"hasAdminRole\" [hasCAFile]=\"hasCAFile\"\n [withAdmiral]=\"withAdmiral\">\n </system-settings>\n </clr-tab-content>\n </clr-tab>\n <clr-tab>\n <button id=\"config-vulnerability\" clrTabLink>{{'CONFIG.VULNERABILITY' | translate}}</button>\n <clr-tab-content id=\"vulnerability\" *clrIfActive>\n <vulnerability-config *ngIf=\"withClair\" #vulnerabilityConfig [(vulnerabilityConfig)]=\"config\" [showSubTitle]=\"true\"></vulnerability-config>\n </clr-tab-content>\n </clr-tab>\n <clr-tab>\n <button id=\"config-gc\" clrTabLink>{{'CONFIG.GC' | translate}}</button>\n <clr-tab-content id=\"gc\" *clrIfActive>\n <gc-config #gcConfig></gc-config>\n </clr-tab-content>\n </clr-tab>\n</clr-tabs>\n<confirmation-dialog #cfgConfirmationDialog (confirmAction)=\"confirmCancel($event)\"></confirmation-dialog>" }] } ]; /** @nocollapse */ RegistryConfigComponent.ctorParameters = () => [ { type: ConfigurationService }, { type: ErrorHandler }, { type: TranslateService }, { type: SystemInfoService } ]; RegistryConfigComponent.propDecorators = { hasAdminRole: [{ type: Input }], systemSettings: [{ type: ViewChild, args: ["systemSettings",] }], vulnerabilityCfg: [{ type: ViewChild, args: ["vulnerabilityConfig",] }], gc: [{ type: ViewChild, args: ["gc",] }], confirmationDlg: [{ type: ViewChild, args: ["cfgConfirmationDialog",] }] }; if (false) { /** @type {?} */ RegistryConfigComponent.prototype.config; /** @type {?} */ RegistryConfigComponent.prototype.configCopy; /** @type {?} */ RegistryConfigComponent.prototype.onGoing; /** @type {?} */ RegistryConfigComponent.prototype.systemInfo; /** @type {?} */ RegistryConfigComponent.prototype.hasAdminRole; /** @type {?} */ RegistryConfigComponent.prototype.systemSettings; /** @type {?} */ RegistryConfigComponent.prototype.vulnerabilityCfg; /** @type {?} */ RegistryConfigComponent.prototype.gc; /** @type {?} */ RegistryConfigComponent.prototype.confirmationDlg; /** @type {?} */ RegistryConfigComponent.prototype.configService; /** @type {?} */ RegistryConfigComponent.prototype.errorHandler; /** @type {?} */ RegistryConfigComponent.prototype.translate; /** @type {?} */ RegistryConfigComponent.prototype.systemInfoService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"registry-config.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/config/registry-config.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\n\nimport { ConfirmationState, ConfirmationTargets } from '../shared/shared.const';\nimport { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component';\nimport { ConfirmationMessage } from '../confirmation-dialog/confirmation-message';\nimport { ConfirmationAcknowledgement } from '../confirmation-dialog/confirmation-state-message';\nimport { ConfigurationService, SystemInfoService, SystemInfo } from '../service/index';\nimport {\n    toPromise,\n    compareValue,\n    isEmptyObject,\n    clone\n} from '../utils';\nimport { ErrorHandler } from '../error-handler/index';\nimport { SystemSettingsComponent, VulnerabilityConfigComponent, GcComponent} from './index';\nimport { Configuration } from './config';\n\n@Component({\n    selector: 'hbr-registry-config',\n    templateUrl: './registry-config.component.html'\n})\nexport class RegistryConfigComponent implements OnInit {\n    config: Configuration = new Configuration();\n    configCopy: Configuration;\n    onGoing: boolean = false;\n    systemInfo: SystemInfo;\n\n    @Input() hasAdminRole: boolean = false;\n\n    @ViewChild(\"systemSettings\") systemSettings: SystemSettingsComponent;\n    @ViewChild(\"vulnerabilityConfig\") vulnerabilityCfg: VulnerabilityConfigComponent;\n    @ViewChild(\"gc\") gc: GcComponent;\n    @ViewChild(\"cfgConfirmationDialog\") confirmationDlg: ConfirmationDialogComponent;\n\n    constructor(\n        private configService: ConfigurationService,\n        private errorHandler: ErrorHandler,\n        private translate: TranslateService,\n        private systemInfoService: SystemInfoService\n    ) { }\n\n    get shouldDisable(): boolean {\n        return !this.isValid() || !this.hasChanges() || this.onGoing;\n    }\n\n    get hasCAFile(): boolean {\n        return this.systemInfo && this.systemInfo.has_ca_root;\n    }\n\n    get withClair(): boolean {\n        return this.systemInfo && this.systemInfo.with_clair;\n    }\n\n    get withAdmiral(): boolean {\n        return this.systemInfo && this.systemInfo.with_admiral;\n    }\n\n    ngOnInit(): void {\n        this.loadSystemInfo();\n        // Initialize\n        this.load();\n    }\n\n    isValid(): boolean {\n        return this.systemSettings &&\n            this.systemSettings.isValid &&\n            this.vulnerabilityCfg &&\n            this.vulnerabilityCfg.isValid;\n    }\n\n    hasChanges(): boolean {\n        return !isEmptyObject(this.getChanges());\n    }\n\n    // Get system info\n    loadSystemInfo(): void {\n        toPromise<SystemInfo>(this.systemInfoService.getSystemInfo())\n            .then((info: SystemInfo) => this.systemInfo = info)\n            .catch(error => this.errorHandler.error(error));\n    }\n\n    // Load configurations\n    load(): void {\n        this.onGoing = true;\n        toPromise<Configuration>(this.configService.getConfigurations())\n            .then((config: Configuration) => {\n                this.configCopy = clone(config);\n                this.config = config;\n                this.onGoing = false;\n            })\n            .catch(error => {\n                this.errorHandler.error(error);\n                this.onGoing = false;\n            });\n    }\n\n    // Save configuration changes\n    save(): void {\n        let changes: { [key: string]: any | any[] } = this.getChanges();\n\n        if (isEmptyObject(changes)) {\n            // Guard code, do nothing\n            return;\n        }\n\n        this.onGoing = true;\n        toPromise<any>(this.configService.saveConfigurations(changes))\n            .then(() => {\n                this.onGoing = false;\n\n                this.translate.get(\"CONFIG.SAVE_SUCCESS\").subscribe((res: string) => {\n                    this.errorHandler.info(res);\n                });\n                // Reload to fetch all the updates\n                this.load();\n                // Reload all system info\n                // this.loadSystemInfo();\n            })\n            .catch(error => {\n                this.onGoing = false;\n                this.errorHandler.error(error);\n            });\n    }\n\n    // Cancel the changes if have\n    cancel(): void {\n        let msg = new ConfirmationMessage(\n            \"CONFIG.CONFIRM_TITLE\",\n            \"CONFIG.CONFIRM_SUMMARY\",\n            \"\",\n            {},\n            ConfirmationTargets.CONFIG\n        );\n        this.confirmationDlg.open(msg);\n    }\n\n    // Confirm cancel\n    confirmCancel(ack: ConfirmationAcknowledgement): void {\n        if (ack && ack.source === ConfirmationTargets.CONFIG &&\n            ack.state === ConfirmationState.CONFIRMED) {\n            this.reset();\n        }\n    }\n\n    reset(): void {\n        // Reset to the values of copy\n        let changes: { [key: string]: any | any[] } = this.getChanges();\n        for (let prop of Object.keys(changes)) {\n            this.config[prop] = clone(this.configCopy[prop]);\n        }\n    }\n\n    getChanges(): { [key: string]: any | any[] } {\n        let changes: { [key: string]: any | any[] } = {};\n        if (!this.config || !this.configCopy) {\n            return changes;\n        }\n\n        for (let prop of Object.keys(this.config)) {\n            let field = this.configCopy[prop];\n            if (field && field.editable) {\n                if (!compareValue(field.value, this.config[prop].value)) {\n                    changes[prop] = this.config[prop].value;\n                    // Number\n                    if (typeof field.value === \"number\") {\n                        changes[prop] = +changes[prop];\n                    }\n\n                    // Trim string value\n                    if (typeof field.value === \"string\") {\n                        changes[prop] = ('' + changes[prop]).trim();\n                    }\n                }\n            }\n        }\n\n        return changes;\n    }\n}\n"]}