@covalent/echarts
Version:
Teradata Charts built on echarts
385 lines • 25.6 kB
JavaScript
/**
* @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":";;;;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;;AAMnB,MAAM,OAAO,iCAAiC;;;YAH7C,SAAS,SAAC;gBACT,QAAQ,EAAE,kCAAkC;aAC7C;;AAQD,MAAM,OAAO,uBAAuB;;;;;;IA4BlC,YACU,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,WAAW;QACT,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;;;;IAEO,WAAW;QAEjB,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,aAAa;QACnB,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC;;;;IAEO,uBAAuB;QAC7B,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,OAAO,qBACP,IAAI,CAAC,OAAO,IACf,QAAQ,oBACH,IAAI,CAAC,OAAO,CAAC,QAAQ,IACxB,eAAe,EAAE,IAAI,CAAC,yBAAyB,EAAE,MAEpD,CAAC;SACH;IACH,CAAC;;;;IAEO,yBAAyB;QAC/B,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;YACvC,OAAO,CAAC,mBAAa,IAAI,CAAC,WAAW,CAAC,aAAa,EAAA,CAAC,CAAC,SAAS,CAAC;QACjE,CAAC,CAAC;IACJ,CAAC;;;YAnGF,SAAS,SAAC;gBACT,QAAQ,EAAE,kBAAkB;gBAC5B,+GAAuC;gBACvC,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;;;;YAzIC,iBAAiB;YADjB,UAAU;YASV,qBAAqB;;;qBAqIpB,KAAK,SAAC,QAAQ;mBAEd,KAAK,SAAC,MAAM;sBACZ,KAAK,SAAC,MAAM;qBACZ,KAAK,SAAC,QAAQ;uBACd,KAAK,SAAC,UAAU;sBAChB,KAAK,SAAC,SAAS;wBACf,KAAK,SAAC,WAAW;oBACjB,KAAK,SAAC,OAAO;sBACb,KAAK,SAAC,SAAS;wBACf,KAAK,SAAC,WAAW;qBACjB,KAAK,SAAC,QAAQ;gBACd,KAAK,SAAC,GAAG;iCACT,KAAK,SAAC,oBAAoB;mBAC1B,KAAK,SAAC,MAAM;kBACZ,KAAK,SAAC,KAAK;oBACX,KAAK,SAAC,OAAO;qBACb,KAAK,SAAC,QAAQ;oBACd,KAAK,SAAC,OAAO;qBACb,KAAK,SAAC,QAAQ;gCAEd,YAAY,SAAC,iCAAiC,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;2BAErE,SAAS,SAAC,gBAAgB;;;;IAzB3B,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"]}