All files / layout/aem-model-provider aem-model-provider.component.ts

91.67% Statements 11/12
100% Branches 0/0
80% Functions 4/5
90.91% Lines 10/11

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62                                              1x       1x       1x       1x   1x   1x               1x 1x 1x         22x              
/*
 * Copyright 2020 Adobe. All rights reserved.
 * This file is licensed to you under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License. You may obtain a copy
 * of the License at http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under
 * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
 * OF ANY KIND, either express or implied. See the License for the specific language
 * governing permissions and limitations under the License.
 */
 
import { Component, Input, ViewChild } from '@angular/core';
import { ModelManager } from '@adobe/aem-spa-page-model-manager';
import { AEMComponentDirective } from '../aem-component.directive';
 
@Component({
  selector: 'aem-model-provider,[aemModelProvider]',
  template: `<ng-container aemComponent [cqItem]='cqItem' [cqPath]='cqPath' [itemName]='itemName'></ng-container>`
})
/**
 * The current component is responsible for providing access to the ModelManager and the model of a component
 */
export class AEMModelProviderComponent {
  /**
   * Path to the model associated with the current instance of the component
   */
  @Input() cqPath;
  /**
   * Model item associated with the current model provider component
   */
  @Input() cqItem;
  /**
   * Name of the item associated with the current model provider component
   */
  @Input() itemName;
 
  @Input() aemModelProvider;
 
  @ViewChild(AEMComponentDirective) aemComponent: AEMComponentDirective;
 
  constructor() { /* void */ }
 
  /**
   * Updates the item data
   */
  updateItem(): void {
    ModelManager.getData({ path: this.cqPath }).then(model => {
      this.cqItem = model;
      this.aemComponent.changeDetectorRef.markForCheck();
    });
  }
 
  ngOnInit(): void {
    ModelManager.addListener(this.cqPath, this.updateItem.bind(this));
  }
 
  ngDestroy(): void {
    ModelManager.removeListener(this.cqPath, this.updateItem.bind(this));
  }
}