@nakedobjects/gemini
Version:
Single Page Application client for a Naked Objects application.
221 lines • 41.6 kB
JavaScript
import { Component } from '@angular/core';
import * as Ro from '@nakedobjects/restful-objects';
import { CollectionViewState } from '@nakedobjects/services';
import { safeUnsubscribe } from '../helpers-components';
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/common";
import * as i5 from "@angular/cdk/drag-drop";
import * as i6 from "../action-list/action-list.component";
import * as i7 from "../action-bar/action-bar.component";
import * as i8 from "../dialog/dialog.component";
import * as i9 from "../row/row.component";
import * as i10 from "../header/header.component";
export class ListComponent {
activatedRoute;
urlManager;
context;
viewModelFactory;
error;
configService;
loggerService;
dragAndDrop;
ddSub;
dropZones = [];
constructor(activatedRoute, urlManager, context, viewModelFactory, error, configService, loggerService, dragAndDrop) {
this.activatedRoute = activatedRoute;
this.urlManager = urlManager;
this.context = context;
this.viewModelFactory = viewModelFactory;
this.error = error;
this.configService = configService;
this.loggerService = loggerService;
this.dragAndDrop = dragAndDrop;
}
collection;
title = '';
currentState = CollectionViewState.List;
selectedDialogId;
actionButton = {
value: 'Actions',
doClick: () => this.toggleActionMenu(),
show: () => true,
disabled: () => this.disableActions(),
tempDisabled: () => null,
title: () => this.actionsTooltip,
accesskey: 'a',
presentationHint: '',
showDialog: () => false
};
reloadButton = {
value: 'Reload',
doClick: () => this.reloadList(),
show: () => true,
disabled: () => null,
tempDisabled: () => null,
title: () => '',
accesskey: null,
presentationHint: '',
showDialog: () => false
};
firstButton = {
value: 'First',
doClick: () => this.pageFirst(),
show: () => true,
disabled: () => this.pageFirstDisabled(),
tempDisabled: () => null,
title: () => '',
accesskey: null,
presentationHint: '',
showDialog: () => false
};
previousButton = {
value: 'Previous',
doClick: () => this.pagePrevious(),
show: () => true,
disabled: () => this.pagePreviousDisabled(),
tempDisabled: () => null,
title: () => '',
accesskey: null,
presentationHint: '',
showDialog: () => false
};
nextButton = {
value: 'Next',
doClick: () => this.pageNext(),
show: () => true,
disabled: () => this.pageNextDisabled(),
tempDisabled: () => null,
title: () => '',
accesskey: null,
presentationHint: '',
showDialog: () => false
};
lastButton = {
value: 'Last',
doClick: () => this.pageLast(),
show: () => true,
disabled: () => this.pageLastDisabled(),
tempDisabled: () => null,
title: () => '',
accesskey: null,
presentationHint: '',
showDialog: () => false
};
activatedRouteDataSub;
paneRouteDataSub;
lastPaneRouteData;
toggleActionMenu = () => this.collection.toggleActionMenu();
reloadList = () => this.collection.reload();
pageFirst = () => this.collection.pageFirst();
pagePrevious = () => this.collection.pagePrevious();
pageNext = () => this.collection.pageNext();
pageLast = () => this.collection.pageLast();
disableActions = () => this.collection.noActions() ? true : null;
hideAllCheckbox = () => this.collection.noActions() || !this.collection.items || this.collection.items.length === 0;
pageFirstDisabled = () => this.collection.pageFirstDisabled() ? true : null;
pagePreviousDisabled = () => this.collection.pagePreviousDisabled() ? true : null;
pageNextDisabled = () => this.collection.pageNextDisabled() ? true : null;
pageLastDisabled = () => this.collection.pageLastDisabled() ? true : null;
showActions = () => this.collection.showActions();
doTable = () => this.collection.doTable();
doList = () => this.collection.doList();
doSummary = () => this.collection.doSummary();
hasTableData = () => this.collection.hasTableData();
get actionsTooltip() {
return this.collection.actionsTooltip();
}
get message() {
return this.collection.getMessage();
}
get description() {
return this.collection.description();
}
get size() {
return this.collection.size;
}
get items() {
return this.collection.items ?? [];
}
get header() {
return this.collection.header;
}
get actionHolders() {
return [this.actionButton, this.reloadButton, this.firstButton, this.previousButton, this.nextButton, this.lastButton];
}
get state() {
return CollectionViewState[this.currentState].toString().toLowerCase();
}
getActionExtensions(routeData) {
return routeData.objectId
? this.context.getActionExtensionsFromObject(routeData.paneId, Ro.ObjectIdWrapper.fromObjectId(routeData.objectId, this.configService.config.keySeparator), routeData.actionId)
: this.context.getActionExtensionsFromMenu(routeData.menuId, routeData.actionId);
}
setup(routeData) {
const cachedList = this.context.getCachedList(routeData.paneId, routeData.page, routeData.pageSize);
this.getActionExtensions(routeData)
.then((ext) => this.title = ext.friendlyName())
.catch((reject) => this.error.handleError(reject));
const listKey = this.urlManager.getListCacheIndex(routeData.paneId, routeData.page, routeData.pageSize);
if (this.collection && this.collection.id === listKey) {
// same collection/page
this.currentState = routeData.state;
this.collection.refresh(routeData);
}
else if (this.collection && cachedList) {
// same collection different page
this.currentState = routeData.state;
this.collection.reset(cachedList, routeData);
}
else if (cachedList) {
// new collection
this.collection = this.viewModelFactory.listViewModel(cachedList, routeData);
this.currentState = routeData.state;
this.collection.refresh(routeData);
}
else {
// should never get here
this.loggerService.throw('ListComponent:setup Missing cachedList');
}
if (this.collection) {
// if any previous messages clear them
this.collection.resetMessage();
}
this.selectedDialogId = routeData.dialogId;
}
setDropZones(ids) {
setTimeout(() => this.dropZones = ids);
}
// now this is a child investigate reworking so object is passed in from parent
ngOnInit() {
this.activatedRouteDataSub = this.activatedRoute.data.subscribe(d => {
const data = d;
const paneId = data.pane;
if (!this.paneRouteDataSub) {
this.paneRouteDataSub =
this.urlManager.getPaneRouteDataObservable(paneId)
.subscribe((paneRouteData) => {
if (!paneRouteData.isEqual(this.lastPaneRouteData)) {
this.lastPaneRouteData = paneRouteData;
this.setup(paneRouteData);
}
});
}
});
this.ddSub = this.dragAndDrop.dropZoneIds$.subscribe(ids => this.setDropZones(ids || []));
}
ngOnDestroy() {
safeUnsubscribe(this.paneRouteDataSub);
safeUnsubscribe(this.activatedRouteDataSub);
safeUnsubscribe(this.ddSub);
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ListComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.UrlManagerService }, { token: i2.ContextService }, { token: i3.ViewModelFactoryService }, { token: i2.ErrorService }, { token: i2.ConfigService }, { token: i2.LoggerService }, { token: i3.DragAndDropService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: ListComponent, selector: "nof-list", ngImport: i0, template: "<ng-container *ngIf=\"collection\">\n <div class=\"list\">\n <header class=\"header\">\n <div class=\"title\">{{title}}</div>\n <nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n <div class=\"messages\">{{message}}</div>\n </header>\n <div class=\"details\" *ngIf=\"size === 0\">{{description}}</div>\n <ng-container *ngIf=\"size > 0\">\n <nof-action-list *ngIf=\"showActions()\" [menuHolder]=\"collection\"></nof-action-list>\n <nof-dialog [parentVM]=\"collection\" [selectedDialogId]=\"selectedDialogId\"></nof-dialog>\n <div class=\"summary\">\n <div class=\"details\">{{description}}</div>\n <div *ngIf=\"state === 'list'\" class=\"icon table\" (click)=\"doTable()\" title=\"View as Table\" alt=\"View as Table\"></div>\n <div *ngIf=\"state === 'table'\" class=\"icon list\" (click)=\"doList()\" title=\"View as List\" alt=\"View as List\"></div>\n </div>\n <table>\n <thead>\n <tr nof-header [collection]=\"collection\" [state]=\"currentState\"></tr>\n </thead>\n <tbody *ngIf=\"state === 'list' || hasTableData()\" cdkDropList [cdkDropListConnectedTo]=\"dropZones\" [cdkDropListOrientation]=\"'horizontal'\">\n <tr *ngFor=\"let item of items; let i = index\" cdkDrag [cdkDragData]=\"item\" nof-row [item]=\"item\" [row]=\"i\" [withCheckbox]=\"!disableActions()\" [isTable]=\"state === 'table'\"></tr>\n </tbody>\n </table>\n </ng-container>\n </div>\n</ng-container>", styles: [".list{color:#fff;padding-left:var(--space-5);height:100%;overflow-y:auto;display:block;font-weight:var(--font-weight-1)}.header{display:block;margin-bottom:var(--space-5);overflow:hidden;color:var(--contrast-text-color);background-color:var(--header-background-color)}.title,.type{position:relative;font-weight:var(--font-weight-1);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}.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-size:var(--font-size-3)}.menu:disabled,.ok:disabled{color:var(--disabled-color)}.summary{display:block;width:var(--table-width);font-size:var(--font-size-2);margin-bottom:var(--space-4);overflow:hidden}.details{padding-left:40px;width:var(--table-width);float:left}.icon{display:block;cursor:pointer;float:right;width:20px;height:var(--field-value-height);padding-top:var(--space-3);padding-left:var(--space-3);margin-right:var(--space-3)}.icon.list{background:var(--list-icon);background-size:cover}.icon.table{background:var(--table-icon);background-size:cover}\n"], dependencies: [{ 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: i5.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i5.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i6.ActionListComponent, selector: "nof-action-list", inputs: ["menuHolder"] }, { kind: "component", type: i7.ActionBarComponent, selector: "nof-action-bar", inputs: ["actions", "menuHolder"] }, { kind: "component", type: i8.DialogComponent, selector: "nof-dialog", inputs: ["parentVM"] }, { kind: "component", type: i9.RowComponent, selector: "[nof-row]", inputs: ["item", "row", "withCheckbox", "isTable"] }, { kind: "component", type: i10.HeaderComponent, selector: "[nof-header]", inputs: ["collection", "state"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ListComponent, decorators: [{
type: Component,
args: [{ selector: 'nof-list', template: "<ng-container *ngIf=\"collection\">\n <div class=\"list\">\n <header class=\"header\">\n <div class=\"title\">{{title}}</div>\n <nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n <div class=\"messages\">{{message}}</div>\n </header>\n <div class=\"details\" *ngIf=\"size === 0\">{{description}}</div>\n <ng-container *ngIf=\"size > 0\">\n <nof-action-list *ngIf=\"showActions()\" [menuHolder]=\"collection\"></nof-action-list>\n <nof-dialog [parentVM]=\"collection\" [selectedDialogId]=\"selectedDialogId\"></nof-dialog>\n <div class=\"summary\">\n <div class=\"details\">{{description}}</div>\n <div *ngIf=\"state === 'list'\" class=\"icon table\" (click)=\"doTable()\" title=\"View as Table\" alt=\"View as Table\"></div>\n <div *ngIf=\"state === 'table'\" class=\"icon list\" (click)=\"doList()\" title=\"View as List\" alt=\"View as List\"></div>\n </div>\n <table>\n <thead>\n <tr nof-header [collection]=\"collection\" [state]=\"currentState\"></tr>\n </thead>\n <tbody *ngIf=\"state === 'list' || hasTableData()\" cdkDropList [cdkDropListConnectedTo]=\"dropZones\" [cdkDropListOrientation]=\"'horizontal'\">\n <tr *ngFor=\"let item of items; let i = index\" cdkDrag [cdkDragData]=\"item\" nof-row [item]=\"item\" [row]=\"i\" [withCheckbox]=\"!disableActions()\" [isTable]=\"state === 'table'\"></tr>\n </tbody>\n </table>\n </ng-container>\n </div>\n</ng-container>", styles: [".list{color:#fff;padding-left:var(--space-5);height:100%;overflow-y:auto;display:block;font-weight:var(--font-weight-1)}.header{display:block;margin-bottom:var(--space-5);overflow:hidden;color:var(--contrast-text-color);background-color:var(--header-background-color)}.title,.type{position:relative;font-weight:var(--font-weight-1);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}.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-size:var(--font-size-3)}.menu:disabled,.ok:disabled{color:var(--disabled-color)}.summary{display:block;width:var(--table-width);font-size:var(--font-size-2);margin-bottom:var(--space-4);overflow:hidden}.details{padding-left:40px;width:var(--table-width);float:left}.icon{display:block;cursor:pointer;float:right;width:20px;height:var(--field-value-height);padding-top:var(--space-3);padding-left:var(--space-3);margin-right:var(--space-3)}.icon.list{background:var(--list-icon);background-size:cover}.icon.table{background:var(--table-icon);background-size:cover}\n"] }]
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.UrlManagerService }, { type: i2.ContextService }, { type: i3.ViewModelFactoryService }, { type: i2.ErrorService }, { type: i2.ConfigService }, { type: i2.LoggerService }, { type: i3.DragAndDropService }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"","sources":["../../../../gemini/src/list/list.component.ts","../../../../gemini/src/list/list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAqB,MAAM,eAAe,CAAC;AAE7D,OAAO,KAAK,EAAE,MAAM,+BAA+B,CAAC;AACpD,OAAO,EACH,mBAAmB,EAStB,MAAM,wBAAwB,CAAC;AAIhC,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;;;;;;;;;;;;AAOxD,MAAM,OAAO,aAAa;IAMD;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IAXb,KAAK,CAAiB;IAC9B,SAAS,GAAa,EAAE,CAAC;IAEzB,YACqB,cAA8B,EAC9B,UAA6B,EAC7B,OAAuB,EACvB,gBAAyC,EACzC,KAAmB,EACnB,aAA4B,EAC5B,aAA4B,EAC5B,WAA+B;QAP/B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,eAAU,GAAV,UAAU,CAAmB;QAC7B,YAAO,GAAP,OAAO,CAAgB;QACvB,qBAAgB,GAAhB,gBAAgB,CAAyB;QACzC,UAAK,GAAL,KAAK,CAAc;QACnB,kBAAa,GAAb,aAAa,CAAe;QAC5B,kBAAa,GAAb,aAAa,CAAe;QAC5B,gBAAW,GAAX,WAAW,CAAoB;IAEpD,CAAC;IAED,UAAU,CAAiB;IAC3B,KAAK,GAAG,EAAE,CAAC;IACX,YAAY,GAAI,mBAAmB,CAAC,IAAI,CAAC;IACzC,gBAAgB,CAAU;IAElB,YAAY,GAAkB;QAClC,KAAK,EAAE,SAAS;QAChB,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE;QACtC,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI;QAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE;QACrC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI;QACxB,KAAK,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc;QAChC,SAAS,EAAE,GAAG;QACd,gBAAgB,EAAE,EAAE;QACpB,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK;KAC1B,CAAC;IAEM,YAAY,GAAkB;QAClC,KAAK,EAAE,QAAQ;QACf,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE;QAChC,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI;QAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI;QACpB,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI;QACxB,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE;QACf,SAAS,EAAE,IAAI;QACf,gBAAgB,EAAE,EAAE;QACpB,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK;KAC1B,CAAC;IAEM,WAAW,GAAkB;QACjC,KAAK,EAAE,OAAO;QACd,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE;QAC/B,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI;QAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE;QACxC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI;QACxB,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE;QACf,SAAS,EAAE,IAAI;QACf,gBAAgB,EAAE,EAAE;QACpB,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK;KAC1B,CAAC;IAEM,cAAc,GAAkB;QACpC,KAAK,EAAE,UAAU;QACjB,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE;QAClC,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI;QAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE;QAC3C,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI;QACxB,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE;QACf,SAAS,EAAE,IAAI;QACf,gBAAgB,EAAE,EAAE;QACpB,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK;KAC1B,CAAC;IAEM,UAAU,GAAkB;QAChC,KAAK,EAAE,MAAM;QACb,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE;QAC9B,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI;QAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE;QACvC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI;QACxB,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE;QACf,SAAS,EAAE,IAAI;QACf,gBAAgB,EAAE,EAAE;QACpB,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK;KAC1B,CAAC;IAEM,UAAU,GAAkB;QAChC,KAAK,EAAE,MAAM;QACb,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE;QAC9B,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI;QAChB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE;QACvC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI;QACxB,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE;QACf,SAAS,EAAE,IAAI;QACf,gBAAgB,EAAE,EAAE;QACpB,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK;KAC1B,CAAC;IAGM,qBAAqB,CAAiB;IACtC,gBAAgB,CAAiB;IACjC,iBAAiB,CAAiB;IAE1C,gBAAgB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;IAC5D,UAAU,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;IAC5C,SAAS,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;IAC9C,YAAY,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;IACpD,QAAQ,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAC5C,QAAQ,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAE5C,cAAc,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IACjE,eAAe,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC;IAEpH,iBAAiB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAC5E,oBAAoB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAClF,gBAAgB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1E,gBAAgB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAE1E,WAAW,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;IAElD,OAAO,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;IAC1C,MAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;IACxC,SAAS,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;IAE9C,YAAY,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;IAEpD,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;IAC5C,CAAC;IAED,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC;IACxC,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;IACzC,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;IAChC,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,IAAI,EAAE,CAAC;IACvC,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAClC,CAAC;IAED,IAAI,aAAa;QACb,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3H,CAAC;IAED,IAAI,KAAK;QACL,OAAO,mBAAmB,CAAC,IAAI,CAAC,YAAa,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC;IAC5E,CAAC;IAED,mBAAmB,CAAC,SAAwB;QACxC,OAAO,SAAS,CAAC,QAAQ;YACrB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,6BAA6B,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,QAAS,CAAC;YAChL,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,SAAS,CAAC,MAAO,EAAE,SAAS,CAAC,QAAS,CAAC,CAAC;IAC3F,CAAC;IAES,KAAK,CAAC,SAAwB;QACpC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,IAAK,EAAE,SAAS,CAAC,QAAS,CAAC,CAAC;QAEtG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC;aAC9B,IAAI,CAAC,CAAC,GAAkB,EAAE,EAAE,CACzB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,YAAY,EAAE,CAAC;aACnC,KAAK,CAAC,CAAC,MAAoB,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC;QAErE,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,IAAK,EAAE,SAAS,CAAC,QAAS,CAAC,CAAC;QAE1G,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,EAAE,KAAK,OAAO,EAAE,CAAC;YACpD,uBAAuB;YACvB,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC,KAAK,CAAC;YACpC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACvC,CAAC;aAAM,IAAI,IAAI,CAAC,UAAU,IAAI,UAAU,EAAE,CAAC;YACvC,iCAAiC;YACjC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC,KAAK,CAAC;YACpC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QACjD,CAAC;aAAM,IAAI,UAAU,EAAE,CAAC;YACpB,iBAAiB;YACjB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;YAC7E,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC,KAAK,CAAC;YACpC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACvC,CAAC;aAAM,CAAC;YACJ,wBAAwB;YACxB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;QACvE,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,sCAAsC;YACtC,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;QACnC,CAAC;QAED,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC,QAAQ,CAAC;IAC/C,CAAC;IAED,YAAY,CAAC,GAAa;QACtB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC;IAC3C,CAAC;IAED,+EAA+E;IAC/E,QAAQ;QACJ,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAChE,MAAM,IAAI,GAAG,CAA8B,CAAC;YAC5C,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC;YAEzB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACzB,IAAI,CAAC,gBAAgB;oBACjB,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,MAAM,CAAC;yBAC7C,SAAS,CAAC,CAAC,aAA4B,EAAE,EAAE;wBACxC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC;4BACjD,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;4BACvC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;wBAC9B,CAAC;oBACL,CAAC,CAAC,CAAC;YACf,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;IAC9F,CAAC;IAED,WAAW;QACP,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACvC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAC5C,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;uGAjOQ,aAAa;2FAAb,aAAa,gDCxB1B,sqDA0Be;;2FDFF,aAAa;kBALzB,SAAS;+BACI,UAAU","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport * as Ro from '@nakedobjects/restful-objects';\nimport {\n    CollectionViewState,\n    ConfigService,\n    ContextService,\n    ErrorService,\n    ErrorWrapper,\n    ICustomActivatedRouteData,\n    LoggerService,\n    PaneRouteData,\n    UrlManagerService\n} from '@nakedobjects/services';\nimport { ItemViewModel, ListViewModel, ViewModelFactoryService, DragAndDropService } from '@nakedobjects/view-models';\nimport { SubscriptionLike as ISubscription } from 'rxjs';\nimport { IActionHolder } from '../action/action.component';\nimport { safeUnsubscribe } from '../helpers-components';\n\n@Component({\n    selector: 'nof-list',\n    templateUrl: 'list.component.html',\n    styleUrls: ['list.component.css']\n})\nexport class ListComponent implements OnInit, OnDestroy {\n\n    private ddSub?: ISubscription;\n    dropZones: string[] = [];\n\n    constructor(\n        private readonly activatedRoute: ActivatedRoute,\n        private readonly urlManager: UrlManagerService,\n        private readonly context: ContextService,\n        private readonly viewModelFactory: ViewModelFactoryService,\n        private readonly error: ErrorService,\n        private readonly configService: ConfigService,\n        private readonly loggerService: LoggerService,\n        private readonly dragAndDrop: DragAndDropService\n    ) {\n    }\n\n    collection!: ListViewModel;\n    title = '';\n    currentState? = CollectionViewState.List;\n    selectedDialogId?: string;\n\n    private actionButton: IActionHolder = {\n        value: 'Actions',\n        doClick: () => this.toggleActionMenu(),\n        show: () => true,\n        disabled: () => this.disableActions(),\n        tempDisabled: () => null,\n        title: () => this.actionsTooltip,\n        accesskey: 'a',\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private reloadButton: IActionHolder = {\n        value: 'Reload',\n        doClick: () => this.reloadList(),\n        show: () => true,\n        disabled: () => null,\n        tempDisabled: () => null,\n        title: () => '',\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private firstButton: IActionHolder = {\n        value: 'First',\n        doClick: () => this.pageFirst(),\n        show: () => true,\n        disabled: () => this.pageFirstDisabled(),\n        tempDisabled: () => null,\n        title: () => '',\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private previousButton: IActionHolder = {\n        value: 'Previous',\n        doClick: () => this.pagePrevious(),\n        show: () => true,\n        disabled: () => this.pagePreviousDisabled(),\n        tempDisabled: () => null,\n        title: () => '',\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private nextButton: IActionHolder = {\n        value: 'Next',\n        doClick: () => this.pageNext(),\n        show: () => true,\n        disabled: () => this.pageNextDisabled(),\n        tempDisabled: () => null,\n        title: () => '',\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private lastButton: IActionHolder = {\n        value: 'Last',\n        doClick: () => this.pageLast(),\n        show: () => true,\n        disabled: () => this.pageLastDisabled(),\n        tempDisabled: () => null,\n        title: () => '',\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    \n    private activatedRouteDataSub?: ISubscription;\n    private paneRouteDataSub?: ISubscription;\n    private lastPaneRouteData?: PaneRouteData;\n\n    toggleActionMenu = () => this.collection.toggleActionMenu();\n    reloadList = () => this.collection.reload();\n    pageFirst = () => this.collection.pageFirst();\n    pagePrevious = () => this.collection.pagePrevious();\n    pageNext = () => this.collection.pageNext();\n    pageLast = () => this.collection.pageLast();\n\n    disableActions = () => this.collection.noActions() ? true : null;\n    hideAllCheckbox = () => this.collection.noActions() || !this.collection.items || this.collection.items.length === 0;\n\n    pageFirstDisabled = () => this.collection.pageFirstDisabled() ? true : null;\n    pagePreviousDisabled = () => this.collection.pagePreviousDisabled() ? true : null;\n    pageNextDisabled = () => this.collection.pageNextDisabled() ? true : null;\n    pageLastDisabled = () => this.collection.pageLastDisabled() ? true : null;\n\n    showActions = () => this.collection.showActions();\n\n    doTable = () => this.collection.doTable();\n    doList = () => this.collection.doList();\n    doSummary = () => this.collection.doSummary();\n\n    hasTableData = () => this.collection.hasTableData();\n\n    get actionsTooltip() {\n        return this.collection.actionsTooltip();\n    }\n\n    get message() {\n        return this.collection.getMessage();\n    }\n\n    get description() {\n        return this.collection.description();\n    }\n\n    get size() {\n        return this.collection.size;\n    }\n\n    get items(): ItemViewModel[] {\n        return this.collection.items ?? [];\n    }\n\n    get header() {\n        return this.collection.header;\n    }\n\n    get actionHolders() {\n        return [this.actionButton, this.reloadButton, this.firstButton, this.previousButton, this.nextButton, this.lastButton];\n    }\n\n    get state() {\n        return CollectionViewState[this.currentState!].toString().toLowerCase();\n    }\n\n    getActionExtensions(routeData: PaneRouteData): Promise<Ro.Extensions> {\n        return routeData.objectId\n            ? this.context.getActionExtensionsFromObject(routeData.paneId, Ro.ObjectIdWrapper.fromObjectId(routeData.objectId, this.configService.config.keySeparator), routeData.actionId!)\n            : this.context.getActionExtensionsFromMenu(routeData.menuId!, routeData.actionId!);\n    }\n\n    protected setup(routeData: PaneRouteData) {\n        const cachedList = this.context.getCachedList(routeData.paneId, routeData.page!, routeData.pageSize!);\n\n        this.getActionExtensions(routeData)\n            .then((ext: Ro.Extensions) =>\n                this.title = ext.friendlyName())\n            .catch((reject: ErrorWrapper) => this.error.handleError(reject));\n\n        const listKey = this.urlManager.getListCacheIndex(routeData.paneId, routeData.page!, routeData.pageSize!);\n\n        if (this.collection && this.collection.id === listKey) {\n            // same collection/page\n            this.currentState = routeData.state;\n            this.collection.refresh(routeData);\n        } else if (this.collection && cachedList) {\n            // same collection different page\n            this.currentState = routeData.state;\n            this.collection.reset(cachedList, routeData);\n        } else if (cachedList) {\n            // new collection\n            this.collection = this.viewModelFactory.listViewModel(cachedList, routeData);\n            this.currentState = routeData.state;\n            this.collection.refresh(routeData);\n        } else {\n            // should never get here\n            this.loggerService.throw('ListComponent:setup Missing cachedList');\n        }\n\n        if (this.collection) {\n            // if any previous messages clear them\n            this.collection.resetMessage();\n        }\n\n        this.selectedDialogId = routeData.dialogId;\n    }\n\n    setDropZones(ids: string[]) {\n        setTimeout(() => this.dropZones = ids);\n    }\n\n    // now this is a child investigate reworking so object is passed in from parent\n    ngOnInit(): void {\n        this.activatedRouteDataSub = this.activatedRoute.data.subscribe(d => {\n            const data = d as ICustomActivatedRouteData;\n            const paneId = data.pane;\n\n            if (!this.paneRouteDataSub) {\n                this.paneRouteDataSub =\n                    this.urlManager.getPaneRouteDataObservable(paneId)\n                        .subscribe((paneRouteData: PaneRouteData) => {\n                            if (!paneRouteData.isEqual(this.lastPaneRouteData)) {\n                                this.lastPaneRouteData = paneRouteData;\n                                this.setup(paneRouteData);\n                            }\n                        });\n            }\n        });\n\n        this.ddSub = this.dragAndDrop.dropZoneIds$.subscribe(ids => this.setDropZones(ids || []));\n    }\n\n    ngOnDestroy(): void {\n        safeUnsubscribe(this.paneRouteDataSub);\n        safeUnsubscribe(this.activatedRouteDataSub);\n        safeUnsubscribe(this.ddSub);\n    }\n}\n","<ng-container *ngIf=\"collection\">\n    <div class=\"list\">\n        <header class=\"header\">\n            <div class=\"title\">{{title}}</div>\n            <nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n            <div class=\"messages\">{{message}}</div>\n        </header>\n        <div class=\"details\" *ngIf=\"size === 0\">{{description}}</div>\n        <ng-container *ngIf=\"size > 0\">\n            <nof-action-list *ngIf=\"showActions()\" [menuHolder]=\"collection\"></nof-action-list>\n            <nof-dialog [parentVM]=\"collection\" [selectedDialogId]=\"selectedDialogId\"></nof-dialog>\n            <div class=\"summary\">\n                <div class=\"details\">{{description}}</div>\n                <div *ngIf=\"state === 'list'\" class=\"icon table\" (click)=\"doTable()\"  title=\"View as Table\" alt=\"View as Table\"></div>\n                <div *ngIf=\"state === 'table'\" class=\"icon list\" (click)=\"doList()\"  title=\"View as List\" alt=\"View as List\"></div>\n             </div>\n             <table>\n                    <thead>\n                        <tr nof-header [collection]=\"collection\" [state]=\"currentState\"></tr>\n                    </thead>\n                    <tbody *ngIf=\"state === 'list' || hasTableData()\" cdkDropList [cdkDropListConnectedTo]=\"dropZones\" [cdkDropListOrientation]=\"'horizontal'\">\n                        <tr *ngFor=\"let item of items; let i = index\" cdkDrag [cdkDragData]=\"item\" nof-row [item]=\"item\" [row]=\"i\" [withCheckbox]=\"!disableActions()\" [isTable]=\"state === 'table'\"></tr>\n                    </tbody>\n                </table>\n        </ng-container>\n    </div>\n</ng-container>"]}