@nakedobjects/gemini
Version:
Single Page Application client for a Naked Objects application.
100 lines • 18.9 kB
JavaScript
import { Component, ViewChild, ViewContainerRef } from '@angular/core';
import * as Ro from '@nakedobjects/restful-objects';
import { ViewType } from '@nakedobjects/services';
import { PaneComponent } from '../pane/pane';
import * as i0 from "@angular/core";
import * as i1 from "@angular/router";
import * as i2 from "@nakedobjects/services";
import * as i3 from "../custom-component.service";
import * as i4 from "@angular/common";
import * as i5 from "../action-bar/action-bar.component";
export class DynamicListComponent extends PaneComponent {
error;
componentFactoryResolver;
customComponentService;
configService;
parent;
constructor(activatedRoute, urlManager, context, error, componentFactoryResolver, customComponentService, configService) {
super(activatedRoute, urlManager, context);
this.error = error;
this.componentFactoryResolver = componentFactoryResolver;
this.customComponentService = customComponentService;
this.configService = configService;
}
reloadPlaceholderButton = {
value: 'Reload',
doClick: () => this.reload(),
show: () => true,
disabled: () => null,
tempDisabled: () => null,
title: () => '',
accesskey: null,
presentationHint: '',
showDialog: () => false
};
lastOid = null;
title = '';
showPlaceholder = true;
cachedRouteData;
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);
}
reload() {
const recreate = () => this.cachedRouteData.objectId
? this.context.getListFromObject(this.cachedRouteData)
: this.context.getListFromMenu(this.cachedRouteData);
recreate()
.then(() => this.setup(this.cachedRouteData))
.catch((reject) => {
this.error.handleError(reject);
});
}
get actionHolders() {
return [this.reloadPlaceholderButton];
}
doSetup(routeData) {
return super.doSetup(routeData) ||
this.context.getCachedList(routeData.paneId, routeData.page, routeData.pageSize) == null;
}
setup(routeData) {
this.cachedRouteData = routeData;
const cachedList = this.context.getCachedList(routeData.paneId, routeData.page, routeData.pageSize);
if (cachedList) {
this.showPlaceholder = false;
const et = cachedList.extensions().elementType();
if (et && et !== this.lastOid) {
this.lastOid = et;
this.parent?.clear();
this.customComponentService.getCustomComponent(et, ViewType.List).then(c => {
const childComponent = this.componentFactoryResolver.resolveComponentFactory(c);
this.parent?.createComponent(childComponent);
});
}
}
else {
this.showPlaceholder = true;
this.title = 'List';
this.parent?.clear();
this.lastOid = null; // so we recreate child after reload
this.getActionExtensions(routeData)
.then((ext) => this.title = ext.friendlyName())
.catch((reject) => this.error.handleError(reject));
}
}
ngOnDestroy() {
super.ngOnDestroy();
this.parent?.clear();
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DynamicListComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.UrlManagerService }, { token: i2.ContextService }, { token: i2.ErrorService }, { token: i0.ComponentFactoryResolver }, { token: i3.CustomComponentService }, { token: i2.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DynamicListComponent, selector: "nof-dynamic-list", viewQueries: [{ propertyName: "parent", first: true, predicate: ["parent"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: "<div [attr.id]=\"paneIdName\" [ngClass]=\"paneType\">\n <div #parent></div>\n <div *ngIf=\"showPlaceholder\"class=\"list\">\n <div class=\"header\">\n <div class=\"title\">\n {{title}}\n </div>\n <nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n </div>\n </div>\n</div>\n<router-outlet (activate)=\"onChild()\" (deactivate)=\"onChildless()\"></router-outlet>\n", styles: [".list{color:var(--contrast-text-color);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}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "component", type: i5.ActionBarComponent, selector: "nof-action-bar", inputs: ["actions", "menuHolder"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DynamicListComponent, decorators: [{
type: Component,
args: [{ selector: 'nof-dynamic-list', template: "<div [attr.id]=\"paneIdName\" [ngClass]=\"paneType\">\n <div #parent></div>\n <div *ngIf=\"showPlaceholder\"class=\"list\">\n <div class=\"header\">\n <div class=\"title\">\n {{title}}\n </div>\n <nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n </div>\n </div>\n</div>\n<router-outlet (activate)=\"onChild()\" (deactivate)=\"onChildless()\"></router-outlet>\n", styles: [".list{color:var(--contrast-text-color);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}\n"] }]
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.UrlManagerService }, { type: i2.ContextService }, { type: i2.ErrorService }, { type: i0.ComponentFactoryResolver }, { type: i3.CustomComponentService }, { type: i2.ConfigService }], propDecorators: { parent: [{
type: ViewChild,
args: ['parent', { read: ViewContainerRef, static: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-list.component.js","sourceRoot":"","sources":["../../../../gemini/src/dynamic-list/dynamic-list.component.ts","../../../../gemini/src/dynamic-list/dynamic-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentFactoryResolver, OnDestroy, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Type } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport * as Ro from '@nakedobjects/restful-objects';\nimport { ConfigService, ContextService, ErrorService, ErrorWrapper, PaneRouteData, UrlManagerService, ViewType } from '@nakedobjects/services';\nimport { IActionHolder } from '../action/action.component';\nimport { CustomComponentService } from '../custom-component.service';\nimport { PaneComponent } from '../pane/pane';\n\n@Component({\n    selector: 'nof-dynamic-list',\n    templateUrl: 'dynamic-list.component.html',\n    styleUrls: ['dynamic-list.component.css']\n})\nexport class DynamicListComponent extends PaneComponent implements OnDestroy {\n\n    @ViewChild('parent', { read: ViewContainerRef, static : true })\n    parent?: ViewContainerRef;\n\n    constructor(\n        activatedRoute: ActivatedRoute,\n        urlManager: UrlManagerService,\n        context: ContextService,\n        private readonly error: ErrorService,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n        private readonly customComponentService: CustomComponentService,\n        private readonly configService: ConfigService) {\n        super(activatedRoute, urlManager, context);\n    }\n\n    private reloadPlaceholderButton: IActionHolder = {\n        value: 'Reload',\n        doClick: () => this.reload(),\n        show: () => true,\n        disabled: () => null,\n        tempDisabled: () => null,\n        title: () => '',\n        accesskey: null,\n        presentationHint: '',\n        showDialog: () => false\n    };\n\n    private lastOid: string | null = null;\n    title = '';\n    showPlaceholder = true;\n    private cachedRouteData!: PaneRouteData;\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    reload() {\n\n        const recreate = () =>\n            this.cachedRouteData!.objectId\n                ? this.context.getListFromObject(this.cachedRouteData)\n                : this.context.getListFromMenu(this.cachedRouteData);\n\n        recreate()\n            .then(() => this.setup(this.cachedRouteData))\n            .catch((reject: ErrorWrapper) => {\n                this.error.handleError(reject);\n            });\n    }\n\n    get actionHolders() {\n        return [this.reloadPlaceholderButton];\n    }\n\n    protected override doSetup(routeData: PaneRouteData) {\n        return super.doSetup(routeData) ||\n            this.context.getCachedList(routeData.paneId, routeData.page!, routeData.pageSize!) == null;\n    }\n\n    protected setup(routeData: PaneRouteData) {\n        this.cachedRouteData = routeData;\n        const cachedList = this.context.getCachedList(routeData.paneId, routeData.page!, routeData.pageSize!);\n\n        if (cachedList) {\n            this.showPlaceholder = false;\n            const et = cachedList.extensions().elementType();\n\n            if (et && et !== this.lastOid) {\n                this.lastOid = et;\n                this.parent?.clear();\n                this.customComponentService.getCustomComponent(et, ViewType.List).then(c => {\n                    const childComponent = this.componentFactoryResolver.resolveComponentFactory(c as Type<unknown>);\n                    this.parent?.createComponent(childComponent);\n                });\n            }\n\n        } else {\n            this.showPlaceholder = true;\n            this.title = 'List';\n            this.parent?.clear();\n            this.lastOid = null; // so we recreate child after reload\n            this.getActionExtensions(routeData)\n                .then((ext: Ro.Extensions) =>\n                    this.title = ext.friendlyName())\n                .catch((reject: ErrorWrapper) => this.error.handleError(reject));\n\n        }\n    }\n\n    override ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.parent?.clear();\n    }\n}\n","<div [attr.id]=\"paneIdName\" [ngClass]=\"paneType\">\n    <div #parent></div>\n    <div *ngIf=\"showPlaceholder\"class=\"list\">\n        <div class=\"header\">\n            <div class=\"title\">\n                {{title}}\n            </div>\n            <nof-action-bar [actions]=\"actionHolders\"></nof-action-bar>\n        </div>\n    </div>\n</div>\n<router-outlet (activate)=\"onChild()\" (deactivate)=\"onChildless()\"></router-outlet>\n"]}