1 | ;
|
2 | var _a, _b, _c, _d, _e;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.LegendPosition = exports.Color = exports.Shading = exports.CustomWidget = exports.SingleValueWidget = exports.GraphWidget = exports.GraphWidgetView = exports.AlarmWidget = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const cdk = require("@aws-cdk/core");
|
8 | const rendering_1 = require("./private/rendering");
|
9 | const widget_1 = require("./widget");
|
10 | /**
|
11 | * Display the metric associated with an alarm, including the alarm line
|
12 | */
|
13 | class AlarmWidget extends widget_1.ConcreteWidget {
|
14 | constructor(props) {
|
15 | super(props.width || 6, props.height || 6);
|
16 | try {
|
17 | jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_AlarmWidgetProps(props);
|
18 | }
|
19 | catch (error) {
|
20 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
21 | Error.captureStackTrace(error, AlarmWidget);
|
22 | }
|
23 | throw error;
|
24 | }
|
25 | this.props = props;
|
26 | }
|
27 | toJson() {
|
28 | return [{
|
29 | type: 'metric',
|
30 | width: this.width,
|
31 | height: this.height,
|
32 | x: this.x,
|
33 | y: this.y,
|
34 | properties: {
|
35 | view: 'timeSeries',
|
36 | title: this.props.title,
|
37 | region: this.props.region || cdk.Aws.REGION,
|
38 | annotations: {
|
39 | alarms: [this.props.alarm.alarmArn],
|
40 | },
|
41 | yAxis: {
|
42 | left: this.props.leftYAxis ?? undefined,
|
43 | },
|
44 | },
|
45 | }];
|
46 | }
|
47 | }
|
48 | exports.AlarmWidget = AlarmWidget;
|
49 | _a = JSII_RTTI_SYMBOL_1;
|
50 | AlarmWidget[_a] = { fqn: "@aws-cdk/aws-cloudwatch.AlarmWidget", version: "1.198.0" };
|
51 | /**
|
52 | * Types of view
|
53 | */
|
54 | var GraphWidgetView;
|
55 | (function (GraphWidgetView) {
|
56 | /**
|
57 | * Display as a line graph.
|
58 | */
|
59 | GraphWidgetView["TIME_SERIES"] = "timeSeries";
|
60 | /**
|
61 | * Display as a bar graph.
|
62 | */
|
63 | GraphWidgetView["BAR"] = "bar";
|
64 | /**
|
65 | * Display as a pie graph.
|
66 | */
|
67 | GraphWidgetView["PIE"] = "pie";
|
68 | })(GraphWidgetView = exports.GraphWidgetView || (exports.GraphWidgetView = {}));
|
69 | /**
|
70 | * A dashboard widget that displays metrics
|
71 | */
|
72 | class GraphWidget extends widget_1.ConcreteWidget {
|
73 | constructor(props) {
|
74 | super(props.width || 6, props.height || 6);
|
75 | try {
|
76 | jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_GraphWidgetProps(props);
|
77 | }
|
78 | catch (error) {
|
79 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
80 | Error.captureStackTrace(error, GraphWidget);
|
81 | }
|
82 | throw error;
|
83 | }
|
84 | this.props = props;
|
85 | this.leftMetrics = props.left ?? [];
|
86 | this.rightMetrics = props.right ?? [];
|
87 | this.copyMetricWarnings(...this.leftMetrics, ...this.rightMetrics);
|
88 | }
|
89 | /**
|
90 | * Add another metric to the left Y axis of the GraphWidget
|
91 | *
|
92 | * @param metric the metric to add
|
93 | */
|
94 | addLeftMetric(metric) {
|
95 | try {
|
96 | jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_IMetric(metric);
|
97 | }
|
98 | catch (error) {
|
99 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
100 | Error.captureStackTrace(error, this.addLeftMetric);
|
101 | }
|
102 | throw error;
|
103 | }
|
104 | this.leftMetrics.push(metric);
|
105 | this.copyMetricWarnings(metric);
|
106 | }
|
107 | /**
|
108 | * Add another metric to the right Y axis of the GraphWidget
|
109 | *
|
110 | * @param metric the metric to add
|
111 | */
|
112 | addRightMetric(metric) {
|
113 | try {
|
114 | jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_IMetric(metric);
|
115 | }
|
116 | catch (error) {
|
117 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
118 | Error.captureStackTrace(error, this.addRightMetric);
|
119 | }
|
120 | throw error;
|
121 | }
|
122 | this.rightMetrics.push(metric);
|
123 | this.copyMetricWarnings(metric);
|
124 | }
|
125 | toJson() {
|
126 | const horizontalAnnotations = [
|
127 | ...(this.props.leftAnnotations || []).map(mapAnnotation('left')),
|
128 | ...(this.props.rightAnnotations || []).map(mapAnnotation('right')),
|
129 | ];
|
130 | const metrics = rendering_1.allMetricsGraphJson(this.leftMetrics, this.rightMetrics);
|
131 | return [{
|
132 | type: 'metric',
|
133 | width: this.width,
|
134 | height: this.height,
|
135 | x: this.x,
|
136 | y: this.y,
|
137 | properties: {
|
138 | view: this.props.view ?? GraphWidgetView.TIME_SERIES,
|
139 | title: this.props.title,
|
140 | region: this.props.region || cdk.Aws.REGION,
|
141 | stacked: this.props.stacked,
|
142 | metrics: metrics.length > 0 ? metrics : undefined,
|
143 | annotations: horizontalAnnotations.length > 0 ? { horizontal: horizontalAnnotations } : undefined,
|
144 | yAxis: {
|
145 | left: this.props.leftYAxis ?? undefined,
|
146 | right: this.props.rightYAxis ?? undefined,
|
147 | },
|
148 | legend: this.props.legendPosition !== undefined ? { position: this.props.legendPosition } : undefined,
|
149 | liveData: this.props.liveData,
|
150 | setPeriodToTimeRange: this.props.setPeriodToTimeRange,
|
151 | period: this.props.period?.toSeconds(),
|
152 | stat: this.props.statistic,
|
153 | },
|
154 | }];
|
155 | }
|
156 | }
|
157 | exports.GraphWidget = GraphWidget;
|
158 | _b = JSII_RTTI_SYMBOL_1;
|
159 | GraphWidget[_b] = { fqn: "@aws-cdk/aws-cloudwatch.GraphWidget", version: "1.198.0" };
|
160 | /**
|
161 | * A dashboard widget that displays the most recent value for every metric
|
162 | */
|
163 | class SingleValueWidget extends widget_1.ConcreteWidget {
|
164 | constructor(props) {
|
165 | super(props.width || 6, props.height || 3);
|
166 | try {
|
167 | jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_SingleValueWidgetProps(props);
|
168 | }
|
169 | catch (error) {
|
170 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
171 | Error.captureStackTrace(error, SingleValueWidget);
|
172 | }
|
173 | throw error;
|
174 | }
|
175 | this.props = props;
|
176 | this.copyMetricWarnings(...props.metrics);
|
177 | }
|
178 | toJson() {
|
179 | return [{
|
180 | type: 'metric',
|
181 | width: this.width,
|
182 | height: this.height,
|
183 | x: this.x,
|
184 | y: this.y,
|
185 | properties: {
|
186 | view: 'singleValue',
|
187 | title: this.props.title,
|
188 | region: this.props.region || cdk.Aws.REGION,
|
189 | metrics: rendering_1.allMetricsGraphJson(this.props.metrics, []),
|
190 | setPeriodToTimeRange: this.props.setPeriodToTimeRange,
|
191 | singleValueFullPrecision: this.props.fullPrecision,
|
192 | },
|
193 | }];
|
194 | }
|
195 | }
|
196 | exports.SingleValueWidget = SingleValueWidget;
|
197 | _c = JSII_RTTI_SYMBOL_1;
|
198 | SingleValueWidget[_c] = { fqn: "@aws-cdk/aws-cloudwatch.SingleValueWidget", version: "1.198.0" };
|
199 | /**
|
200 | * A CustomWidget shows the result of a AWS lambda function
|
201 | */
|
202 | class CustomWidget extends widget_1.ConcreteWidget {
|
203 | constructor(props) {
|
204 | super(props.width ?? 6, props.height ?? 6);
|
205 | try {
|
206 | jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_CustomWidgetProps(props);
|
207 | }
|
208 | catch (error) {
|
209 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
210 | Error.captureStackTrace(error, CustomWidget);
|
211 | }
|
212 | throw error;
|
213 | }
|
214 | this.props = props;
|
215 | }
|
216 | toJson() {
|
217 | return [{
|
218 | type: 'custom',
|
219 | width: this.width,
|
220 | height: this.height,
|
221 | x: this.x,
|
222 | y: this.y,
|
223 | properties: {
|
224 | endpoint: this.props.functionArn,
|
225 | params: this.props.params,
|
226 | title: this.props.title,
|
227 | updateOn: {
|
228 | refresh: this.props.updateOnRefresh ?? true,
|
229 | resize: this.props.updateOnResize ?? true,
|
230 | timeRange: this.props.updateOnTimeRangeChange ?? true,
|
231 | },
|
232 | },
|
233 | }];
|
234 | }
|
235 | }
|
236 | exports.CustomWidget = CustomWidget;
|
237 | _d = JSII_RTTI_SYMBOL_1;
|
238 | CustomWidget[_d] = { fqn: "@aws-cdk/aws-cloudwatch.CustomWidget", version: "1.198.0" };
|
239 | /**
|
240 | * Fill shading options that will be used with an annotation
|
241 | */
|
242 | var Shading;
|
243 | (function (Shading) {
|
244 | /**
|
245 | * Don't add shading
|
246 | */
|
247 | Shading["NONE"] = "none";
|
248 | /**
|
249 | * Add shading above the annotation
|
250 | */
|
251 | Shading["ABOVE"] = "above";
|
252 | /**
|
253 | * Add shading below the annotation
|
254 | */
|
255 | Shading["BELOW"] = "below";
|
256 | })(Shading = exports.Shading || (exports.Shading = {}));
|
257 | /**
|
258 | * A set of standard colours that can be used in annotations in a GraphWidget.
|
259 | */
|
260 | class Color {
|
261 | constructor() { }
|
262 | }
|
263 | exports.Color = Color;
|
264 | _e = JSII_RTTI_SYMBOL_1;
|
265 | Color[_e] = { fqn: "@aws-cdk/aws-cloudwatch.Color", version: "1.198.0" };
|
266 | /** blue - hex #1f77b4 */
|
267 | Color.BLUE = '#1f77b4';
|
268 | /** brown - hex #8c564b */
|
269 | Color.BROWN = '#8c564b';
|
270 | /** green - hex #2ca02c */
|
271 | Color.GREEN = '#2ca02c';
|
272 | /** grey - hex #7f7f7f */
|
273 | Color.GREY = '#7f7f7f';
|
274 | /** orange - hex #ff7f0e */
|
275 | Color.ORANGE = '#ff7f0e';
|
276 | /** pink - hex #e377c2 */
|
277 | Color.PINK = '#e377c2';
|
278 | /** purple - hex #9467bd */
|
279 | Color.PURPLE = '#9467bd';
|
280 | /** red - hex #d62728 */
|
281 | Color.RED = '#d62728';
|
282 | /**
|
283 | * The position of the legend on a GraphWidget.
|
284 | */
|
285 | var LegendPosition;
|
286 | (function (LegendPosition) {
|
287 | /**
|
288 | * Legend appears below the graph (default).
|
289 | */
|
290 | LegendPosition["BOTTOM"] = "bottom";
|
291 | /**
|
292 | * Add shading above the annotation
|
293 | */
|
294 | LegendPosition["RIGHT"] = "right";
|
295 | /**
|
296 | * Add shading below the annotation
|
297 | */
|
298 | LegendPosition["HIDDEN"] = "hidden";
|
299 | })(LegendPosition = exports.LegendPosition || (exports.LegendPosition = {}));
|
300 | function mapAnnotation(yAxis) {
|
301 | return (a) => {
|
302 | return { ...a, yAxis };
|
303 | };
|
304 | }
|
305 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.js","sourceRoot":"","sources":["graph.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { IAlarm } from './alarm-base';\nimport { IMetric } from './metric-types';\nimport { allMetricsGraphJson } from './private/rendering';\nimport { ConcreteWidget } from './widget';\n\n/**\n * Basic properties for widgets that display metrics\n */\nexport interface MetricWidgetProps {\n  /**\n   * Title for the graph\n   *\n   * @default - None\n   */\n  readonly title?: string;\n\n  /**\n   * The region the metrics of this graph should be taken from\n   *\n   * @default - Current region\n   */\n  readonly region?: string;\n\n  /**\n   * Width of the widget, in a grid of 24 units wide\n   *\n   * @default 6\n   */\n  readonly width?: number;\n\n  /**\n   * Height of the widget\n   *\n   * @default - 6 for Alarm and Graph widgets.\n   *   3 for single value widgets where most recent value of a metric is displayed.\n   */\n  readonly height?: number;\n}\n\n/**\n * Properties for a Y-Axis\n */\nexport interface YAxisProps {\n  /**\n   * The min value\n   *\n   * @default 0\n   */\n  readonly min?: number;\n\n  /**\n   * The max value\n   *\n   * @default - No maximum value\n   */\n  readonly max?: number;\n\n  /**\n   * The label\n   *\n   * @default - No label\n   */\n  readonly label?: string;\n\n  /**\n   * Whether to show units\n   *\n   * @default true\n   */\n  readonly showUnits?: boolean;\n}\n\n/**\n * Properties for an AlarmWidget\n */\nexport interface AlarmWidgetProps extends MetricWidgetProps {\n  /**\n   * The alarm to show\n   */\n  readonly alarm: IAlarm;\n\n  /**\n   * Left Y axis\n   *\n   * @default - No minimum or maximum values for the left Y-axis\n   */\n  readonly leftYAxis?: YAxisProps;\n}\n\n/**\n * Display the metric associated with an alarm, including the alarm line\n */\nexport class AlarmWidget extends ConcreteWidget {\n  private readonly props: AlarmWidgetProps;\n\n  constructor(props: AlarmWidgetProps) {\n    super(props.width || 6, props.height || 6);\n    this.props = props;\n  }\n\n  public toJson(): any[] {\n    return [{\n      type: 'metric',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        view: 'timeSeries',\n        title: this.props.title,\n        region: this.props.region || cdk.Aws.REGION,\n        annotations: {\n          alarms: [this.props.alarm.alarmArn],\n        },\n        yAxis: {\n          left: this.props.leftYAxis ?? undefined,\n        },\n      },\n    }];\n  }\n}\n\n/**\n * Types of view\n */\nexport enum GraphWidgetView {\n  /**\n   * Display as a line graph.\n   */\n  TIME_SERIES = 'timeSeries',\n  /**\n   * Display as a bar graph.\n   */\n  BAR = 'bar',\n  /**\n   * Display as a pie graph.\n   */\n  PIE = 'pie',\n}\n\n/**\n * Properties for a GraphWidget\n */\nexport interface GraphWidgetProps extends MetricWidgetProps {\n  /**\n   * Metrics to display on left Y axis\n   *\n   * @default - No metrics\n   */\n  readonly left?: IMetric[];\n\n  /**\n   * Metrics to display on right Y axis\n   *\n   * @default - No metrics\n   */\n  readonly right?: IMetric[];\n\n  /**\n   * Annotations for the left Y axis\n   *\n   * @default - No annotations\n   */\n  readonly leftAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Annotations for the right Y axis\n   *\n   * @default - No annotations\n   */\n  readonly rightAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Whether the graph should be shown as stacked lines\n   *\n   * @default false\n   */\n  readonly stacked?: boolean;\n\n  /**\n   * Left Y axis\n   *\n   * @default - None\n   */\n  readonly leftYAxis?: YAxisProps;\n\n  /**\n   * Right Y axis\n   *\n   * @default - None\n   */\n  readonly rightYAxis?: YAxisProps;\n\n  /**\n   * Position of the legend\n   *\n   * @default - bottom\n   */\n  readonly legendPosition?: LegendPosition;\n\n  /**\n   * Whether the graph should show live data\n   *\n   * @default false\n   */\n  readonly liveData?: boolean;\n\n  /**\n   * Display this metric\n   *\n   * @default TimeSeries\n   */\n  readonly view?: GraphWidgetView;\n\n  /**\n   * Whether to show the value from the entire time range. Only applicable for Bar and Pie charts.\n   *\n   * If false, values will be from the most recent period of your chosen time range;\n   * if true, shows the value from the entire time range.\n   *\n   * @default false\n   */\n  readonly setPeriodToTimeRange?: boolean;\n\n  /**\n   * The default period for all metrics in this widget.\n   * The period is the length of time represented by one data point on the graph.\n   * This default can be overridden within each metric definition.\n   *\n   * @default cdk.Duration.seconds(300)\n   */\n  readonly period?: cdk.Duration;\n\n  /**\n   * The default statistic to be displayed for each metric.\n   * This default can be overridden within the definition of each individual metric\n   *\n   * @default - The statistic for each metric is used\n   */\n  readonly statistic?: string;\n}\n\n/**\n * A dashboard widget that displays metrics\n */\nexport class GraphWidget extends ConcreteWidget {\n\n  private readonly props: GraphWidgetProps;\n\n  private readonly leftMetrics: IMetric[];\n  private readonly rightMetrics: IMetric[];\n\n  constructor(props: GraphWidgetProps) {\n    super(props.width || 6, props.height || 6);\n    this.props = props;\n    this.leftMetrics = props.left ?? [];\n    this.rightMetrics = props.right ?? [];\n    this.copyMetricWarnings(...this.leftMetrics, ...this.rightMetrics);\n  }\n\n  /**\n   * Add another metric to the left Y axis of the GraphWidget\n   *\n   * @param metric the metric to add\n   */\n  public addLeftMetric(metric: IMetric) {\n    this.leftMetrics.push(metric);\n    this.copyMetricWarnings(metric);\n  }\n\n  /**\n   * Add another metric to the right Y axis of the GraphWidget\n   *\n   * @param metric the metric to add\n   */\n  public addRightMetric(metric: IMetric) {\n    this.rightMetrics.push(metric);\n    this.copyMetricWarnings(metric);\n  }\n\n  public toJson(): any[] {\n    const horizontalAnnotations = [\n      ...(this.props.leftAnnotations || []).map(mapAnnotation('left')),\n      ...(this.props.rightAnnotations || []).map(mapAnnotation('right')),\n    ];\n\n    const metrics = allMetricsGraphJson(this.leftMetrics, this.rightMetrics);\n    return [{\n      type: 'metric',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        view: this.props.view ?? GraphWidgetView.TIME_SERIES,\n        title: this.props.title,\n        region: this.props.region || cdk.Aws.REGION,\n        stacked: this.props.stacked,\n        metrics: metrics.length > 0 ? metrics : undefined,\n        annotations: horizontalAnnotations.length > 0 ? { horizontal: horizontalAnnotations } : undefined,\n        yAxis: {\n          left: this.props.leftYAxis ?? undefined,\n          right: this.props.rightYAxis ?? undefined,\n        },\n        legend: this.props.legendPosition !== undefined ? { position: this.props.legendPosition } : undefined,\n        liveData: this.props.liveData,\n        setPeriodToTimeRange: this.props.setPeriodToTimeRange,\n        period: this.props.period?.toSeconds(),\n        stat: this.props.statistic,\n      },\n    }];\n  }\n}\n\n/**\n * Properties for a SingleValueWidget\n */\nexport interface SingleValueWidgetProps extends MetricWidgetProps {\n  /**\n   * Metrics to display\n   */\n  readonly metrics: IMetric[];\n\n  /**\n   * Whether to show the value from the entire time range.\n   *\n   * @default false\n   */\n  readonly setPeriodToTimeRange?: boolean;\n\n  /**\n   * Whether to show as many digits as can fit, before rounding.\n   *\n   * @default false\n   */\n  readonly fullPrecision?: boolean;\n}\n\n/**\n * A dashboard widget that displays the most recent value for every metric\n */\nexport class SingleValueWidget extends ConcreteWidget {\n  private readonly props: SingleValueWidgetProps;\n\n  constructor(props: SingleValueWidgetProps) {\n    super(props.width || 6, props.height || 3);\n    this.props = props;\n    this.copyMetricWarnings(...props.metrics);\n  }\n\n  public toJson(): any[] {\n    return [{\n      type: 'metric',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        view: 'singleValue',\n        title: this.props.title,\n        region: this.props.region || cdk.Aws.REGION,\n        metrics: allMetricsGraphJson(this.props.metrics, []),\n        setPeriodToTimeRange: this.props.setPeriodToTimeRange,\n        singleValueFullPrecision: this.props.fullPrecision,\n      },\n    }];\n  }\n}\n\n/**\n * The properties for a CustomWidget\n */\nexport interface CustomWidgetProps {\n  /**\n   * The Arn of the AWS Lambda function that returns HTML or JSON that will be displayed in the widget\n   */\n  readonly functionArn: string;\n\n  /**\n   * Width of the widget, in a grid of 24 units wide\n   *\n   * @default 6\n   */\n  readonly width?: number;\n\n  /**\n   * Height of the widget\n   *\n   * @default - 6 for Alarm and Graph widgets.\n   *   3 for single value widgets where most recent value of a metric is displayed.\n   */\n  readonly height?: number;\n\n  /**\n   * The title of the widget\n   */\n  readonly title: string;\n\n  /**\n   * Update the widget on refresh\n   *\n   * @default true\n   */\n  readonly updateOnRefresh?: boolean;\n\n  /**\n   * Update the widget on resize\n   *\n   * @default true\n   */\n  readonly updateOnResize?: boolean;\n\n  /**\n   * Update the widget on time range change\n   *\n   * @default true\n   */\n  readonly updateOnTimeRangeChange?: boolean;\n\n  /**\n   * Parameters passed to the lambda function\n   *\n   * @default - no parameters are passed to the lambda function\n   */\n  readonly params?: any;\n}\n\n/**\n * A CustomWidget shows the result of a AWS lambda function\n */\nexport class CustomWidget extends ConcreteWidget {\n\n  private readonly props: CustomWidgetProps;\n\n  public constructor(props: CustomWidgetProps) {\n    super(props.width ?? 6, props.height ?? 6);\n    this.props = props;\n  }\n\n  public toJson(): any[] {\n    return [{\n      type: 'custom',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        endpoint: this.props.functionArn,\n        params: this.props.params,\n        title: this.props.title,\n        updateOn: {\n          refresh: this.props.updateOnRefresh ?? true,\n          resize: this.props.updateOnResize ?? true,\n          timeRange: this.props.updateOnTimeRangeChange ?? true,\n        },\n      },\n    }];\n  }\n}\n\n/**\n * Horizontal annotation to be added to a graph\n */\nexport interface HorizontalAnnotation {\n  /**\n   * The value of the annotation\n   */\n  readonly value: number;\n\n  /**\n   * Label for the annotation\n   *\n   * @default - No label\n   */\n  readonly label?: string;\n\n  /**\n   * The hex color code, prefixed with '#' (e.g. '#00ff00'), to be used for the annotation.\n   * The `Color` class has a set of standard colors that can be used here.\n   *\n   * @default - Automatic color\n   */\n  readonly color?: string;\n\n  /**\n   * Add shading above or below the annotation\n   *\n   * @default No shading\n   */\n  readonly fill?: Shading;\n\n  /**\n   * Whether the annotation is visible\n   *\n   * @default true\n   */\n  readonly visible?: boolean;\n}\n\n/**\n * Fill shading options that will be used with an annotation\n */\nexport enum Shading {\n  /**\n   * Don't add shading\n   */\n  NONE = 'none',\n\n  /**\n   * Add shading above the annotation\n   */\n  ABOVE = 'above',\n\n  /**\n   * Add shading below the annotation\n   */\n  BELOW = 'below'\n}\n\n/**\n * A set of standard colours that can be used in annotations in a GraphWidget.\n */\nexport class Color {\n  /** blue - hex #1f77b4 */\n  public static readonly BLUE = '#1f77b4';\n\n  /** brown - hex #8c564b */\n  public static readonly BROWN = '#8c564b';\n\n  /** green - hex #2ca02c */\n  public static readonly GREEN = '#2ca02c';\n\n  /** grey - hex #7f7f7f */\n  public static readonly GREY = '#7f7f7f';\n\n  /** orange - hex #ff7f0e */\n  public static readonly ORANGE = '#ff7f0e';\n\n  /** pink - hex #e377c2 */\n  public static readonly PINK = '#e377c2';\n\n  /** purple - hex #9467bd */\n  public static readonly PURPLE = '#9467bd';\n\n  /** red - hex #d62728 */\n  public static readonly RED = '#d62728';\n\n  private constructor() {}\n}\n\n/**\n * The position of the legend on a GraphWidget.\n */\nexport enum LegendPosition {\n  /**\n   * Legend appears below the graph (default).\n   */\n  BOTTOM = 'bottom',\n\n  /**\n   * Add shading above the annotation\n   */\n  RIGHT = 'right',\n\n  /**\n   * Add shading below the annotation\n   */\n  HIDDEN = 'hidden'\n}\n\nfunction mapAnnotation(yAxis: string): ((x: HorizontalAnnotation) => any) {\n  return (a: HorizontalAnnotation) => {\n    return { ...a, yAxis };\n  };\n}\n"]} |
\ | No newline at end of file |