angular-google-charts
Version:
A wrapper for the Google Charts library written with Angular
112 lines • 16 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';
import { ReplaySubject } from 'rxjs';
import { generateRandomId } from '../../helpers/id.helper';
import { ScriptLoaderService } from '../../services/script-loader.service';
import { FilterType } from '../../types/control-type';
import * as i0 from "@angular/core";
import * as i1 from "../../services/script-loader.service";
export class ControlWrapperComponent {
constructor(loaderService) {
this.loaderService = loaderService;
/**
* Emits when an error occurs when attempting to render the control.
*/
this.error = new EventEmitter();
/**
* The control is ready to accept user interaction and for external method calls.
*
* Alternatively, you can listen for a ready event on the dashboard holding the control
* and call control methods only after the event was fired.
*/
this.ready = new EventEmitter();
/**
* Emits when the user interacts with the control, affecting its state.
* For example, a `stateChange` event will be emitted whenever you move the thumbs of a range slider control.
*
* To retrieve an updated control state after the event fired, call `ControlWrapper.getState()`.
*/
this.stateChange = new EventEmitter();
/**
* A generated id assigned to this components DOM element.
*/
this.id = generateRandomId();
this.wrapperReadySubject = new ReplaySubject(1);
}
/**
* Emits after the `ControlWrapper` was created.
*/
get wrapperReady$() {
return this.wrapperReadySubject.asObservable();
}
get controlWrapper() {
if (!this._controlWrapper) {
throw new Error(`Cannot access the control wrapper before it being initialized.`);
}
return this._controlWrapper;
}
ngOnInit() {
this.loaderService.loadChartPackages('controls').subscribe(() => {
this.createControlWrapper();
});
}
ngOnChanges(changes) {
if (!this._controlWrapper) {
return;
}
if (changes.type) {
this._controlWrapper.setControlType(this.type);
}
if (changes.options) {
this._controlWrapper.setOptions(this.options || {});
}
if (changes.state) {
this._controlWrapper.setState(this.state || {});
}
}
createControlWrapper() {
this._controlWrapper = new google.visualization.ControlWrapper({
containerId: this.id,
controlType: this.type,
state: this.state,
options: this.options
});
this.addEventListeners();
this.wrapperReadySubject.next(this._controlWrapper);
}
addEventListeners() {
google.visualization.events.removeAllListeners(this._controlWrapper);
google.visualization.events.addListener(this._controlWrapper, 'ready', (event) => this.ready.emit(event));
google.visualization.events.addListener(this._controlWrapper, 'error', (event) => this.error.emit(event));
google.visualization.events.addListener(this._controlWrapper, 'statechange', (event) => this.stateChange.emit(event));
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ControlWrapperComponent, deps: [{ token: i1.ScriptLoaderService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ControlWrapperComponent, selector: "control-wrapper", inputs: { for: "for", type: "type", options: "options", state: "state" }, outputs: { error: "error", ready: "ready", stateChange: "stateChange" }, host: { properties: { "id": "this.id" }, classAttribute: "control-wrapper" }, exportAs: ["controlWrapper"], usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ControlWrapperComponent, decorators: [{
type: Component,
args: [{
selector: 'control-wrapper',
template: '',
host: { class: 'control-wrapper' },
exportAs: 'controlWrapper',
changeDetection: ChangeDetectionStrategy.OnPush
}]
}], ctorParameters: function () { return [{ type: i1.ScriptLoaderService }]; }, propDecorators: { for: [{
type: Input
}], type: [{
type: Input
}], options: [{
type: Input
}], state: [{
type: Input
}], error: [{
type: Output
}], ready: [{
type: Output
}], stateChange: [{
type: Output
}], id: [{
type: HostBinding,
args: ['id']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control-wrapper.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-google-charts/src/lib/components/control-wrapper/control-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { ReplaySubject } from 'rxjs';\n\nimport { generateRandomId } from '../../helpers/id.helper';\nimport { ScriptLoaderService } from '../../services/script-loader.service';\nimport { FilterType } from '../../types/control-type';\nimport { ChartErrorEvent, ChartReadyEvent } from '../../types/events';\nimport { ChartBase } from '../chart-base/chart-base.component';\n\n@Component({\n  selector: 'control-wrapper',\n  template: '',\n  host: { class: 'control-wrapper' },\n  exportAs: 'controlWrapper',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ControlWrapperComponent implements OnInit, OnChanges {\n  /**\n   * Charts controlled by this control wrapper. Can be a single chart or an array of charts.\n   */\n  @Input()\n  public for!: ChartBase | ChartBase[];\n\n  /**\n   * The class name of the control.\n   * The `google.visualization` package name can be omitted for Google controls.\n   *\n   * @example\n   *\n   * ```html\n   * <control-wrapper type=\"CategoryFilter\"></control-wrapper>\n   * ```\n   */\n  @Input()\n  public type!: FilterType;\n\n  /**\n   * An object describing the options for the control.\n   * You can use either JavaScript literal notation, or provide a handle to the object.\n   *\n   * @example\n   *\n   * ```html\n   * <control-wrapper [options]=\"{'filterColumnLabel': 'Age', 'minValue': 10, 'maxValue': 80}\"></control-wrapper>\n   * ```\n   */\n  @Input()\n  public options?: object;\n\n  /**\n   * An object describing the state of the control.\n   * The state collects all the variables that the user operating the control can affect.\n   *\n   * For example, a range slider state can be described in term of the positions that the low and high thumb\n   * of the slider occupy.\n   * You can use either Javascript literal notation, or provide a handle to the object.\n   *\n   * @example\n   *\n   *  ```html\n   * <control-wrapper [state]=\"{'lowValue': 20, 'highValue': 50}\"></control-wrapper>\n   * ```\n   */\n  @Input()\n  public state?: object;\n\n  /**\n   * Emits when an error occurs when attempting to render the control.\n   */\n  @Output()\n  public error = new EventEmitter<ChartErrorEvent>();\n\n  /**\n   * The control is ready to accept user interaction and for external method calls.\n   *\n   * Alternatively, you can listen for a ready event on the dashboard holding the control\n   * and call control methods only after the event was fired.\n   */\n  @Output()\n  public ready = new EventEmitter<ChartReadyEvent>();\n\n  /**\n   * Emits when the user interacts with the control, affecting its state.\n   * For example, a `stateChange` event will be emitted whenever you move the thumbs of a range slider control.\n   *\n   * To retrieve an updated control state after the event fired, call `ControlWrapper.getState()`.\n   */\n  @Output()\n  public stateChange = new EventEmitter<unknown>();\n\n  /**\n   * A generated id assigned to this components DOM element.\n   */\n  @HostBinding('id')\n  public readonly id = generateRandomId();\n\n  private _controlWrapper?: google.visualization.ControlWrapper;\n  private wrapperReadySubject = new ReplaySubject<google.visualization.ControlWrapper>(1);\n\n  constructor(private loaderService: ScriptLoaderService) {}\n\n  /**\n   * Emits after the `ControlWrapper` was created.\n   */\n  public get wrapperReady$() {\n    return this.wrapperReadySubject.asObservable();\n  }\n\n  public get controlWrapper(): google.visualization.ControlWrapper {\n    if (!this._controlWrapper) {\n      throw new Error(`Cannot access the control wrapper before it being initialized.`);\n    }\n\n    return this._controlWrapper;\n  }\n\n  public ngOnInit() {\n    this.loaderService.loadChartPackages('controls').subscribe(() => {\n      this.createControlWrapper();\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (!this._controlWrapper) {\n      return;\n    }\n\n    if (changes.type) {\n      this._controlWrapper.setControlType(this.type);\n    }\n\n    if (changes.options) {\n      this._controlWrapper.setOptions(this.options || {});\n    }\n\n    if (changes.state) {\n      this._controlWrapper.setState(this.state || {});\n    }\n  }\n\n  private createControlWrapper() {\n    this._controlWrapper = new google.visualization.ControlWrapper({\n      containerId: this.id,\n      controlType: this.type,\n      state: this.state,\n      options: this.options\n    });\n\n    this.addEventListeners();\n    this.wrapperReadySubject.next(this._controlWrapper);\n  }\n\n  private addEventListeners() {\n    google.visualization.events.removeAllListeners(this._controlWrapper);\n\n    google.visualization.events.addListener(this._controlWrapper, 'ready', (event: ChartReadyEvent) =>\n      this.ready.emit(event)\n    );\n    google.visualization.events.addListener(this._controlWrapper, 'error', (event: ChartErrorEvent) =>\n      this.error.emit(event)\n    );\n    google.visualization.events.addListener(this._controlWrapper, 'statechange', (event: unknown) =>\n      this.stateChange.emit(event)\n    );\n  }\n}\n"]}