@nstudio/ui-collectionview 5.1.9-alpha.3 → 5.1.9-alpha.5

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.
@@ -56,7 +56,9 @@ export declare class CollectionViewComponent implements DoCheck, OnDestroy, Afte
56
56
  registerTemplateSupplemental(key: string, template: TemplateRef<ItemContext>, type: 'header' | 'footer'): void;
57
57
  onItemLoading(args: CollectionViewItemEventData): void;
58
58
  onItemRecyclingInternal(args: any): void;
59
+ onItemDisplayInternal(args: CollectionViewItemEventData): void;
59
60
  onItemDisposingInternal(args: any): void;
61
+ private getNgView;
60
62
  setupViewRef(view: EmbeddedViewRef<ItemContext>, data: any, index: number): void;
61
63
  getItemTemplateViewFactory(template: TemplateRef<ItemContext>): () => View;
62
64
  viewPool: Map<TemplateRef<ItemContext>, {
@@ -73,7 +75,7 @@ export declare class CollectionViewComponent implements DoCheck, OnDestroy, Afte
73
75
  private detectChangesOnChild;
74
76
  private refresh;
75
77
  static ɵfac: i0.ɵɵFactoryDeclaration<CollectionViewComponent, never>;
76
- static ɵcmp: i0.ɵɵComponentDeclaration<CollectionViewComponent, "CollectionView", never, { "autoReuseViews": "autoReuseViews"; "itemTemplate": "itemTemplate"; "headerItemTemplate": "headerItemTemplate"; "footerItemTemplate": "footerItemTemplate"; "items": "items"; }, { "setupItemView": "setupItemView"; }, ["itemTemplateQuery"], never, false, never>;
78
+ static ɵcmp: i0.ɵɵComponentDeclaration<CollectionViewComponent, "CollectionView", never, { "autoReuseViews": { "alias": "autoReuseViews"; "required": false; }; "itemTemplate": { "alias": "itemTemplate"; "required": false; }; "headerItemTemplate": { "alias": "headerItemTemplate"; "required": false; }; "footerItemTemplate": { "alias": "footerItemTemplate"; "required": false; }; "items": { "alias": "items"; "required": false; }; }, { "setupItemView": "setupItemView"; }, ["itemTemplateQuery"], never, false, never>;
77
79
  }
