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