@harbor/ui
Version:
Harbor shared UI components based on Clarity and Angular6
299 lines (298 loc) • 29.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ViewChild, Inject } from '@angular/core';
import { NgForm } from '@angular/forms';
import { Configuration, StringValueItem } from '../config';
import { SERVICE_CONFIG } from '../../service.config';
import { clone, isEmpty, getChanges, toPromise } from '../../utils';
import { ErrorHandler } from '../../error-handler/index';
import { ConfirmationMessage } from '../../confirmation-dialog/confirmation-message';
import { ConfirmationDialogComponent } from '../../confirmation-dialog/confirmation-dialog.component';
import { ConfigurationService } from '../../service/index';
import { from } from 'rxjs';
/** @type {?} */
const fakePass = 'aWpLOSYkIzJTTU4wMDkx';
export class SystemSettingsComponent {
/**
* @param {?} configInfo
* @param {?} configService
* @param {?} errorHandler
*/
constructor(configInfo, configService, errorHandler) {
this.configInfo = configInfo;
this.configService = configService;
this.errorHandler = errorHandler;
this.config = new Configuration();
this.onGoing = false;
this.configChange = new EventEmitter();
this.readOnlyChange = new EventEmitter();
this.reloadSystemConfig = new EventEmitter();
this.showSubTitle = false;
this.hasAdminRole = false;
this.hasCAFile = false;
this.withAdmiral = false;
if (this.configInfo && this.configInfo.systemInfoEndpoint) {
this.downloadLink = this.configInfo.systemInfoEndpoint + "/getcert";
}
}
/**
* @return {?}
*/
get systemSettings() {
return this.config;
}
/**
* @param {?} cfg
* @return {?}
*/
set systemSettings(cfg) {
this.config = cfg;
this.configChange.emit(this.config);
}
/**
* @return {?}
*/
get editable() {
return this.systemSettings &&
this.systemSettings.token_expiration &&
this.systemSettings.token_expiration.editable;
}
/**
* @return {?}
*/
isValid() {
return this.systemSettingsForm && this.systemSettingsForm.valid;
}
/**
* @return {?}
*/
hasChanges() {
return !isEmpty(this.getChanges());
}
/**
* @return {?}
*/
getChanges() {
/** @type {?} */
let allChanges = getChanges(this.originalConfig, this.config);
if (allChanges) {
return this.getSystemChanges(allChanges);
}
return null;
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes && changes["systemSettings"]) {
this.originalConfig = clone(this.config);
}
}
/**
* @param {?} allChanges
* @return {?}
*/
getSystemChanges(allChanges) {
/** @type {?} */
let changes = {};
for (let prop in allChanges) {
if (prop === 'token_expiration' || prop === 'read_only' || prop === 'project_creation_restriction') {
changes[prop] = allChanges[prop];
}
}
return changes;
}
/**
* @param {?} $event
* @return {?}
*/
setRepoReadOnlyValue($event) {
this.systemSettings.read_only.value = $event;
}
/**
* @param {?} prop
* @return {?}
*/
disabled(prop) {
return !(prop && prop.editable);
}
/**
* @return {?}
*/
get canDownloadCert() {
return this.hasAdminRole && this.hasCAFile;
}
/**
*
* Save the changed values
*
* \@memberOf ConfigurationComponent
* @return {?}
*/
save() {
/** @type {?} */
let changes = this.getChanges();
if (!isEmpty(changes)) {
this.onGoing = true;
this.configService.saveConfigurations(changes)
.then(response => {
this.onGoing = false;
// API should return the updated configurations here
// Unfortunately API does not do that
// To refresh the view, we can clone the original data copy
// or force refresh by calling service.
// HERE we choose force way
this.retrieveConfig();
if ('read_only' in changes) {
this.readOnlyChange.emit(changes['read_only']);
}
this.reloadSystemConfig.emit();
this.errorHandler.info('CONFIG.SAVE_SUCCESS');
})
.catch(error => {
this.onGoing = false;
this.errorHandler.error(error);
});
}
else {
// Inprop situation, should not come here
console.error('Save abort because nothing changed');
}
}
/**
* @return {?}
*/
retrieveConfig() {
this.onGoing = true;
from(toPromise(this.configService.getConfigurations()))
.subscribe((configurations) => {
this.onGoing = false;
// Add two password fields
configurations.email_password = new StringValueItem(fakePass, true);
this.config = configurations;
// Keep the original copy of the data
this.originalConfig = clone(configurations);
}, error => {
this.onGoing = false;
this.errorHandler.error(error);
});
}
/**
* @param {?} changes
* @return {?}
*/
reset(changes) {
if (!isEmpty(changes)) {
for (let prop in changes) {
if (this.originalConfig[prop]) {
this.config[prop] = clone(this.originalConfig[prop]);
}
}
}
else {
// force reset
this.retrieveConfig();
}
}
/**
* @param {?} ack
* @return {?}
*/
confirmCancel(ack) {
if (ack && ack.source === 9 /* CONFIG */ &&
ack.state === 1 /* CONFIRMED */) {
/** @type {?} */
let changes = this.getChanges();
this.reset(changes);
}
}
/**
* @return {?}
*/
get inProgress() {
return this.onGoing;
}
/**
*
* Discard current changes if have and reset
*
* \@memberOf ConfigurationComponent
* @return {?}
*/
cancel() {
/** @type {?} */
let changes = this.getChanges();
if (!isEmpty(changes)) {
/** @type {?} */
let msg = new ConfirmationMessage('CONFIG.CONFIRM_TITLE', 'CONFIG.CONFIRM_SUMMARY', '', {}, 9 /* CONFIG */);
this.confirmationDlg.open(msg);
}
else {
// Invalid situation, should not come here
console.error('Nothing changed');
}
}
}
SystemSettingsComponent.decorators = [
{ type: Component, args: [{
selector: 'system-settings',
template: "<form #systemConfigFrom=\"ngForm\" class=\"compact\">\n <section class=\"form-block\" style=\"margin-top:0px;margin-bottom:0px;\">\n <label style=\"font-size:14px;font-weight:600;\" *ngIf=\"showSubTitle\">{{'CONFIG.SYSTEM' | translate}}</label>\n <div class=\"form-group\">\n <label for=\"proCreation\">{{'CONFIG.PRO_CREATION_RESTRICTION' | translate}}</label>\n <div class=\"select\">\n <select id=\"proCreation\" name=\"proCreation\" [(ngModel)]=\"systemSettings.project_creation_restriction.value\" [disabled]=\"disabled(systemSettings.project_creation_restriction)\">\n <option value=\"everyone\">{{'CONFIG.PRO_CREATION_EVERYONE' | translate }}</option>\n <option value=\"adminonly\">{{'CONFIG.PRO_CREATION_ADMIN' | translate }}</option>\n </select>\n </div>\n <a href=\"javascript:void(0)\" role=\"tooltip\" aria-haspopup=\"true\" class=\"tooltip tooltip-lg tooltip-top-right\" style=\"top: -1px;\">\n <clr-icon shape=\"info-circle\" class=\"info-tips-icon\" size=\"24\"></clr-icon>\n <span class=\"tooltip-content\">{{'CONFIG.TOOLTIP.PRO_CREATION_RESTRICTION' | translate}}</span>\n </a>\n </div>\n <div class=\"form-group\">\n <label for=\"tokenExpiration\" class=\"required\">{{'CONFIG.TOKEN_EXPIRATION' | translate}}</label>\n <label for=\"tokenExpiration\" aria-haspopup=\"true\" role=\"tooltip\" class=\"tooltip tooltip-validation tooltip-md tooltip-top-right\"\n [class.invalid]=\"tokenExpirationInput.invalid && (tokenExpirationInput.dirty || tokenExpirationInput.touched)\">\n <input name=\"tokenExpiration\" type=\"text\" #tokenExpirationInput=\"ngModel\" [(ngModel)]=\"systemSettings.token_expiration.value\"\n required pattern=\"^[1-9]{1}[0-9]*$\" id=\"tokenExpiration\" size=\"20\" [disabled]=\"!editable\">\n <span class=\"tooltip-content\">\n {{'TOOLTIP.NUMBER_REQUIRED' | translate}}\n </span>\n </label>\n <a href=\"javascript:void(0)\" role=\"tooltip\" aria-haspopup=\"true\" class=\"tooltip tooltip-top-right\">\n <clr-icon shape=\"info-circle\" class=\"info-tips-icon\" size=\"24\"></clr-icon>\n <span class=\"tooltip-content\">{{'CONFIG.TOOLTIP.TOKEN_EXPIRATION' | translate}}</span>\n </a>\n </div>\n <div class=\"form-group\" *ngIf=\"canDownloadCert\">\n <label for=\"certDownloadLink\" class=\"required\">{{'CONFIG.ROOT_CERT' | translate}}</label>\n <a #certDownloadLink [href]=\"downloadLink\" target=\"_blank\">{{'CONFIG.ROOT_CERT_LINK' | translate}}</a>\n <a href=\"javascript:void(0)\" role=\"tooltip\" aria-haspopup=\"true\" class=\"tooltip tooltip-top-right\">\n <clr-icon shape=\"info-circle\" class=\"info-tips-icon\" size=\"24\"></clr-icon>\n <span class=\"tooltip-content\">{{'CONFIG.TOOLTIP.ROOT_CERT_DOWNLOAD' | translate}}</span>\n </a>\n </div>\n <div *ngIf=\"!withAdmiral\" class=\"form-group\">\n <label for=\"repoReadOnly\">{{'CONFIG.REPO_READ_ONLY' | translate}}</label>\n <clr-checkbox name=\"repoReadOnly\" id=\"repoReadOnly\" [clrChecked]=\"systemSettings.read_only.value\" (clrCheckedChange)=\"setRepoReadOnlyValue($event)\">\n <a href=\"javascript:void(0)\" role=\"tooltip\" aria-haspopup=\"true\" class=\"tooltip tooltip-top-right\" style=\"top:-7px;\">\n <clr-icon shape=\"info-circle\" class=\"info-tips-icon\" size=\"24\"></clr-icon>\n <span class=\"tooltip-content\">{{'CONFIG.TOOLTIP.REPO_TOOLTIP' | translate}}</span>\n </a>\n </clr-checkbox>\n </div>\n </section>\n</form>\n<div>\n <button type=\"button\" id=\"config_system_save\" class=\"btn btn-primary\" (click)=\"save()\" [disabled]=\"!isValid() || !hasChanges()\">{{'BUTTON.SAVE' | translate}}</button>\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancel()\" [disabled]=\"!isValid() || !hasChanges()\">{{'BUTTON.CANCEL' | translate}}</button>\n</div>\n<confirmation-dialog #cfgConfirmationDialog (confirmAction)=\"confirmCancel($event)\"></confirmation-dialog>",
styles: ["", ".info-tips-icon{color:grey}.info-tips-icon:hover{color:#007cbb}"]
}] }
];
/** @nocollapse */
SystemSettingsComponent.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Inject, args: [SERVICE_CONFIG,] }] },
{ type: ConfigurationService },
{ type: ErrorHandler }
];
SystemSettingsComponent.propDecorators = {
configChange: [{ type: Output }],
readOnlyChange: [{ type: Output }],
reloadSystemConfig: [{ type: Output }],
systemSettings: [{ type: Input }],
showSubTitle: [{ type: Input }],
hasAdminRole: [{ type: Input }],
hasCAFile: [{ type: Input }],
withAdmiral: [{ type: Input }],
systemSettingsForm: [{ type: ViewChild, args: ["systemConfigFrom",] }],
confirmationDlg: [{ type: ViewChild, args: ["cfgConfirmationDialog",] }]
};
if (false) {
/** @type {?} */
SystemSettingsComponent.prototype.config;
/** @type {?} */
SystemSettingsComponent.prototype.onGoing;
/** @type {?} */
SystemSettingsComponent.prototype.originalConfig;
/** @type {?} */
SystemSettingsComponent.prototype.downloadLink;
/** @type {?} */
SystemSettingsComponent.prototype.configChange;
/** @type {?} */
SystemSettingsComponent.prototype.readOnlyChange;
/** @type {?} */
SystemSettingsComponent.prototype.reloadSystemConfig;
/** @type {?} */
SystemSettingsComponent.prototype.showSubTitle;
/** @type {?} */
SystemSettingsComponent.prototype.hasAdminRole;
/** @type {?} */
SystemSettingsComponent.prototype.hasCAFile;
/** @type {?} */
SystemSettingsComponent.prototype.withAdmiral;
/** @type {?} */
SystemSettingsComponent.prototype.systemSettingsForm;
/** @type {?} */
SystemSettingsComponent.prototype.confirmationDlg;
/** @type {?} */
SystemSettingsComponent.prototype.configInfo;
/** @type {?} */
SystemSettingsComponent.prototype.configService;
/** @type {?} */
SystemSettingsComponent.prototype.errorHandler;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"system-settings.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/config/system/system-settings.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, Inject, OnChanges, SimpleChanges } from '@angular/core';\nimport { NgForm } from '@angular/forms';\nimport { Configuration, StringValueItem } from '../config';\nimport { SERVICE_CONFIG, IServiceConfig } from '../../service.config';\nimport { clone, isEmpty, getChanges, toPromise } from '../../utils';\nimport { ErrorHandler } from '../../error-handler/index';\nimport { ConfirmationMessage } from '../../confirmation-dialog/confirmation-message';\nimport { ConfirmationDialogComponent } from '../../confirmation-dialog/confirmation-dialog.component';\nimport { ConfirmationState, ConfirmationTargets } from '../../shared/shared.const';\nimport { ConfirmationAcknowledgement } from '../../confirmation-dialog/confirmation-state-message';\nimport {\n    ConfigurationService\n} from '../../service/index';\nimport { from } from 'rxjs';\nconst fakePass = 'aWpLOSYkIzJTTU4wMDkx';\n\n@Component({\n    selector: 'system-settings',\n    templateUrl: './system-settings.component.html',\n    styleUrls: ['./system-settings.component.scss', '../registry-config.component.scss']\n})\nexport class SystemSettingsComponent implements OnChanges {\n    config: Configuration = new Configuration();\n    onGoing = false;\n    private originalConfig: Configuration;\n    downloadLink: string;\n    @Output() configChange: EventEmitter<Configuration> = new EventEmitter<Configuration>();\n    @Output() readOnlyChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Output() reloadSystemConfig: EventEmitter<any> = new EventEmitter<any>();\n\n    @Input()\n    get systemSettings(): Configuration {\n        return this.config;\n    }\n    set systemSettings(cfg: Configuration) {\n        this.config = cfg;\n        this.configChange.emit(this.config);\n    }\n\n    @Input() showSubTitle: boolean = false;\n    @Input() hasAdminRole: boolean = false;\n    @Input() hasCAFile: boolean = false;\n    @Input() withAdmiral = false;\n\n    @ViewChild(\"systemConfigFrom\") systemSettingsForm: NgForm;\n    @ViewChild(\"cfgConfirmationDialog\") confirmationDlg: ConfirmationDialogComponent;\n\n    get editable(): boolean {\n        return this.systemSettings &&\n            this.systemSettings.token_expiration &&\n            this.systemSettings.token_expiration.editable;\n    }\n\n    public isValid(): boolean {\n        return this.systemSettingsForm && this.systemSettingsForm.valid;\n    }\n\n    public hasChanges(): boolean {\n        return !isEmpty(this.getChanges());\n    }\n\n    public getChanges() {\n        let allChanges = getChanges(this.originalConfig, this.config);\n        if (allChanges) {\n            return this.getSystemChanges(allChanges);\n        }\n        return null;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes && changes[\"systemSettings\"]) {\n            this.originalConfig = clone(this.config);\n        }\n    }\n\n    public getSystemChanges(allChanges: any) {\n        let changes = {};\n        for (let prop in allChanges) {\n            if (prop === 'token_expiration' || prop === 'read_only' || prop === 'project_creation_restriction') {\n                changes[prop] = allChanges[prop];\n            }\n        }\n        return changes;\n    }\n\n    setRepoReadOnlyValue($event: any) {\n        this.systemSettings.read_only.value = $event;\n    }\n\n    disabled(prop: any): boolean {\n        return !(prop && prop.editable);\n    }\n\n    get canDownloadCert(): boolean {\n        return this.hasAdminRole && this.hasCAFile;\n    }\n\n    /**\n     *\n     * Save the changed values\n     *\n     * @memberOf ConfigurationComponent\n     */\n    public save(): void {\n        let changes = this.getChanges();\n        if (!isEmpty(changes)) {\n            this.onGoing = true;\n            this.configService.saveConfigurations(changes)\n                .then(response => {\n                    this.onGoing = false;\n                    // API should return the updated configurations here\n                    // Unfortunately API does not do that\n                    // To refresh the view, we can clone the original data copy\n                    // or force refresh by calling service.\n                    // HERE we choose force way\n                    this.retrieveConfig();\n                    if ('read_only' in changes) {\n                        this.readOnlyChange.emit(changes['read_only']);\n                    }\n\n                    this.reloadSystemConfig.emit();\n                    this.errorHandler.info('CONFIG.SAVE_SUCCESS');\n                })\n                .catch(error => {\n                    this.onGoing = false;\n                    this.errorHandler.error(error);\n                });\n        } else {\n            // Inprop situation, should not come here\n            console.error('Save abort because nothing changed');\n        }\n    }\n\n    retrieveConfig(): void {\n        this.onGoing = true;\n        from(toPromise(this.configService.getConfigurations()))\n            .subscribe((configurations: Configuration) => {\n                this.onGoing = false;\n                // Add two password fields\n                configurations.email_password = new StringValueItem(fakePass, true);\n                this.config = configurations;\n                // Keep the original copy of the data\n                this.originalConfig = clone(configurations);\n            }, error => {\n                this.onGoing = false;\n                this.errorHandler.error(error);\n            });\n    }\n\n    reset(changes: any): void {\n        if (!isEmpty(changes)) {\n            for (let prop in changes) {\n                if (this.originalConfig[prop]) {\n                    this.config[prop] = clone(this.originalConfig[prop]);\n                }\n            }\n        } else {\n            // force reset\n            this.retrieveConfig();\n        }\n    }\n\n    confirmCancel(ack: ConfirmationAcknowledgement): void {\n        if (ack && ack.source === ConfirmationTargets.CONFIG &&\n            ack.state === ConfirmationState.CONFIRMED) {\n            let changes = this.getChanges();\n            this.reset(changes);\n        }\n    }\n\n\n    public get inProgress(): boolean {\n        return this.onGoing;\n    }\n\n    /**\n     *\n     * Discard current changes if have and reset\n     *\n     * @memberOf ConfigurationComponent\n     */\n    public cancel(): void {\n        let changes = this.getChanges();\n        if (!isEmpty(changes)) {\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        } else {\n            // Invalid situation, should not come here\n            console.error('Nothing changed');\n        }\n    }\n\n    constructor(@Inject(SERVICE_CONFIG) private configInfo: IServiceConfig,\n        private configService: ConfigurationService,\n        private errorHandler: ErrorHandler) {\n        if (this.configInfo && this.configInfo.systemInfoEndpoint) {\n            this.downloadLink = this.configInfo.systemInfoEndpoint + \"/getcert\";\n        }\n    }\n\n\n\n}\n"]}