UNPKG

igniteui-react-charts

Version:

Ignite UI React charting components for building rich data visualizations using TypeScript APIs.

446 lines (444 loc) 13.3 kB
import { PieChartSweepDirection_$type } from "./PieChartSweepDirection"; import { CalloutCollisionMode_$type } from "igniteui-react-core"; import { LegendEmptyValuesMode_$type } from "igniteui-react-core"; import { OthersCategoryType_$type } from "igniteui-react-core"; import { AxisRangeBufferMode_$type } from "./AxisRangeBufferMode"; import { RadialLabelMode_$type } from "igniteui-react-core"; import { CollisionAvoidanceType_$type } from "./CollisionAvoidanceType"; import { IgrOthersCategoryContext } from "./igr-others-category-context"; import { IgrRadialBaseChart } from "./igr-radial-base-chart"; import { ensureEnum, brushToString, stringToBrush, ensureBool, arrayFindByName } from "igniteui-react-core"; /** * Represents a base class for PieBase chart control that can plot scatter data */ export class IgrDataPieBaseChart extends IgrRadialBaseChart { /** * @hidden */ get i() { return this._implementation; } constructor(props) { super(props); } /** * Gets or sets the label format for the slices. */ get sliceLabelFormat() { return this.i.ak0; } set sliceLabelFormat(v) { this.i.ak0 = v; } /** * Gets or sets the format specifiers to use with the labels for the slices. */ get sliceLabelFormatSpecifiers() { return this.i.aia; } set sliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.aia = v; } /** * Gets or sets the label format for the LegendSlices. */ get legendSliceLabelFormat() { return this.i.akk; } set legendSliceLabelFormat(v) { this.i.akk = v; } /** * Gets or sets the format specifiers to use with the labels for the LegendSlices. */ get legendSliceLabelFormatSpecifiers() { return this.i.ah8; } set legendSliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.ah8 = v; } /** * Gets or sets the label format for the OthersSlices. */ get othersSliceLabelFormat() { return this.i.akt; } set othersSliceLabelFormat(v) { this.i.akt = v; } /** * Gets or sets the format specifiers to use with the labels for the OthersSlices. */ get othersSliceLabelFormatSpecifiers() { return this.i.ah9; } set othersSliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.ah9 = v; } /** * Gets or sets the label format for the LegendOthersSlices. */ get legendOthersSliceLabelFormat() { return this.i.akg; } set legendOthersSliceLabelFormat(v) { this.i.akg = v; } /** * Gets or sets the format specifiers to use with the labels for the LegendOthersSlices. */ get legendOthersSliceLabelFormatSpecifiers() { return this.i.ah7; } set legendOthersSliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.ah7 = v; } /** * Defines the percentage of the maximum radius extent to leave blank at the center of the chart. Should be * a value between 0.0 and 1.0. */ get innerExtent() { return this.i.ajk; } set innerExtent(v) { this.i.ajk = +v; } /** * Defines the percentage of the maximum radius extent to leave blank at the center of the chart. Should be * a value between 0.0 and 1.0. */ get sweepDirection() { return this.i.aip; } set sweepDirection(v) { this.i.aip = ensureEnum(PieChartSweepDirection_$type, v); } /** * Defines the positioning mode of the slice labels for the pie chart. */ get sliceLabelPositionMode() { return this.i.aie; } set sliceLabelPositionMode(v) { this.i.aie = ensureEnum(CalloutCollisionMode_$type, v); } /** * Gets or sets the light color to use for slice labels. */ get lightSliceLabelColor() { return brushToString(this.i.als); } set lightSliceLabelColor(v) { this.i.als = stringToBrush(v); } /** * Gets or sets the Dark color to use for slice labels. */ get darkSliceLabelColor() { return brushToString(this.i.alr); } set darkSliceLabelColor(v) { this.i.alr = stringToBrush(v); } /** * Gets or sets the overridden value member path to use. */ get valueMemberPath() { return this.i.alg; } set valueMemberPath(v) { this.i.alg = v; } /** * Gets or sets the legend label member path to use. */ get legendLabelMemberPath() { return this.i.ake; } set legendLabelMemberPath(v) { this.i.ake = v; } get legendEmptyValuesMode() { return this.i.aii; } set legendEmptyValuesMode(v) { this.i.aii = ensureEnum(LegendEmptyValuesMode_$type, v); } /** * Gets or sets whether to use numeric or percent-based threshold value. */ get othersCategoryType() { return this.i.ain; } set othersCategoryType(v) { this.i.ain = ensureEnum(OthersCategoryType_$type, v); } /** * Gets or sets the threshold value that determines if slices are grouped into the Others slice. */ get othersCategoryThreshold() { return this.i.ajl; } set othersCategoryThreshold(v) { this.i.ajl = +v; } /** * Gets or sets the label of the Others slice. */ get othersCategoryText() { return this.i.akp; } set othersCategoryText(v) { this.i.akp = v; } /** * Gets or sets the overridden value member path to use. */ get labelMemberPath() { return this.i.akb; } set labelMemberPath(v) { this.i.akb = v; } /** * Gets or sets whether the axis should favor emitting a label at the end of the scale. */ get valueAxisFavorLabellingScaleEnd() { return this.i.ai6; } set valueAxisFavorLabellingScaleEnd(v) { this.i.ai6 = ensureBool(v); } /** * Gets or sets how the numeric axis will adjust its range buffer to less closely fix the data from the series. */ get valueAxisAutoRangeBufferMode() { return this.i.aic; } set valueAxisAutoRangeBufferMode(v) { this.i.aic = ensureEnum(AxisRangeBufferMode_$type, v); } /** * Gets or sets the frequency of displayed labels along the X-axis. * Gets or sets the set value is a factor that determines which labels will be hidden. For example, an interval of 2 will display every other label. */ get angleAxisInterval() { return this.i.aji; } set angleAxisInterval(v) { this.i.aji = +v; } /** * Gets or sets the frequency of displayed minor lines along the X-axis. * Gets or sets the set value is a factor that determines how the minor lines will be displayed. */ get angleAxisMinorInterval() { return this.i.ajj; } set angleAxisMinorInterval(v) { this.i.ajj = +v; } /** * Gets or sets the distance between each label and grid line along the Y-axis. */ get valueAxisInterval() { return this.i.ajq; } set valueAxisInterval(v) { this.i.ajq = +v; } /** * Gets or sets whether the Y-axis should use a logarithmic scale instead of a linear one. * Since log(-1) is imaginary and log(0) is undefined, it is recommended to enable this property only when the Y-axis minimum is greater than zero. */ get valueAxisIsLogarithmic() { return this.i.ai7; } set valueAxisIsLogarithmic(v) { this.i.ai7 = ensureBool(v); } /** * Gets or sets the base value to use in the log function when mapping the position of data items along the Y-axis. * This property is effective only when ValueAxisIsLogarithmic is true. */ get valueAxisLogarithmBase() { return this.i.ajv; } set valueAxisLogarithmBase(v) { this.i.ajv = +v; } /** * Gets or sets the data value corresponding to the minimum value of the Y-axis. */ get valueAxisMinimumValue() { return this.i.ajs; } set valueAxisMinimumValue(v) { this.i.ajs = +v; } /** * Gets or sets the data value corresponding to the maximum value of the Y-axis. */ get valueAxisMaximumValue() { return this.i.ajr; } set valueAxisMaximumValue(v) { this.i.ajr = +v; } /** * Gets or sets the frequency of displayed minor lines along the Y-axis. */ get valueAxisMinorInterval() { return this.i.ajt; } set valueAxisMinorInterval(v) { this.i.ajt = +v; } /** * Gets the current minimum value for the Y-axis. */ get valueAxisActualMinimum() { return this.i.ajp; } /** * Gets the current maximum value for the Y-axis. */ get valueAxisActualMaximum() { return this.i.ajo; } /** * Gets or sets the extent of the chart's radius. Value between 0 and 1. */ get radiusExtent() { return this.i.ajm; } set radiusExtent(v) { this.i.ajm = +v; } /** * Gets or sets the start angle to use for the pie chart measured in degrees from the positive x axis. */ get startAngle() { return this.i.ajn; } set startAngle(v) { this.i.ajn = +v; } /** * Gets or sets the label of the Others slice. */ get sliceLabelContentSeparator() { return this.i.aky; } set sliceLabelContentSeparator(v) { this.i.aky = v; } /** * Gets or sets the label of the Others slice. */ get sliceLabelContentMode() { return this.i.aiv; } set sliceLabelContentMode(v) { this.i.aiv = ensureEnum(RadialLabelMode_$type, v); } /** * Gets or sets the label of the Others slice. */ get legendSliceLabelContentMode() { return this.i.aiu; } set legendSliceLabelContentMode(v) { this.i.aiu = ensureEnum(RadialLabelMode_$type, v); } /** * Gets or sets whether to favor labelling the end of the scale. */ get angleAxisFavorLabellingScaleEnd() { return this.i.ai2; } set angleAxisFavorLabellingScaleEnd(v) { this.i.ai2 = ensureBool(v); } /** * Gets or sets whether the large numbers on the Y-axis labels are abbreviated. */ get valueAxisAbbreviateLargeNumbers() { return this.i.ai5; } set valueAxisAbbreviateLargeNumbers(v) { this.i.ai5 = ensureBool(v); } /** * Gets or sets collision avoidance between markers on series that support this behaviour. */ get markerCollision() { return this.i.aig; } set markerCollision(v) { this.i.aig = ensureEnum(CollisionAvoidanceType_$type, v); } /** * Gets or sets whether the mouse leave event should fire when a manipulation is starting. */ get fireMouseLeaveOnManipulationStart() { return this.i.ai3; } set fireMouseLeaveOnManipulationStart(v) { this.i.ai3 = ensureBool(v); } findByName(name) { var baseResult = super.findByName(name); if (baseResult) { return baseResult; } if (this.sliceLabelFormatSpecifiers != null && arrayFindByName(this.sliceLabelFormatSpecifiers, name)) { return arrayFindByName(this.sliceLabelFormatSpecifiers, name); } if (this.legendSliceLabelFormatSpecifiers != null && arrayFindByName(this.legendSliceLabelFormatSpecifiers, name)) { return arrayFindByName(this.legendSliceLabelFormatSpecifiers, name); } if (this.othersSliceLabelFormatSpecifiers != null && arrayFindByName(this.othersSliceLabelFormatSpecifiers, name)) { return arrayFindByName(this.othersSliceLabelFormatSpecifiers, name); } if (this.legendOthersSliceLabelFormatSpecifiers != null && arrayFindByName(this.legendOthersSliceLabelFormatSpecifiers, name)) { return arrayFindByName(this.legendOthersSliceLabelFormatSpecifiers, name); } return null; } /** * Gets the Others context which provides a current list of items in Others slice. */ getOthersContext() { let iv = this.i.ail(); let ret = null; if (iv && iv.externalObject) { ret = iv.externalObject; } else { if (iv) { let e = IgrOthersCategoryContext._createFromInternal(iv); e._implementation = iv; iv.externalObject = e; ret = e; } } return ret; } }