@nstudio/ui-collectionview 5.1.8 → 5.1.9-alpha.1

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,5 +1,5 @@
1
1
  import { AfterContentInit, ComponentRef, DoCheck, ElementRef, EmbeddedViewRef, EventEmitter, IterableDiffers, NgZone, OnDestroy, TemplateRef, ViewContainerRef } from '@angular/core';
2
- import { CollectionViewItemEventData } from '@nstudio/ui-collectionview';
2
+ import { CollectionView, CollectionViewItemEventData } from '@nstudio/ui-collectionview';
3
3
  import { DetachedLoader, NativeScriptRendererFactory } from '@nativescript/angular';
4
4
  import { View } from '@nativescript/core';
5
5
  import * as i0 from "@angular/core";
@@ -22,15 +22,19 @@ export declare class CollectionViewComponent implements DoCheck, OnDestroy, Afte
22
22
  private _iterableDiffers;
23
23
  private _renderer;
24
24
  private _ngZone;
25
- get nativeElement(): any;
26
- get listView(): any;
25
+ get nativeElement(): CollectionView;
26
+ get listView(): CollectionView;
27
27
  loader: ViewContainerRef;
28
28
  setupItemView: EventEmitter<SetupItemViewArgs>;
29
29
  itemTemplateQuery: TemplateRef<ItemContext>;
30
30
  autoReuseViews: boolean;
31
31
  detachedLoaderFactory(): ComponentRef<DetachedLoader>;
32
- get itemTemplate(): any;
33
- set itemTemplate(value: any);
32
+ get itemTemplate(): TemplateRef<ItemContext>;
33
+ set itemTemplate(value: TemplateRef<ItemContext>);
34
+ get headerItemTemplate(): TemplateRef<ItemContext>;
35
+ set headerItemTemplate(value: TemplateRef<ItemContext>);
36
+ get footerItemTemplate(): TemplateRef<ItemContext>;
37
+ set footerItemTemplate(value: TemplateRef<ItemContext>);
34
38
  get items(): any;
35
39
  set items(value: any);
36
40
  private _collectionView;
@@ -38,6 +42,10 @@ export declare class CollectionViewComponent implements DoCheck, OnDestroy, Afte
38
42
  private _differ;
39
43
  private _itemTemplate;
40
44
  private _templateMap;
45
+ private _headerTemplate;
46
+ private _headerTemplateMap;
47
+ private _footerTemplate;
48
+ private _footerTemplateMap;
41
49
  private _loaders;
42
50
  constructor(_elementRef: ElementRef, _iterableDiffers: IterableDiffers, _renderer: NativeScriptRendererFactory, _ngZone: NgZone);
43
51
  private itemViewLoader;
@@ -45,11 +53,12 @@ export declare class CollectionViewComponent implements DoCheck, OnDestroy, Afte
45
53
  ngOnDestroy(): void;
46
54
  ngDoCheck(): void;
47
55
  registerTemplate(key: string, template: TemplateRef<ItemContext>): void;
56
+ registerTemplateSupplemental(key: string, template: TemplateRef<ItemContext>, type: 'header' | 'footer'): void;
48
57
  onItemLoading(args: CollectionViewItemEventData): void;
49
58
  onItemRecyclingInternal(args: any): void;
50
59
  onItemDisposingInternal(args: any): void;
51
60
  setupViewRef(view: EmbeddedViewRef<ItemContext>, data: any, index: number): void;
