@nakedobjects/gemini
Version:
Single Page Application client for a Naked Objects application.
119 lines • 23.6 kB
JavaScript
import { Component, Input, ViewChildren } from '@angular/core';
import { ParameterViewModel } from '@nakedobjects/view-models';
import { BaseDialogComponent } from '../base-dialog/base-dialog.component';
import some from 'lodash-es/some';
import map from 'lodash-es/map';
import fromPairs from 'lodash-es/fromPairs';
import { EditParameterComponent } from '../edit-parameter/edit-parameter.component';
import * as i0 from "@angular/core";
import * as i1 from "@nakedobjects/view-models";
import * as i2 from "@nakedobjects/services";
import * as i3 from "@angular/forms";
import * as i4 from "@angular/common";
import * as i5 from "../action-bar/action-bar.component";
import * as i6 from "../view-property/view-property.component";
import * as i7 from "../edit-parameter/edit-parameter.component";
export class CreateNewDialogComponent extends BaseDialogComponent {
colorService;
configService;
constructor(viewModelFactory, error, context, colorService, configService, formBuilder) {
super(viewModelFactory, error, context, formBuilder);
this.colorService = colorService;
this.configService = configService;
this.pendingColor = `${configService.config.objectColor}${colorService.getConfiguredDefault()}`;
}
parmComponents;
set toCreateClass(cls) {
this.toCreate = cls;
this.colorService.toColorNumberFromType(cls).then(c => this.pendingColor = `${this.configService.config.objectColor}${c}`);
}
set parentMenu(parent) {
this.parent = parent;
}
get parentMenu() {
return this.parent;
}
// used to smooth transition before object set
pendingColor;
get color() {
return this.pendingColor;
}
toCreate;
saveButton = {
value: 'Save',
doClick: () => this.onSubmit(),
doRightClick: () => this.onSubmit(true),
show: () => true,
disabled: () => this.form && !this.form.valid ? true : null,
tempDisabled: () => null,
title: () => this.tooltip,
accesskey: null,
presentationHint: '',
showDialog: () => false
};
cancelButton = {
value: 'Cancel',
doClick: () => this.close(),
show: () => true,
disabled: () => null,
tempDisabled: () => null,
title: () => '',
accesskey: null,
presentationHint: '',
showDialog: () => false
};
saveButtons = [this.saveButton, this.cancelButton];
get actionHolders() {
return this.saveButtons;
}
get parametersProperties() {
const properties = this.dialog?.actionViewModel.createNewProperties;
const parmMap = fromPairs(this.parameters.map((p) => [p.title.toLowerCase(), p]));
return map(properties, (p) => parmMap[p.toLowerCase()] ?? p);
}
isParameter(parmprop) {
return parmprop instanceof ParameterViewModel;
}
asParameter(parmprop) {
return parmprop;
}
isProperty(parmprop) {
return !this.isParameter(parmprop);
}
asProperty(parmprop) {
return parmprop;
}
hasHint(parm) {
return parm?.presentationHint !== null && parm.presentationHint !== undefined;
}
classes(parmprop) {
return ({ parameter: true, [parmprop.presentationHint]: this.hasHint(parmprop) });
}
ngAfterViewInit() {
this.sub = this.parmComponents?.changes.subscribe(() => this.focus());
}
focus() {
const parms = this.parmComponents;
if (parms && parms.length > 0) {
// until first element returns true
return some(parms.toArray(), i => i.focus());
}
return false;
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CreateNewDialogComponent, deps: [{ token: i1.ViewModelFactoryService }, { token: i2.ErrorService }, { token: i2.ContextService }, { token: i2.ColorService }, { token: i2.ConfigService }, { token: i3.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: CreateNewDialogComponent, selector: "nof-create-new-dialog", inputs: { toCreateClass: "toCreateClass", parentMenu: "parentMenu" }, viewQueries: [{ propertyName: "parmComponents", predicate: EditParameterComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"object edit\" [ngClass]=\"color\">\n <header class=\"header\">\n <div class=\"title\" tabindex=\"0\">{{title}}</div>\n\t\t<div class=\"menus\">\n\t\t\t<nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n\t\t</div>\n\t\t<div class=\"messages\">{{message}}</div>\n </header>\n <div class=\"main-column\">\n <div *ngIf=\"dialog\" class=\"dialog\">\n\t\t\t<form *ngIf=\"form\" (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\n\t\t\t\t<ng-container *ngFor=\"let parmprop of parametersProperties\">\n\t\t\t\t\t<nof-edit-parameter *ngIf=\"isParameter(parmprop)\" [ngClass]=\"classes(asParameter(parmprop))\" [parameter]=\"asParameter(parmprop)\" [parent]=\"parentMenu\" [form]=\"form\"></nof-edit-parameter>\n\t\t\t\t\t<nof-view-property *ngIf=\"isProperty(parmprop)\" [propertyName]=\"asProperty(parmprop)\" class=\"property\"></nof-view-property>\n\t\t\t\t</ng-container>\n\t\t\t\t<div class=\"co-validation\">{{message}}</div>\n\t\t\t</form>\n\t\t</div>\n </div>\n</div>", styles: [":host{overflow-y:auto;color:var(--default-text-color);font-size:var(--font-size-2);font-weight:var(--font-weight-1);display:block;height:100%}.object{height:100%;display:block;padding-left:var(--space-5);overflow-y:auto}.header{display:block;margin-bottom:var(--space-5);overflow:hidden;color:var(--contrast-text-color);background-color:var(--header-background-color)}viewTitle{display:inline-block}.title,.type{position:relative;font-weight:var(--font-weight-2);font-size:var(--font-size-4);line-height:38pt;margin-left:var(--space-1);padding-left:var(--space-3);padding-right:var(--space-3);margin-right:var(--space-5);margin-top:var(--space-1);display:inline-block}.type{float:left;margin-right:var(--space-5);display:none}.menus{display:block}.menu,.header .action{display:block;float:left;padding:var(--space-3);margin-top:0;margin-left:var(--space-1);margin-right:var(--space-4);margin-bottom:var(--space-3);font:inherit;font-size:var(--font-size-3);color:var(--default-text-color);background-color:transparent}.menu:disabled{color:var(--disabled-color)}.title:hover,.title:focus{outline-color:var(--contrast-outline-color);outline-width:1px}.actions,.main-column{float:left;margin-bottom:var(--space-5);margin-right:var(--space-5)}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i5.ActionBarComponent, selector: "nof-action-bar", inputs: ["actions", "menuHolder"] }, { kind: "component", type: i6.ViewPropertyComponent, selector: "nof-view-property", inputs: ["property", "propertyName"] }, { kind: "component", type: i7.EditParameterComponent, selector: "nof-edit-parameter", inputs: ["parent", "parameter", "form"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CreateNewDialogComponent, decorators: [{
type: Component,
args: [{ selector: 'nof-create-new-dialog', template: "<div class=\"object edit\" [ngClass]=\"color\">\n <header class=\"header\">\n <div class=\"title\" tabindex=\"0\">{{title}}</div>\n\t\t<div class=\"menus\">\n\t\t\t<nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n\t\t</div>\n\t\t<div class=\"messages\">{{message}}</div>\n </header>\n <div class=\"main-column\">\n <div *ngIf=\"dialog\" class=\"dialog\">\n\t\t\t<form *ngIf=\"form\" (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\n\t\t\t\t<ng-container *ngFor=\"let parmprop of parametersProperties\">\n\t\t\t\t\t<nof-edit-parameter *ngIf=\"isParameter(parmprop)\" [ngClass]=\"classes(asParameter(parmprop))\" [parameter]=\"asParameter(parmprop)\" [parent]=\"parentMenu\" [form]=\"form\"></nof-edit-parameter>\n\t\t\t\t\t<nof-view-property *ngIf=\"isProperty(parmprop)\" [propertyName]=\"asProperty(parmprop)\" class=\"property\"></nof-view-property>\n\t\t\t\t</ng-container>\n\t\t\t\t<div class=\"co-validation\">{{message}}</div>\n\t\t\t</form>\n\t\t</div>\n </div>\n</div>", styles: [":host{overflow-y:auto;color:var(--default-text-color);font-size:var(--font-size-2);font-weight:var(--font-weight-1);display:block;height:100%}.object{height:100%;display:block;padding-left:var(--space-5);overflow-y:auto}.header{display:block;margin-bottom:var(--space-5);overflow:hidden;color:var(--contrast-text-color);background-color:var(--header-background-color)}viewTitle{display:inline-block}.title,.type{position:relative;font-weight:var(--font-weight-2);font-size:var(--font-size-4);line-height:38pt;margin-left:var(--space-1);padding-left:var(--space-3);padding-right:var(--space-3);margin-right:var(--space-5);margin-top:var(--space-1);display:inline-block}.type{float:left;margin-right:var(--space-5);display:none}.menus{display:block}.menu,.header .action{display:block;float:left;padding:var(--space-3);margin-top:0;margin-left:var(--space-1);margin-right:var(--space-4);margin-bottom:var(--space-3);font:inherit;font-size:var(--font-size-3);color:var(--default-text-color);background-color:transparent}.menu:disabled{color:var(--disabled-color)}.title:hover,.title:focus{outline-color:var(--contrast-outline-color);outline-width:1px}.actions,.main-column{float:left;margin-bottom:var(--space-5);margin-right:var(--space-5)}\n"] }]
}], ctorParameters: () => [{ type: i1.ViewModelFactoryService }, { type: i2.ErrorService }, { type: i2.ContextService }, { type: i2.ColorService }, { type: i2.ConfigService }, { type: i3.FormBuilder }], propDecorators: { parmComponents: [{
type: ViewChildren,
args: [EditParameterComponent]
}], toCreateClass: [{
type: Input,
args: [{ required: true }]
}], parentMenu: [{
type: Input,
args: [{ required: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-new-dialog.component.js","sourceRoot":"","sources":["../../../../gemini/src/create-new-dialog/create-new-dialog.component.ts","../../../../gemini/src/create-new-dialog/create-new-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Input, OnDestroy, OnChanges, ViewChildren, QueryList } from '@angular/core';\nimport { FormBuilder } from '@angular/forms';\nimport { ColorService, ConfigService, ContextService, ErrorService } from '@nakedobjects/services';\nimport {\n    DomainObjectViewModel,\n    MenuViewModel,\n    ParameterViewModel,\n    ViewModelFactoryService\n} from '@nakedobjects/view-models';\nimport { BaseDialogComponent } from '../base-dialog/base-dialog.component';\nimport some from 'lodash-es/some';\nimport map from 'lodash-es/map';\nimport fromPairs from 'lodash-es/fromPairs';\nimport { EditParameterComponent } from '../edit-parameter/edit-parameter.component';\nimport { IActionHolder } from '../action/action.component';\n\n@Component({\n    selector: 'nof-create-new-dialog',\n    templateUrl: 'create-new-dialog.component.html',\n    styleUrls: ['create-new-dialog.component.css']\n})\nexport class CreateNewDialogComponent extends BaseDialogComponent implements AfterViewInit, OnDestroy, OnChanges {\n\n    constructor(\n        viewModelFactory: ViewModelFactoryService,\n        error: ErrorService,\n        context: ContextService,\n        private readonly colorService: ColorService,\n        private readonly configService: ConfigService,\n        formBuilder: FormBuilder) {\n            super(viewModelFactory, error, context, formBuilder);\n            this.pendingColor = `${configService.config.objectColor}${colorService.getConfiguredDefault()}`;\n    }\n\n    @ViewChildren(EditParameterComponent)\n    parmComponents?: QueryList<EditParameterComponent>;\n\n    @Input({required : true})\n    set toCreateClass(cls: string) {\n        this.toCreate = cls;\n        this.colorService.toColorNumberFromType(cls).then(c => this.pendingColor = `${this.configService.config.objectColor}${c}`);\n    }\n\n    @Input({required : true})\n    set parentMenu(parent: MenuViewModel | DomainObjectViewModel) {\n        this.parent = parent;\n    }\n\n    get parentMenu() {\n        return this.parent as MenuViewModel | DomainObjectViewModel;\n    }\n\n     // used to smooth transition before object set\n    private pendingColor: string;\n\n    get color() {\n         return this.pendingColor;\n    }\n\n    toCreate!: string;\n\n    private saveButton: IActionHolder = {\n        value: 'Save',\n        doClick: () => this.onSubmit(),\n        doRightClick: () => this.onSubmit(true),\n        show: () => true,\n        disabled: () => this.form && !this.form.valid ? true : null,\n        tempDisabled: () => null,\n        title: () => this.tooltip,\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private cancelButton: IActionHolder = {\n        value: 'Cancel',\n        doClick: () => this.close(),\n        show: () => true,\n        disabled: () => null,\n        tempDisabled: () => null,\n        title: () => '',\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private saveButtons = [this.saveButton, this.cancelButton];\n\n    get actionHolders() {\n        return this.saveButtons;\n    }\n\n    get parametersProperties(): (ParameterViewModel | string)[] {\n        const properties = this.dialog?.actionViewModel.createNewProperties;\n        const parmMap = fromPairs(this.parameters.map((p) => [p.title.toLowerCase(), p]));\n        return map(properties, (p) => parmMap[p.toLowerCase()] ?? p);\n    }\n\n    isParameter(parmprop: ParameterViewModel | string) {\n        return parmprop instanceof ParameterViewModel;\n    }\n\n    asParameter(parmprop: ParameterViewModel | string) {\n        return parmprop as ParameterViewModel;\n    }\n\n    isProperty(parmprop: ParameterViewModel | string) {\n        return !this.isParameter(parmprop);\n    }\n\n    asProperty(parmprop: ParameterViewModel | string) {\n        return parmprop as string;\n    }\n\n    private hasHint(parm: ParameterViewModel) {\n        return parm?.presentationHint !== null && parm.presentationHint !== undefined;\n    }\n\n    classes(parmprop: ParameterViewModel) {\n        return ({ parameter: true, [parmprop.presentationHint]: this.hasHint(parmprop)});\n    }\n\n    ngAfterViewInit(): void {\n        this.sub = this.parmComponents?.changes.subscribe(() => this.focus());\n    }\n\n    focus() {\n        const parms = this.parmComponents;\n        if (parms && parms.length > 0) {\n            // until first element returns true\n            return some(parms.toArray(), i => i.focus());\n        }\n        return false;\n    }\n}\n","<div  class=\"object edit\" [ngClass]=\"color\">\n    <header class=\"header\">\n        <div class=\"title\" tabindex=\"0\">{{title}}</div>\n\t\t<div  class=\"menus\">\n\t\t\t<nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n\t\t</div>\n\t\t<div class=\"messages\">{{message}}</div>\n    </header>\n    <div class=\"main-column\">\n        <div *ngIf=\"dialog\" class=\"dialog\">\n\t\t\t<form  *ngIf=\"form\" (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\n\t\t\t\t<ng-container *ngFor=\"let parmprop of parametersProperties\">\n\t\t\t\t\t<nof-edit-parameter *ngIf=\"isParameter(parmprop)\" [ngClass]=\"classes(asParameter(parmprop))\" [parameter]=\"asParameter(parmprop)\" [parent]=\"parentMenu\" [form]=\"form\"></nof-edit-parameter>\n\t\t\t\t\t<nof-view-property *ngIf=\"isProperty(parmprop)\" [propertyName]=\"asProperty(parmprop)\" class=\"property\"></nof-view-property>\n\t\t\t\t</ng-container>\n\t\t\t\t<div class=\"co-validation\">{{message}}</div>\n\t\t\t</form>\n\t\t</div>\n    </div>\n</div>"]}