UNPKG

@covalent/echarts

Version:
406 lines 26.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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; } var TdChartViewDataFormatterDirective = /** @class */ (function () { function TdChartViewDataFormatterDirective() { } TdChartViewDataFormatterDirective.decorators = [ { type: Directive, args: [{ selector: 'ng-template[tdViewDataFormatter]', },] } ]; return TdChartViewDataFormatterDirective; }()); export { TdChartViewDataFormatterDirective }; var TdChartToolboxComponent = /** @class */ (function () { function TdChartToolboxComponent(_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 {?} */ TdChartToolboxComponent.prototype.ngOnChanges = /** * @return {?} */ function () { this._setOptions(); }; /** * @return {?} */ TdChartToolboxComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this._removeOption(); }; /** * @return {?} */ TdChartToolboxComponent.prototype._setOptions = /** * @return {?} */ function () { this._checkFormatterTemplate(); /** @type {?} */ var 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 {?} */ TdChartToolboxComponent.prototype._removeOption = /** * @return {?} */ function () { this._optionsService.clearOption('toolbox'); }; /** * @return {?} */ TdChartToolboxComponent.prototype._checkFormatterTemplate = /** * @return {?} */ function () { if (this.formatterTemplate) { this.feature = tslib_1.__assign({}, this.feature, { dataView: tslib_1.__assign({}, this.feature.dataView, { optionToContent: this._optionToContentFormatter() }) }); } }; /** * @return {?} */ TdChartToolboxComponent.prototype._optionToContentFormatter = /** * @return {?} */ function () { var _this = this; return function () { _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 = function () { return [ { 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',] }] }; return TdChartToolboxComponent; }()); export { TdChartToolboxComponent }; 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":";;;;;AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,SAAS,EACT,WAAW,EACX,uBAAuB,EACvB,UAAU,EACV,iBAAiB,EAEjB,YAAY,EACZ,SAAS,GAEV,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,qBAAqB,EACrB,aAAa,GAMd,MAAM,wBAAwB,CAAC;;;;AAKhC,2CAOC;;;IANC,qCAAc;;IACd,wCAAiB;;IACjB,sCAAe;;IACf,sCAAe;;IACf,qCAAc;;IACd,sCAAe;;;;;AAGjB,2CAKC;;;IAJC,qCAAc;;IACd,oCAAa;;IACb,sCAAe;;IACf,sCAAe;;;;;AAGjB,4CAA0E;;;;AAE1E,yCAIC;;;IAHC,2CAA8B;;IAC9B,wCAAwB;;IACxB,uCAAkC;;;;;AAGpC,mCAGC;;;IAFC,6BAAc;;IACd,6BAAc;;;;;AAGhB,oCAUC;;;IATC,8BAAmB;;IACnB,8BAAc;;IACd,yCAAsB;;IACtB,2CAA6B;;IAC7B,8BAAe;;IACf,+BAAe;;IACf,8BAAc;;IACd,mCAAgC;;IAChC,oCAAoB;;;;;AAGtB,gCAKC;;;IAJC,0BAAe;;IACf,2BAAe;;IACf,0BAAc;;IACd,+BAAgC;;;;;AAGlC,iCAcC;;;IAbC,2BAAe;;IACf,4BAAe;;IACf,2BAAc;;IACd,gCAAgC;;IAChC,+BAAmB;;IACnB,sCAA2B;;IAC3B,sCAA2B;;IAC3B,2BAAgB;;IAChB,oCAAuB;;IACvB,0CAA6B;;IAC7B,gCAAmB;;IACnB,kCAAqB;;IACrB,sCAAyB;;;;;AAG3B,iCAOC;;;IANC,2BAAe;;IACf,4BAAsB;;IACtB,2BAAqB;;IACrB,gCAAgC;;IAChC,iCAAyC;;IACzC,iCAAyC;;;;;AAG3C,kCAkBC;;;IAjBC,4BAAe;;IACf,4BAAgB;;IAChB,6BAA8B;;IAC9B,4BAA6B;;IAC7B,iCAAgC;;IAChC,8BAKE;;IACF,mCAKE;;;;;AAGJ,8BAIC;;;IAHC,wBAAa;;IACb,wBAA6B;;IAC7B,yBAA8B;;;;;AAGhC,uCAOC;;;IANC,wCAA6B;;IAC7B,oCAAqB;;IACrB,qCAAuB;;IACvB,qCAAuB;;IACvB,sCAAyB;;IACzB,kCAAiB;;AAGnB;IAAA;IAGgD,CAAC;;gBAHhD,SAAS,SAAC;oBACT,QAAQ,EAAE,kCAAkC;iBAC7C;;IAC+C,wCAAC;CAAA,AAHjD,IAGiD;SAApC,iCAAiC;AAE9C;IAiCE,iCACU,kBAAqC,EACrC,WAAuB,EACvB,eAAsC;QAFtC,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,gBAAW,GAAX,WAAW,CAAY;QACvB,oBAAe,GAAf,eAAe,CAAuB;QA9BxC,WAAM,GAAQ,EAAE,CAAC;QAER,WAAM,GAAQ,EAAE,CAAC;QAEnB,SAAI,GAAY,IAAI,CAAC;QAKhB,cAAS,GAAY,IAAI,CAAC;QAMjB,uBAAkB,GAAW,GAAG,CAAC;QAC/C,SAAI,GAAoB,MAAM,CAAC;QAChC,QAAG,GAAoB,MAAM,CAAC;QAC5B,UAAK,GAAoB,MAAM,CAAC;QAC/B,WAAM,GAAoB,MAAM,CAAC;QAClC,UAAK,GAAoB,MAAM,CAAC;QAC/B,WAAM,GAAoB,MAAM,CAAC;IAU/C,CAAC;;;;IAEJ,6CAAW;;;IAAX;QACE,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;;;;IAED,6CAAW;;;IAAX;QACE,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;;;;IAEO,6CAAW;;;IAAnB;QAEE,IAAI,CAAC,uBAAuB,EAAE,CAAC;;YAE3B,MAAM,GAAQ,aAAa,CAC7B,IAAI,CAAC,MAAM,EAAE;YACX,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,OAAO;YAClB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,CAAC,EAAE,IAAI,CAAC,CAAC;YACT,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;YAC3C,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,EACD,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAC/B;QACD,0EAA0E;QAC1E,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IACpD,CAAC;;;;IAEO,+CAAa;;;IAArB;QACE,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC;;;;IAEO,yDAAuB;;;IAA/B;QACE,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,OAAO,wBACP,IAAI,CAAC,OAAO,IACf,QAAQ,uBACH,IAAI,CAAC,OAAO,CAAC,QAAQ,IACxB,eAAe,EAAE,IAAI,CAAC,yBAAyB,EAAE,MAEpD,CAAC;SACH;IACH,CAAC;;;;IAEO,2DAAyB;;;IAAjC;QAAA,iBAKC;QAJC,OAAO;YACL,KAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;YACvC,OAAO,CAAC,mBAAa,KAAI,CAAC,WAAW,CAAC,aAAa,EAAA,CAAC,CAAC,SAAS,CAAC;QACjE,CAAC,CAAC;IACJ,CAAC;;gBAnGF,SAAS,SAAC;oBACT,QAAQ,EAAE,kBAAkB;oBAC5B,+GAAuC;oBACvC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;;;;gBAzIC,iBAAiB;gBADjB,UAAU;gBASV,qBAAqB;;;yBAqIpB,KAAK,SAAC,QAAQ;uBAEd,KAAK,SAAC,MAAM;0BACZ,KAAK,SAAC,MAAM;yBACZ,KAAK,SAAC,QAAQ;2BACd,KAAK,SAAC,UAAU;0BAChB,KAAK,SAAC,SAAS;4BACf,KAAK,SAAC,WAAW;wBACjB,KAAK,SAAC,OAAO;0BACb,KAAK,SAAC,SAAS;4BACf,KAAK,SAAC,WAAW;yBACjB,KAAK,SAAC,QAAQ;oBACd,KAAK,SAAC,GAAG;qCACT,KAAK,SAAC,oBAAoB;uBAC1B,KAAK,SAAC,MAAM;sBACZ,KAAK,SAAC,KAAK;wBACX,KAAK,SAAC,OAAO;yBACb,KAAK,SAAC,QAAQ;wBACd,KAAK,SAAC,OAAO;yBACb,KAAK,SAAC,QAAQ;oCAEd,YAAY,SAAC,iCAAiC,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;+BAErE,SAAS,SAAC,gBAAgB;;IAqE7B,8BAAC;CAAA,AApGD,IAoGC;SA/FY,uBAAuB;;;IAClC,yCAAyB;;IAEzB,yCAAkC;;IAElC,uCAAoC;;IACpC,0CAA+B;;IAC/B,yCAAyC;;IACzC,2CAAoC;;IACpC,0CAAkC;;IAClC,4CAA8C;;IAC9C,wCAAgC;;IAChC,0CAA6C;;IAC7C,4CAAmD;;IACnD,yCAAgC;;IAChC,oCAAsB;;IACtB,qDAA8D;;IAC9D,uCAA8C;;IAC9C,sCAA4C;;IAC5C,wCAAgD;;IAChD,yCAAkD;;IAClD,wCAAgD;;IAChD,yCAAkD;;IAElD,oDACoC;;IACpC,+CAA4D;;IAG1D,qDAA6C;;IAC7C,8CAA+B;;IAC/B,kDAA8C","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"]}