UNPKG

igniteui-react-charts

Version:

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

416 lines (415 loc) 12.4 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 { 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.aj4; } set sliceLabelFormat(v) { this.i.aj4 = v; } /** * Gets or sets the format specifiers to use with the labels for the slices. */ get sliceLabelFormatSpecifiers() { return this.i.ahi; } set sliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.ahi = v; } /** * Gets or sets the label format for the LegendSlices. */ get legendSliceLabelFormat() { return this.i.ajo; } set legendSliceLabelFormat(v) { this.i.ajo = v; } /** * Gets or sets the format specifiers to use with the labels for the LegendSlices. */ get legendSliceLabelFormatSpecifiers() { return this.i.ahg; } set legendSliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.ahg = v; } /** * Gets or sets the label format for the OthersSlices. */ get othersSliceLabelFormat() { return this.i.ajx; } set othersSliceLabelFormat(v) { this.i.ajx = v; } /** * Gets or sets the format specifiers to use with the labels for the OthersSlices. */ get othersSliceLabelFormatSpecifiers() { return this.i.ahh; } set othersSliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.ahh = v; } /** * Gets or sets the label format for the LegendOthersSlices. */ get legendOthersSliceLabelFormat() { return this.i.ajk; } set legendOthersSliceLabelFormat(v) { this.i.ajk = v; } /** * Gets or sets the format specifiers to use with the labels for the LegendOthersSlices. */ get legendOthersSliceLabelFormatSpecifiers() { return this.i.ahf; } set legendOthersSliceLabelFormatSpecifiers(v) { if (v && !Array.isArray(v) && typeof (v) == "string") { const re = /\s*(?:,|\s|$)\s*/gm; v = v.split(re); } this.i.ahf = 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.aip; } set innerExtent(v) { this.i.aip = +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.ahw; } set sweepDirection(v) { this.i.ahw = ensureEnum(PieChartSweepDirection_$type, v); } /** * Defines the positioning mode of the slice labels for the pie chart. */ get sliceLabelPositionMode() { return this.i.ahm; } set sliceLabelPositionMode(v) { this.i.ahm = ensureEnum(CalloutCollisionMode_$type, v); } /** * Gets or sets the light color to use for slice labels. */ get lightSliceLabelColor() { return brushToString(this.i.akw); } set lightSliceLabelColor(v) { this.i.akw = stringToBrush(v); } /** * Gets or sets the Dark color to use for slice labels. */ get darkSliceLabelColor() { return brushToString(this.i.akv); } set darkSliceLabelColor(v) { this.i.akv = stringToBrush(v); } /** * Gets or sets the overridden value member path to use. */ get valueMemberPath() { return this.i.akk; } set valueMemberPath(v) { this.i.akk = v; } /** * Gets or sets the legend label member path to use. */ get legendLabelMemberPath() { return this.i.aji; } set legendLabelMemberPath(v) { this.i.aji = v; } get legendEmptyValuesMode() { return this.i.ahq; } set legendEmptyValuesMode(v) { this.i.ahq = ensureEnum(LegendEmptyValuesMode_$type, v); } /** * Gets or sets whether to use numeric or percent-based threshold value. */ get othersCategoryType() { return this.i.ahu; } set othersCategoryType(v) { this.i.ahu = 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.aiq; } set othersCategoryThreshold(v) { this.i.aiq = +v; } /** * Gets or sets the label of the Others slice. */ get othersCategoryText() { return this.i.ajt; } set othersCategoryText(v) { this.i.ajt = v; } /** * Gets or sets the overridden value member path to use. */ get labelMemberPath() { return this.i.ajf; } set labelMemberPath(v) { this.i.ajf = v; } /** * Gets or sets whether the axis should favor emitting a label at the end of the scale. */ get valueAxisFavorLabellingScaleEnd() { return this.i.aib; } set valueAxisFavorLabellingScaleEnd(v) { this.i.aib = 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.ahk; } set valueAxisAutoRangeBufferMode(v) { this.i.ahk = 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.ain; } set angleAxisInterval(v) { this.i.ain = +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.aio; } set angleAxisMinorInterval(v) { this.i.aio = +v; } /** * Gets or sets the distance between each label and grid line along the Y-axis. */ get valueAxisInterval() { return this.i.aiv; } set valueAxisInterval(v) { this.i.aiv = +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.aic; } set valueAxisIsLogarithmic(v) { this.i.aic = 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.ai0; } set valueAxisLogarithmBase(v) { this.i.ai0 = +v; } /** * Gets or sets the data value corresponding to the minimum value of the Y-axis. */ get valueAxisMinimumValue() { return this.i.aix; } set valueAxisMinimumValue(v) { this.i.aix = +v; } /** * Gets or sets the data value corresponding to the maximum value of the Y-axis. */ get valueAxisMaximumValue() { return this.i.aiw; } set valueAxisMaximumValue(v) { this.i.aiw = +v; } /** * Gets or sets the frequency of displayed minor lines along the Y-axis. */ get valueAxisMinorInterval() { return this.i.aiy; } set valueAxisMinorInterval(v) { this.i.aiy = +v; } /** * Gets the current minimum value for the Y-axis. */ get valueAxisActualMinimum() { return this.i.aiu; } /** * Gets the current maximum value for the Y-axis. */ get valueAxisActualMaximum() { return this.i.ait; } /** * Gets or sets the extent of the chart's radius. Value between 0 and 1. */ get radiusExtent() { return this.i.air; } set radiusExtent(v) { this.i.air = +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.ais; } set startAngle(v) { this.i.ais = +v; } /** * Gets or sets the label of the Others slice. */ get sliceLabelContentSeparator() { return this.i.aj2; } set sliceLabelContentSeparator(v) { this.i.aj2 = v; } /** * Gets or sets the label of the Others slice. */ get sliceLabelContentMode() { return this.i.ah2; } set sliceLabelContentMode(v) { this.i.ah2 = ensureEnum(RadialLabelMode_$type, v); } /** * Gets or sets the label of the Others slice. */ get legendSliceLabelContentMode() { return this.i.ah1; } set legendSliceLabelContentMode(v) { this.i.ah1 = ensureEnum(RadialLabelMode_$type, v); } /** * Gets or sets whether to favor labelling the end of the scale. */ get angleAxisFavorLabellingScaleEnd() { return this.i.ah8; } set angleAxisFavorLabellingScaleEnd(v) { this.i.ah8 = ensureBool(v); } /** * Gets or sets whether the large numbers on the Y-axis labels are abbreviated. */ get valueAxisAbbreviateLargeNumbers() { return this.i.aia; } set valueAxisAbbreviateLargeNumbers(v) { this.i.aia = ensureBool(v); } /** * Gets or sets collision avoidance between markers on series that support this behaviour. */ get markerCollision() { return this.i.aho; } set markerCollision(v) { this.i.aho = ensureEnum(CollisionAvoidanceType_$type, 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; } }