ngx-vflow 1.10.0 → 1.11.0
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.
- package/esm2022/lib/vflow/components/edge/edge.component.mjs +3 -3
- package/esm2022/lib/vflow/components/node/node.component.mjs +3 -3
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +3 -9
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +3 -3
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +11 -3
- package/esm2022/lib/vflow/services/edge-rendering.service.mjs +1 -3
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +2 -6
- package/fesm2022/ngx-vflow.mjs +20 -262
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/vflow/vflow.component.d.ts +0 -4
- package/lib/vflow/public-components/resizable/resizable.component.d.ts +2 -0
- package/lib/vflow/services/edge-rendering.service.d.ts +0 -1
- package/lib/vflow/services/node-rendering.service.d.ts +0 -3
- package/package.json +1 -1
- package/esm2022/lib/vflow/directives/lazy-for.directive.mjs +0 -243
- package/esm2022/lib/vflow/utils/entities-per-frame.mjs +0 -2
- package/lib/vflow/directives/lazy-for.directive.d.ts +0 -94
- package/lib/vflow/utils/entities-per-frame.d.ts +0 -1
|
@@ -85,17 +85,13 @@ export declare class VflowComponent {
|
|
|
85
85
|
*/
|
|
86
86
|
set nodes(newNodes: Node[] | DynamicNode[]);
|
|
87
87
|
protected nodeModels: import("@angular/core").Signal<NodeModel<unknown>[]>;
|
|
88
|
-
protected nodesPerFrame: import("@angular/core").Signal<number>;
|
|
89
88
|
protected groups: import("@angular/core").Signal<NodeModel<unknown>[]>;
|
|
90
|
-
protected groupsPerFrame: import("@angular/core").Signal<number>;
|
|
91
89
|
protected nonGroups: import("@angular/core").Signal<NodeModel<unknown>[]>;
|
|
92
|
-
protected nonGroupsPerFrame: import("@angular/core").Signal<number>;
|
|
93
90
|
/**
|
|
94
91
|
* Edges to render
|
|
95
92
|
*/
|
|
96
93
|
set edges(newEdges: Edge[]);
|
|
97
94
|
protected edgeModels: import("@angular/core").Signal<EdgeModel[]>;
|
|
98
|
-
protected edgesPerFrame: import("@angular/core").Signal<number>;
|
|
99
95
|
/**
|
|
100
96
|
* Event that accumulates all custom node events
|
|
101
97
|
*
|
|
@@ -21,6 +21,8 @@ export declare class ResizableComponent implements OnInit, AfterViewInit {
|
|
|
21
21
|
private zoom;
|
|
22
22
|
private minWidth;
|
|
23
23
|
private minHeight;
|
|
24
|
+
private maxWidth;
|
|
25
|
+
private maxHeight;
|
|
24
26
|
protected resizeOnGlobalMouseMove: import("rxjs").Subscription;
|
|
25
27
|
protected endResizeOnGlobalMouseUp: import("rxjs").Subscription;
|
|
26
28
|
constructor();
|
|
@@ -3,7 +3,6 @@ import * as i0 from "@angular/core";
|
|
|
3
3
|
export declare class EdgeRenderingService {
|
|
4
4
|
private flowEntitiesService;
|
|
5
5
|
readonly edges: import("@angular/core").Signal<EdgeModel[]>;
|
|
6
|
-
readonly edgesPerFrame: import("@angular/core").Signal<number>;
|
|
7
6
|
private maxOrder;
|
|
8
7
|
pull(edge: EdgeModel): void;
|
|
9
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<EdgeRenderingService, never>;
|
|
@@ -5,9 +5,6 @@ export declare class NodeRenderingService {
|
|
|
5
5
|
readonly nodes: import("@angular/core").Signal<NodeModel<unknown>[]>;
|
|
6
6
|
readonly groups: import("@angular/core").Signal<NodeModel<unknown>[]>;
|
|
7
7
|
readonly nonGroups: import("@angular/core").Signal<NodeModel<unknown>[]>;
|
|
8
|
-
readonly nodesPerFrame: import("@angular/core").Signal<number>;
|
|
9
|
-
readonly groupsPerFrame: import("@angular/core").Signal<number>;
|
|
10
|
-
readonly nonGroupsPerFrame: import("@angular/core").Signal<number>;
|
|
11
8
|
private maxOrder;
|
|
12
9
|
pullNode(node: NodeModel): void;
|
|
13
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<NodeRenderingService, never>;
|
package/package.json
CHANGED
|
@@ -1,243 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectorRef, DestroyRef, Directive, inject, Input, IterableDiffers, TemplateRef, ViewContainerRef, isDevMode, } from '@angular/core';
|
|
2
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
|
-
import { Subject, animationFrames, bufferCount, concatMap, delayWhen, finalize, from, of, take, takeUntil, tap, } from 'rxjs';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
/** Enum with lazy render directive state */
|
|
6
|
-
var LazyForState;
|
|
7
|
-
(function (LazyForState) {
|
|
8
|
-
/** Directive is in idle state */
|
|
9
|
-
LazyForState["idle"] = "idle";
|
|
10
|
-
/** Directive is rendering */
|
|
11
|
-
LazyForState["rendering"] = "rendering";
|
|
12
|
-
})(LazyForState || (LazyForState = {}));
|
|
13
|
-
/**
|
|
14
|
-
* Context for an element in lazyFor
|
|
15
|
-
*/
|
|
16
|
-
class LazyForContextModel {
|
|
17
|
-
/** Whether the element is first */
|
|
18
|
-
get first() {
|
|
19
|
-
return this.index === 0;
|
|
20
|
-
}
|
|
21
|
-
/** Whether the element is last */
|
|
22
|
-
get last() {
|
|
23
|
-
return this.index === this.count - 1;
|
|
24
|
-
}
|
|
25
|
-
/** Whether the element is even */
|
|
26
|
-
get even() {
|
|
27
|
-
return this.index % 2 === 0;
|
|
28
|
-
}
|
|
29
|
-
/** Whether the element is odd */
|
|
30
|
-
get odd() {
|
|
31
|
-
return !this.even;
|
|
32
|
-
}
|
|
33
|
-
constructor($implicit, lazyFor, index, count) {
|
|
34
|
-
this.$implicit = $implicit;
|
|
35
|
-
this.lazyFor = lazyFor;
|
|
36
|
-
this.index = index;
|
|
37
|
-
this.count = count;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
export class LazyForDirective {
|
|
41
|
-
/**
|
|
42
|
-
* Asserts the correct type of the context for the template that `lazyFor` will render.
|
|
43
|
-
*
|
|
44
|
-
* The presence of this method is a signal to the Ivy template type-check compiler that the
|
|
45
|
-
* `lazyFor` structural directive renders its template with a specific context type.
|
|
46
|
-
*/
|
|
47
|
-
static ngTemplateContextGuard(dir, ctx) {
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
//#region INPUTS
|
|
51
|
-
/** Setter for the array to be rendered by the directive */
|
|
52
|
-
set lazyForOf(lazyFor) {
|
|
53
|
-
this._lazyFor = lazyFor;
|
|
54
|
-
this._lazyForDirty = true;
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Input - setter for TrackBy function
|
|
58
|
-
* @description is required
|
|
59
|
-
*/
|
|
60
|
-
set lazyForTrackBy(fn) {
|
|
61
|
-
if (isDevMode() && fn !== null && typeof fn !== 'function') {
|
|
62
|
-
console.warn(`trackBy must be a function, but received ${JSON.stringify(fn)}. ` +
|
|
63
|
-
`See https://angular.io/api/common/NgForOf#change-propagation for more information.`);
|
|
64
|
-
}
|
|
65
|
-
this._trackByFn = fn;
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Setter for the number of items that will be rendered per frame
|
|
69
|
-
* @param value number of items that will be rendered per frame
|
|
70
|
-
*/
|
|
71
|
-
set lazyForItemsPerFrame(value) {
|
|
72
|
-
if (value <= 0) {
|
|
73
|
-
if (isDevMode()) {
|
|
74
|
-
console.warn('Items per frame parameter cannot be lower than 0! Input value was ignored');
|
|
75
|
-
}
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
this._itemsPerFrame = value;
|
|
79
|
-
}
|
|
80
|
-
/** Setter for array item template */
|
|
81
|
-
set lazyForTemplate(value) {
|
|
82
|
-
if (value) {
|
|
83
|
-
this._template = value;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
/** Getter for TrackBy function */
|
|
87
|
-
get lazyForTrackBy() {
|
|
88
|
-
return this._trackByFn;
|
|
89
|
-
}
|
|
90
|
-
//#endregion
|
|
91
|
-
constructor() {
|
|
92
|
-
this._template = inject(TemplateRef);
|
|
93
|
-
this._viewContainer = inject(ViewContainerRef);
|
|
94
|
-
this._differs = inject(IterableDiffers);
|
|
95
|
-
this._cdr = inject(ChangeDetectorRef);
|
|
96
|
-
this._destroyRef$ = inject(DestroyRef);
|
|
97
|
-
//#region PROPERTIES
|
|
98
|
-
/** Array for rendering */
|
|
99
|
-
this._lazyFor = null;
|
|
100
|
-
/** lazyFor initialization flag */
|
|
101
|
-
this._lazyForDirty = true;
|
|
102
|
-
/** Differ for tracking changes in input array */
|
|
103
|
-
this._differ = null;
|
|
104
|
-
/** Number of items to be rendered per frame */
|
|
105
|
-
this._itemsPerFrame = 5;
|
|
106
|
-
/** Directive state */
|
|
107
|
-
this._lazyForState = LazyForState.idle;
|
|
108
|
-
//#endregion
|
|
109
|
-
//#region RXJS
|
|
110
|
-
/** Private subject for stopping dynamic render process */
|
|
111
|
-
this._rerenderUnsub$ = new Subject();
|
|
112
|
-
this._destroyRef$.onDestroy(() => this._viewContainer.clear());
|
|
113
|
-
}
|
|
114
|
-
/** ngDoCheck hook */
|
|
115
|
-
ngDoCheck() {
|
|
116
|
-
if (this._lazyForDirty) {
|
|
117
|
-
this._lazyForDirty = false;
|
|
118
|
-
const value = this._lazyFor;
|
|
119
|
-
if (!this._differ && value) {
|
|
120
|
-
this._differ = this._differs.find(value).create(this.lazyForTrackBy);
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
if (this._differ) {
|
|
124
|
-
let changes = this._differ.diff(this._lazyFor);
|
|
125
|
-
if (changes) {
|
|
126
|
-
if (this._lazyForState === LazyForState.rendering) {
|
|
127
|
-
/**
|
|
128
|
-
* If the array changed during an active render process
|
|
129
|
-
* Need to clear container of all views
|
|
130
|
-
* And restart rendering from the beginning.
|
|
131
|
-
*/
|
|
132
|
-
this._rerenderUnsub$.next();
|
|
133
|
-
changes = this._differ.diff([]);
|
|
134
|
-
changes = this._differ.diff(this._lazyFor);
|
|
135
|
-
this._viewContainer.clear();
|
|
136
|
-
if (changes) {
|
|
137
|
-
this.applyChanges(changes);
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
else {
|
|
141
|
-
this.applyChanges(changes);
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
/**
|
|
147
|
-
* Apply changes detected by differ
|
|
148
|
-
* @param changes changes
|
|
149
|
-
*/
|
|
150
|
-
applyChanges(changes) {
|
|
151
|
-
const itemDataListToRender = [];
|
|
152
|
-
changes.forEachOperation((item, adjustedPreviousIndex, currentIndex) => {
|
|
153
|
-
const itemToPush = {
|
|
154
|
-
item: { ...item },
|
|
155
|
-
adjustedPreviousIndex,
|
|
156
|
-
currentIndex,
|
|
157
|
-
};
|
|
158
|
-
itemDataListToRender.push(itemToPush);
|
|
159
|
-
});
|
|
160
|
-
this.performLazyRender(itemDataListToRender, changes);
|
|
161
|
-
}
|
|
162
|
-
/**
|
|
163
|
-
* Perform lazy rendering
|
|
164
|
-
* @param itemDataListToRender list of items to render
|
|
165
|
-
* @param changes changes
|
|
166
|
-
*/
|
|
167
|
-
performLazyRender(itemDataListToRender, changes) {
|
|
168
|
-
this.updateLazyForState(LazyForState.rendering);
|
|
169
|
-
this._rerenderUnsub$.next();
|
|
170
|
-
from(itemDataListToRender)
|
|
171
|
-
.pipe(bufferCount(this._itemsPerFrame), concatMap((itemList) => of(itemList).pipe(delayWhen(() => animationFrames()))), tap((itemList) => {
|
|
172
|
-
for (let i = 0; i < itemList.length; i++) {
|
|
173
|
-
const data = itemList[i];
|
|
174
|
-
if (data.item.previousIndex === null) {
|
|
175
|
-
this._viewContainer.createEmbeddedView(this._template, new LazyForContextModel(data.item.item, this._lazyFor, -1, -1), data.currentIndex === null ? undefined : data.currentIndex);
|
|
176
|
-
}
|
|
177
|
-
else if (data.currentIndex === null) {
|
|
178
|
-
this._viewContainer.remove(data.adjustedPreviousIndex === null ? undefined : data.adjustedPreviousIndex);
|
|
179
|
-
}
|
|
180
|
-
else if (data.adjustedPreviousIndex !== null) {
|
|
181
|
-
const view = this._viewContainer.get(data.adjustedPreviousIndex);
|
|
182
|
-
this._viewContainer.move(view, data.currentIndex);
|
|
183
|
-
this.applyViewChange(view, data.item);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
this.updateViewContext();
|
|
187
|
-
this._cdr.markForCheck();
|
|
188
|
-
}),
|
|
189
|
-
/** Using take we automatically unsubscribe from the stream when rendering is complete */
|
|
190
|
-
take(Math.ceil(itemDataListToRender.length / this._itemsPerFrame)), takeUntil(this._rerenderUnsub$), takeUntilDestroyed(this._destroyRef$), finalize(() => {
|
|
191
|
-
changes.forEachIdentityChange((record) => {
|
|
192
|
-
const viewRef = (this._viewContainer.get(record.currentIndex));
|
|
193
|
-
this.applyViewChange(viewRef, record);
|
|
194
|
-
});
|
|
195
|
-
this.updateLazyForState(LazyForState.idle);
|
|
196
|
-
}))
|
|
197
|
-
.subscribe();
|
|
198
|
-
}
|
|
199
|
-
/** Update context (without implicit$) for elements inside view */
|
|
200
|
-
updateViewContext() {
|
|
201
|
-
for (let i = 0, ilen = this._viewContainer.length; i < ilen; i++) {
|
|
202
|
-
const viewRef = (this._viewContainer.get(i));
|
|
203
|
-
const context = viewRef.context;
|
|
204
|
-
context.index = i;
|
|
205
|
-
context.count = ilen;
|
|
206
|
-
context.lazyFor = this._lazyFor;
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
/**
|
|
210
|
-
* Apply implicit$ context
|
|
211
|
-
* @param view view
|
|
212
|
-
* @param record data
|
|
213
|
-
*/
|
|
214
|
-
applyViewChange(view, record) {
|
|
215
|
-
view.context.$implicit = record.item;
|
|
216
|
-
}
|
|
217
|
-
/**
|
|
218
|
-
* Update directive state
|
|
219
|
-
* @param stateToSet state to set
|
|
220
|
-
*/
|
|
221
|
-
updateLazyForState(stateToSet) {
|
|
222
|
-
this._lazyForState = stateToSet;
|
|
223
|
-
}
|
|
224
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LazyForDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
225
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: LazyForDirective, isStandalone: true, selector: "[lazyFor][lazyForOf]", inputs: { lazyForOf: "lazyForOf", lazyForTrackBy: "lazyForTrackBy", lazyForItemsPerFrame: "lazyForItemsPerFrame", lazyForTemplate: "lazyForTemplate" }, ngImport: i0 }); }
|
|
226
|
-
}
|
|
227
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LazyForDirective, decorators: [{
|
|
228
|
-
type: Directive,
|
|
229
|
-
args: [{
|
|
230
|
-
selector: '[lazyFor][lazyForOf]',
|
|
231
|
-
standalone: true,
|
|
232
|
-
}]
|
|
233
|
-
}], ctorParameters: () => [], propDecorators: { lazyForOf: [{
|
|
234
|
-
type: Input
|
|
235
|
-
}], lazyForTrackBy: [{
|
|
236
|
-
type: Input,
|
|
237
|
-
args: [{ required: true }]
|
|
238
|
-
}], lazyForItemsPerFrame: [{
|
|
239
|
-
type: Input
|
|
240
|
-
}], lazyForTemplate: [{
|
|
241
|
-
type: Input
|
|
242
|
-
}] } });
|
|
243
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-for.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/lazy-for.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  DestroyRef,\n  Directive,\n  DoCheck,\n  EmbeddedViewRef,\n  inject,\n  Input,\n  IterableChangeRecord,\n  IterableChanges,\n  IterableDiffer,\n  IterableDiffers,\n  NgIterable,\n  TemplateRef,\n  TrackByFunction,\n  ViewContainerRef,\n  ViewRef,\n  isDevMode,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  Subject,\n  animationFrames,\n  bufferCount,\n  concatMap,\n  delayWhen,\n  finalize,\n  from,\n  of,\n  take,\n  takeUntil,\n  tap,\n} from 'rxjs';\n\n/** Enum with lazy render directive state */\nenum LazyForState {\n  /** Directive is in idle state */\n  idle = 'idle',\n  /** Directive is rendering */\n  rendering = 'rendering',\n}\n\n/**\n * Context for an element in lazyFor\n */\nclass LazyForContextModel<T, U extends NgIterable<T> = NgIterable<T>> {\n  /** Whether the element is first */\n  public get first(): boolean {\n    return this.index === 0;\n  }\n\n  /** Whether the element is last */\n  public get last(): boolean {\n    return this.index === this.count - 1;\n  }\n\n  /** Whether the element is even */\n  public get even(): boolean {\n    return this.index % 2 === 0;\n  }\n\n  /** Whether the element is odd */\n  public get odd(): boolean {\n    return !this.even;\n  }\n\n  constructor(\n    public $implicit: T,\n    public lazyFor: U,\n    public index: number,\n    public count: number,\n  ) {}\n}\n\ntype LazyForItem<T> = {\n  item: IterableChangeRecord<T>;\n  adjustedPreviousIndex: number | null;\n  currentIndex: number | null;\n};\n\n@Directive({\n  selector: '[lazyFor][lazyForOf]',\n  standalone: true,\n})\nexport class LazyForDirective<T, U extends NgIterable<T> = NgIterable<T>> implements DoCheck {\n  private _template = inject<TemplateRef<LazyForContextModel<T, U>>>(TemplateRef);\n  private _viewContainer = inject(ViewContainerRef);\n  private _differs = inject(IterableDiffers);\n  private _cdr = inject(ChangeDetectorRef);\n  private _destroyRef$ = inject(DestroyRef);\n\n  /**\n   * Asserts the correct type of the context for the template that `lazyFor` will render.\n   *\n   * The presence of this method is a signal to the Ivy template type-check compiler that the\n   * `lazyFor` structural directive renders its template with a specific context type.\n   */\n  public static ngTemplateContextGuard<T, U extends NgIterable<T>>(\n    dir: LazyForDirective<T, U>,\n    ctx: any,\n  ): ctx is LazyForContextModel<T, U> {\n    return true;\n  }\n\n  //#region INPUTS\n  /** Setter for the array to be rendered by the directive */\n  @Input()\n  public set lazyForOf(lazyFor: (U & NgIterable<T>) | undefined | null) {\n    this._lazyFor = lazyFor;\n    this._lazyForDirty = true;\n  }\n\n  /**\n   * Input - setter for TrackBy function\n   * @description is required\n   */\n  @Input({ required: true })\n  public set lazyForTrackBy(fn: TrackByFunction<T>) {\n    if (isDevMode() && fn !== null && typeof fn !== 'function') {\n      console.warn(\n        `trackBy must be a function, but received ${JSON.stringify(fn)}. ` +\n          `See https://angular.io/api/common/NgForOf#change-propagation for more information.`,\n      );\n    }\n    this._trackByFn = fn;\n  }\n\n  /**\n   * Setter for the number of items that will be rendered per frame\n   * @param value number of items that will be rendered per frame\n   */\n  @Input()\n  public set lazyForItemsPerFrame(value: number) {\n    if (value <= 0) {\n      if (isDevMode()) {\n        console.warn('Items per frame parameter cannot be lower than 0! Input value was ignored');\n      }\n\n      return;\n    }\n\n    this._itemsPerFrame = value;\n  }\n\n  /** Setter for array item template */\n  @Input()\n  public set lazyForTemplate(value: TemplateRef<LazyForContextModel<T, U>>) {\n    if (value) {\n      this._template = value;\n    }\n  }\n\n  /** Getter for TrackBy function */\n  public get lazyForTrackBy(): TrackByFunction<T> {\n    return this._trackByFn;\n  }\n\n  //#region PROPERTIES\n  /** Array for rendering */\n  private _lazyFor: U | undefined | null = null;\n  /** lazyFor initialization flag */\n  private _lazyForDirty: boolean = true;\n  /** Differ for tracking changes in input array */\n  private _differ: IterableDiffer<T> | null = null;\n  /** trackBy function */\n  private _trackByFn!: TrackByFunction<T>;\n  /** Number of items to be rendered per frame */\n  private _itemsPerFrame: number = 5;\n  /** Directive state */\n  private _lazyForState: LazyForState = LazyForState.idle;\n  //#endregion\n\n  //#region RXJS\n  /** Private subject for stopping dynamic render process */\n  private readonly _rerenderUnsub$: Subject<void> = new Subject<void>();\n  //#endregion\n\n  constructor() {\n    this._destroyRef$.onDestroy(() => this._viewContainer.clear());\n  }\n\n  /** ngDoCheck hook */\n  public ngDoCheck(): void {\n    if (this._lazyForDirty) {\n      this._lazyForDirty = false;\n      const value: U | undefined | null = this._lazyFor;\n      if (!this._differ && value) {\n        this._differ = this._differs.find(value).create(this.lazyForTrackBy);\n      }\n    }\n\n    if (this._differ) {\n      let changes: IterableChanges<T> | null = this._differ.diff(this._lazyFor);\n      if (changes) {\n        if (this._lazyForState === LazyForState.rendering) {\n          /**\n           * If the array changed during an active render process\n           * Need to clear container of all views\n           * And restart rendering from the beginning.\n           */\n          this._rerenderUnsub$.next();\n          changes = this._differ.diff([]);\n          changes = this._differ.diff(this._lazyFor);\n          this._viewContainer.clear();\n          if (changes) {\n            this.applyChanges(changes);\n          }\n        } else {\n          this.applyChanges(changes);\n        }\n      }\n    }\n  }\n\n  /**\n   * Apply changes detected by differ\n   * @param changes changes\n   */\n  private applyChanges(changes: IterableChanges<T>): void {\n    const itemDataListToRender: Array<LazyForItem<T>> = [];\n    changes.forEachOperation(\n      (item: IterableChangeRecord<T>, adjustedPreviousIndex: number | null, currentIndex: number | null) => {\n        const itemToPush: LazyForItem<T> = {\n          item: { ...item },\n          adjustedPreviousIndex,\n          currentIndex,\n        };\n        itemDataListToRender.push(itemToPush);\n      },\n    );\n\n    this.performLazyRender(itemDataListToRender, changes);\n  }\n\n  /**\n   * Perform lazy rendering\n   * @param itemDataListToRender list of items to render\n   * @param changes changes\n   */\n  private performLazyRender(itemDataListToRender: Array<LazyForItem<T>>, changes: IterableChanges<T>): void {\n    this.updateLazyForState(LazyForState.rendering);\n    this._rerenderUnsub$.next();\n\n    from(itemDataListToRender)\n      .pipe(\n        bufferCount(this._itemsPerFrame),\n        concatMap((itemList) => of(itemList).pipe(delayWhen(() => animationFrames()))),\n        tap((itemList: Array<LazyForItem<T>>) => {\n          for (let i: number = 0; i < itemList.length; i++) {\n            const data: LazyForItem<T> = itemList[i];\n\n            if (data.item.previousIndex === null) {\n              this._viewContainer.createEmbeddedView(\n                this._template,\n                new LazyForContextModel<T, U>(data.item.item, this._lazyFor!, -1, -1),\n                data.currentIndex === null ? undefined : data.currentIndex,\n              );\n            } else if (data.currentIndex === null) {\n              this._viewContainer.remove(data.adjustedPreviousIndex === null ? undefined : data.adjustedPreviousIndex);\n            } else if (data.adjustedPreviousIndex !== null) {\n              const view: ViewRef | null = this._viewContainer.get(data.adjustedPreviousIndex)!;\n              this._viewContainer.move(view, data.currentIndex);\n              this.applyViewChange(view as EmbeddedViewRef<LazyForContextModel<T, U>>, data.item);\n            }\n          }\n\n          this.updateViewContext();\n\n          this._cdr.markForCheck();\n        }),\n        /** Using take we automatically unsubscribe from the stream when rendering is complete */\n        take(Math.ceil(itemDataListToRender.length / this._itemsPerFrame)),\n        takeUntil(this._rerenderUnsub$),\n        takeUntilDestroyed(this._destroyRef$),\n        finalize(() => {\n          changes.forEachIdentityChange((record: any) => {\n            const viewRef: EmbeddedViewRef<LazyForContextModel<T, U>> = <EmbeddedViewRef<LazyForContextModel<T, U>>>(\n              this._viewContainer.get(record.currentIndex)\n            );\n            this.applyViewChange(viewRef, record);\n          });\n          this.updateLazyForState(LazyForState.idle);\n        }),\n      )\n      .subscribe();\n  }\n\n  /** Update context (without implicit$) for elements inside view */\n  private updateViewContext(): void {\n    for (let i: number = 0, ilen: number = this._viewContainer.length; i < ilen; i++) {\n      const viewRef: EmbeddedViewRef<LazyForContextModel<T, U>> = <EmbeddedViewRef<LazyForContextModel<T, U>>>(\n        this._viewContainer.get(i)\n      );\n      const context: LazyForContextModel<T, U> = viewRef.context;\n      context.index = i;\n      context.count = ilen;\n      context.lazyFor = this._lazyFor!;\n    }\n  }\n\n  /**\n   * Apply implicit$ context\n   * @param view view\n   * @param record data\n   */\n  private applyViewChange(view: EmbeddedViewRef<LazyForContextModel<T>>, record: IterableChangeRecord<T>): void {\n    view.context.$implicit = record.item;\n  }\n\n  /**\n   * Update directive state\n   * @param stateToSet state to set\n   */\n  private updateLazyForState(stateToSet: LazyForState): void {\n    this._lazyForState = stateToSet;\n  }\n}\n"]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export const entitiesPerFrame = (total, perFrame) => Math.max(1, Math.ceil(total / perFrame));
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXRpZXMtcGVyLWZyYW1lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3V0aWxzL2VudGl0aWVzLXBlci1mcmFtZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEtBQWEsRUFBRSxRQUFnQixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssR0FBRyxRQUFRLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGVudGl0aWVzUGVyRnJhbWUgPSAodG90YWw6IG51bWJlciwgcGVyRnJhbWU6IG51bWJlcikgPT4gTWF0aC5tYXgoMSwgTWF0aC5jZWlsKHRvdGFsIC8gcGVyRnJhbWUpKTtcbiJdfQ==
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import { DoCheck, NgIterable, TemplateRef, TrackByFunction } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
/**
|
|
4
|
-
* Context for an element in lazyFor
|
|
5
|
-
*/
|
|
6
|
-
declare class LazyForContextModel<T, U extends NgIterable<T> = NgIterable<T>> {
|
|
7
|
-
$implicit: T;
|
|
8
|
-
lazyFor: U;
|
|
9
|
-
index: number;
|
|
10
|
-
count: number;
|
|
11
|
-
/** Whether the element is first */
|
|
12
|
-
get first(): boolean;
|
|
13
|
-
/** Whether the element is last */
|
|
14
|
-
get last(): boolean;
|
|
15
|
-
/** Whether the element is even */
|
|
16
|
-
get even(): boolean;
|
|
17
|
-
/** Whether the element is odd */
|
|
18
|
-
get odd(): boolean;
|
|
19
|
-
constructor($implicit: T, lazyFor: U, index: number, count: number);
|
|
20
|
-
}
|
|
21
|
-
export declare class LazyForDirective<T, U extends NgIterable<T> = NgIterable<T>> implements DoCheck {
|
|
22
|
-
private _template;
|
|
23
|
-
private _viewContainer;
|
|
24
|
-
private _differs;
|
|
25
|
-
private _cdr;
|
|
26
|
-
private _destroyRef$;
|
|
27
|
-
/**
|
|
28
|
-
* Asserts the correct type of the context for the template that `lazyFor` will render.
|
|
29
|
-
*
|
|
30
|
-
* The presence of this method is a signal to the Ivy template type-check compiler that the
|
|
31
|
-
* `lazyFor` structural directive renders its template with a specific context type.
|
|
32
|
-
*/
|
|
33
|
-
static ngTemplateContextGuard<T, U extends NgIterable<T>>(dir: LazyForDirective<T, U>, ctx: any): ctx is LazyForContextModel<T, U>;
|
|
34
|
-
/** Setter for the array to be rendered by the directive */
|
|
35
|
-
set lazyForOf(lazyFor: (U & NgIterable<T>) | undefined | null);
|
|
36
|
-
/**
|
|
37
|
-
* Input - setter for TrackBy function
|
|
38
|
-
* @description is required
|
|
39
|
-
*/
|
|
40
|
-
set lazyForTrackBy(fn: TrackByFunction<T>);
|
|
41
|
-
/**
|
|
42
|
-
* Setter for the number of items that will be rendered per frame
|
|
43
|
-
* @param value number of items that will be rendered per frame
|
|
44
|
-
*/
|
|
45
|
-
set lazyForItemsPerFrame(value: number);
|
|
46
|
-
/** Setter for array item template */
|
|
47
|
-
set lazyForTemplate(value: TemplateRef<LazyForContextModel<T, U>>);
|
|
48
|
-
/** Getter for TrackBy function */
|
|
49
|
-
get lazyForTrackBy(): TrackByFunction<T>;
|
|
50
|
-
/** Array for rendering */
|
|
51
|
-
private _lazyFor;
|
|
52
|
-
/** lazyFor initialization flag */
|
|
53
|
-
private _lazyForDirty;
|
|
54
|
-
/** Differ for tracking changes in input array */
|
|
55
|
-
private _differ;
|
|
56
|
-
/** trackBy function */
|
|
57
|
-
private _trackByFn;
|
|
58
|
-
/** Number of items to be rendered per frame */
|
|
59
|
-
private _itemsPerFrame;
|
|
60
|
-
/** Directive state */
|
|
61
|
-
private _lazyForState;
|
|
62
|
-
/** Private subject for stopping dynamic render process */
|
|
63
|
-
private readonly _rerenderUnsub$;
|
|
64
|
-
constructor();
|
|
65
|
-
/** ngDoCheck hook */
|
|
66
|
-
ngDoCheck(): void;
|
|
67
|
-
/**
|
|
68
|
-
* Apply changes detected by differ
|
|
69
|
-
* @param changes changes
|
|
70
|
-
*/
|
|
71
|
-
private applyChanges;
|
|
72
|
-
/**
|
|
73
|
-
* Perform lazy rendering
|
|
74
|
-
* @param itemDataListToRender list of items to render
|
|
75
|
-
* @param changes changes
|
|
76
|
-
*/
|
|
77
|
-
private performLazyRender;
|
|
78
|
-
/** Update context (without implicit$) for elements inside view */
|
|
79
|
-
private updateViewContext;
|
|
80
|
-
/**
|
|
81
|
-
* Apply implicit$ context
|
|
82
|
-
* @param view view
|
|
83
|
-
* @param record data
|
|
84
|
-
*/
|
|
85
|
-
private applyViewChange;
|
|
86
|
-
/**
|
|
87
|
-
* Update directive state
|
|
88
|
-
* @param stateToSet state to set
|
|
89
|
-
*/
|
|
90
|
-
private updateLazyForState;
|
|
91
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<LazyForDirective<any, any>, never>;
|
|
92
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<LazyForDirective<any, any>, "[lazyFor][lazyForOf]", never, { "lazyForOf": { "alias": "lazyForOf"; "required": false; }; "lazyForTrackBy": { "alias": "lazyForTrackBy"; "required": true; }; "lazyForItemsPerFrame": { "alias": "lazyForItemsPerFrame"; "required": false; }; "lazyForTemplate": { "alias": "lazyForTemplate"; "required": false; }; }, {}, never, never, true, never>;
|
|
93
|
-
}
|
|
94
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const entitiesPerFrame: (total: number, perFrame: number) => number;
|