@nakedobjects/gemini
Version:
Single Page Application client for a Naked Objects application.
111 lines • 23.6 kB
JavaScript
import { Component, Input, ViewChildren } from '@angular/core';
import { ParameterViewModel, PropertyViewModel } 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 "../view-property/view-property.component";
import * as i6 from "../edit-parameter/edit-parameter.component";
import * as i7 from "../click.directive";
export class EditDialogComponent extends BaseDialogComponent {
constructor(viewModelFactory, error, context, formBuilder) {
super(viewModelFactory, error, context, formBuilder);
}
properties;
parmComponents;
set parentObject(obj) {
this.parent = obj;
}
get parentObject() {
return this.parent;
}
get parametersProperties() {
const parmMap = fromPairs(this.parameters.map((p) => [p.id.toLowerCase(), p]));
return map(this.properties, (p) => parmMap[p.id.toLowerCase()] ?? p);
}
isParameter(parmprop) {
return parmprop instanceof ParameterViewModel;
}
asParameter(parmprop) {
return parmprop;
}
isLastParameter(parmprop) {
return parmprop === this.parameters[this.parameters.length - 1];
}
isProperty(parmprop) {
return parmprop instanceof PropertyViewModel;
}
asProperty(parmprop) {
return parmprop;
}
hasHint(parm) {
return parm?.presentationHint !== null && parm.presentationHint !== undefined;
}
classes(parmprop) {
if (parmprop instanceof PropertyViewModel) {
const hint = parmprop.presentationHint ?? '';
return `property ${hint}`.trim();
}
return ({ parameter: true, [parmprop.presentationHint]: this.hasHint(parmprop) });
}
doNextEditByAction(i) {
const property = this.properties[i];
if (property.isEditByAction && !property.isEditActionDisabled) {
property.doEditByAction();
return true;
}
return false;
}
onSubmitNext(right) {
this.onSubmit(right);
const merged = this.parametersProperties;
const lastParameter = this.parameters[this.parameters.length - 1];
const lastParameterIndex = merged.indexOf(lastParameter);
const nextMergedIndex = lastParameterIndex + 1;
const nextProperty = (nextMergedIndex > merged.length - 1) ? this.properties[0] : merged[nextMergedIndex];
const nextPropertyIndex = this.properties.indexOf(nextProperty);
for (let i = nextPropertyIndex; i < this.properties.length; i++) {
if (this.doNextEditByAction(i)) {
return;
}
}
for (let i = 0; i < nextPropertyIndex; i++) {
if (this.doNextEditByAction(i)) {
return;
}
}
}
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: EditDialogComponent, deps: [{ token: i1.ViewModelFactoryService }, { token: i2.ErrorService }, { token: i2.ContextService }, { token: i3.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: EditDialogComponent, selector: "nof-edit-dialog", inputs: { properties: "properties", parentObject: "parentObject" }, viewQueries: [{ propertyName: "parmComponents", predicate: EditParameterComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"dialog\">\n\t<form *ngIf=\"form\" (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\n\t\t<ng-container *ngFor=\"let parmprop of parametersProperties\">\n\t\t\t<nof-edit-parameter *ngIf=\"isParameter(parmprop)\" [ngClass]=\"classes(parmprop)\" [parameter]=\"asParameter(parmprop)\" [parent]=\"parentObject\" [form]=\"form\"></nof-edit-parameter>\n\t\t\t<ng-container *ngIf=\"isLastParameter(parmprop)\">\n\t\t\t\t<div class=\"co-validation\">{{message}}</div>\n\t\t\t\t<div class=\"form-row\">\n\t\t\t\t\t<input class=\"ok\" tabindex=\"0\" type=\"submit\" value=\"OK\" title=\"{{tooltip}}\" nofClick (leftClick)=\"onSubmit()\" (rightClick)=\"onSubmit(true)\" [disabled]=\"!form.valid\" />\n\t\t\t\t\t<input class=\"cancel\" tabindex=\"0\" type=\"button\" nofClick (leftClick)=\"close()\" value=\"Cancel\"/>\n\t\t\t\t\t<input class=\"next\" tabindex=\"0\" type=\"submit\" value=\"Next\" title=\"{{tooltip}}\" nofClick (leftClick)=\"onSubmitNext()\" (rightClick)=\"onSubmitNext(true)\" [disabled]=\"!form.valid\" />\n\t\t\t\t</div>\n\t\t\t</ng-container>\t\t\n\t\t\t<nof-view-property *ngIf=\"isProperty(parmprop)\" [ngClass]=\"classes(parmprop)\" [property]=\"asProperty(parmprop)\"></nof-view-property>\n\t\t</ng-container>\t\t\n\t</form>\n</div>", styles: [".dialog{display:block;overflow-y:auto;border-style:solid;border-color:#000;border-width:1px}.dialog select{margin-bottom:var(--space-4);border-style:solid;border-color:gray;border-width:1px}input[type=text]{padding-right:var(--space-4);padding-left:var(--space-3);margin-bottom:var(--space-4);border-style:solid;border-color:gray;border-width:1px}input[type=button],input[type=reset],input[type=submit]{margin-left:var(--space-3);margin-top:var(--space-4);margin-right:var(--space-3);margin-bottom:var(--space-3);padding:var(--space-3) 1var(--space-1);text-align:center;vertical-align:middle;border:1px transparent solid;cursor:pointer;width:auto;float:right;outline:solid;outline-color:#d3d3d3;outline-width:1px}input[type=button]:focus,input[type=button]:hover,input[type=submit]:focus,input[type=submit]:hover{outline:solid;outline-width:1px;outline-color:#000;background-color:#fff;color:var(--dialog-contrast-text-color)}input[value=Next]{display:none}input[type=button]:disabled,input[type=submit]:disabled{color:var(--disabled-color)}.parameter .name{width:var(--field-name-width)}.parameter{overflow:hidden;display:block}.form-row{height:40px}\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.ViewPropertyComponent, selector: "nof-view-property", inputs: ["property", "propertyName"] }, { kind: "component", type: i6.EditParameterComponent, selector: "nof-edit-parameter", inputs: ["parent", "parameter", "form"] }, { kind: "directive", type: i7.ClickDirective, selector: "[nofClick]", outputs: ["leftClick", "rightClick"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: EditDialogComponent, decorators: [{
type: Component,
args: [{ selector: 'nof-edit-dialog', template: "<div *ngIf=\"dialog\">\n\t<form *ngIf=\"form\" (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\n\t\t<ng-container *ngFor=\"let parmprop of parametersProperties\">\n\t\t\t<nof-edit-parameter *ngIf=\"isParameter(parmprop)\" [ngClass]=\"classes(parmprop)\" [parameter]=\"asParameter(parmprop)\" [parent]=\"parentObject\" [form]=\"form\"></nof-edit-parameter>\n\t\t\t<ng-container *ngIf=\"isLastParameter(parmprop)\">\n\t\t\t\t<div class=\"co-validation\">{{message}}</div>\n\t\t\t\t<div class=\"form-row\">\n\t\t\t\t\t<input class=\"ok\" tabindex=\"0\" type=\"submit\" value=\"OK\" title=\"{{tooltip}}\" nofClick (leftClick)=\"onSubmit()\" (rightClick)=\"onSubmit(true)\" [disabled]=\"!form.valid\" />\n\t\t\t\t\t<input class=\"cancel\" tabindex=\"0\" type=\"button\" nofClick (leftClick)=\"close()\" value=\"Cancel\"/>\n\t\t\t\t\t<input class=\"next\" tabindex=\"0\" type=\"submit\" value=\"Next\" title=\"{{tooltip}}\" nofClick (leftClick)=\"onSubmitNext()\" (rightClick)=\"onSubmitNext(true)\" [disabled]=\"!form.valid\" />\n\t\t\t\t</div>\n\t\t\t</ng-container>\t\t\n\t\t\t<nof-view-property *ngIf=\"isProperty(parmprop)\" [ngClass]=\"classes(parmprop)\" [property]=\"asProperty(parmprop)\"></nof-view-property>\n\t\t</ng-container>\t\t\n\t</form>\n</div>", styles: [".dialog{display:block;overflow-y:auto;border-style:solid;border-color:#000;border-width:1px}.dialog select{margin-bottom:var(--space-4);border-style:solid;border-color:gray;border-width:1px}input[type=text]{padding-right:var(--space-4);padding-left:var(--space-3);margin-bottom:var(--space-4);border-style:solid;border-color:gray;border-width:1px}input[type=button],input[type=reset],input[type=submit]{margin-left:var(--space-3);margin-top:var(--space-4);margin-right:var(--space-3);margin-bottom:var(--space-3);padding:var(--space-3) 1var(--space-1);text-align:center;vertical-align:middle;border:1px transparent solid;cursor:pointer;width:auto;float:right;outline:solid;outline-color:#d3d3d3;outline-width:1px}input[type=button]:focus,input[type=button]:hover,input[type=submit]:focus,input[type=submit]:hover{outline:solid;outline-width:1px;outline-color:#000;background-color:#fff;color:var(--dialog-contrast-text-color)}input[value=Next]{display:none}input[type=button]:disabled,input[type=submit]:disabled{color:var(--disabled-color)}.parameter .name{width:var(--field-name-width)}.parameter{overflow:hidden;display:block}.form-row{height:40px}\n"] }]
}], ctorParameters: () => [{ type: i1.ViewModelFactoryService }, { type: i2.ErrorService }, { type: i2.ContextService }, { type: i3.FormBuilder }], propDecorators: { properties: [{
type: Input,
args: [{ required: true }]
}], parmComponents: [{
type: ViewChildren,
args: [EditParameterComponent]
}], parentObject: [{
type: Input,
args: [{ required: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-dialog.component.js","sourceRoot":"","sources":["../../../../gemini/src/edit-dialog/edit-dialog.component.ts","../../../../gemini/src/edit-dialog/edit-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 { ContextService, ErrorService } from '@nakedobjects/services';\nimport {\n    DomainObjectViewModel,\n    ParameterViewModel,\n    PropertyViewModel,\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';\n\n@Component({\n    selector: 'nof-edit-dialog',\n    templateUrl: 'edit-dialog.component.html',\n    styleUrls: ['edit-dialog.component.css']\n})\nexport class EditDialogComponent extends BaseDialogComponent implements AfterViewInit, OnDestroy, OnChanges {\n\n    constructor(\n        viewModelFactory: ViewModelFactoryService,\n        error: ErrorService,\n        context: ContextService,\n        formBuilder: FormBuilder) {\n            super(viewModelFactory, error, context, formBuilder);\n    }\n\n    @Input({required: true})\n    properties!: PropertyViewModel[];\n\n    @ViewChildren(EditParameterComponent)\n    parmComponents?: QueryList<EditParameterComponent>;\n\n    @Input({required: true})\n    set parentObject(obj : DomainObjectViewModel) {\n        this.parent = obj;\n    }\n\n    get parentObject() {\n        return this.parent as DomainObjectViewModel;\n    }\n\n    get parametersProperties(): (ParameterViewModel | PropertyViewModel)[] {\n        const parmMap = fromPairs(this.parameters.map((p) => [p.id.toLowerCase(), p]));\n        return map(this.properties, (p) => parmMap[p.id.toLowerCase()] ?? p);\n    }\n\n    isParameter(parmprop: PropertyViewModel | ParameterViewModel) {\n        return parmprop instanceof ParameterViewModel;\n    }\n\n    asParameter(parmprop: PropertyViewModel | ParameterViewModel) {\n        return parmprop as ParameterViewModel;\n    }\n\n    isLastParameter(parmprop: PropertyViewModel | ParameterViewModel) {\n        return parmprop === this.parameters[this.parameters.length - 1];\n    }\n\n    isProperty(parmprop: PropertyViewModel | ParameterViewModel) {\n        return parmprop instanceof PropertyViewModel;\n    }\n\n    asProperty(parmprop: PropertyViewModel | ParameterViewModel) {\n        return parmprop as PropertyViewModel;\n    }\n\n    private hasHint(parm: ParameterViewModel) {\n        return parm?.presentationHint !== null && parm.presentationHint !== undefined;\n    }\n\n    classes(parmprop: PropertyViewModel | ParameterViewModel) {\n        if (parmprop instanceof PropertyViewModel) {\n            const hint = parmprop.presentationHint ?? '';\n            return `property ${hint}`.trim();\n        }\n        return ({ parameter: true, [parmprop.presentationHint]: this.hasHint(parmprop)});\n    }\n\n    private doNextEditByAction(i: number) {\n        const property = this.properties[i];\n        if (property.isEditByAction && !property.isEditActionDisabled) {\n            property.doEditByAction();\n            return true;\n        }\n        return false;\n    }\n\n    onSubmitNext(right?: boolean) {\n        this.onSubmit(right);\n\n        const merged = this.parametersProperties;\n        const lastParameter = this.parameters[this.parameters.length - 1];\n        const lastParameterIndex = merged.indexOf(lastParameter);\n        const nextMergedIndex = lastParameterIndex + 1;\n        const nextProperty = (nextMergedIndex > merged.length - 1) ? this.properties[0] : merged[nextMergedIndex] as PropertyViewModel;\n        const nextPropertyIndex = this.properties.indexOf(nextProperty);\n\n        for (let i = nextPropertyIndex; i < this.properties.length; i++) {\n            if (this.doNextEditByAction(i)) {\n                return;\n            }\n        }\n\n        for (let i = 0; i < nextPropertyIndex; i++) {\n            if (this.doNextEditByAction(i)) {\n                return;\n            }\n        }\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 *ngIf=\"dialog\">\n\t<form *ngIf=\"form\" (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\n\t\t<ng-container *ngFor=\"let parmprop of parametersProperties\">\n\t\t\t<nof-edit-parameter *ngIf=\"isParameter(parmprop)\" [ngClass]=\"classes(parmprop)\" [parameter]=\"asParameter(parmprop)\" [parent]=\"parentObject\" [form]=\"form\"></nof-edit-parameter>\n\t\t\t<ng-container *ngIf=\"isLastParameter(parmprop)\">\n\t\t\t\t<div class=\"co-validation\">{{message}}</div>\n\t\t\t\t<div class=\"form-row\">\n\t\t\t\t\t<input class=\"ok\" tabindex=\"0\" type=\"submit\" value=\"OK\" title=\"{{tooltip}}\" nofClick (leftClick)=\"onSubmit()\" (rightClick)=\"onSubmit(true)\" [disabled]=\"!form.valid\" />\n\t\t\t\t\t<input class=\"cancel\" tabindex=\"0\" type=\"button\" nofClick (leftClick)=\"close()\" value=\"Cancel\"/>\n\t\t\t\t\t<input class=\"next\" tabindex=\"0\" type=\"submit\" value=\"Next\" title=\"{{tooltip}}\" nofClick (leftClick)=\"onSubmitNext()\" (rightClick)=\"onSubmitNext(true)\" [disabled]=\"!form.valid\" />\n\t\t\t\t</div>\n\t\t\t</ng-container>\t\t\n\t\t\t<nof-view-property  *ngIf=\"isProperty(parmprop)\" [ngClass]=\"classes(parmprop)\"  [property]=\"asProperty(parmprop)\"></nof-view-property>\n\t\t</ng-container>\t\t\n\t</form>\n</div>"]}