UNPKG

powerbi-client-angular

Version:
92 lines 12 kB
// Copyright (c) Microsoft Corporation. // Licensed under the MIT License. import { Component, Input, ViewChild } from '@angular/core'; import { PowerBIEmbedComponent } from '../powerbi-embed/powerbi-embed.component'; import { isEmbedSetupValid } from '../../utils/utils'; import * as i0 from "@angular/core"; /** * Visual component to embed the visual, extends Base component */ export class PowerBIVisualEmbedComponent extends PowerBIEmbedComponent { // Getter for this._embed get embed() { return this._embed; } // Setter for this._embed set embed(newEmbedInstance) { this._embed = newEmbedInstance; } constructor() { super(); } // Returns embed object to calling function getVisual() { return this._embed; } ngOnInit() { // Initialize PowerBI service instance variable from parent super.ngOnInit(); } ngOnChanges(changes) { if (changes.embedConfig) { // Check if the function is being called for the first time if (changes.embedConfig.isFirstChange()) { return; } const prevEmbedConfig = changes.embedConfig.previousValue; const currentEmbedConfig = changes.embedConfig.currentValue; if (JSON.stringify(prevEmbedConfig) !== JSON.stringify(currentEmbedConfig)) { // Input from parent get updated, thus call embedVisual function this.embedVisual(); } } // Set event handlers if available if (this.eventHandlers && this.embed) { super.setEventHandlers(this.embed, this.eventHandlers); } } ngAfterViewInit() { // Check if container exists on the UI if (this.containerRef.nativeElement) { // Decide to embed or bootstrap if (this.embedConfig.accessToken && this.embedConfig.embedUrl) { this.embedVisual(); } else { this.embed = this.powerbi.bootstrap(this.containerRef.nativeElement, this.embedConfig); } } // Set event handlers if available if (this.eventHandlers && this.embed) { super.setEventHandlers(this.embed, this.eventHandlers); } } /** * Embed the PowerBI Visual * * @returns void */ embedVisual() { if (!isEmbedSetupValid(this.containerRef, this.embedConfig)) { return; } this.embed = this.powerbi.embed(this.containerRef.nativeElement, this.embedConfig); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PowerBIVisualEmbedComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PowerBIVisualEmbedComponent, selector: "powerbi-visual[embedConfig]", inputs: { embedConfig: "embedConfig", eventHandlers: "eventHandlers" }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["visualContainer"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: '<div class={{cssClassName}} #visualContainer></div>', isInline: true }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PowerBIVisualEmbedComponent, decorators: [{ type: Component, args: [{ selector: 'powerbi-visual[embedConfig]', template: '<div class={{cssClassName}} #visualContainer></div>', }] }], ctorParameters: () => [], propDecorators: { embedConfig: [{ type: Input }], eventHandlers: [{ type: Input }], containerRef: [{ type: ViewChild, args: ['visualContainer'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"powerbi-visual-embed.component.js","sourceRoot":"","sources":["../../../../../src/components/powerbi-visual-embed/powerbi-visual-embed.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\r\n// Licensed under the MIT License.\r\n\r\nimport { AfterViewInit, Component, ElementRef, Input, OnChanges, OnInit, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { Embed, IVisualEmbedConfiguration, Visual } from 'powerbi-client';\r\nimport { EventHandler, PowerBIEmbedComponent } from '../powerbi-embed/powerbi-embed.component';\r\nimport { isEmbedSetupValid } from '../../utils/utils';\r\n\r\n/**\r\n * Visual component to embed the visual, extends Base component\r\n */\r\n@Component({\r\n  selector: 'powerbi-visual[embedConfig]',\r\n  template: '<div class={{cssClassName}} #visualContainer></div>',\r\n})\r\nexport class PowerBIVisualEmbedComponent extends PowerBIEmbedComponent implements OnInit, OnChanges, AfterViewInit {\r\n  // Input() specify properties that will be passed from parent\r\n  // Configuration for embedding the PowerBI Visual (Required)\r\n  @Input() embedConfig!: IVisualEmbedConfiguration;\r\n\r\n  // Map of event name and handler methods pairs to be triggered on the event (Optional)\r\n  @Input() eventHandlers?: Map<string, EventHandler | null>;\r\n\r\n  // Ref to the HTML div container element\r\n  @ViewChild('visualContainer') private containerRef!: ElementRef<HTMLDivElement>;\r\n\r\n  // Embedded entity\r\n  // Note: Do not read or assign to this member variable directly, instead use the getter and setter\r\n  private _embed?: Embed;\r\n\r\n  // Getter for this._embed\r\n  private get embed(): Embed | undefined {\r\n    return this._embed;\r\n  }\r\n\r\n  // Setter for this._embed\r\n  private set embed(newEmbedInstance: Embed | undefined) {\r\n    this._embed = newEmbedInstance;\r\n  }\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  // Returns embed object to calling function\r\n  getVisual(): Visual {\r\n    return this._embed as Visual;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // Initialize PowerBI service instance variable from parent\r\n    super.ngOnInit();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.embedConfig) {\r\n      // Check if the function is being called for the first time\r\n      if (changes.embedConfig.isFirstChange()) {\r\n        return;\r\n      }\r\n\r\n      const prevEmbedConfig: IVisualEmbedConfiguration = changes.embedConfig.previousValue;\r\n      const currentEmbedConfig: IVisualEmbedConfiguration = changes.embedConfig.currentValue;\r\n      if (JSON.stringify(prevEmbedConfig) !== JSON.stringify(currentEmbedConfig)) {\r\n        // Input from parent get updated, thus call embedVisual function\r\n        this.embedVisual();\r\n      }\r\n    }\r\n\r\n    // Set event handlers if available\r\n    if (this.eventHandlers && this.embed) {\r\n      super.setEventHandlers(this.embed, this.eventHandlers);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // Check if container exists on the UI\r\n    if (this.containerRef.nativeElement) {\r\n      // Decide to embed or bootstrap\r\n      if (this.embedConfig.accessToken && this.embedConfig.embedUrl) {\r\n        this.embedVisual();\r\n      } else {\r\n        this.embed = this.powerbi.bootstrap(this.containerRef.nativeElement, this.embedConfig);\r\n      }\r\n    }\r\n\r\n    // Set event handlers if available\r\n    if (this.eventHandlers && this.embed) {\r\n      super.setEventHandlers(this.embed, this.eventHandlers);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Embed the PowerBI Visual\r\n   *\r\n   * @returns void\r\n   */\r\n  private embedVisual(): void {\r\n    if (!isEmbedSetupValid(this.containerRef, this.embedConfig)) {\r\n      return;\r\n    }\r\n\r\n    this.embed = this.powerbi.embed(this.containerRef.nativeElement, this.embedConfig);\r\n  }\r\n}\r\n"]}