igniteui-webcomponents-charts
Version:
Ignite UI Web Components charting components for building rich data visualizations using TypeScript APIs.
222 lines (219 loc) • 8.61 kB
JavaScript
import { IndicatorDisplayType_$type } from "./IndicatorDisplayType";
import { TrendLineType_$type } from "igniteui-webcomponents-core";
import { IgcFinancialSeriesComponent } from "./igc-financial-series-component";
import { getAllPropertyNames, toSpinal, ensureEnum, enumToString, brushToString, stringToBrush, toDoubleCollection, fromDoubleCollection, doubleCollectionToString, toPoint, fromRect } from "igniteui-webcomponents-core";
/**
* Represents the base functionality for a IgxDataChartComponent financial indicator series.
*
* The `FinancialIndicator` class represents the base functionality for a IgxDataChartComponent financial indicator series.
*/
export let IgcFinancialIndicatorComponent = /*@__PURE__*/ (() => {
class IgcFinancialIndicatorComponent extends IgcFinancialSeriesComponent {
/**
* @hidden
*/
get i() {
return this._implementation;
}
constructor() {
super();
}
connectedCallback() {
if (super["connectedCallback"]) {
super["connectedCallback"]();
}
if (this.i.connectedCallback) {
this.i.connectedCallback();
}
if (!this._attached) {
this._attached = true;
this._flushQueuedAttributes();
}
}
disconnectedCallback() {
if (super["disconnectedCallback"]) {
super["disconnectedCallback"]();
}
if (this.i.disconnectedCallback) {
this.i.disconnectedCallback();
}
if (this._attached) {
this._attached = false;
}
}
static get observedAttributes() {
if (IgcFinancialIndicatorComponent._observedAttributesIgcFinancialIndicatorComponent == null) {
let names = getAllPropertyNames(IgcFinancialIndicatorComponent);
for (let i = 0; i < names.length; i++) {
names[i] = toSpinal(names[i]);
}
IgcFinancialIndicatorComponent._observedAttributesIgcFinancialIndicatorComponent = names;
}
return IgcFinancialIndicatorComponent._observedAttributesIgcFinancialIndicatorComponent;
}
/**
* Gets whether the series is financial indicator
*/
get isFinancialIndicator() {
return this.i.e9;
}
/**
* Gets or sets the display for the current FinancialIndicator object.
*
* The `DisplayType` property is used to display the current FinancialIndicator object.
*
* ```ts
* series.displayType= IndicatorDisplayType.Column;
* ```
*/
get displayType() {
return this.i.aa8;
}
set displayType(v) {
this.i.aa8 = ensureEnum(IndicatorDisplayType_$type, v);
this._a("displayType", enumToString(IndicatorDisplayType_$type, this.i.aa8));
}
/**
* Gets default display type for the current Financial Indicator
*/
get defaultDisplayType() {
return this.i.aa7;
}
/**
* Gets or sets the number of values to hide at the beginning of the indicator.
*
* Use the `IgnoreFirst` propert to hide the number of values at the beginning of the indicator.
*
* ```ts
* series.ignoreFirst = 2;
* ```
*/
get ignoreFirst() {
return this.i.abe;
}
set ignoreFirst(v) {
this.i.abe = +v;
this._a("ignoreFirst", this.i.abe);
}
/**
* Gets or sets the trend type for the current indicator series.
*
* Use `TrendLineType` property to get the trend type for the current indicator series.
*
* ```ts
* series.trendLineType= TrendLineType.CubicFit;
* ```
*/
get trendLineType() {
return this.i.trendLineType;
}
set trendLineType(v) {
this.i.trendLineType = ensureEnum(TrendLineType_$type, v);
this._a("trendLineType", enumToString(TrendLineType_$type, this.i.trendLineType));
}
/**
* Gets or sets the brush to use to draw the trend line.
*
* Use the `TrendLineBrush` propert to draw the trend line.
*/
get trendLineBrush() {
return brushToString(this.i.trendLineBrush);
}
set trendLineBrush(v) {
this.i.trendLineBrush = stringToBrush(v);
this._a("trendLineBrush", brushToString(this.i.trendLineBrush));
}
/**
* Gets the effective TrendLineBrush for this indicator.
*
* Use the `ActualTrendLineBrush` property to Gets the effective TrendLineBrush for the FinancialIndicator.
*/
get actualTrendLineBrush() {
return brushToString(this.i.abw);
}
set actualTrendLineBrush(v) {
this.i.abw = stringToBrush(v);
this._a("actualTrendLineBrush", brushToString(this.i.abw));
}
/**
* Gets or sets the thickness of the current indicator object's trend line.
*
* Use `TrendLineThickness` property for the thickness of the current indicator object's trend line.
*
* ```ts
* series.trendLineThickness=2 ;
* ```
*/
get trendLineThickness() {
return this.i.trendLineThickness;
}
set trendLineThickness(v) {
this.i.trendLineThickness = +v;
this._a("trendLineThickness", this.i.trendLineThickness);
}
/**
* Gets or sets a collection of double values that indicate the pattern of dashes and gaps that
* is used to draw the trend line for the current indicator object.
*/
get trendLineDashArray() {
return fromDoubleCollection(this.i.abx);
}
set trendLineDashArray(v) {
this.i.abx = toDoubleCollection(v);
this._a("trendLineDashArray", doubleCollectionToString(this.i.abx));
}
/**
* Gets or sets the trend line period for the current series.
* The typical, and initial, value for trend line period is 7.
*
* Use `TrendLinePeriod` property for the trend line period of the current series.
*
* ```ts
* series.trendLinePeriod =30;
* ```
*/
get trendLinePeriod() {
return this.i.trendLinePeriod;
}
set trendLinePeriod(v) {
this.i.trendLinePeriod = +v;
this._a("trendLinePeriod", this.i.trendLinePeriod);
}
/**
* If possible, will return the best available value bounding box within the series that has the best value match for the world position provided.
* @param world * The world coordinate for which to get a value bounding box for
*
* The `GetSeriesValueBoundingBox` method returns the best available value bounding box within the series that has the best value match for the world position provided.
*/
getSeriesValueBoundingBox(world) {
let iv = this.i.ws(toPoint(world));
return fromRect(iv);
}
getSeriesValue(world, useInterpolation, skipUnknowns) {
let iv = this.i.i6(toPoint(world), useInterpolation, skipUnknowns);
return (iv);
}
getPreviousOrExactIndex(world, skipUnknowns) {
let iv = this.i.kb(toPoint(world), skipUnknowns);
return (iv);
}
getNextOrExactIndex(world, skipUnknowns) {
let iv = this.i.j9(toPoint(world), skipUnknowns);
return (iv);
}
/**
* Scrolls the series to display the item for the specified data item.
* The series is scrolled by the minimum amount required to place the specified data item within
* the central 80% of the visible axis.
* @param item * The data item (item) to scroll to.
*
* The `ScrollIntoView` method scrolls the series to display the item for the specified data item.
*/
scrollIntoView(item) {
let iv = this.i.ge(item);
return (iv);
}
}
IgcFinancialIndicatorComponent._observedAttributesIgcFinancialIndicatorComponent = null;
return IgcFinancialIndicatorComponent;
})();