@nakedobjects/gemini
Version:
Single Page Application client for a Naked Objects application.
148 lines • 30.6 kB
JavaScript
import { Component, ViewChildren } from '@angular/core';
import * as Ro from '@nakedobjects/restful-objects';
import each from 'lodash-es/each';
import find from 'lodash-es/find';
import forEach from 'lodash-es/forEach';
import map from 'lodash-es/map';
import some from 'lodash-es/some';
import { createForm, safeUnsubscribe } from '../helpers-components';
import { PaneComponent } from '../pane/pane';
import { ParametersComponent } from '../parameters/parameters.component';
import * as i0 from "@angular/core";
import * as i1 from "@angular/router";
import * as i2 from "@nakedobjects/services";
import * as i3 from "@nakedobjects/view-models";
import * as i4 from "@angular/forms";
import * as i5 from "@angular/common";
import * as i6 from "../parameters/parameters.component";
import * as i7 from "../click.directive";
export class MultiLineDialogComponent extends PaneComponent {
viewModelFactory;
error;
formBuilder;
configService;
constructor(activatedRoute, urlManager, viewModelFactory, context, error, formBuilder, configService) {
super(activatedRoute, urlManager, context);
this.viewModelFactory = viewModelFactory;
this.error = error;
this.formBuilder = formBuilder;
this.configService = configService;
}
parmComponents;
sub;
dialog;
rowData;
form = (i) => {
const rowData = this.rowData[i];
return rowData.form;
};
get objectFriendlyName() {
return this.dialog.objectFriendlyName;
}
get objectTitle() {
return this.dialog.objectTitle;
}
get dialogTitle() {
return this.dialog.title;
}
get header() {
return this.dialog.header();
}
get rows() {
return this.dialog.dialogs;
}
parameters = (row) => row.parameters;
rowSubmitted = (row) => row.submitted;
rowTooltip = (row) => row.tooltip();
rowMessage = (row) => {
return row.getMessageOrSubmitted();
};
rowDisabled = (row) => {
return !row.clientValid() || row.submitted;
};
get count() {
return this.dialog.submittedCountMsg();
}
invokeAndAdd(index) {
const parms = this.rowData[index].parms;
forEach(parms, p => {
const newValue = this.rowData[index].form.value[p.id];
p.setValueFromControl(newValue);
});
const addedIndex = this.dialog.invokeAndAdd(index);
if (addedIndex) {
this.rowData.push(this.createForm(this.dialog.dialogs[addedIndex]));
}
}
close = () => {
this.urlManager.popUrlState();
};
createForm(dialog) {
return createForm(dialog, this.formBuilder);
}
setMultiLineDialog(holder, newDialogId, routeData, actionViewModel) {
const action = holder.actionMember(newDialogId);
this.context.getInvokableAction(action).
then(details => {
if (actionViewModel) {
actionViewModel.makeInvokable(details);
}
this.dialog = this.viewModelFactory.multiLineDialogViewModel(routeData, details, holder);
this.rowData = map(this.dialog.dialogs, d => this.createForm(d));
}).
catch((reject) => this.error.handleError(reject));
}
setup(routeData) {
if (routeData.menuId) {
this.context.getMenu(routeData.menuId)
.then((menu) => {
this.setMultiLineDialog(menu, routeData.dialogId, routeData);
})
.catch((reject) => {
this.error.handleError(reject);
});
}
else if (routeData.objectId) {
const oid = Ro.ObjectIdWrapper.fromObjectId(routeData.objectId, this.configService.config.keySeparator);
this.context.getObject(routeData.paneId, oid, routeData.interactionMode).
then((object) => {
const ovm = this.viewModelFactory.domainObjectViewModel(object, routeData, false);
const newDialogId = routeData.dialogId;
const lcaCollection = find(ovm.collections, c => c.hasMatchingLocallyContributedAction(newDialogId));
if (lcaCollection) {
const actionViewModel = find(lcaCollection.actions, a => a.actionRep.actionId() === newDialogId);
this.setMultiLineDialog(lcaCollection, newDialogId, routeData, actionViewModel);
}
else {
this.setMultiLineDialog(object, newDialogId, routeData);
}
}).
catch((reject) => {
this.error.handleError(reject);
});
}
}
focus(parms) {
if (parms && parms.length > 0) {
some(parms.toArray(), p => p.focus());
}
}
ngAfterViewInit() {
this.sub = this.parmComponents?.changes.subscribe(ql => this.focus(ql));
}
ngOnDestroy() {
safeUnsubscribe(this.sub);
each(this.rowData, rd => safeUnsubscribe(rd.sub));
super.ngOnDestroy();
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: MultiLineDialogComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.UrlManagerService }, { token: i3.ViewModelFactoryService }, { token: i2.ContextService }, { token: i2.ErrorService }, { token: i4.FormBuilder }, { token: i2.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: MultiLineDialogComponent, selector: "nof-multi-line-dialog", viewQueries: [{ propertyName: "parmComponents", predicate: ParametersComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div id=\"pane1\" class=\"single\">\n <div *ngIf=\"dialog\" class=\"multilinedialog\">\n <div class=\"header\">\n <div class=\"type\">{{objectFriendlyName}}</div>\n <div class=\"title\" gemini-drag tabindex=\"0\">\n <div>{{objectTitle}}</div>\n <div>{{dialogTitle}}</div>\n </div>\n </div>\n <div class=\"columnHeader\" *ngFor=\"let column of header\">{{column}}</div>\n <div class=\"lineDialog\" *ngFor=\"let row of rows; let i = index \">\n <form *ngIf=\"!rowSubmitted(row)\" (ngSubmit)=\"invokeAndAdd(i)\" [formGroup]=\"form(i)\" autocomplete=\"off\">\n <nof-parameters class=\"parameters multilinedialog\" [parameters]=\"parameters(row)\" [parent]=\"row\" [form]=\"form(i)\"></nof-parameters> \n <input class=\"ok\" tabindex=\"0\" type=\"submit\" value=\"OK\" title=\"{{rowTooltip(row)}}\" [disabled]=\"rowDisabled(row)\" nofClick (leftClick)=\"invokeAndAdd(i)\" />\n <div class=\"co-validation\">{{rowMessage(row)}}</div>\n </form>\n <nof-parameters *ngIf=\"rowSubmitted(row)\" class=\"parameters\" [parameters]=\"parameters(row)\" [parent]=\"row\"></nof-parameters>\n <div *ngIf=\"rowSubmitted(row)\" class=\"co-validation\">{{rowMessage(row)}}</div>\n </div>\n <input class=\"close\" tabindex=\"0\" type=\"submit\" value=\"Close\" title=\"\" nofClick (leftClick)=\"close()\" />\n <div class=\"count\">{{count}}</div>\n </div>\n</div>\n", styles: [":host{overflow-y:auto;color:var(--default-text-color);font-size:var(--font-size-2);font-weight:var(--font-weight-1);display:block;margin-left:var(--space-5);padding-bottom:60px}viewTitle{display:inline-block}.title,.header .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:block}.header .type{float:left;margin-right:var(--space-5);display:none}nof-parameters{display:inline-block}.columnHeader{display:inline-block;vertical-align:top;width:var(--field-value-width);padding-left:var(--space-4)}input.ok{font-size:var(--font-size-1);height:var(--field-value-height);margin-top:var(--space-1);margin-right:0;margin-left:var(--space-1);margin-bottom:var(--space-3);padding-top:var(--space-1);padding-bottom:0;padding-left:var(--space-1);padding-right:var(--space-1);vertical-align:top}input.close{float:left;margin-left:6px;margin-right:var(--space-4)}.count{display:inline-block;margin-top:var(--space-1)}.co-validation{display:inline-block}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i6.ParametersComponent, selector: "nof-parameters", inputs: ["parent", "form", "parameters"] }, { kind: "directive", type: i7.ClickDirective, selector: "[nofClick]", outputs: ["leftClick", "rightClick"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: MultiLineDialogComponent, decorators: [{
type: Component,
args: [{ selector: 'nof-multi-line-dialog', template: "<div id=\"pane1\" class=\"single\">\n <div *ngIf=\"dialog\" class=\"multilinedialog\">\n <div class=\"header\">\n <div class=\"type\">{{objectFriendlyName}}</div>\n <div class=\"title\" gemini-drag tabindex=\"0\">\n <div>{{objectTitle}}</div>\n <div>{{dialogTitle}}</div>\n </div>\n </div>\n <div class=\"columnHeader\" *ngFor=\"let column of header\">{{column}}</div>\n <div class=\"lineDialog\" *ngFor=\"let row of rows; let i = index \">\n <form *ngIf=\"!rowSubmitted(row)\" (ngSubmit)=\"invokeAndAdd(i)\" [formGroup]=\"form(i)\" autocomplete=\"off\">\n <nof-parameters class=\"parameters multilinedialog\" [parameters]=\"parameters(row)\" [parent]=\"row\" [form]=\"form(i)\"></nof-parameters> \n <input class=\"ok\" tabindex=\"0\" type=\"submit\" value=\"OK\" title=\"{{rowTooltip(row)}}\" [disabled]=\"rowDisabled(row)\" nofClick (leftClick)=\"invokeAndAdd(i)\" />\n <div class=\"co-validation\">{{rowMessage(row)}}</div>\n </form>\n <nof-parameters *ngIf=\"rowSubmitted(row)\" class=\"parameters\" [parameters]=\"parameters(row)\" [parent]=\"row\"></nof-parameters>\n <div *ngIf=\"rowSubmitted(row)\" class=\"co-validation\">{{rowMessage(row)}}</div>\n </div>\n <input class=\"close\" tabindex=\"0\" type=\"submit\" value=\"Close\" title=\"\" nofClick (leftClick)=\"close()\" />\n <div class=\"count\">{{count}}</div>\n </div>\n</div>\n", styles: [":host{overflow-y:auto;color:var(--default-text-color);font-size:var(--font-size-2);font-weight:var(--font-weight-1);display:block;margin-left:var(--space-5);padding-bottom:60px}viewTitle{display:inline-block}.title,.header .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:block}.header .type{float:left;margin-right:var(--space-5);display:none}nof-parameters{display:inline-block}.columnHeader{display:inline-block;vertical-align:top;width:var(--field-value-width);padding-left:var(--space-4)}input.ok{font-size:var(--font-size-1);height:var(--field-value-height);margin-top:var(--space-1);margin-right:0;margin-left:var(--space-1);margin-bottom:var(--space-3);padding-top:var(--space-1);padding-bottom:0;padding-left:var(--space-1);padding-right:var(--space-1);vertical-align:top}input.close{float:left;margin-left:6px;margin-right:var(--space-4)}.count{display:inline-block;margin-top:var(--space-1)}.co-validation{display:inline-block}\n"] }]
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.UrlManagerService }, { type: i3.ViewModelFactoryService }, { type: i2.ContextService }, { type: i2.ErrorService }, { type: i4.FormBuilder }, { type: i2.ConfigService }], propDecorators: { parmComponents: [{
type: ViewChildren,
args: [ParametersComponent]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-line-dialog.component.js","sourceRoot":"","sources":["../../../../gemini/src/multi-line-dialog/multi-line-dialog.component.ts","../../../../gemini/src/multi-line-dialog/multi-line-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAwB,YAAY,EAAE,MAAM,eAAe,CAAC;AAG7F,OAAO,KAAK,EAAE,MAAM,+BAA+B,CAAC;AAIpD,OAAO,IAAI,MAAM,gBAAgB,CAAC;AAClC,OAAO,IAAI,MAAM,gBAAgB,CAAC;AAClC,OAAO,OAAO,MAAM,mBAAmB,CAAC;AACxC,OAAO,GAAG,MAAM,eAAe,CAAC;AAChC,OAAO,IAAI,MAAM,gBAAgB,CAAC;AAElC,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;;;;;;;;;AAOzE,MAAM,OAAO,wBAAyB,SAAQ,aAAa;IAKlC;IAEA;IACA;IACA;IAPrB,YACI,cAA8B,EAC9B,UAA6B,EACZ,gBAAyC,EAC1D,OAAuB,EACN,KAAmB,EACnB,WAAwB,EACxB,aAA4B;QAE7C,KAAK,CAAC,cAAc,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;QAN1B,qBAAgB,GAAhB,gBAAgB,CAAyB;QAEzC,UAAK,GAAL,KAAK,CAAc;QACnB,gBAAW,GAAX,WAAW,CAAa;QACxB,kBAAa,GAAb,aAAa,CAAe;IAGjD,CAAC;IAGD,cAAc,CAAkC;IAExC,GAAG,CAAiB;IAC5B,MAAM,CAA4B;IAElC,OAAO,CAA6G;IAEpH,IAAI,GAAG,CAAC,CAAS,EAAE,EAAE;QACjB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChC,OAAO,OAAO,CAAC,IAAI,CAAC;IACxB,CAAC,CAAC;IAEF,IAAI,kBAAkB;QAClB,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC;IAC1C,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;IACnC,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;IAC7B,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;IAChC,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;IAC/B,CAAC;IAED,UAAU,GAAG,CAAC,GAAoB,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC;IAEtD,YAAY,GAAG,CAAC,GAAoB,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC;IAEvD,UAAU,GAAG,CAAC,GAAoB,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAErD,UAAU,GAAG,CAAC,GAAoB,EAAE,EAAE;QAClC,OAAO,GAAG,CAAC,qBAAqB,EAAE,CAAC;IACvC,CAAC,CAAC;IAEF,WAAW,GAAG,CAAC,GAAoB,EAAE,EAAE;QACnC,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,GAAG,CAAC,SAAS,CAAC;IAC/C,CAAC,CAAC;IAEF,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;IAC3C,CAAC;IAED,YAAY,CAAC,KAAa;QACtB,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC;QAExC,OAAO,CAAC,KAAK,EACT,CAAC,CAAC,EAAE;YACA,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACtD,CAAC,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEP,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAEnD,IAAI,UAAU,EAAE,CAAC;YACb,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACxE,CAAC;IACL,CAAC;IAED,KAAK,GAAG,GAAG,EAAE;QACT,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC,CAAC;IAEM,UAAU,CAAC,MAAuB;QACtC,OAAO,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IAChD,CAAC;IAED,kBAAkB,CAAC,MAAmF,EAClG,WAAmB,EACnB,SAAwB,EACxB,eAAiC;QAEjC,MAAM,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,WAAW,CAAE,CAAC;QACjD,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC;YACnC,IAAI,CAAC,OAAO,CAAC,EAAE;YAEX,IAAI,eAAe,EAAE,CAAC;gBAClB,eAAe,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YAC3C,CAAC;YAED,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,wBAAwB,CAAC,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;YACzF,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,CAAC,CAAC;YACF,KAAK,CAAC,CAAC,MAAoB,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC;IACxE,CAAC;IAES,KAAK,CAAC,SAAwB;QACpC,IAAI,SAAS,CAAC,MAAM,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC;iBACjC,IAAI,CAAC,CAAC,IAA2B,EAAE,EAAE;gBAClC,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,SAAS,CAAC,QAAS,EAAE,SAAS,CAAC,CAAC;YAClE,CAAC,CAAC;iBACD,KAAK,CAAC,CAAC,MAAoB,EAAE,EAAE;gBAC5B,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACnC,CAAC,CAAC,CAAC;QACX,CAAC;aAAM,IAAI,SAAS,CAAC,QAAQ,EAAE,CAAC;YAC5B,MAAM,GAAG,GAAG,EAAE,CAAC,eAAe,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YACxG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,EAAE,GAAG,EAAE,SAAS,CAAC,eAAgB,CAAC;gBACrE,IAAI,CAAC,CAAC,MAAqC,EAAE,EAAE;gBAE3C,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,MAAM,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;gBAClF,MAAM,WAAW,GAAG,SAAS,CAAC,QAAQ,CAAC;gBAEvC,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,mCAAmC,CAAC,WAAY,CAAC,CAAC,CAAC;gBAEtG,IAAI,aAAa,EAAE,CAAC;oBAChB,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,EAAE,KAAK,WAAW,CAAC,CAAC;oBACjG,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,WAAY,EAAE,SAAS,EAAE,eAAe,CAAC,CAAC;gBACrF,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,WAAY,EAAE,SAAS,CAAC,CAAC;gBAC7D,CAAC;YAEL,CAAC,CAAC;gBACF,KAAK,CAAC,CAAC,MAAoB,EAAE,EAAE;gBAC3B,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACnC,CAAC,CAAC,CAAC;QACX,CAAC;IACL,CAAC;IAED,KAAK,CAAC,KAAqC;QACvC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAC1C,CAAC;IACL,CAAC;IAED,eAAe;QACX,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,EAAE,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;IAEQ,WAAW;QAChB,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAClD,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;uGA3JQ,wBAAwB;2FAAxB,wBAAwB,gGAcnB,mBAAmB,uECpCrC,+hDAuBA;;2FDDa,wBAAwB;kBALpC,SAAS;+BACI,uBAAuB;uQAmBjC,cAAc;sBADb,YAAY;uBAAC,mBAAmB","sourcesContent":["import { AfterViewInit, Component, OnDestroy, QueryList, ViewChildren } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { ActivatedRoute } from '@angular/router';\nimport * as Ro from '@nakedobjects/restful-objects';\nimport { ConfigService, ContextService, ErrorService, ErrorWrapper, PaneRouteData, UrlManagerService } from '@nakedobjects/services';\nimport { ActionViewModel, CollectionViewModel, DialogViewModel, MultiLineDialogViewModel, ParameterViewModel, ViewModelFactoryService } from '@nakedobjects/view-models';\nimport { Dictionary } from 'lodash';\nimport each from 'lodash-es/each';\nimport find from 'lodash-es/find';\nimport forEach from 'lodash-es/forEach';\nimport map from 'lodash-es/map';\nimport some from 'lodash-es/some';\nimport { SubscriptionLike as ISubscription } from 'rxjs';\nimport { createForm, safeUnsubscribe } from '../helpers-components';\nimport { PaneComponent } from '../pane/pane';\nimport { ParametersComponent } from '../parameters/parameters.component';\n\n@Component({\n    selector: 'nof-multi-line-dialog',\n    templateUrl: 'multi-line-dialog.component.html',\n    styleUrls: ['multi-line-dialog.component.css']\n})\nexport class MultiLineDialogComponent extends PaneComponent implements AfterViewInit, OnDestroy {\n\n    constructor(\n        activatedRoute: ActivatedRoute,\n        urlManager: UrlManagerService,\n        private readonly viewModelFactory: ViewModelFactoryService,\n        context: ContextService,\n        private readonly error: ErrorService,\n        private readonly formBuilder: FormBuilder,\n        private readonly configService: ConfigService\n    ) {\n        super(activatedRoute, urlManager, context);\n    }\n\n    @ViewChildren(ParametersComponent)\n    parmComponents?: QueryList<ParametersComponent>;\n\n    private sub?: ISubscription;\n    dialog!: MultiLineDialogViewModel;\n\n    rowData!: { form: FormGroup, dialog: DialogViewModel, parms: Dictionary<ParameterViewModel>, sub: ISubscription }[];\n\n    form = (i: number) => {\n        const rowData = this.rowData[i];\n        return rowData.form;\n    };\n\n    get objectFriendlyName() {\n        return this.dialog.objectFriendlyName;\n    }\n\n    get objectTitle() {\n        return this.dialog.objectTitle;\n    }\n\n    get dialogTitle() {\n        return this.dialog.title;\n    }\n\n    get header() {\n        return this.dialog.header();\n    }\n\n    get rows() {\n        return this.dialog.dialogs;\n    }\n\n    parameters = (row: DialogViewModel) => row.parameters;\n\n    rowSubmitted = (row: DialogViewModel) => row.submitted;\n\n    rowTooltip = (row: DialogViewModel) => row.tooltip();\n\n    rowMessage = (row: DialogViewModel) => {\n        return row.getMessageOrSubmitted();\n    };\n\n    rowDisabled = (row: DialogViewModel) => {\n        return !row.clientValid() || row.submitted;\n    };\n\n    get count() {\n        return this.dialog.submittedCountMsg();\n    }\n\n    invokeAndAdd(index: number) {\n        const parms = this.rowData[index].parms;\n\n        forEach(parms,\n            p => {\n                const newValue = this.rowData[index].form.value[p.id];\n                p.setValueFromControl(newValue);\n            });\n\n        const addedIndex = this.dialog.invokeAndAdd(index);\n\n        if (addedIndex) {\n            this.rowData.push(this.createForm(this.dialog.dialogs[addedIndex]));\n        }\n    }\n\n    close = () => {\n        this.urlManager.popUrlState();\n    };\n\n    private createForm(dialog: DialogViewModel) {\n        return createForm(dialog, this.formBuilder);\n    }\n\n    setMultiLineDialog(holder: Ro.MenuRepresentation | Ro.DomainObjectRepresentation | CollectionViewModel,\n        newDialogId: string,\n        routeData: PaneRouteData,\n        actionViewModel?: ActionViewModel) {\n\n        const action = holder.actionMember(newDialogId)!;\n        this.context.getInvokableAction(action).\n            then(details => {\n\n                if (actionViewModel) {\n                    actionViewModel.makeInvokable(details);\n                }\n\n                this.dialog = this.viewModelFactory.multiLineDialogViewModel(routeData, details, holder);\n                this.rowData = map(this.dialog.dialogs, d => this.createForm(d));\n            }).\n            catch((reject: ErrorWrapper) => this.error.handleError(reject));\n    }\n\n    protected setup(routeData: PaneRouteData) {\n        if (routeData.menuId) {\n            this.context.getMenu(routeData.menuId)\n                .then((menu: Ro.MenuRepresentation) => {\n                    this.setMultiLineDialog(menu, routeData.dialogId!, routeData);\n                })\n                .catch((reject: ErrorWrapper) => {\n                    this.error.handleError(reject);\n                });\n        } else if (routeData.objectId) {\n            const oid = Ro.ObjectIdWrapper.fromObjectId(routeData.objectId, this.configService.config.keySeparator);\n            this.context.getObject(routeData.paneId, oid, routeData.interactionMode!).\n                then((object: Ro.DomainObjectRepresentation) => {\n\n                    const ovm = this.viewModelFactory.domainObjectViewModel(object, routeData, false);\n                    const newDialogId = routeData.dialogId;\n\n                    const lcaCollection = find(ovm.collections, c => c.hasMatchingLocallyContributedAction(newDialogId!));\n\n                    if (lcaCollection) {\n                        const actionViewModel = find(lcaCollection.actions, a => a.actionRep.actionId() === newDialogId);\n                        this.setMultiLineDialog(lcaCollection, newDialogId!, routeData, actionViewModel);\n                    } else {\n                        this.setMultiLineDialog(object, newDialogId!, routeData);\n                    }\n\n                }).\n                catch((reject: ErrorWrapper) => {\n                    this.error.handleError(reject);\n                });\n        }\n    }\n\n    focus(parms: QueryList<ParametersComponent>) {\n        if (parms && parms.length > 0) {\n            some(parms.toArray(), p => p.focus());\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.sub = this.parmComponents?.changes.subscribe(ql => this.focus(ql));\n    }\n\n    override ngOnDestroy(): void {\n        safeUnsubscribe(this.sub);\n        each(this.rowData, rd => safeUnsubscribe(rd.sub));\n        super.ngOnDestroy();\n    }\n}\n","<div id=\"pane1\" class=\"single\">\n    <div  *ngIf=\"dialog\" class=\"multilinedialog\">\n        <div class=\"header\">\n            <div class=\"type\">{{objectFriendlyName}}</div>\n            <div class=\"title\" gemini-drag tabindex=\"0\">\n                <div>{{objectTitle}}</div>\n                <div>{{dialogTitle}}</div>\n            </div>\n        </div>\n        <div class=\"columnHeader\" *ngFor=\"let column of header\">{{column}}</div>\n        <div class=\"lineDialog\" *ngFor=\"let row of rows; let i = index \">\n            <form *ngIf=\"!rowSubmitted(row)\" (ngSubmit)=\"invokeAndAdd(i)\" [formGroup]=\"form(i)\" autocomplete=\"off\">\n                <nof-parameters  class=\"parameters multilinedialog\" [parameters]=\"parameters(row)\" [parent]=\"row\" [form]=\"form(i)\"></nof-parameters>               \n                <input class=\"ok\" tabindex=\"0\" type=\"submit\" value=\"OK\" title=\"{{rowTooltip(row)}}\" [disabled]=\"rowDisabled(row)\" nofClick (leftClick)=\"invokeAndAdd(i)\" />\n                <div class=\"co-validation\">{{rowMessage(row)}}</div>\n            </form>\n            <nof-parameters *ngIf=\"rowSubmitted(row)\" class=\"parameters\" [parameters]=\"parameters(row)\" [parent]=\"row\"></nof-parameters>\n            <div *ngIf=\"rowSubmitted(row)\" class=\"co-validation\">{{rowMessage(row)}}</div>\n        </div>\n        <input class=\"close\" tabindex=\"0\" type=\"submit\" value=\"Close\" title=\"\" nofClick (leftClick)=\"close()\" />\n        <div class=\"count\">{{count}}</div>\n    </div>\n</div>\n"]}