52
- protected getItemTemplateViewFactory(template: TemplateRef<ItemContext>): () => View;
61
+ getItemTemplateViewFactory(template: TemplateRef<ItemContext>): () => View;
53
62
  viewPool: Map<TemplateRef<ItemContext>, {
54
63
  scrapSize: number;
55
64
  scrapHead: Set<EmbeddedViewRef<ItemContext>>;
@@ -64,7 +73,7 @@ export declare class CollectionViewComponent implements DoCheck, OnDestroy, Afte
64
73
  private detectChangesOnChild;
65
74
  private refresh;
66
75
  static ɵfac: i0.ɵɵFactoryDeclaration<CollectionViewComponent, never>;
67
- static ɵcmp: i0.ɵɵComponentDeclaration<CollectionViewComponent, "CollectionView", never, { "autoReuseViews": "autoReuseViews"; "itemTemplate": "itemTemplate"; "items": "items"; }, { "setupItemView": "setupItemView"; }, ["itemTemplateQuery"], never, false, 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>;
68
77
  }
69
78
  export interface ComponentView {
70
79
  rootNodes: any[];
@@ -80,3 +89,19 @@ export declare class TemplateKeyDirective {
80
89
  static ɵfac: i0.ɵɵFactoryDeclaration<TemplateKeyDirective, [null, { host: true; }]>;
81
90
  static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateKeyDirective, "[cvTemplateKey]", never, { "cvTemplateKey": "cvTemplateKey"; }, {}, never, never, false, never>;
82
91
  }
92
+ export declare class TemplateHeaderDirective {
93
+ private templateRef;
94
+ private collectionView;
95
+ constructor(templateRef: TemplateRef<any>, collectionView: CollectionViewComponent);
96
+ set cvTemplateHeader(value: any);
97
+ static ɵfac: i0.ɵɵFactoryDeclaration<TemplateHeaderDirective, [null, { host: true; }]>;
98
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateHeaderDirective, "[cvTemplateHeader]", never, { "cvTemplateHeader": "cvTemplateHeader"; }, {}, never, never, false, never>;
99
+ }
100
+ export declare class TemplateFooterDirective {
101
+ private templateRef;
102
+ private collectionView;
103
+ constructor(templateRef: TemplateRef<any>, collectionView: CollectionViewComponent);
104
+ set cvTemplateFooter(value: any);
105
+ static ɵfac: i0.ɵɵFactoryDeclaration<TemplateFooterDirective, [null, { host: true; }]>;
106
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TemplateFooterDirective, "[cvTemplateFooter]", never, { "cvTemplateFooter": "cvTemplateFooter"; }, {}, never, never, false, never>;
107
+ }
@@ -1,5 +1,5 @@
1
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, ListViewViewTypes } from '@nstudio/ui-collectionview';
2
+ import { CLog, CLogTypes, CollectionView, ViewTemplateType } from '@nstudio/ui-collectionview';
3
3
  import { DetachedLoader, NativeScriptRendererFactory, extractSingleViewRecursive, isListLikeIterable, registerElement } from '@nativescript/angular';
4
4
  import { LayoutBase, ObservableArray, Trace } from '@nativescript/core';
5
5
  import * as i0 from "@angular/core";
@@ -35,7 +35,19 @@ export class CollectionViewComponent {
35
35
  }
36
36
  set itemTemplate(value) {
37
37
  this._itemTemplate = value;
38
- this._collectionView.refresh();
38
+ // this._collectionView.refresh();
39
+ }
40
+ get headerItemTemplate() {
41
+ return this._headerTemplate;
42
+ }
43
+ set headerItemTemplate(value) {
44
+ this._headerTemplate = value;
45
+ }
46
+ get footerItemTemplate() {
47
+ return this._footerTemplate;
48
+ }
49
+ set footerItemTemplate(value) {
50
+ this._footerTemplate = value;
39
51
  }