78
80
  export interface ComponentView {
79
81
  rootNodes: any[];
@@ -87,7 +89,7 @@ export declare class TemplateKeyDirective {
87
89
  constructor(templateRef: TemplateRef<any>, collectionView: CollectionViewComponent);
88
90
  set cvTemplateKey(value: any);
89
91
  static ɵfac: i0.ɵɵFactoryDeclaration<TemplateKeyDirective, [null, { host: true; }]>;
90
- static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateKeyDirective, "[cvTemplateKey]", never, { "cvTemplateKey": "cvTemplateKey"; }, {}, never, never, false, never>;
92
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateKeyDirective, "[cvTemplateKey]", never, { "cvTemplateKey": { "alias": "cvTemplateKey"; "required": false; }; }, {}, never, never, false, never>;
91
93
  }
92
94
  export declare class TemplateHeaderDirective {
93
95
  private templateRef;
@@ -95,7 +97,7 @@ export declare class TemplateHeaderDirective {
95
97
  constructor(templateRef: TemplateRef<any>, collectionView: CollectionViewComponent);
96
98
  set cvTemplateHeader(value: any);
97
99
  static ɵfac: i0.ɵɵFactoryDeclaration<TemplateHeaderDirective, [null, { host: true; }]>;
98
- static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateHeaderDirective, "[cvTemplateHeader]", never, { "cvTemplateHeader": "cvTemplateHeader"; }, {}, never, never, false, never>;
100
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateHeaderDirective, "[cvTemplateHeader]", never, { "cvTemplateHeader": { "alias": "cvTemplateHeader"; "required": false; }; }, {}, never, never, false, never>;
99
101
  }
100
102
  export declare class TemplateFooterDirective {
101
103
  private templateRef;
@@ -103,5 +105,5 @@ export declare class TemplateFooterDirective {
103
105
  constructor(templateRef: TemplateRef<any>, collectionView: CollectionViewComponent);
104
106
  set cvTemplateFooter(value: any);
105
107
  static ɵfac: i0.ɵɵFactoryDeclaration<TemplateFooterDirective, [null, { host: true; }]>;
106
- static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateFooterDirective, "[cvTemplateFooter]", never, { "cvTemplateFooter": "cvTemplateFooter"; }, {}, never, never, false, never>;
108
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateFooterDirective, "[cvTemplateFooter]", never, { "cvTemplateFooter": { "alias": "cvTemplateFooter"; "required": false; }; }, {}, never, never, false, never>;
107
109
  }
@@ -0,0 +1,525 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChild, Directive, ElementRef, EventEmitter, Host, HostListener, Inject, Input, IterableDiffers, NgZone, Output, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
2
+ import { CLog, CLogTypes, CollectionView, ViewTemplateType } from '@nstudio/ui-collectionview';
3
+ import { DetachedLoader, NativeScriptRendererFactory, extractSingleViewRecursive, isListLikeIterable, registerElement } from '@nativescript/angular';
4
+ import { LayoutBase, ObservableArray, Trace } from '@nativescript/core';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@nativescript/angular";
7
+ registerElement('CollectionView', () => CollectionView);
8
+ const NG_VIEW = '_ngViewRef';
9
+ export class ItemContext {
10
+ $implicit;
11
+ item;
12
+ index;
13
+ even;
14
+ odd;
15
+ constructor($implicit, item, index, even, odd) {
16
+ this.$implicit = $implicit;
17
+ this.item = item;
18
+ this.index = index;
19
+ this.even = even;
20
+ this.odd = odd;
21
+ }
22
+ }
23
+ export class CollectionViewComponent {
24
+ _elementRef;
25
+ _iterableDiffers;
26
+ _renderer;
27
+ _ngZone;
28
+ get nativeElement() {
29
+ return this._collectionView;
30
+ }
31
+ get listView() {
32
+ return this._collectionView;
33
+ }
34
+ loader;
35
+ setupItemView = new EventEmitter();
36
+ itemTemplateQuery;
37
+ autoReuseViews = false;
38
+ detachedLoaderFactory() {
39
+ const ref = this.loader.createComponent(DetachedLoader, {
40
+ index: 0,
41
+ });
42
+ this.loader.detach(0);
43
+ this._loaders.push(ref);
44
+ return ref;
45
+ }
46
+ get itemTemplate() {
47
+ return this._itemTemplate;
48
+ }
49
+ set itemTemplate(value) {
50
+ this._itemTemplate = value;
51
+ // this._collectionView.refresh();
52
+ }
53
+ get headerItemTemplate() {
54
+ return this._headerTemplate;
55
+ }
56
+ set headerItemTemplate(value) {
57
+ this._headerTemplate = value;
58
+ }
59
+ get footerItemTemplate() {
60
+ return this._footerTemplate;
61
+ }
62
+ set footerItemTemplate(value) {
63
+ this._footerTemplate = value;
64
+ }
65
+ get items() {
66
+ return this._items;
67
+ }
68
+ set items(value) {
69
+ this._items = value;
70
+ let needDiffer = true;
71
+ if (value instanceof ObservableArray) {
72
+ needDiffer = false;
73
+ }
74
+ if (needDiffer && !this._differ && isListLikeIterable(value)) {
75
+ this._differ = this._iterableDiffers.find(this._items).create((_index, item) => item);
76
+ }
77
+ this._collectionView.items = this._items;
78
+ }
79
+ _collectionView;
80
+ _items;
81
+ _differ;
82
+ _itemTemplate;
83
+ _templateMap;
84
+ _headerTemplate;
85
+ _headerTemplateMap;
86
+ _footerTemplate;
87
+ _footerTemplateMap;
88
+ _loaders;
89
+ constructor(_elementRef, _iterableDiffers, _renderer, _ngZone) {
90
+ this._elementRef = _elementRef;
91
+ this._iterableDiffers = _iterableDiffers;
92
+ this._renderer = _renderer;
93
+ this._ngZone = _ngZone;
94
+ this._collectionView = _elementRef.nativeElement;
95
+ this._collectionView.on(CollectionView.itemLoadingEvent, this.onItemLoading, this);
96
+ this._collectionView.itemViewLoader = this.itemViewLoader;
97
+ this._loaders = [];
98
+ }
99
+ itemViewLoader = (viewType) => {
100
+ this._ngZone.run(() => {
101
+ switch (viewType) {
102
+ case ViewTemplateType.Item:
103
+ if (this._itemTemplate) {
104
+ return this.getOrCreate(this._itemTemplate);
105
+ }
106
+ break;
107
+ case ViewTemplateType.Header:
108
+ if (this._headerTemplate) {
109
+ return this.getOrCreate(this._headerTemplate);
110
+ }
111
+ break;
112
+ case ViewTemplateType.Footer:
113
+ if (this._footerTemplate) {
114
+ return this.getOrCreate(this._footerTemplate);
115
+ }
116
+ break;
117
+ }
118
+ return null;
119
+ });
120
+ };
121
+ ngAfterContentInit() {
122
+ if (Trace.isEnabled()) {
123
+ CLog(CLogTypes.info, 'CollectionView.ngAfterContentInit()');
124
+ }
125
+ this.setItemTemplates();
126
+ }
127
+ ngOnDestroy() {
128
+ this._collectionView.off(CollectionView.itemLoadingEvent, this.onItemLoading, this);
129
+ this._collectionView = null;
130
+ this._loaders.forEach((l) => l.destroy());
131
+ this._loaders = null;
132
+ this.viewToLoader = null;
133
+ this.viewToTemplate = null;
134
+ this.viewPool = null;
135
+ this._items = null;
136
+ this._differ = null;
137
+ this._itemTemplate = null;
138
+ if (this._templateMap) {
139
+ this._templateMap.clear();
140
+ }
141
+ if (this._headerTemplateMap) {
142
+ this._headerTemplateMap.clear();
143
+ }
144
+ if (this._footerTemplateMap) {
145
+ this._footerTemplateMap.clear();
146
+ }
147
+ this._templateMap = null;
148
+ this._headerTemplateMap = null;
149
+ this._footerTemplateMap = null;
150
+ }
151
+ ngDoCheck() {
152
+ if (Trace.isEnabled()) {
153
+ CLog(CLogTypes.info, 'ngDoCheck() - execute differ? ' + this._differ);
154
+ }
155
+ if (this._differ) {
156
+ if (Trace.isEnabled()) {
157
+ CLog(CLogTypes.info, 'ngDoCheck() - execute differ');
158
+ }
159
+ const changes = this._differ.diff(this._items);
160
+ if (changes) {
161
+ if (Trace.isEnabled()) {
162
+ CLog(CLogTypes.info, 'ngDoCheck() - refresh');
163
+ }
164
+ this.refresh();
165
+ }
166
+ }
167
+ }
168
+ registerTemplate(key, template) {
169
+ if (Trace.isEnabled()) {
170
+ CLog(CLogTypes.info, 'registerTemplate for key: ' + key);
171
+ }
172
+ if (!this._templateMap) {
173
+ this._templateMap = new Map();
174
+ }
175
+ const keyedTemplate = {
176
+ key,
177
+ createView: this.getItemTemplateViewFactory(template),
178
+ };
179
+ this._templateMap.set(key, keyedTemplate);
180
+ }
181
+ registerTemplateSupplemental(key, template, type) {
182
+ if (Trace.isEnabled()) {
183
+ CLog(CLogTypes.info, 'registerTemplate for key: ' + key);
184
+ }
185
+ switch (type) {
186
+ case 'header':
187
+ // if (!this._headerTemplateMap) {
188
+ // this._headerTemplateMap = new Map<string, KeyedTemplate>();
189
+ // }
190
+ // this._headerTemplateMap.set(key, keyedTemplate);
191
+ this._collectionView.headerKey = key;
192
+ this.headerItemTemplate = template;
193
+ this._collectionView.headerItemTemplate = this.getItemTemplateViewFactory(template);
194
+ break;
195
+ case 'footer':
196
+ // if (!this._footerTemplateMap) {
197
+ // this._footerTemplateMap = new Map<string, KeyedTemplate>();
198
+ // }
199
+ // this._footerTemplateMap.set(key, keyedTemplate);
200
+ this._collectionView.footerKey = key;
201
+ this.footerItemTemplate = template;
202
+ this._collectionView.footerItemTemplate = this.getItemTemplateViewFactory(template);
203
+ break;
204
+ }
205
+ }
206
+ onItemLoading(args) {
207
+ if (!args.view && !this.itemTemplate) {
208
+ return;
209
+ }
210
+ if (!this.items)
211
+ return;
212
+ const index = args.index;
213
+ const items = args.object.items;
214
+ const currentItem = typeof items.getItem === 'function' ? items.getItem(index) : items[index];
215
+ let viewRef;
216
+ if (Trace.isEnabled()) {
217
+ CLog(CLogTypes.info, `onItemLoading: ${index} - Reusing existing view`);
218
+ }
219
+ viewRef = this.getNgView(args.view);
220
+ if (!viewRef && Trace.isEnabled()) {
221
+ if (Trace.isEnabled()) {
222
+ CLog(CLogTypes.info, `ViewReference not found for item ${index}. View recycling is not working`);
223
+ }
224
+ }
225
+ if (!viewRef) {
226
+ if (Trace.isEnabled()) {
227
+ CLog(CLogTypes.info, `onItemLoading: ${index} - Creating view from template`);
228
+ }
229
+ viewRef = this.getOrCreate(this.itemTemplate);
230
+ }
231
+ this.setupViewRef(viewRef, currentItem, index);
232
+ this.detectChangesOnChild(viewRef, index);
233
+ }
234
+ onItemRecyclingInternal(args) {
235
+ if (!args.view) {
236
+ return;
237
+ }
238
+ const ngView = this.getNgView(args.view);
239
+ // console.log('recycling', args.view);
240
+ if (ngView) {
241
+ ngView.detach();
242
+ }
243
+ }
244
+ onItemDisplayInternal(args) {
245
+ if (!args.view) {
246
+ return;
247
+ }
248
+ const ngView = this.getNgView(args.view);
249
+ if (ngView) {
250
+ ngView.reattach();
251
+ }
252
+ }
253
+ onItemDisposingInternal(args) {
254
+ if (!args.view) {
255
+ return;
256
+ }
257
+ const ngView = this.getNgView(args.view);
258
+ if (ngView) {
259
+ ngView.detach();
260
+ this.storeViewRef(ngView);
261
+ }
262
+ }
263
+ getNgView(view) {
264
+ const ngView = view[NG_VIEW];
265
+ // Getting angular view from original element (in cases when ProxyViewContainer
266
+ // is used NativeScript internally wraps it in a StackLayout)
267
+ if (!ngView && view instanceof LayoutBase && view.getChildrenCount() > 0) {
268
+ return view.getChildAt(0)[NG_VIEW];
269
+ }
270
+ return ngView;
271
+ }
272
+ setupViewRef(view, data, index) {
273
+ const context = view.context;
274
+ context.$implicit = data;
275
+ context.item = data;
276
+ context.index = index;
277
+ context.even = index % 2 === 0;
278
+ context.odd = !context.even;
279
+ this.setupItemView.next({
280
+ context,
281
+ data,
282
+ index,
283
+ view,
284
+ });
285
+ }
286
+ getItemTemplateViewFactory(template) {
287
+ return () => {
288
+ return this.getOrCreate(template);
289
+ };
290
+ }
291
+ viewPool = new Map();
292
+ storeViewRef(viewRef) {
293
+ const templateRef = this.viewToTemplate.get(viewRef);
294
+ if (templateRef) {
295
+ const scrap = this.viewPool.get(templateRef);
296
+ if (scrap) {
297
+ if (scrap.scrapHead.size >= scrap.scrapSize) {
298
+ viewRef.destroy();
299
+ this.viewToLoader.get(viewRef)?.destroy();
300
+ }
301
+ else {
302
+ scrap.scrapHead.add(viewRef);
303
+ }
304
+ }
305
+ }
306
+ }
307
+ viewToTemplate = new WeakMap();
308
+ viewToLoader = new WeakMap();
309
+ getOrCreate(templateRef) {
310
+ return this._ngZone.run(() => {
311
+ let viewRef = this.getView(templateRef);
312
+ if (!viewRef) {
313
+ const loader = this.detachedLoaderFactory();
314
+ viewRef = loader.instance.vc.createEmbeddedView(templateRef, new ItemContext(), 0);
315
+ this.viewToLoader.set(viewRef, loader);
316
+ this.viewToTemplate.set(viewRef, templateRef);
317
+ }
318
+ viewRef.detach();
319
+ const resultView = getItemViewRoot(viewRef);
320
+ resultView[NG_VIEW] = viewRef;
321
+ resultView.reusable = this.autoReuseViews;
322
+ return resultView;
323
+ });
324
+ }
325
+ getView(templateRef) {
326
+ const pool = this.getViewPool(templateRef);
327
+ while (pool.scrapHead.size > 0) {
328
+ const viewRef = pool.scrapHead.values().next().value;
329
+ pool.scrapHead.delete(viewRef);
330
+ if (!viewRef.destroyed) {
331
+ return viewRef;
332
+ }
333
+ }
334
+ return null;
335
+ }
336
+ getViewPool(templateRef) {
337
+ if (!this.viewPool.has(templateRef)) {
338
+ this.viewPool.set(templateRef, {
339
+ scrapSize: this.autoReuseViews ? Infinity : 0,
340
+ scrapHead: new Set(),
341
+ });
342
+ }
343
+ return this.viewPool.get(templateRef);
344
+ }
345
+ setItemTemplates() {
346
+ // The itemTemplateQuery may be changed after list items are added that contain <template> inside,
347
+ // so cache and use only the original template to avoid errors.
348
+ this.itemTemplate = this.itemTemplateQuery;
349
+ if (this._templateMap) {
350
+ if (Trace.isEnabled()) {
351
+ CLog(CLogTypes.info, 'Setting templates');
352
+ }
353
+ const templates = [];
354
+ this._templateMap.forEach((value) => {
355
+ templates.push(value);
356
+ });
357
+ this._collectionView.itemTemplates = templates;
358
+ }
359
+ else {
360
+ // If the map was not initialized this means that there are no named templates, so we register the default one.
361
+ this._collectionView.itemTemplate = this.getItemTemplateViewFactory(this.itemTemplate);
362
+ }
363
+ }
364
+ detectChangesOnChild(viewRef, index) {
365
+ if (Trace.isEnabled()) {
366
+ CLog(CLogTypes.info, 'Manually detect changes in child: ' + index);
367
+ }
368
+ viewRef.markForCheck();
369
+ viewRef.detectChanges();
370
+ }
371
+ refresh() {
372
+ if (this._collectionView) {
373
+ this._collectionView.refresh();
374
+ }
375
+ }
376
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: CollectionViewComponent, deps: [{ token: ElementRef }, { token: IterableDiffers }, { token: NativeScriptRendererFactory }, { token: NgZone }], target: i0.ɵɵFactoryTarget.Component });
377
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.9", type: CollectionViewComponent, selector: "CollectionView", inputs: { autoReuseViews: "autoReuseViews", itemTemplate: "itemTemplate", headerItemTemplate: "headerItemTemplate", footerItemTemplate: "footerItemTemplate", items: "items" }, outputs: { setupItemView: "setupItemView" }, host: { listeners: { "itemLoading": "onItemLoading($event)", "itemRecycling": "onItemRecyclingInternal($event)", "displayItem": "onItemDisplayInternal($event)", "itemDisposing": "onItemDisposingInternal($event)" } }, queries: [{ propertyName: "itemTemplateQuery", first: true, predicate: TemplateRef, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "loader", first: true, predicate: ["loader"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: `
378
+ <DetachedContainer>
379
+ <Placeholder #loader></Placeholder>
380
+ </DetachedContainer>
381
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
382
+ }
383
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: CollectionViewComponent, decorators: [{
384
+ type: Component,
385
+ args: [{
386
+ selector: 'CollectionView',
387
+ template: `
388
+ <DetachedContainer>
389
+ <Placeholder #loader></Placeholder>
390
+ </DetachedContainer>
391
+ `,
392
+ changeDetection: ChangeDetectionStrategy.OnPush,
393
+ }]
394
+ }], ctorParameters: () => [{ type: i0.ElementRef, decorators: [{
395
+ type: Inject,
396
+ args: [ElementRef]
397
+ }] }, { type: i0.IterableDiffers, decorators: [{
398
+ type: Inject,
399
+ args: [IterableDiffers]
400
+ }] }, { type: i1.NativeScriptRendererFactory, decorators: [{
401
+ type: Inject,
402
+ args: [NativeScriptRendererFactory]
403
+ }] }, { type: i0.NgZone, decorators: [{
404
+ type: Inject,
405
+ args: [NgZone]
406
+ }] }], propDecorators: { loader: [{
407
+ type: ViewChild,
408
+ args: ['loader', { read: ViewContainerRef, static: true }]
409
+ }], setupItemView: [{
410
+ type: Output
411
+ }], itemTemplateQuery: [{
412
+ type: ContentChild,
413
+ args: [TemplateRef, { read: TemplateRef, static: true }]
414
+ }], autoReuseViews: [{
415
+ type: Input
416
+ }], itemTemplate: [{
417
+ type: Input
418
+ }], headerItemTemplate: [{
419
+ type: Input
420
+ }], footerItemTemplate: [{
421
+ type: Input
422
+ }], items: [{
423
+ type: Input
424
+ }], onItemLoading: [{
425
+ type: HostListener,
426
+ args: ['itemLoading', ['$event']]
427
+ }], onItemRecyclingInternal: [{
428
+ type: HostListener,
429
+ args: ['itemRecycling', ['$event']]
430
+ }], onItemDisplayInternal: [{
431
+ type: HostListener,
432
+ args: ['displayItem', ['$event']]
433
+ }], onItemDisposingInternal: [{
434
+ type: HostListener,
435
+ args: ['itemDisposing', ['$event']]
436
+ }] } });
437
+ export function getItemViewRoot(viewRef, rootLocator = extractSingleViewRecursive) {
438
+ const rootView = rootLocator(viewRef.rootNodes, 0);
439
+ return rootView;
440
+ }
441
+ export class TemplateKeyDirective {
442
+ templateRef;
443
+ collectionView;
444
+ constructor(templateRef, collectionView) {
445
+ this.templateRef = templateRef;
446
+ this.collectionView = collectionView;
447
+ }
448
+ set cvTemplateKey(value) {
449
+ if (Trace.isEnabled()) {
450
+ CLog(CLogTypes.info, 'cvTemplateKey: ' + value);
451
+ }
452
+ if (this.collectionView && this.templateRef) {
453
+ this.collectionView.registerTemplate(value.toLowerCase(), this.templateRef);
454
+ }
455
+ }
456
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: TemplateKeyDirective, deps: [{ token: i0.TemplateRef }, { token: CollectionViewComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
457
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.9", type: TemplateKeyDirective, selector: "[cvTemplateKey]", inputs: { cvTemplateKey: "cvTemplateKey" }, ngImport: i0 });
458
+ }
459
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: TemplateKeyDirective, decorators: [{
460
+ type: Directive,
461
+ args: [{ selector: '[cvTemplateKey]' }]
462
+ }], ctorParameters: () => [{ type: i0.TemplateRef }, { type: CollectionViewComponent, decorators: [{
463
+ type: Host
464
+ }] }], propDecorators: { cvTemplateKey: [{
465
+ type: Input
466
+ }] } });
467
+ export class TemplateHeaderDirective {
468
+ templateRef;
469
+ collectionView;
470
+ constructor(templateRef, collectionView) {
471
+ this.templateRef = templateRef;
472
+ this.collectionView = collectionView;
473
+ }
474
+ set cvTemplateHeader(value) {
475
+ if (Trace.isEnabled()) {
476
+ CLog(CLogTypes.info, 'cvTemplateHeader: ' + value);
477
+ }
478
+ if (this.collectionView && this.templateRef) {
479
+ // TODO: allow keying of multiple headers per section
480
+ this.collectionView.registerTemplateSupplemental(value || ViewTemplateType.Header, this.templateRef, 'header');
481
+ }
482
+ }
483
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: TemplateHeaderDirective, deps: [{ token: i0.TemplateRef }, { token: CollectionViewComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
484
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.9", type: TemplateHeaderDirective, selector: "[cvTemplateHeader]", inputs: { cvTemplateHeader: "cvTemplateHeader" }, ngImport: i0 });
485
+ }
486
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: TemplateHeaderDirective, decorators: [{
487
+ type: Directive,
488
+ args: [{
489
+ selector: '[cvTemplateHeader]',
490
+ }]
491
+ }], ctorParameters: () => [{ type: i0.TemplateRef }, { type: CollectionViewComponent, decorators: [{
492
+ type: Host
493
+ }] }], propDecorators: { cvTemplateHeader: [{
494
+ type: Input
495
+ }] } });
496
+ export class TemplateFooterDirective {
497
+ templateRef;
498
+ collectionView;
499
+ constructor(templateRef, collectionView) {
500
+ this.templateRef = templateRef;
501
+ this.collectionView = collectionView;
502
+ }
503
+ set cvTemplateFooter(value) {
504
+ if (Trace.isEnabled()) {
505
+ CLog(CLogTypes.info, 'cvTemplateFooter: ' + value);
506
+ }
507
+ if (this.collectionView && this.templateRef) {
508
+ // TODO: allow keying of multiple footers per section
509
+ this.collectionView.registerTemplateSupplemental(value || ViewTemplateType.Footer, this.templateRef, 'footer');
510
+ }
511
+ }
512
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: TemplateFooterDirective, deps: [{ token: i0.TemplateRef }, { token: CollectionViewComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
513
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.9", type: TemplateFooterDirective, selector: "[cvTemplateFooter]", inputs: { cvTemplateFooter: "cvTemplateFooter" }, ngImport: i0 });
514
+ }
515
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: TemplateFooterDirective, decorators: [{
516
+ type: Directive,
517
+ args: [{
518
+ selector: '[cvTemplateFooter]',
519
+ }]
520
+ }], ctorParameters: () => [{ type: i0.TemplateRef }, { type: CollectionViewComponent, decorators: [{
521
+ type: Host
522
+ }] }], propDecorators: { cvTemplateFooter: [{
523
+ type: Input
524
+ }] } });
525
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collectionview.component.js","sourceRoot":"","sources":["../../../../../packages/ui-collectionview/angular/collectionview.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, ChangeDetectionStrategy, Component, ComponentRef, ContentChild, Directive, DoCheck, ElementRef, EmbeddedViewRef, EventEmitter, Host, HostListener, Inject, Input, IterableDiffer, IterableDiffers, NgZone, OnDestroy, Output, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { CLog, CLogTypes, CollectionView, CollectionViewItemEventData, ViewTemplateType } from '@nstudio/ui-collectionview';\nimport { DetachedLoader, NativeScriptRendererFactory, extractSingleViewRecursive, isListLikeIterable, registerElement } from '@nativescript/angular';\nimport { KeyedTemplate, LayoutBase, ObservableArray, Trace, View } from '@nativescript/core';\n\nregisterElement('CollectionView', () => CollectionView);\n\nconst NG_VIEW = '_ngViewRef';\n\nexport class ItemContext {\n  constructor(public $implicit?: any, public item?: any, public index?: number, public even?: boolean, public odd?: boolean) {}\n}\n\nexport interface SetupItemViewArgs {\n  view: EmbeddedViewRef<any>;\n  data: any;\n  index: number;\n  context: ItemContext;\n}\n\n@Component({\n  selector: 'CollectionView',\n  template: `\n    <DetachedContainer>\n      <Placeholder #loader></Placeholder>\n    </DetachedContainer>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CollectionViewComponent implements DoCheck, OnDestroy, AfterContentInit {\n  public get nativeElement() {\n    return this._collectionView;\n  }\n  public get listView() {\n    return this._collectionView;\n  }\n\n  @ViewChild('loader', { read: ViewContainerRef, static: true }) public loader: ViewContainerRef;\n  @Output() public setupItemView = new EventEmitter<SetupItemViewArgs>();\n  @ContentChild(TemplateRef, { read: TemplateRef, static: true }) public itemTemplateQuery: TemplateRef<ItemContext>;\n\n  @Input() autoReuseViews = false;\n\n  detachedLoaderFactory() {\n    const ref = this.loader.createComponent(DetachedLoader, {\n      index: 0,\n    });\n    this.loader.detach(0);\n    this._loaders.push(ref);\n    return ref;\n  }\n\n  @Input()\n  public get itemTemplate() {\n    return this._itemTemplate;\n  }\n  public set itemTemplate(value: TemplateRef<ItemContext>) {\n    this._itemTemplate = value;\n    // this._collectionView.refresh();\n  }\n  @Input()\n  public get headerItemTemplate() {\n    return this._headerTemplate;\n  }\n  public set headerItemTemplate(value: TemplateRef<ItemContext>) {\n    this._headerTemplate = value;\n  }\n  @Input()\n  public get footerItemTemplate() {\n    return this._footerTemplate;\n  }\n  public set footerItemTemplate(value: TemplateRef<ItemContext>) {\n    this._footerTemplate = value;\n  }\n  @Input()\n  public get items() {\n    return this._items;\n  }\n  public set items(value: any) {\n    this._items = value;\n    let needDiffer = true;\n    if (value instanceof ObservableArray) {\n      needDiffer = false;\n    }\n    if (needDiffer && !this._differ && isListLikeIterable(value)) {\n      this._differ = this._iterableDiffers.find(this._items).create((_index, item) => item);\n    }\n\n    this._collectionView.items = this._items;\n  }\n\n  private _collectionView: CollectionView;\n  private _items: any;\n  private _differ: IterableDiffer<KeyedTemplate>;\n  private _itemTemplate: TemplateRef<ItemContext>;\n  private _templateMap: Map<string, KeyedTemplate>;\n  private _headerTemplate: TemplateRef<ItemContext>;\n  private _headerTemplateMap: Map<string, KeyedTemplate>;\n  private _footerTemplate: TemplateRef<ItemContext>;\n  private _footerTemplateMap: Map<string, KeyedTemplate>;\n  private _loaders: ComponentRef<DetachedLoader>[];\n\n  constructor(@Inject(ElementRef) private _elementRef: ElementRef, @Inject(IterableDiffers) private _iterableDiffers: IterableDiffers, @Inject(NativeScriptRendererFactory) private _renderer: NativeScriptRendererFactory, @Inject(NgZone) private _ngZone: NgZone) {\n    this._collectionView = _elementRef.nativeElement;\n\n    this._collectionView.on(CollectionView.itemLoadingEvent, this.onItemLoading, this);\n    this._collectionView.itemViewLoader = this.itemViewLoader;\n    this._loaders = [];\n  }\n\n  private itemViewLoader = (viewType) => {\n    this._ngZone.run(() => {\n      switch (viewType) {\n        case ViewTemplateType.Item:\n          if (this._itemTemplate) {\n            return this.getOrCreate(this._itemTemplate);\n          }\n          break;\n        case ViewTemplateType.Header:\n          if (this._headerTemplate) {\n            return this.getOrCreate(this._headerTemplate);\n          }\n          break;\n        case ViewTemplateType.Footer:\n          if (this._footerTemplate) {\n            return this.getOrCreate(this._footerTemplate);\n          }\n          break;\n      }\n      return null;\n    });\n  };\n\n  public ngAfterContentInit() {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'CollectionView.ngAfterContentInit()');\n    }\n    this.setItemTemplates();\n  }\n\n  public ngOnDestroy() {\n    this._collectionView.off(CollectionView.itemLoadingEvent, this.onItemLoading, this);\n    this._collectionView = null;\n    this._loaders.forEach((l) => l.destroy());\n    this._loaders = null;\n    this.viewToLoader = null;\n    this.viewToTemplate = null;\n    this.viewPool = null;\n\n    this._items = null;\n    this._differ = null;\n    this._itemTemplate = null;\n    if (this._templateMap) {\n      this._templateMap.clear();\n    }\n    if (this._headerTemplateMap) {\n      this._headerTemplateMap.clear();\n    }\n    if (this._footerTemplateMap) {\n      this._footerTemplateMap.clear();\n    }\n    this._templateMap = null;\n    this._headerTemplateMap = null;\n    this._footerTemplateMap = null;\n  }\n\n  public ngDoCheck() {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'ngDoCheck() - execute differ? ' + this._differ);\n    }\n    if (this._differ) {\n      if (Trace.isEnabled()) {\n        CLog(CLogTypes.info, 'ngDoCheck() - execute differ');\n      }\n      const changes = this._differ.diff(this._items);\n      if (changes) {\n        if (Trace.isEnabled()) {\n          CLog(CLogTypes.info, 'ngDoCheck() - refresh');\n        }\n        this.refresh();\n      }\n    }\n  }\n\n  public registerTemplate(key: string, template: TemplateRef<ItemContext>) {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'registerTemplate for key: ' + key);\n    }\n    if (!this._templateMap) {\n      this._templateMap = new Map<string, KeyedTemplate>();\n    }\n\n    const keyedTemplate = {\n      key,\n      createView: this.getItemTemplateViewFactory(template),\n    };\n\n    this._templateMap.set(key, keyedTemplate);\n  }\n\n  public registerTemplateSupplemental(key: string, template: TemplateRef<ItemContext>, type: 'header' | 'footer') {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'registerTemplate for key: ' + key);\n    }\n\n    switch (type) {\n      case 'header':\n        // if (!this._headerTemplateMap) {\n        //   this._headerTemplateMap = new Map<string, KeyedTemplate>();\n        // }\n        // this._headerTemplateMap.set(key, keyedTemplate);\n        this._collectionView.headerKey = key;\n        this.headerItemTemplate = template;\n        this._collectionView.headerItemTemplate = this.getItemTemplateViewFactory(template);\n        break;\n      case 'footer':\n        // if (!this._footerTemplateMap) {\n        //   this._footerTemplateMap = new Map<string, KeyedTemplate>();\n        // }\n\n        // this._footerTemplateMap.set(key, keyedTemplate);\n\n        this._collectionView.footerKey = key;\n        this.footerItemTemplate = template;\n        this._collectionView.footerItemTemplate = this.getItemTemplateViewFactory(template);\n        break;\n    }\n  }\n\n  @HostListener('itemLoading', ['$event'])\n  public onItemLoading(args: CollectionViewItemEventData) {\n    if (!args.view && !this.itemTemplate) {\n      return;\n    }\n    if (!this.items) return;\n    const index = args.index;\n    const items = (args.object as any).items;\n    const currentItem = typeof items.getItem === 'function' ? items.getItem(index) : items[index];\n    let viewRef: EmbeddedViewRef<ItemContext>;\n\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, `onItemLoading: ${index} - Reusing existing view`);\n    }\n\n    viewRef = this.getNgView(args.view);\n\n    if (!viewRef && Trace.isEnabled()) {\n      if (Trace.isEnabled()) {\n        CLog(CLogTypes.info, `ViewReference not found for item ${index}. View recycling is not working`);\n      }\n    }\n\n    if (!viewRef) {\n      if (Trace.isEnabled()) {\n        CLog(CLogTypes.info, `onItemLoading: ${index} - Creating view from template`);\n      }\n      viewRef = this.getOrCreate(this.itemTemplate) as any;\n    }\n    this.setupViewRef(viewRef, currentItem, index);\n    this.detectChangesOnChild(viewRef, index);\n  }\n  @HostListener('itemRecycling', ['$event'])\n  public onItemRecyclingInternal(args: any) {\n    if (!args.view) {\n      return;\n    }\n    const ngView = this.getNgView(args.view);\n    // console.log('recycling', args.view);\n\n    if (ngView) {\n      ngView.detach();\n    }\n  }\n\n  @HostListener('displayItem', ['$event'])\n  public onItemDisplayInternal(args: CollectionViewItemEventData) {\n    if (!args.view) {\n      return;\n    }\n    const ngView = this.getNgView(args.view);\n\n    if (ngView) {\n      ngView.reattach();\n    }\n  }\n\n  @HostListener('itemDisposing', ['$event'])\n  public onItemDisposingInternal(args: any) {\n    if (!args.view) {\n      return;\n    }\n    const ngView = this.getNgView(args.view);\n\n    if (ngView) {\n      ngView.detach();\n      this.storeViewRef(ngView);\n    }\n  }\n\n  private getNgView(view: View): EmbeddedViewRef<unknown> {\n    const ngView = view[NG_VIEW];\n    // Getting angular view from original element (in cases when ProxyViewContainer\n    // is used NativeScript internally wraps it in a StackLayout)\n    if (!ngView && view instanceof LayoutBase && view.getChildrenCount() > 0) {\n      return view.getChildAt(0)[NG_VIEW];\n    }\n    return ngView;\n  }\n\n  public setupViewRef(view: EmbeddedViewRef<ItemContext>, data: any, index: number): void {\n    const context = view.context;\n    context.$implicit = data;\n    context.item = data;\n    context.index = index;\n    context.even = index % 2 === 0;\n    context.odd = !context.even;\n\n    this.setupItemView.next({\n      context,\n      data,\n      index,\n      view,\n    });\n  }\n\n  getItemTemplateViewFactory(template: TemplateRef<ItemContext>): () => View {\n    return () => {\n      return this.getOrCreate(template);\n    };\n  }\n  viewPool = new Map<\n    TemplateRef<ItemContext>,\n    {\n      scrapSize: number;\n      scrapHead: Set<EmbeddedViewRef<ItemContext>>;\n    }\n  >();\n  private storeViewRef(viewRef: EmbeddedViewRef<any>) {\n    const templateRef = this.viewToTemplate.get(viewRef);\n    if (templateRef) {\n      const scrap = this.viewPool.get(templateRef);\n      if (scrap) {\n        if (scrap.scrapHead.size >= scrap.scrapSize) {\n          viewRef.destroy();\n          this.viewToLoader.get(viewRef)?.destroy();\n        } else {\n          scrap.scrapHead.add(viewRef);\n        }\n      }\n    }\n  }\n  viewToTemplate = new WeakMap<EmbeddedViewRef<any>, TemplateRef<any>>();\n  viewToLoader = new WeakMap<EmbeddedViewRef<any>, ComponentRef<DetachedLoader>>();\n\n  private getOrCreate(templateRef: TemplateRef<ItemContext>) {\n    return this._ngZone.run(() => {\n      let viewRef = this.getView(templateRef);\n      if (!viewRef) {\n        const loader = this.detachedLoaderFactory();\n        viewRef = loader.instance.vc.createEmbeddedView(templateRef, new ItemContext(), 0);\n        this.viewToLoader.set(viewRef, loader);\n        this.viewToTemplate.set(viewRef, templateRef);\n      }\n      viewRef.detach();\n      const resultView = getItemViewRoot(viewRef);\n      resultView[NG_VIEW] = viewRef;\n      resultView.reusable = this.autoReuseViews;\n      return resultView;\n    });\n  }\n  private getView(templateRef: TemplateRef<ItemContext>) {\n    const pool = this.getViewPool(templateRef);\n    while (pool.scrapHead.size > 0) {\n      const viewRef: EmbeddedViewRef<ItemContext> = pool.scrapHead.values().next().value;\n      pool.scrapHead.delete(viewRef);\n      if (!viewRef.destroyed) {\n        return viewRef;\n      }\n    }\n    return null;\n  }\n\n  private getViewPool(templateRef: TemplateRef<ItemContext>) {\n    if (!this.viewPool.has(templateRef)) {\n      this.viewPool.set(templateRef, {\n        scrapSize: this.autoReuseViews ? Infinity : 0,\n        scrapHead: new Set<EmbeddedViewRef<ItemContext>>(),\n      });\n    }\n    return this.viewPool.get(templateRef);\n  }\n\n  private setItemTemplates() {\n    // The itemTemplateQuery may be changed after list items are added that contain <template> inside,\n    // so cache and use only the original template to avoid errors.\n    this.itemTemplate = this.itemTemplateQuery;\n\n    if (this._templateMap) {\n      if (Trace.isEnabled()) {\n        CLog(CLogTypes.info, 'Setting templates');\n      }\n\n      const templates: KeyedTemplate[] = [];\n      this._templateMap.forEach((value) => {\n        templates.push(value);\n      });\n      this._collectionView.itemTemplates = templates;\n    } else {\n      // If the map was not initialized this means that there are no named templates, so we register the default one.\n      this._collectionView.itemTemplate = this.getItemTemplateViewFactory(this.itemTemplate);\n    }\n  }\n\n  private detectChangesOnChild(viewRef: EmbeddedViewRef<ItemContext>, index: number) {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'Manually detect changes in child: ' + index);\n    }\n    viewRef.markForCheck();\n    viewRef.detectChanges();\n  }\n\n  private refresh() {\n    if (this._collectionView) {\n      this._collectionView.refresh();\n    }\n  }\n}\n\nexport interface ComponentView {\n  rootNodes: any[];\n  destroy(): void;\n}\n\nexport type RootLocator = (nodes: any[], nestLevel: number) => View;\n\nexport function getItemViewRoot(viewRef: ComponentView, rootLocator: RootLocator = extractSingleViewRecursive): View {\n  const rootView = rootLocator(viewRef.rootNodes, 0);\n  return rootView;\n}\n\n@Directive({ selector: '[cvTemplateKey]' })\nexport class TemplateKeyDirective {\n  constructor(private templateRef: TemplateRef<any>, @Host() private collectionView: CollectionViewComponent) {}\n\n  @Input()\n  set cvTemplateKey(value: any) {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'cvTemplateKey: ' + value);\n    }\n    if (this.collectionView && this.templateRef) {\n      this.collectionView.registerTemplate(value.toLowerCase(), this.templateRef);\n    }\n  }\n}\n\n@Directive({\n  selector: '[cvTemplateHeader]',\n})\nexport class TemplateHeaderDirective {\n  constructor(private templateRef: TemplateRef<any>, @Host() private collectionView: CollectionViewComponent) {}\n\n  @Input()\n  set cvTemplateHeader(value: any) {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'cvTemplateHeader: ' + value);\n    }\n    if (this.collectionView && this.templateRef) {\n      // TODO: allow keying of multiple headers per section\n      this.collectionView.registerTemplateSupplemental(value || ViewTemplateType.Header, this.templateRef, 'header');\n    }\n  }\n}\n\n@Directive({\n  selector: '[cvTemplateFooter]',\n})\nexport class TemplateFooterDirective {\n  constructor(private templateRef: TemplateRef<any>, @Host() private collectionView: CollectionViewComponent) {}\n\n  @Input()\n  set cvTemplateFooter(value: any) {\n    if (Trace.isEnabled()) {\n      CLog(CLogTypes.info, 'cvTemplateFooter: ' + value);\n    }\n    if (this.collectionView && this.templateRef) {\n      // TODO: allow keying of multiple footers per section\n      this.collectionView.registerTemplateSupplemental(value || ViewTemplateType.Footer, this.templateRef, 'footer');\n    }\n  }\n}\n"]}