UNPKG

@nakedobjects/gemini

Version:

Single Page Application client for a Naked Objects application.

166 lines 22.6 kB
import { Component, Input } from '@angular/core'; import { CollectionViewModel, DomainObjectViewModel, ListViewModel, MenuViewModel } from '@nakedobjects/view-models'; import find from 'lodash-es/find'; import forEach from 'lodash-es/forEach'; import { createForm, safeUnsubscribe } from '../helpers-components'; 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"; export class BaseDialogComponent { viewModelFactory; error; context; formBuilder; constructor(viewModelFactory, error, context, formBuilder) { this.viewModelFactory = viewModelFactory; this.error = error; this.context = context; this.formBuilder = formBuilder; } parentViewModel; parms; formSub; sub; createFormSub; set parent(parent) { this.parentChanged = this.parentViewModel !== parent; this.parentViewModel = parent; } get parent() { return this.parentViewModel; } currentDialogId; parentChanged = false; set selectedDialogId(id) { this.currentDialogId = id; } get selectedDialogId() { return this.currentDialogId; } dialog = null; form; get title() { const dialog = this.dialog; return dialog ? dialog.title : ''; } get message() { const dialog = this.dialog; return dialog ? dialog.getMessage() : ''; } get parameters() { const dialog = this.dialog; return dialog ? dialog.parameters : []; } get tooltip() { const dialog = this.dialog; return dialog ? dialog.tooltip() : ''; } onSubmit(right) { if (this.dialog) { forEach(this.parms, (p, _) => { if (p.isEditable) { const newValue = this.form.value[p.id]; p.setValueFromControl(newValue); } }); this.dialog.doInvoke(right); } } close = () => { if (this.dialog) { this.dialog.doCloseReplaceHistory(); this.dialog = null; } }; createForm(dialog) { safeUnsubscribe(this.formSub); safeUnsubscribe(this.createFormSub); ({ form: this.form, dialog: this.dialog, parms: this.parms, sub: this.createFormSub } = createForm(dialog, this.formBuilder)); this.formSub = this.form.valueChanges.subscribe((_) => this.onValueChanged()); } onValueChanged() { if (this.dialog) { // clear messages if dialog changes this.dialog.resetMessage(); this.context.clearMessages(); this.context.clearWarnings(); } } closeExistingDialog() { if (this.dialog) { if (this.dialog.id !== this.currentDialogId) { this.dialog.doCloseKeepHistory(); } else { this.dialog.doCloseKeepUrl(); } this.dialog = null; } } getDialog() { // if it's the same dialog just return if (this.parent && this.currentDialogId) { if (!this.parentChanged && this.dialog && this.dialog.id === this.currentDialogId) { return; } this.parentChanged = false; const p = this.parent; let action = null; let actionViewModel = null; if (p instanceof MenuViewModel) { action = p.menuRep.actionMember(this.currentDialogId); } if (p instanceof DomainObjectViewModel && p.domainObject.hasActionMember(this.currentDialogId)) { action = p.domainObject.actionMember(this.currentDialogId); } if (p instanceof ListViewModel) { action = p.actionMember(this.currentDialogId); actionViewModel = find(p.actions, a => a.actionRep.actionId() === this.currentDialogId) || null; } if (p instanceof CollectionViewModel && p.hasMatchingLocallyContributedAction(this.currentDialogId)) { action = p.actionMember(this.currentDialogId); actionViewModel = find(p.actions, a => a.actionRep.actionId() === this.currentDialogId) || null; } if (action) { this.context.getInvokableAction(action) .then(details => { // only if we still have a dialog (may have beenn removed while getting invokable action) if (this.currentDialogId) { // must be a change this.closeExistingDialog(); const dialogViewModel = this.viewModelFactory.dialogViewModel(this.parent.routeData, details, actionViewModel, false); this.createForm(dialogViewModel); } }) .catch((reject) => { this.error.handleError(reject); }); } else { this.closeExistingDialog(); } } else { this.closeExistingDialog(); } } ngOnDestroy() { safeUnsubscribe(this.createFormSub); safeUnsubscribe(this.formSub); safeUnsubscribe(this.sub); this.closeExistingDialog(); } ngOnChanges() { this.getDialog(); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: BaseDialogComponent, 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: BaseDialogComponent, selector: "ng-component", inputs: { selectedDialogId: "selectedDialogId" }, usesOnChanges: true, ngImport: i0, template: '<div></div>', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: BaseDialogComponent, decorators: [{ type: Component, args: [{ template: '<div></div>' }] }], ctorParameters: () => [{ type: i1.ViewModelFactoryService }, { type: i2.ErrorService }, { type: i2.ContextService }, { type: i3.FormBuilder }], propDecorators: { selectedDialogId: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dialog.component.js","sourceRoot":"","sources":["../../../../gemini/src/base-dialog/base-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnChanges } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport * as Ro from '@nakedobjects/restful-objects';\nimport { ContextService, ErrorService, ErrorWrapper } from '@nakedobjects/services';\nimport {\n    ActionViewModel,\n    CollectionViewModel,\n    DialogViewModel,\n    DomainObjectViewModel,\n    ListViewModel,\n    MenuViewModel,\n    ParameterViewModel,\n    ViewModelFactoryService\n} from '@nakedobjects/view-models';\nimport { Dictionary } from 'lodash';\nimport find from 'lodash-es/find';\nimport forEach from 'lodash-es/forEach';\nimport { SubscriptionLike as ISubscription } from 'rxjs';\nimport { createForm, safeUnsubscribe } from '../helpers-components';\n\n@Component({template : '<div></div>'})\nexport class BaseDialogComponent implements OnDestroy, OnChanges {\n\n    constructor(\n        private readonly viewModelFactory: ViewModelFactoryService,\n        private readonly error: ErrorService,\n        private readonly context: ContextService,\n        private readonly formBuilder: FormBuilder) {\n    }\n\n    private parentViewModel?: MenuViewModel | DomainObjectViewModel | ListViewModel | CollectionViewModel;\n    private parms?: Dictionary<ParameterViewModel>;\n    \n    private formSub?: ISubscription;\n    protected sub?: ISubscription;\n    private createFormSub?: ISubscription;\n\n    protected set parent(parent: MenuViewModel | DomainObjectViewModel | ListViewModel | CollectionViewModel) {\n        this.parentChanged = this.parentViewModel !== parent;\n        this.parentViewModel = parent;\n    }\n\n    protected get parent(): MenuViewModel | DomainObjectViewModel | ListViewModel | CollectionViewModel {\n        return this.parentViewModel!;\n    }\n\n    private currentDialogId?: string;\n    private parentChanged = false;\n\n    @Input()\n    set selectedDialogId(id: string | undefined) {\n        this.currentDialogId = id;\n    }\n\n    get selectedDialogId(): string | undefined {\n        return this.currentDialogId;\n    }\n\n    dialog: DialogViewModel | null = null;\n\n    form?: FormGroup;\n\n    get title() {\n        const dialog = this.dialog;\n        return dialog ? dialog.title : '';\n    }\n\n    get message() {\n        const dialog = this.dialog;\n        return dialog ? dialog.getMessage() : '';\n    }\n\n    get parameters() {\n        const dialog = this.dialog;\n        return dialog ? dialog.parameters : [];\n    }\n\n    get tooltip(): string {\n        const dialog = this.dialog;\n        return dialog ? dialog.tooltip() : '';\n    }\n\n    onSubmit(right?: boolean) {\n        if (this.dialog) {\n            forEach(this.parms,\n                (p, _) => {\n                    if (p.isEditable) {\n                        const newValue = this.form!.value[p.id];\n                        p.setValueFromControl(newValue);\n                    }\n                });\n            this.dialog.doInvoke(right);\n        }\n    }\n\n    close = () => {\n        if (this.dialog) {\n            this.dialog.doCloseReplaceHistory();\n            this.dialog = null;\n        }\n    };\n\n    private createForm(dialog: DialogViewModel) {\n        safeUnsubscribe(this.formSub);\n        safeUnsubscribe(this.createFormSub);\n        ({ form: this.form, dialog: this.dialog, parms: this.parms, sub: this.createFormSub } = createForm(dialog, this.formBuilder));\n        this.formSub = this.form.valueChanges.subscribe((_) => this.onValueChanged());\n    }\n\n    onValueChanged() {\n        if (this.dialog) {\n            // clear messages if dialog changes\n            this.dialog.resetMessage();\n            this.context.clearMessages();\n            this.context.clearWarnings();\n        }\n    }\n\n    closeExistingDialog() {\n        if (this.dialog) {\n            if (this.dialog.id !== this.currentDialogId) {\n                this.dialog.doCloseKeepHistory();\n            } else {\n                this.dialog.doCloseKeepUrl();\n            }\n            this.dialog = null;\n        }\n    }\n\n    getDialog() {\n\n        // if it's the same dialog just return\n\n        if (this.parent && this.currentDialogId) {\n\n            if (!this.parentChanged && this.dialog && this.dialog.id === this.currentDialogId) {\n                return;\n            }\n            this.parentChanged = false;\n\n            const p = this.parent;\n            let action: Ro.ActionMember | Ro.ActionRepresentation | null = null;\n            let actionViewModel: ActionViewModel | null = null;\n\n            if (p instanceof MenuViewModel) {\n                action = p.menuRep.actionMember(this.currentDialogId);\n            }\n\n            if (p instanceof DomainObjectViewModel && p.domainObject.hasActionMember(this.currentDialogId)) {\n                action = p.domainObject.actionMember(this.currentDialogId);\n            }\n\n            if (p instanceof ListViewModel) {\n                action = p.actionMember(this.currentDialogId)!;\n                actionViewModel = find(p.actions, a => a.actionRep.actionId() === this.currentDialogId) || null;\n            }\n\n            if (p instanceof CollectionViewModel && p.hasMatchingLocallyContributedAction(this.currentDialogId)) {\n                action = p.actionMember(this.currentDialogId)!;\n                actionViewModel = find(p.actions, a => a.actionRep.actionId() === this.currentDialogId) || null;\n            }\n\n            if (action) {\n                this.context.getInvokableAction(action)\n                    .then(details => {\n                        // only if we still have a dialog (may have beenn removed while getting invokable action)\n\n                        if (this.currentDialogId) {\n                            // must be a change\n                            this.closeExistingDialog();\n                            const dialogViewModel = this.viewModelFactory.dialogViewModel(this.parent!.routeData, details, actionViewModel, false);\n                            this.createForm(dialogViewModel);\n                        }\n                    })\n                    .catch((reject: ErrorWrapper) => {\n                        this.error.handleError(reject);\n                    });\n            } else {\n                this.closeExistingDialog();\n            }\n\n        } else {\n            this.closeExistingDialog();\n        }\n    }\n\n    ngOnDestroy(): void {\n        safeUnsubscribe(this.createFormSub);\n        safeUnsubscribe(this.formSub);\n        safeUnsubscribe(this.sub);\n        this.closeExistingDialog();\n    }\n\n    ngOnChanges(): void {\n        this.getDialog();\n    }\n}\n"]}