40
52
  get items() {
41
53
  return this._items;
@@ -58,17 +70,28 @@ export class CollectionViewComponent {
58
70
  this._ngZone = _ngZone;
59
71
  this.setupItemView = new EventEmitter();
60
72
  this.autoReuseViews = false;
61
- this.itemViewLoader = (viewType) => this._ngZone.run(() => {
62
- switch (viewType) {
63
- case ListViewViewTypes.ItemView:
64
- if (this._itemTemplate && this.loader) {
65
- const typedView = this.getOrCreate(this._itemTemplate);
66
- return typedView;
67
- }
68
- break;
69
- }
70
- return null;
71
- });
73
+ this.itemViewLoader = (viewType) => {
74
+ this._ngZone.run(() => {
75
+ switch (viewType) {
76
+ case ViewTemplateType.Item:
77
+ if (this._itemTemplate) {
78
+ return this.getOrCreate(this._itemTemplate);
79
+ }
80
+ break;
81
+ case ViewTemplateType.Header:
82
+ if (this._headerTemplate) {
83
+ return this.getOrCreate(this._headerTemplate);
84
+ }
85
+ break;
86
+ case ViewTemplateType.Footer:
87
+ if (this._footerTemplate) {
88
+ return this.getOrCreate(this._footerTemplate);
89
+ }
90
+ break;
91
+ }
92
+ return null;
93
+ });
94
+ };
72
95
  this.viewPool = new Map();
73
96
  this.viewToTemplate = new WeakMap();
74
97
  this.viewToLoader = new WeakMap();
@@ -97,7 +120,15 @@ export class CollectionViewComponent {
97
120
  if (this._templateMap) {
98
121
  this._templateMap.clear();
99
122
  }
123
+ if (this._headerTemplateMap) {
124
+ this._headerTemplateMap.clear();
125
+ }
126
+ if (this._footerTemplateMap) {
127
+ this._footerTemplateMap.clear();
128
+ }
100
129
  this._templateMap = null;
130
+ this._headerTemplateMap = null;
131
+ this._footerTemplateMap = null;
101
132
  }
102
133
  ngDoCheck() {
103
134
  if (Trace.isEnabled()) {
@@ -129,6 +160,31 @@ export class CollectionViewComponent {
129
160
  };
130
161
  this._templateMap.set(key, keyedTemplate);
131
162
  }
163
+ registerTemplateSupplemental(key, template, type) {
164
+ if (Trace.isEnabled()) {
165
+ CLog(CLogTypes.info, 'registerTemplate for key: ' + key);
166
+ }
167
+ switch (type) {
168
+ case 'header':
169
+ // if (!this._headerTemplateMap) {
170
+ // this._headerTemplateMap = new Map<string, KeyedTemplate>();
171
+ // }
172
+ // this._headerTemplateMap.set(key, keyedTemplate);
173
+ this._collectionView.headerKey = key;
174
+ this.headerItemTemplate = template;
175
+ this._collectionView.headerItemTemplate = this.getItemTemplateViewFactory(template);
176
+ break;
177
+ case 'footer':
178
+ // if (!this._footerTemplateMap) {
179
+ // this._footerTemplateMap = new Map<string, KeyedTemplate>();
180
+ // }
181
+ // this._footerTemplateMap.set(key, keyedTemplate);
182
+ this._collectionView.footerKey = key;
183
+ this.footerItemTemplate = template;
184
+ this._collectionView.footerItemTemplate = this.getItemTemplateViewFactory(template);
185
+ break;
186
+ }
187
+ }
132
188
  onItemLoading(args) {
133
189
  if (!args.view && !this.itemTemplate) {
134
190
  return;
@@ -236,7 +292,6 @@ export class CollectionViewComponent {
236
292
  let viewRef = this.getView(templateRef);
237
293
  if (!viewRef) {
238
294
  const loader = this.detachedLoaderFactory();
239
- // viewRef = this.loader.createEmbeddedView(templateRef, new ItemContext(), 0);
240
295
  viewRef = loader.instance.vc.createEmbeddedView(templateRef, new ItemContext(), 0);
241
296
  this.viewToLoader.set(viewRef, loader);
242
297
  this.viewToTemplate.set(viewRef, templateRef);
@@ -301,7 +356,7 @@ export class CollectionViewComponent {
301
356
  }
302
357
  }
303
358
  CollectionViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CollectionViewComponent, deps: [{ token: ElementRef }, { token: IterableDiffers }, { token: NativeScriptRendererFactory }, { token: NgZone }], target: i0.ɵɵFactoryTarget.Component });
304
- CollectionViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CollectionViewComponent, selector: "CollectionView", inputs: { autoReuseViews: "autoReuseViews", itemTemplate: "itemTemplate", items: "items" }, outputs: { setupItemView: "setupItemView" }, host: { listeners: { "itemLoading": "onItemLoading($event)", "itemRecycling": "onItemRecyclingInternal($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: `
359
+ CollectionViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.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)", "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: `
305
360
  <DetachedContainer>
306
361
  <Placeholder #loader></Placeholder>
307
362
  </DetachedContainer>
@@ -341,6 +396,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
341
396
  type: Input
342
397
  }], itemTemplate: [{
343
398
  type: Input
399
+ }], headerItemTemplate: [{
400
+ type: Input
401
+ }], footerItemTemplate: [{
402
+ type: Input
344
403
  }], items: [{
345
404
  type: Input
346
405
  }], onItemLoading: [{
@@ -381,4 +440,58 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
381
440
  }] }]; }, propDecorators: { cvTemplateKey: [{
382
441
  type: Input
383
442
  }] } });
384
- //# 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, ListViewViewTypes } 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(): any {\n    return this._collectionView;\n  }\n  public get listView(): any {\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: any) {\n    this._itemTemplate = value;\n    this._collectionView.refresh();\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 _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 ListViewViewTypes.ItemView:\n          if (this._itemTemplate && this.loader) {\n            const typedView = this.getOrCreate(this._itemTemplate);\n            return typedView;\n          }\n          break;\n      }\n      return null;\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    this._templateMap = 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  @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 = args.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 (!viewRef && args.view instanceof LayoutBase && args.view.getChildrenCount() > 0) {\n      viewRef = args.view.getChildAt(0)[NG_VIEW];\n    }\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\n      viewRef = this.loader.createEmbeddedView(this.itemTemplate, new ItemContext(), 0);\n      args.view = getItemViewRoot(viewRef);\n      args.view[NG_VIEW] = viewRef;\n    }\n\n    this.setupViewRef(viewRef, currentItem, index);\n\n    this.detectChangesOnChild(viewRef, index);\n  }\n  @HostListener('itemRecycling', ['$event'])\n  public onItemRecyclingInternal(args: any) {\n    if (!args.view) {\n      return;\n    }\n    let ngView: EmbeddedViewRef<any> = args.view[NG_VIEW];\n\n    // Getting angular view from original element (in cases when ProxyViewContainer\n    // is used NativeScript internally wraps it in a StackLayout)\n    if (!ngView && args.view instanceof LayoutBase && args.view.getChildrenCount() > 0) {\n      ngView = args.view.getChildAt(0)[NG_VIEW];\n    }\n    // console.log('recycling', args.view);\n\n    if (ngView) {\n      ngView.detach();\n    }\n  }\n\n  @HostListener('itemDisposing', ['$event'])\n  public onItemDisposingInternal(args: any) {\n    if (!args.view) {\n      return;\n    }\n    let ngView: EmbeddedViewRef<any> = args.view[NG_VIEW];\n\n    // Getting angular view from original element (in cases when ProxyViewContainer\n    // is used NativeScript internally wraps it in a StackLayout)\n    if (!ngView && args.view instanceof LayoutBase && args.view.getChildrenCount() > 0) {\n      ngView = args.view.getChildAt(0)[NG_VIEW];\n    }\n\n    if (ngView) {\n      ngView.detach();\n      this.storeViewRef(ngView);\n    }\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  protected getItemTemplateViewFactory(template: TemplateRef<ItemContext>): () => View {\n    return () => {\n      const viewRef = this.loader.createEmbeddedView(template, new ItemContext(), 0);\n      const resultView = getItemViewRoot(viewRef);\n      resultView[NG_VIEW] = viewRef;\n\n      return resultView;\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 = this.loader.createEmbeddedView(templateRef, new ItemContext(), 0);\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"]}
443
+ export class TemplateHeaderDirective {
444
+ constructor(templateRef, collectionView) {
445
+ this.templateRef = templateRef;
446
+ this.collectionView = collectionView;
447
+ }
448
+ set cvTemplateHeader(value) {
449
+ if (Trace.isEnabled()) {
450
+ CLog(CLogTypes.info, 'cvTemplateHeader: ' + value);
451
+ }
452
+ if (this.collectionView && this.templateRef) {
453
+ // TODO: allow keying of multiple headers per section
454
+ this.collectionView.registerTemplateSupplemental(value || ViewTemplateType.Header, this.templateRef, 'header');
455
+ }
456
+ }
457
+ }
458
+ TemplateHeaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TemplateHeaderDirective, deps: [{ token: i0.TemplateRef }, { token: CollectionViewComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
459
+ TemplateHeaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TemplateHeaderDirective, selector: "[cvTemplateHeader]", inputs: { cvTemplateHeader: "cvTemplateHeader" }, ngImport: i0 });
460
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TemplateHeaderDirective, decorators: [{
461
+ type: Directive,
462
+ args: [{
463
+ selector: '[cvTemplateHeader]',
464
+ }]
465
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: CollectionViewComponent, decorators: [{
466
+ type: Host
467
+ }] }]; }, propDecorators: { cvTemplateHeader: [{
468
+ type: Input
469
+ }] } });
470
+ export class TemplateFooterDirective {
471
+ constructor(templateRef, collectionView) {
472
+ this.templateRef = templateRef;
473
+ this.collectionView = collectionView;
474
+ }
475
+ set cvTemplateFooter(value) {
476
+ if (Trace.isEnabled()) {
477
+ CLog(CLogTypes.info, 'cvTemplateFooter: ' + value);
478
+ }
479
+ if (this.collectionView && this.templateRef) {
480
+ // TODO: allow keying of multiple footers per section
481
+ this.collectionView.registerTemplateSupplemental(value || ViewTemplateType.Footer, this.templateRef, 'footer');
482
+ }
483
+ }
484
+ }
485
+ TemplateFooterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TemplateFooterDirective, deps: [{ token: i0.TemplateRef }, { token: CollectionViewComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
486
+ TemplateFooterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TemplateFooterDirective, selector: "[cvTemplateFooter]", inputs: { cvTemplateFooter: "cvTemplateFooter" }, ngImport: i0 });
487
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TemplateFooterDirective, decorators: [{
488
+ type: Directive,
489
+ args: [{
490
+ selector: '[cvTemplateFooter]',
491
+ }]
492
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: CollectionViewComponent, decorators: [{
493
+ type: Host
494
+ }] }]; }, propDecorators: { cvTemplateFooter: [{
495
+ type: Input
496
+ }] } });
497
+ //# 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 = args.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 (!viewRef && args.view instanceof LayoutBase && args.view.getChildrenCount() > 0) {\n      viewRef = args.view.getChildAt(0)[NG_VIEW];\n    }\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\n      viewRef = this.loader.createEmbeddedView(this.itemTemplate, new ItemContext(), 0);\n      args.view = getItemViewRoot(viewRef);\n      args.view[NG_VIEW] = viewRef;\n    }\n\n    this.setupViewRef(viewRef, currentItem, index);\n\n    this.detectChangesOnChild(viewRef, index);\n  }\n  @HostListener('itemRecycling', ['$event'])\n  public onItemRecyclingInternal(args: any) {\n    if (!args.view) {\n      return;\n    }\n    let ngView: EmbeddedViewRef<any> = args.view[NG_VIEW];\n\n    // Getting angular view from original element (in cases when ProxyViewContainer\n    // is used NativeScript internally wraps it in a StackLayout)\n    if (!ngView && args.view instanceof LayoutBase && args.view.getChildrenCount() > 0) {\n      ngView = args.view.getChildAt(0)[NG_VIEW];\n    }\n    // console.log('recycling', args.view);\n\n    if (ngView) {\n      ngView.detach();\n    }\n  }\n\n  @HostListener('itemDisposing', ['$event'])\n  public onItemDisposingInternal(args: any) {\n    if (!args.view) {\n      return;\n    }\n    let ngView: EmbeddedViewRef<any> = args.view[NG_VIEW];\n\n    // Getting angular view from original element (in cases when ProxyViewContainer\n    // is used NativeScript internally wraps it in a StackLayout)\n    if (!ngView && args.view instanceof LayoutBase && args.view.getChildrenCount() > 0) {\n      ngView = args.view.getChildAt(0)[NG_VIEW];\n    }\n\n    if (ngView) {\n      ngView.detach();\n      this.storeViewRef(ngView);\n    }\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      const viewRef = this.loader.createEmbeddedView(template, new ItemContext(), 0);\n      const resultView = getItemViewRoot(viewRef);\n      resultView[NG_VIEW] = viewRef;\n      return resultView;\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"]}
@@ -1,19 +1,19 @@
1
1
  // External
2
2
  import { NO_ERRORS_SCHEMA, NgModule } from '@angular/core';
3
- import { CollectionViewComponent, TemplateKeyDirective } from './collectionview.component';
3
+ import { CollectionViewComponent, TemplateKeyDirective, TemplateHeaderDirective, TemplateFooterDirective } from './collectionview.component';
4
4
  import * as i0 from "@angular/core";
5
- export { CollectionViewComponent, TemplateKeyDirective } from './collectionview.component';
5
+ export { CollectionViewComponent, TemplateKeyDirective, TemplateHeaderDirective, TemplateFooterDirective } from './collectionview.component';
6
6
  export class CollectionViewModule {
7
7
  }
8
8
  CollectionViewModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CollectionViewModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- CollectionViewModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: CollectionViewModule, declarations: [CollectionViewComponent, TemplateKeyDirective], exports: [CollectionViewComponent, TemplateKeyDirective] });
9
+ CollectionViewModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: CollectionViewModule, declarations: [CollectionViewComponent, TemplateKeyDirective, TemplateHeaderDirective, TemplateFooterDirective], exports: [CollectionViewComponent, TemplateKeyDirective, TemplateHeaderDirective, TemplateFooterDirective] });
10
10
  CollectionViewModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CollectionViewModule });
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CollectionViewModule, decorators: [{
12
12
  type: NgModule,
13
13
  args: [{
14
- declarations: [CollectionViewComponent, TemplateKeyDirective],
15
- exports: [CollectionViewComponent, TemplateKeyDirective],
14
+ declarations: [CollectionViewComponent, TemplateKeyDirective, TemplateHeaderDirective, TemplateFooterDirective],
15
+ exports: [CollectionViewComponent, TemplateKeyDirective, TemplateHeaderDirective, TemplateFooterDirective],
16
16
  schemas: [NO_ERRORS_SCHEMA],
17
17
  }]
18
18
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy91aS1jb2xsZWN0aW9udmlldy9hbmd1bGFyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFdBQVc7QUFDWCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQUMzRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQU8zRixNQUFNLE9BQU8sb0JBQW9COztpSEFBcEIsb0JBQW9CO2tIQUFwQixvQkFBb0IsaUJBSmhCLHVCQUF1QixFQUFFLG9CQUFvQixhQUNsRCx1QkFBdUIsRUFBRSxvQkFBb0I7a0hBRzVDLG9CQUFvQjsyRkFBcEIsb0JBQW9CO2tCQUxoQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHVCQUF1QixFQUFFLG9CQUFvQixDQUFDO29CQUM3RCxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxvQkFBb0IsQ0FBQztvQkFDeEQsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gRXh0ZXJuYWxcbmltcG9ydCB7IE5PX0VSUk9SU19TQ0hFTUEsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IENvbGxlY3Rpb25WaWV3Q29tcG9uZW50LCBUZW1wbGF0ZUtleURpcmVjdGl2ZSB9IGZyb20gJy4vY29sbGVjdGlvbnZpZXcuY29tcG9uZW50JztcbmV4cG9ydCB7IENvbGxlY3Rpb25WaWV3Q29tcG9uZW50LCBUZW1wbGF0ZUtleURpcmVjdGl2ZSB9IGZyb20gJy4vY29sbGVjdGlvbnZpZXcuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbQ29sbGVjdGlvblZpZXdDb21wb25lbnQsIFRlbXBsYXRlS2V5RGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW0NvbGxlY3Rpb25WaWV3Q29tcG9uZW50LCBUZW1wbGF0ZUtleURpcmVjdGl2ZV0sXG4gIHNjaGVtYXM6IFtOT19FUlJPUlNfU0NIRU1BXSxcbn0pXG5leHBvcnQgY2xhc3MgQ29sbGVjdGlvblZpZXdNb2R1bGUge31cbiJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy91aS1jb2xsZWN0aW9udmlldy9hbmd1bGFyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFdBQVc7QUFDWCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxvQkFBb0IsRUFBRSx1QkFBdUIsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQUM3SSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsb0JBQW9CLEVBQUUsdUJBQXVCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQU83SSxNQUFNLE9BQU8sb0JBQW9COztpSEFBcEIsb0JBQW9CO2tIQUFwQixvQkFBb0IsaUJBSmhCLHVCQUF1QixFQUFFLG9CQUFvQixFQUFFLHVCQUF1QixFQUFFLHVCQUF1QixhQUNwRyx1QkFBdUIsRUFBRSxvQkFBb0IsRUFBRSx1QkFBdUIsRUFBRSx1QkFBdUI7a0hBRzlGLG9CQUFvQjsyRkFBcEIsb0JBQW9CO2tCQUxoQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHVCQUF1QixFQUFFLG9CQUFvQixFQUFFLHVCQUF1QixFQUFFLHVCQUF1QixDQUFDO29CQUMvRyxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxvQkFBb0IsRUFBRSx1QkFBdUIsRUFBRSx1QkFBdUIsQ0FBQztvQkFDMUcsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gRXh0ZXJuYWxcbmltcG9ydCB7IE5PX0VSUk9SU19TQ0hFTUEsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IENvbGxlY3Rpb25WaWV3Q29tcG9uZW50LCBUZW1wbGF0ZUtleURpcmVjdGl2ZSwgVGVtcGxhdGVIZWFkZXJEaXJlY3RpdmUsIFRlbXBsYXRlRm9vdGVyRGlyZWN0aXZlIH0gZnJvbSAnLi9jb2xsZWN0aW9udmlldy5jb21wb25lbnQnO1xuZXhwb3J0IHsgQ29sbGVjdGlvblZpZXdDb21wb25lbnQsIFRlbXBsYXRlS2V5RGlyZWN0aXZlLCBUZW1wbGF0ZUhlYWRlckRpcmVjdGl2ZSwgVGVtcGxhdGVGb290ZXJEaXJlY3RpdmUgfSBmcm9tICcuL2NvbGxlY3Rpb252aWV3LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0NvbGxlY3Rpb25WaWV3Q29tcG9uZW50LCBUZW1wbGF0ZUtleURpcmVjdGl2ZSwgVGVtcGxhdGVIZWFkZXJEaXJlY3RpdmUsIFRlbXBsYXRlRm9vdGVyRGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW0NvbGxlY3Rpb25WaWV3Q29tcG9uZW50LCBUZW1wbGF0ZUtleURpcmVjdGl2ZSwgVGVtcGxhdGVIZWFkZXJEaXJlY3RpdmUsIFRlbXBsYXRlRm9vdGVyRGlyZWN0aXZlXSxcbiAgc2NoZW1hczogW05PX0VSUk9SU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uVmlld01vZHVsZSB7fVxuIl19