UNPKG

@covalent/echarts

Version:
385 lines 25.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc */ import { Component, Input, Directive, TemplateRef, ChangeDetectionStrategy, ElementRef, ChangeDetectorRef, ContentChild, ViewChild, } from '@angular/core'; import { TdChartOptionsService, assignDefined, } from '@covalent/echarts/base'; /** * @record */ export function ITdAcceptedBrushTypes() { } if (false) { /** @type {?|undefined} */ ITdAcceptedBrushTypes.prototype.rect; /** @type {?|undefined} */ ITdAcceptedBrushTypes.prototype.polygon; /** @type {?|undefined} */ ITdAcceptedBrushTypes.prototype.lineX; /** @type {?|undefined} */ ITdAcceptedBrushTypes.prototype.lineY; /** @type {?|undefined} */ ITdAcceptedBrushTypes.prototype.keep; /** @type {?|undefined} */ ITdAcceptedBrushTypes.prototype.clear; } /** * @record */ export function ITdAcceptedMagicTypes() { } if (false) { /** @type {?|undefined} */ ITdAcceptedMagicTypes.prototype.line; /** @type {?|undefined} */ ITdAcceptedMagicTypes.prototype.bar; /** @type {?|undefined} */ ITdAcceptedMagicTypes.prototype.stack; /** @type {?|undefined} */ ITdAcceptedMagicTypes.prototype.tiled; } /** * @record */ export function ITdToolboxIconEmphasis() { } /** * @record */ export function ITdFeatureIconStyle() { } if (false) { /** @type {?|undefined} */ ITdFeatureIconStyle.prototype.textPosition; /** @type {?|undefined} */ ITdFeatureIconStyle.prototype.textAlign; /** @type {?|undefined} */ ITdFeatureIconStyle.prototype.emphasis; } /** * @record */ export function ITdZoomTitles() { } if (false) { /** @type {?|undefined} */ ITdZoomTitles.prototype.zoom; /** @type {?|undefined} */ ITdZoomTitles.prototype.back; } /** * @record */ export function ITdSaveAsImage() { } if (false) { /** @type {?|undefined} */ ITdSaveAsImage.prototype.type; /** @type {?|undefined} */ ITdSaveAsImage.prototype.name; /** @type {?|undefined} */ ITdSaveAsImage.prototype.backgroundColor; /** @type {?|undefined} */ ITdSaveAsImage.prototype.excludeComponents; /** @type {?|undefined} */ ITdSaveAsImage.prototype.show; /** @type {?|undefined} */ ITdSaveAsImage.prototype.title; /** @type {?|undefined} */ ITdSaveAsImage.prototype.icon; /** @type {?|undefined} */ ITdSaveAsImage.prototype.iconStyle; /** @type {?|undefined} */ ITdSaveAsImage.prototype.pixelRatio; } /** * @record */ export function ITdRestore() { } if (false) { /** @type {?|undefined} */ ITdRestore.prototype.show; /** @type {?|undefined} */ ITdRestore.prototype.title; /** @type {?|undefined} */ ITdRestore.prototype.icon; /** @type {?|undefined} */ ITdRestore.prototype.iconStyle; } /** * @record */ export function ITdDataView() { } if (false) { /** @type {?|undefined} */ ITdDataView.prototype.show; /** @type {?|undefined} */ ITdDataView.prototype.title; /** @type {?|undefined} */ ITdDataView.prototype.icon; /** @type {?|undefined} */ ITdDataView.prototype.iconStyle; /** @type {?|undefined} */ ITdDataView.prototype.readOnly; /** @type {?|undefined} */ ITdDataView.prototype.optionToContent; /** @type {?|undefined} */ ITdDataView.prototype.contentToOption; /** @type {?|undefined} */ ITdDataView.prototype.lang; /** @type {?|undefined} */ ITdDataView.prototype.textareaColor; /** @type {?|undefined} */ ITdDataView.prototype.textareaBorderColor; /** @type {?|undefined} */ ITdDataView.prototype.textColor; /** @type {?|undefined} */ ITdDataView.prototype.buttonColor; /** @type {?|undefined} */ ITdDataView.prototype.buttonTextColor; } /** * @record */ export function ITdDataZoom() { } if (false) { /** @type {?|undefined} */ ITdDataZoom.prototype.show; /** @type {?|undefined} */ ITdDataZoom.prototype.title; /** @type {?|undefined} */ ITdDataZoom.prototype.icon; /** @type {?|undefined} */ ITdDataZoom.prototype.iconStyle; /** @type {?|undefined} */ ITdDataZoom.prototype.xAxisIndex; /** @type {?|undefined} */ ITdDataZoom.prototype.yAxisIndex; } /** * @record */ export function ITdMagicType() { } if (false) { /** @type {?|undefined} */ ITdMagicType.prototype.show; /** @type {?|undefined} */ ITdMagicType.prototype.type; /** @type {?|undefined} */ ITdMagicType.prototype.title; /** @type {?|undefined} */ ITdMagicType.prototype.icon; /** @type {?|undefined} */ ITdMagicType.prototype.iconStyle; /** @type {?|undefined} */ ITdMagicType.prototype.option; /** @type {?|undefined} */ ITdMagicType.prototype.seriesIndex; } /** * @record */ export function ITdBrush() { } if (false) { /** @type {?|undefined} */ ITdBrush.prototype.type; /** @type {?|undefined} */ ITdBrush.prototype.icon; /** @type {?|undefined} */ ITdBrush.prototype.title; } /** * @record */ export function ITdToolboxFeature() { } if (false) { /** @type {?|undefined} */ ITdToolboxFeature.prototype.saveAsImage; /** @type {?|undefined} */ ITdToolboxFeature.prototype.restore; /** @type {?|undefined} */ ITdToolboxFeature.prototype.dataView; /** @type {?|undefined} */ ITdToolboxFeature.prototype.dataZoom; /** @type {?|undefined} */ ITdToolboxFeature.prototype.magicType; /** @type {?|undefined} */ ITdToolboxFeature.prototype.brush; } export class TdChartViewDataFormatterDirective { } TdChartViewDataFormatterDirective.decorators = [ { type: Directive, args: [{ selector: 'ng-template[tdViewDataFormatter]', },] } ]; export class TdChartToolboxComponent { /** * @param {?} _changeDetectorRef * @param {?} _elementRef * @param {?} _optionsService */ constructor(_changeDetectorRef, _elementRef, _optionsService) { this._changeDetectorRef = _changeDetectorRef; this._elementRef = _elementRef; this._optionsService = _optionsService; this._state = {}; this.config = {}; this.show = true; this.showTitle = true; this.transitionDuration = 0.5; this.left = 'auto'; this.top = 'auto'; this.right = 'auto'; this.bottom = 'auto'; this.width = 'auto'; this.height = 'auto'; } /** * @return {?} */ ngOnChanges() { this._setOptions(); } /** * @return {?} */ ngOnDestroy() { this._removeOption(); } /** * @return {?} */ _setOptions() { this._checkFormatterTemplate(); /** @type {?} */ let config = assignDefined(this._state, { show: this.show, name: this.trigger, orient: this.orient, itemSize: this.itemSize, itemGap: this.itemGap, showTitle: this.showTitle, label: this.label, feature: this.feature, iconStyle: this.iconStyle, zlevel: this.zlevel, z: this.z, transitionDuration: this.transitionDuration, left: this.left, top: this.top, right: this.right, bottom: this.bottom, width: this.width, height: this.height, }, this.config ? this.config : {}); // set toolbox configuration in parent chart and render new configurations this._optionsService.setOption('toolbox', config); } /** * @return {?} */ _removeOption() { this._optionsService.clearOption('toolbox'); } /** * @return {?} */ _checkFormatterTemplate() { if (this.formatterTemplate) { this.feature = Object.assign({}, this.feature, { dataView: Object.assign({}, this.feature.dataView, { optionToContent: this._optionToContentFormatter() }) }); } } /** * @return {?} */ _optionToContentFormatter() { return () => { this._changeDetectorRef.markForCheck(); return ((/** @type {?} */ (this._elementRef.nativeElement))).innerHTML; }; } } TdChartToolboxComponent.decorators = [ { type: Component, args: [{ selector: 'td-chart-toolbox', template: "<ng-template #toolboxContent\n [ngTemplateOutlet]=\"formatterTemplate\">\n</ng-template>", changeDetection: ChangeDetectionStrategy.OnPush }] } ]; /** @nocollapse */ TdChartToolboxComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: ElementRef }, { type: TdChartOptionsService } ]; TdChartToolboxComponent.propDecorators = { config: [{ type: Input, args: ['config',] }], show: [{ type: Input, args: ['show',] }], trigger: [{ type: Input, args: ['name',] }], orient: [{ type: Input, args: ['orient',] }], itemSize: [{ type: Input, args: ['itemSize',] }], itemGap: [{ type: Input, args: ['itemGap',] }], showTitle: [{ type: Input, args: ['showTitle',] }], label: [{ type: Input, args: ['label',] }], feature: [{ type: Input, args: ['feature',] }], iconStyle: [{ type: Input, args: ['iconStyle',] }], zlevel: [{ type: Input, args: ['zlevel',] }], z: [{ type: Input, args: ['z',] }], transitionDuration: [{ type: Input, args: ['transitionDuration',] }], left: [{ type: Input, args: ['left',] }], top: [{ type: Input, args: ['top',] }], right: [{ type: Input, args: ['right',] }], bottom: [{ type: Input, args: ['bottom',] }], width: [{ type: Input, args: ['width',] }], height: [{ type: Input, args: ['height',] }], formatterTemplate: [{ type: ContentChild, args: [TdChartViewDataFormatterDirective, { read: TemplateRef },] }], fullTemplate: [{ type: ViewChild, args: ['toolboxContent',] }] }; if (false) { /** @type {?} */ TdChartToolboxComponent.prototype._state; /** @type {?} */ TdChartToolboxComponent.prototype.config; /** @type {?} */ TdChartToolboxComponent.prototype.show; /** @type {?} */ TdChartToolboxComponent.prototype.trigger; /** @type {?} */ TdChartToolboxComponent.prototype.orient; /** @type {?} */ TdChartToolboxComponent.prototype.itemSize; /** @type {?} */ TdChartToolboxComponent.prototype.itemGap; /** @type {?} */ TdChartToolboxComponent.prototype.showTitle; /** @type {?} */ TdChartToolboxComponent.prototype.label; /** @type {?} */ TdChartToolboxComponent.prototype.feature; /** @type {?} */ TdChartToolboxComponent.prototype.iconStyle; /** @type {?} */ TdChartToolboxComponent.prototype.zlevel; /** @type {?} */ TdChartToolboxComponent.prototype.z; /** @type {?} */ TdChartToolboxComponent.prototype.transitionDuration; /** @type {?} */ TdChartToolboxComponent.prototype.left; /** @type {?} */ TdChartToolboxComponent.prototype.top; /** @type {?} */ TdChartToolboxComponent.prototype.right; /** @type {?} */ TdChartToolboxComponent.prototype.bottom; /** @type {?} */ TdChartToolboxComponent.prototype.width; /** @type {?} */ TdChartToolboxComponent.prototype.height; /** @type {?} */ TdChartToolboxComponent.prototype.formatterTemplate; /** @type {?} */ TdChartToolboxComponent.prototype.fullTemplate; /** @type {?} */ TdChartToolboxComponent.prototype._changeDetectorRef; /** @type {?} */ TdChartToolboxComponent.prototype._elementRef; /** @type {?} */ TdChartToolboxComponent.prototype._optionsService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbox.component.js","sourceRoot":"ng://@covalent/echarts/toolbox/","sources":["toolbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Directive,\n  TemplateRef,\n  ChangeDetectionStrategy,\n  ElementRef,\n  ChangeDetectorRef,\n  OnChanges,\n  ContentChild,\n  ViewChild,\n  OnDestroy,\n} from '@angular/core';\n\nimport {\n  TdChartOptionsService,\n  assignDefined,\n  ITdLabel,\n  ITdShadow,\n  ITdItemStyle,\n  TdTextPosition,\n  TdTextAlign,\n} from '@covalent/echarts/base';\n\nexport type TdToolboxOrient = 'horizontal' | 'vertical';\nexport type TdImageType = 'png' | 'jpeg';\n\nexport interface ITdAcceptedBrushTypes {\n  rect?: string;\n  polygon?: string;\n  lineX?: string;\n  lineY?: string;\n  keep?: string;\n  clear?: string;\n}\n\nexport interface ITdAcceptedMagicTypes {\n  line?: string;\n  bar?: string;\n  stack?: string;\n  tiled?: string;\n}\n\nexport interface ITdToolboxIconEmphasis extends ITdItemStyle, ITdShadow {}\n\nexport interface ITdFeatureIconStyle extends ITdItemStyle, ITdShadow {\n  textPosition?: TdTextPosition;\n  textAlign?: TdTextAlign;\n  emphasis?: ITdToolboxIconEmphasis;\n}\n\nexport interface ITdZoomTitles {\n  zoom?: string;\n  back?: string;\n}\n\nexport interface ITdSaveAsImage {\n  type?: TdImageType;\n  name?: string;\n  backgroundColor?: any;\n  excludeComponents?: string[]; // defaults to ['toolbox']\n  show?: boolean;\n  title?: string;\n  icon?: string;\n  iconStyle?: ITdFeatureIconStyle;\n  pixelRatio?: number;\n}\n\nexport interface ITdRestore {\n  show?: boolean;\n  title?: string;\n  icon?: string;\n  iconStyle?: ITdFeatureIconStyle;\n}\n\nexport interface ITdDataView {\n  show?: boolean;\n  title?: string;\n  icon?: string;\n  iconStyle?: ITdFeatureIconStyle;\n  readOnly?: boolean;\n  optionToContent?: Function;\n  contentToOption?: Function;\n  lang?: string[]; // Defaults to Chinese, there are 3 names in data view, which are ['data view', 'turn off' and 'refresh'].\n  textareaColor?: string;\n  textareaBorderColor?: string;\n  textColor?: string;\n  buttonColor?: string;\n  buttonTextColor?: string;\n}\n\nexport interface ITdDataZoom {\n  show?: boolean;\n  title?: ITdZoomTitles;\n  icon?: ITdZoomTitles;\n  iconStyle?: ITdFeatureIconStyle;\n  xAxisIndex?: number | number[] | boolean;\n  yAxisIndex?: number | number[] | boolean;\n}\n\nexport interface ITdMagicType {\n  show?: boolean;\n  type?: string[]; // only expects 'line' | 'bar' | 'stack' | 'tiled';\n  title?: ITdAcceptedMagicTypes;\n  icon?: ITdAcceptedMagicTypes;\n  iconStyle?: ITdFeatureIconStyle;\n  option?: {\n    line?: object;\n    bar?: object;\n    stack?: object;\n    tiled?: object;\n  };\n  seriesIndex?: {\n    line?: any[];\n    bar?: any[];\n    stack?: any[];\n    tiled?: any[];\n  };\n}\n\nexport interface ITdBrush {\n  type?: any[];\n  icon?: ITdAcceptedBrushTypes;\n  title?: ITdAcceptedBrushTypes;\n}\n\nexport interface ITdToolboxFeature {\n  saveAsImage?: ITdSaveAsImage;\n  restore?: ITdRestore;\n  dataView?: ITdDataView;\n  dataZoom?: ITdDataZoom;\n  magicType?: ITdMagicType;\n  brush?: ITdBrush;\n}\n\n@Directive({\n  selector: 'ng-template[tdViewDataFormatter]',\n})\nexport class TdChartViewDataFormatterDirective {}\n\n@Component({\n  selector: 'td-chart-toolbox',\n  templateUrl: './toolbox.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TdChartToolboxComponent implements OnChanges, OnDestroy {\n  private _state: any = {};\n\n  @Input('config') config: any = {};\n\n  @Input('show') show: boolean = true;\n  @Input('name') trigger: string;\n  @Input('orient') orient: TdToolboxOrient;\n  @Input('itemSize') itemSize: number;\n  @Input('itemGap') itemGap: number;\n  @Input('showTitle') showTitle: boolean = true;\n  @Input('label') label: ITdLabel;\n  @Input('feature') feature: ITdToolboxFeature;\n  @Input('iconStyle') iconStyle: ITdFeatureIconStyle;\n  @Input('zlevel') zlevel: number;\n  @Input('z') z: number;\n  @Input('transitionDuration') transitionDuration: number = 0.5;\n  @Input('left') left: string | number = 'auto';\n  @Input('top') top: string | number = 'auto';\n  @Input('right') right: string | number = 'auto';\n  @Input('bottom') bottom: string | number = 'auto';\n  @Input('width') width: string | number = 'auto';\n  @Input('height') height: string | number = 'auto';\n\n  @ContentChild(TdChartViewDataFormatterDirective, { read: TemplateRef })\n  formatterTemplate: TemplateRef<any>;\n  @ViewChild('toolboxContent') fullTemplate: TemplateRef<any>;\n\n  constructor(\n    private _changeDetectorRef: ChangeDetectorRef,\n    private _elementRef: ElementRef,\n    private _optionsService: TdChartOptionsService,\n  ) {}\n\n  ngOnChanges(): void {\n    this._setOptions();\n  }\n\n  ngOnDestroy(): void {\n    this._removeOption();\n  }\n\n  private _setOptions(): void {\n\n    this._checkFormatterTemplate();\n\n    let config: any = assignDefined(\n      this._state, {\n        show: this.show,\n        name: this.trigger,\n        orient: this.orient,\n        itemSize: this.itemSize,\n        itemGap: this.itemGap,\n        showTitle: this.showTitle,\n        label: this.label,\n        feature: this.feature,\n        iconStyle: this.iconStyle,\n        zlevel: this.zlevel,\n        z: this.z,\n        transitionDuration: this.transitionDuration,\n        left: this.left,\n        top: this.top,\n        right: this.right,\n        bottom: this.bottom,\n        width: this.width,\n        height: this.height,\n      },\n      this.config ? this.config : {},\n    );\n    // set toolbox configuration in parent chart and render new configurations\n    this._optionsService.setOption('toolbox', config);\n  }\n\n  private _removeOption(): void {\n    this._optionsService.clearOption('toolbox');\n  }\n\n  private _checkFormatterTemplate(): void {\n    if (this.formatterTemplate) {\n      this.feature = {\n        ...this.feature,\n        dataView: {\n          ...this.feature.dataView,\n          optionToContent: this._optionToContentFormatter(),\n        },\n      };\n    }\n  }\n\n  private _optionToContentFormatter(): Function {\n    return () => {\n      this._changeDetectorRef.markForCheck();\n      return (<HTMLElement>this._elementRef.nativeElement).innerHTML;\n    };\n  }\n}\n"]}