@trudb/tru-common-lib 0.0.810 → 0.0.813
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "../../services/tru-data-context";
|
|
4
|
-
import * as i2 from "../../services/tru-
|
|
5
|
-
import * as i3 from "../../
|
|
4
|
+
import * as i2 from "../../services/tru-app-environment";
|
|
5
|
+
import * as i3 from "../../services/tru-text-manager";
|
|
6
|
+
import * as i4 from "../../components/desktop/services/tru-window-event-handler";
|
|
6
7
|
export class TruDetailViewBase {
|
|
7
8
|
dataContext;
|
|
9
|
+
appEnvironment;
|
|
8
10
|
textManager;
|
|
9
11
|
windowEventHandler;
|
|
10
12
|
view;
|
|
@@ -16,11 +18,26 @@ export class TruDetailViewBase {
|
|
|
16
18
|
disableNavigationToPreviousEntity = false;
|
|
17
19
|
disableNavigationToNextEntity = false;
|
|
18
20
|
navigationIndex = 0;
|
|
19
|
-
|
|
21
|
+
recordsBeforeRevert = 0;
|
|
22
|
+
subs = [];
|
|
23
|
+
constructor(dataContext, appEnvironment, textManager, windowEventHandler) {
|
|
20
24
|
this.dataContext = dataContext;
|
|
25
|
+
this.appEnvironment = appEnvironment;
|
|
21
26
|
this.textManager = textManager;
|
|
22
27
|
this.windowEventHandler = windowEventHandler;
|
|
23
28
|
}
|
|
29
|
+
calculateNextIndex = () => {
|
|
30
|
+
let nextIndex = 0;
|
|
31
|
+
var removedRecords = this.recordsBeforeRevert - this.entities.length;
|
|
32
|
+
if (this.navigationIndex > this.entities.length - 1)
|
|
33
|
+
nextIndex = this.entities.length - 1;
|
|
34
|
+
else {
|
|
35
|
+
nextIndex = (this.navigationIndex - removedRecords);
|
|
36
|
+
}
|
|
37
|
+
if (nextIndex < 0)
|
|
38
|
+
nextIndex = 0;
|
|
39
|
+
return nextIndex;
|
|
40
|
+
};
|
|
24
41
|
onAddEntity = () => {
|
|
25
42
|
let newEntity = this.dataContext.entityAccess().add(this.entityType);
|
|
26
43
|
this.entities.splice(this.navigationIndex + 1, 0, newEntity);
|
|
@@ -48,6 +65,19 @@ export class TruDetailViewBase {
|
|
|
48
65
|
this.setNavigationIndex(index);
|
|
49
66
|
this.setEntityDisplayValues(this.tableName);
|
|
50
67
|
};
|
|
68
|
+
subscribe() {
|
|
69
|
+
this.subs.push(this.appEnvironment.onRevertComplete$.subscribe((event) => {
|
|
70
|
+
if (event?.successful && this.view.entities) {
|
|
71
|
+
this.recordsBeforeRevert = this.entities.length;
|
|
72
|
+
this.entities = this.entities.filter((e) => { return !e.entityAspect.entityState.isDetached(); });
|
|
73
|
+
this.setNavigationIndex(this.calculateNextIndex());
|
|
74
|
+
}
|
|
75
|
+
}));
|
|
76
|
+
this.subs.push(this.view.onActive().subscribe((active) => {
|
|
77
|
+
if (active)
|
|
78
|
+
this.setEntityDisplayValues(this.tableName);
|
|
79
|
+
}));
|
|
80
|
+
}
|
|
51
81
|
setNavigationIndex(index) {
|
|
52
82
|
this.navigationIndex = index;
|
|
53
83
|
this.disableNavigationToPreviousEntity = index === 0;
|
|
@@ -71,13 +101,13 @@ export class TruDetailViewBase {
|
|
|
71
101
|
this.windowEventHandler.setWindowTitle(this.textManager.formatWindowTitle(title));
|
|
72
102
|
this.recordLocation = recordIndex + ' of ' + this.entities.length;
|
|
73
103
|
}
|
|
74
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDetailViewBase, deps: [{ token: i1.TruDataContext }, { token: i2.
|
|
104
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDetailViewBase, deps: [{ token: i1.TruDataContext }, { token: i2.TruAppEnvironment }, { token: i3.TruTextManager }, { token: i4.TruWindowEventHandler }], target: i0.ɵɵFactoryTarget.Component });
|
|
75
105
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TruDetailViewBase, selector: "tru-detail-view-base", inputs: { view: "view" }, ngImport: i0, template: "", styles: [""] });
|
|
76
106
|
}
|
|
77
107
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDetailViewBase, decorators: [{
|
|
78
108
|
type: Component,
|
|
79
109
|
args: [{ selector: 'tru-detail-view-base', template: "" }]
|
|
80
|
-
}], ctorParameters: () => [{ type: i1.TruDataContext }, { type: i2.
|
|
110
|
+
}], ctorParameters: () => [{ type: i1.TruDataContext }, { type: i2.TruAppEnvironment }, { type: i3.TruTextManager }, { type: i4.TruWindowEventHandler }], propDecorators: { view: [{
|
|
81
111
|
type: Input
|
|
82
112
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWRldGFpbC12aWV3LWJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cnUtY29tbW9uLWxpYi9zcmMvbGliL2Jhc2Utdmlld3MvZGV0YWlsL3RydS1kZXRhaWwtdmlldy1iYXNlLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJ1LWNvbW1vbi1saWIvc3JjL2xpYi9iYXNlLXZpZXdzL2RldGFpbC90cnUtZGV0YWlsLXZpZXctYmFzZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQVdqRCxNQUFNLE9BQU8saUJBQWlCO0lBYWhCO0lBQ0E7SUFDQTtJQWRILElBQUksQ0FBd0I7SUFFckMsU0FBUyxDQUFNO0lBQ2YsUUFBUSxHQUFlLEVBQUUsQ0FBQztJQUMxQixNQUFNLENBQU07SUFDWixVQUFVLENBQU07SUFDaEIsY0FBYyxHQUFrQixJQUFJLENBQUM7SUFDckMsaUNBQWlDLEdBQVksS0FBSyxDQUFDO0lBQ25ELDZCQUE2QixHQUFZLEtBQUssQ0FBQztJQUMvQyxlQUFlLEdBQVcsQ0FBQyxDQUFDO0lBRTVCLFlBQ1ksV0FBMkIsRUFDM0IsV0FBMkIsRUFDM0Isa0JBQXlDO1FBRnpDLGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtRQUMzQixnQkFBVyxHQUFYLFdBQVcsQ0FBZ0I7UUFDM0IsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUF1QjtJQUVyRCxDQUFDO0lBRUQsV0FBVyxHQUFHLEdBQUcsRUFBRTtRQUNqQixJQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDckUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLGVBQWUsR0FBRyxDQUFDLEVBQUUs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Q0FBQztJQUNwRSxDQUFDO3VHQTdFVSxpQkFBaUI7MkZBQWpCLGlCQUFpQixzRkNYOUIsRUFBQTs7MkZEV2EsaUJBQWlCO2tCQUw3QixTQUFTOytCQUNFLHNCQUFzQjtvSkFLdkIsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcnVEZXNrdG9wVmlld0NvbmZpZyB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvZGVza3RvcC9jbGFzc2VzL3RydS1kZXNrdG9wLXZpZXctY29uZmlnJztcclxuaW1wb3J0IHsgVHJ1V2luZG93RXZlbnRIYW5kbGVyIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9kZXNrdG9wL3NlcnZpY2VzL3RydS13aW5kb3ctZXZlbnQtaGFuZGxlcic7XHJcbmltcG9ydCB7IFRydURhdGFDb250ZXh0IH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdHJ1LWRhdGEtY29udGV4dCc7XHJcbmltcG9ydCB7IFRydVRleHRNYW5hZ2VyIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdHJ1LXRleHQtbWFuYWdlcic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3RydS1kZXRhaWwtdmlldy1iYXNlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdHJ1LWRldGFpbC12aWV3LWJhc2UuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdHJ1LWRldGFpbC12aWV3LWJhc2UuY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFRydURldGFpbFZpZXdCYXNlIHtcclxuICBASW5wdXQoKSB2aWV3ITogVHJ1RGVza3RvcFZpZXdDb25maWc7XHJcblxyXG4gIHRhYmxlTmFtZTogYW55O1xyXG4gIGVudGl0aWVzOiBBcnJheTxhbnk+ID0gW107XHJcbiAgZW50aXR5OiBhbnk7XHJcbiAgZW50aXR5VHlwZTogYW55O1xyXG4gIHJlY29yZExvY2F0aW9uOiBzdHJpbmcgfCBudWxsID0gbnVsbDtcclxuICBkaXNhYmxlTmF2aWdhdGlvblRvUHJldmlvdXNFbnRpdHk6IGJvb2xlYW4gPSBmYWxzZTtcclxuICBkaXNhYmxlTmF2aWdhdGlvblRvTmV4dEVudGl0eTogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIG5hdmlnYXRpb25JbmRleDogbnVtYmVyID0gMDtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcm90ZWN0ZWQgZGF0YUNvbnRleHQ6IFRydURhdGFDb250ZXh0LFxyXG4gICAgcHJvdGVjdGVkIHRleHRNYW5hZ2VyOiBUcnVUZXh0TWFuYWdlcixcclxuICAgIHByb3RlY3RlZCB3aW5kb3dFdmVudEhhbmRsZXI6IFRydVdpbmRvd0V2ZW50SGFuZGxlcikge1xyXG5cclxuICB9XHJcblxyXG4gIG9uQWRkRW50aXR5ID0gKCkgPT4ge1xyXG4gICAgbGV0IG5ld0VudGl0eSA9IHRoaXMuZGF0YUNvbnRleHQuZW50aXR5QWNjZXNzKCkuYWRkKHRoaXMuZW50aXR5VHlwZSk7XHJcbiAgICB0aGlzLmVudGl0aWVzLnNwbGljZSh0aGlzLm5hdmlnYXRpb25JbmRleCArIDEsIDAsIG5ld0VudGl0eSk7XHJcbiAgICB0aGlzLm5hdmlnYXRlVG8odGhpcy5uYXZpZ2F0aW9uSW5kZXggKyAxKTtcclxuICB9XHJcblxyXG4gIG9uQ2xvbmVFbnRpdHkgPSAoKSA9PiB7XHJcblxyXG4gIH1cclxuXHJcbiAgb25EZWxldGVFbnRpdHkgPSAoKSA9PiB7XHJcbiAgICBsZXQgY29uZmlybU1zZyA9IHRoaXMudGV4dE1hbmFnZXIuZm10RGVsZXRlQ29uZmlybWF0aW9uKHRoaXMuZW50aXR5VHlwZS5uYW1lKTtcclxuICAgIHRoaXMuZGF0YUNvbnRleHQuZGVsZXRlKFt0aGlzLmVudGl0eV0sIGNvbmZpcm1Nc2csICgpID0+IHsgcmV0dXJuIHRydWU7IH0pO1xyXG4gIH1cclxuXHJcbiAgb25GaXJzdEVudGl0eSA9ICgpID0+IHtcclxuICAgIHRoaXMubmF2aWdhdGVUbygwKTtcclxuICB9XHJcblxyXG4gIG9uUHJldmlvdXNFbnRpdHkgPSAoKSA9PiB7XHJcbiAgICB0aGlzLm5hdmlnYXRlVG8odGhpcy5uYXZpZ2F0aW9uSW5kZXggLSAxKTtcclxuICB9XHJcblxyXG4gIG9uTmV4dEVudGl0eSA9ICgpID0+IHtcclxuICAgIHRoaXMubmF2aWdhdGVUbyh0aGlzLm5hdmlnYXRpb25JbmRleCArIDEpO1xyXG4gIH1cclxuXHJcbiAgb25MYXN0RW50aXR5ID0gKCkgPT4ge1xyXG4gICAgdGhpcy5uYXZpZ2F0ZVRvKHRoaXMuZW50aXRpZXMubGVuZ3RoIC0gMSk7XHJcbiAgfVxyXG5cclxuICBuYXZpZ2F0ZVRvID0gKGluZGV4OiBudW1iZXIpID0+IHtcclxuICAgIHRoaXMuc2V0TmF2aWdhdGlvbkluZGV4KGluZGV4KTtcclxuICAgIHRoaXMuc2V0RW50aXR5RGlzcGxheVZhbHVlcyh0aGlzLnRhYmxlTmFtZSk7XHJcbiAgfVxyXG5cclxuICBzZXROYXZpZ2F0aW9uSW5kZXgoaW5kZXg6IG51bWJlcikge1xyXG4gICAgdGhpcy5uYXZpZ2F0aW9uSW5kZXggPSBpbmRleDtcclxuICAgIHRoaXMuZGlzYWJsZU5hdmlnYXRpb25Ub1ByZXZpb3VzRW50aXR5ID0gaW5kZXggPT09IDA7XHJcbiAgICB0aGlzLmRpc2FibGVOYXZpZ2F0aW9uVG9OZXh0RW50aXR5ID0gaW5kZXggPT09IHRoaXMuZW50aXRpZXMubGVuZ3RoIC0gMTtcclxuICAgIHRoaXMuZW50aXR5ID0gdGhpcy5lbnRpdGllc1t0aGlzLm5hdmlnYXRpb25JbmRleF07XHJcbiAgfVxyXG5cclxuICBzZXRFbnRpdHlEaXNwbGF5VmFsdWVzKHRhYmxlTmFtZTogc3RyaW5nKSB7XHJcbiAgICBsZXQgdGl0bGUgPSAnJztcclxuICAgIGxldCByZWNvcmRJbmRleCA9ICc/JztcclxuICAgIGxldCBlbnRpdHkgPSB0aGlzLmVudGl0aWVzW3RoaXMubmF2aWdhdGlvbkluZGV4XTtcclxuICAgIGlmIChlbnRpdHkpIHtcclxuICAgICAgdGl0bGUgPSB0YWJsZU5hbWUgKyAnIC0gJztcclxuICAgICAgaWYgKGVudGl0eS5lbnRpdHlBc3BlY3QuZW50aXR5U3RhdGUuaXNBZGRlZCgpKSB7XHJcbiAgICAgICAgdGl0bGUgKz0gJ05ldyBSZWNvcmQnO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHRpdGxlICs9IHRoaXMuZW50aXR5LkhJRDtcclxuICAgICAgfVxyXG4gICAgICByZWNvcmRJbmRleCA9ICh0aGlzLm5hdmlnYXRpb25JbmRleCArIDEpLnRvU3RyaW5nKCk7XHJcbiAgICB9XHJcbiAgICB0aGlzLndpbmRvd0V2ZW50SGFuZGxlci5zZXRXaW5kb3dUaXRsZSh0aGlzLnRleHRNYW5hZ2VyLmZvcm1hdFdpbmRvd1RpdGxlKHRpdGxlKSk7XHJcbiAgICB0aGlzLnJlY29yZExvY2F0aW9uID0gcmVjb3JkSW5kZXggKyAnIG9mICcgKyB0aGlzLmVudGl0aWVzLmxlbmd0aDtcclxuICB9XHJcbn1cclxuIiwiIl19
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-detail-view-base.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/base-views/detail/tru-detail-view-base.ts","../../../../../../projects/tru-common-lib/src/lib/base-views/detail/tru-detail-view-base.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { TruDesktopViewConfig } from '../../components/desktop/classes/tru-desktop-view-config';\r\nimport { TruWindowEventHandler } from '../../components/desktop/services/tru-window-event-handler';\r\nimport { TruAppEnvironment } from '../../services/tru-app-environment';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\nimport { TruTextManager } from '../../services/tru-text-manager';\r\n\r\n@Component({\r\n  selector: 'tru-detail-view-base',\r\n  templateUrl: './tru-detail-view-base.html',\r\n  styleUrls: ['./tru-detail-view-base.css']\r\n})\r\nexport class TruDetailViewBase {\r\n  @Input() view!: TruDesktopViewConfig;\r\n\r\n  tableName: any;\r\n  entities: Array<any> = [];\r\n  entity: any;\r\n  entityType: any;\r\n  recordLocation: string | null = null;\r\n  disableNavigationToPreviousEntity: boolean = false;\r\n  disableNavigationToNextEntity: boolean = false;\r\n  navigationIndex: number = 0;\r\n  recordsBeforeRevert: number = 0;\r\n  subs: Array<Subscription> = [];\r\n\r\n  constructor(\r\n    protected dataContext: TruDataContext,\r\n    protected appEnvironment: TruAppEnvironment,\r\n    protected textManager: TruTextManager,\r\n    protected windowEventHandler: TruWindowEventHandler) {\r\n  }\r\n\r\n  private calculateNextIndex = (): number => {\r\n    let nextIndex = 0;\r\n    var removedRecords = this.recordsBeforeRevert - this.entities.length;\r\n    if (this.navigationIndex > this.entities.length - 1)\r\n      nextIndex = this.entities.length - 1;\r\n    else {\r\n      nextIndex = (this.navigationIndex - removedRecords);\r\n    }\r\n\r\n    if (nextIndex < 0)\r\n      nextIndex = 0;\r\n\r\n    return nextIndex;\r\n  }\r\n\r\n  onAddEntity = () => {\r\n    let newEntity = this.dataContext.entityAccess().add(this.entityType);\r\n    this.entities.splice(this.navigationIndex + 1, 0, newEntity);\r\n    this.navigateTo(this.navigationIndex + 1);\r\n  }\r\n\r\n  onCloneEntity = () => {\r\n\r\n  }\r\n\r\n  onDeleteEntity = () => {\r\n    let confirmMsg = this.textManager.fmtDeleteConfirmation(this.entityType.name);\r\n    this.dataContext.delete([this.entity], confirmMsg, () => { return true; });\r\n  }\r\n\r\n  onFirstEntity = () => {\r\n    this.navigateTo(0);\r\n  }\r\n\r\n  onPreviousEntity = () => {\r\n    this.navigateTo(this.navigationIndex - 1);\r\n  }\r\n\r\n  onNextEntity = () => {\r\n    this.navigateTo(this.navigationIndex + 1);\r\n  }\r\n\r\n  onLastEntity = () => {\r\n    this.navigateTo(this.entities.length - 1);\r\n  }\r\n\r\n  navigateTo = (index: number) => {\r\n    this.setNavigationIndex(index);\r\n    this.setEntityDisplayValues(this.tableName);\r\n  }\r\n\r\n  subscribe() {\r\n    this.subs.push(this.appEnvironment.onRevertComplete$.subscribe((event: any) => {\r\n      if (event?.successful && this.view.entities) {\r\n        this.recordsBeforeRevert = this.entities.length;\r\n        this.entities = this.entities.filter((e: any) => { return !e.entityAspect.entityState.isDetached() });\r\n        this.setNavigationIndex(this.calculateNextIndex());\r\n      }\r\n    }));\r\n    this.subs.push(this.view.onActive().subscribe((active: boolean) => {\r\n      if (active)\r\n        this.setEntityDisplayValues(this.tableName);\r\n    }));\r\n  }\r\n\r\n  setNavigationIndex(index: number) {\r\n    this.navigationIndex = index;\r\n    this.disableNavigationToPreviousEntity = index === 0;\r\n    this.disableNavigationToNextEntity = index === this.entities.length - 1;\r\n    this.entity = this.entities[this.navigationIndex];\r\n  }\r\n\r\n  setEntityDisplayValues(tableName: string) {\r\n    let title = '';\r\n    let recordIndex = '?';\r\n    let entity = this.entities[this.navigationIndex];\r\n    if (entity) {\r\n      title = tableName + ' - ';\r\n      if (entity.entityAspect.entityState.isAdded()) {\r\n        title += 'New Record';\r\n      } else {\r\n        title += this.entity.HID;\r\n      }\r\n      recordIndex = (this.navigationIndex + 1).toString();\r\n    }\r\n    this.windowEventHandler.setWindowTitle(this.textManager.formatWindowTitle(title));\r\n    this.recordLocation = recordIndex + ' of ' + this.entities.length;\r\n  }\r\n}\r\n",""]}
|
|
@@ -1547,6 +1547,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
|
|
|
1547
1547
|
|
|
1548
1548
|
class TruDetailViewBase {
|
|
1549
1549
|
dataContext;
|
|
1550
|
+
appEnvironment;
|
|
1550
1551
|
textManager;
|
|
1551
1552
|
windowEventHandler;
|
|
1552
1553
|
view;
|
|
@@ -1558,11 +1559,26 @@ class TruDetailViewBase {
|
|
|
1558
1559
|
disableNavigationToPreviousEntity = false;
|
|
1559
1560
|
disableNavigationToNextEntity = false;
|
|
1560
1561
|
navigationIndex = 0;
|
|
1561
|
-
|
|
1562
|
+
recordsBeforeRevert = 0;
|
|
1563
|
+
subs = [];
|
|
1564
|
+
constructor(dataContext, appEnvironment, textManager, windowEventHandler) {
|
|
1562
1565
|
this.dataContext = dataContext;
|
|
1566
|
+
this.appEnvironment = appEnvironment;
|
|
1563
1567
|
this.textManager = textManager;
|
|
1564
1568
|
this.windowEventHandler = windowEventHandler;
|
|
1565
1569
|
}
|
|
1570
|
+
calculateNextIndex = () => {
|
|
1571
|
+
let nextIndex = 0;
|
|
1572
|
+
var removedRecords = this.recordsBeforeRevert - this.entities.length;
|
|
1573
|
+
if (this.navigationIndex > this.entities.length - 1)
|
|
1574
|
+
nextIndex = this.entities.length - 1;
|
|
1575
|
+
else {
|
|
1576
|
+
nextIndex = (this.navigationIndex - removedRecords);
|
|
1577
|
+
}
|
|
1578
|
+
if (nextIndex < 0)
|
|
1579
|
+
nextIndex = 0;
|
|
1580
|
+
return nextIndex;
|
|
1581
|
+
};
|
|
1566
1582
|
onAddEntity = () => {
|
|
1567
1583
|
let newEntity = this.dataContext.entityAccess().add(this.entityType);
|
|
1568
1584
|
this.entities.splice(this.navigationIndex + 1, 0, newEntity);
|
|
@@ -1590,6 +1606,19 @@ class TruDetailViewBase {
|
|
|
1590
1606
|
this.setNavigationIndex(index);
|
|
1591
1607
|
this.setEntityDisplayValues(this.tableName);
|
|
1592
1608
|
};
|
|
1609
|
+
subscribe() {
|
|
1610
|
+
this.subs.push(this.appEnvironment.onRevertComplete$.subscribe((event) => {
|
|
1611
|
+
if (event?.successful && this.view.entities) {
|
|
1612
|
+
this.recordsBeforeRevert = this.entities.length;
|
|
1613
|
+
this.entities = this.entities.filter((e) => { return !e.entityAspect.entityState.isDetached(); });
|
|
1614
|
+
this.setNavigationIndex(this.calculateNextIndex());
|
|
1615
|
+
}
|
|
1616
|
+
}));
|
|
1617
|
+
this.subs.push(this.view.onActive().subscribe((active) => {
|
|
1618
|
+
if (active)
|
|
1619
|
+
this.setEntityDisplayValues(this.tableName);
|
|
1620
|
+
}));
|
|
1621
|
+
}
|
|
1593
1622
|
setNavigationIndex(index) {
|
|
1594
1623
|
this.navigationIndex = index;
|
|
1595
1624
|
this.disableNavigationToPreviousEntity = index === 0;
|
|
@@ -1613,13 +1642,13 @@ class TruDetailViewBase {
|
|
|
1613
1642
|
this.windowEventHandler.setWindowTitle(this.textManager.formatWindowTitle(title));
|
|
1614
1643
|
this.recordLocation = recordIndex + ' of ' + this.entities.length;
|
|
1615
1644
|
}
|
|
1616
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDetailViewBase, deps: [{ token: TruDataContext }, { token: TruTextManager }, { token: TruWindowEventHandler }], target: i0.ɵɵFactoryTarget.Component });
|
|
1645
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDetailViewBase, deps: [{ token: TruDataContext }, { token: TruAppEnvironment }, { token: TruTextManager }, { token: TruWindowEventHandler }], target: i0.ɵɵFactoryTarget.Component });
|
|
1617
1646
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TruDetailViewBase, selector: "tru-detail-view-base", inputs: { view: "view" }, ngImport: i0, template: "", styles: [""] });
|
|
1618
1647
|
}
|
|
1619
1648
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TruDetailViewBase, decorators: [{
|
|
1620
1649
|
type: Component,
|
|
1621
1650
|
args: [{ selector: 'tru-detail-view-base', template: "" }]
|
|
1622
|
-
}], ctorParameters: () => [{ type: TruDataContext }, { type: TruTextManager }, { type: TruWindowEventHandler }], propDecorators: { view: [{
|
|
1651
|
+
}], ctorParameters: () => [{ type: TruDataContext }, { type: TruAppEnvironment }, { type: TruTextManager }, { type: TruWindowEventHandler }], propDecorators: { view: [{
|
|
1623
1652
|
type: Input
|
|
1624
1653
|
}] } });
|
|
1625
1654
|
|