UNPKG

35 kBJavaScriptView Raw
1"use strict";
2var _a, _b, _c, _d, _e;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.LegendPosition = exports.Color = exports.Shading = exports.CustomWidget = exports.SingleValueWidget = exports.GraphWidget = exports.GraphWidgetView = exports.AlarmWidget = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const cdk = require("@aws-cdk/core");
8const rendering_1 = require("./private/rendering");
9const widget_1 = require("./widget");
10/**
11 * Display the metric associated with an alarm, including the alarm line
12 */
13class 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}
48exports.AlarmWidget = AlarmWidget;
49_a = JSII_RTTI_SYMBOL_1;
50AlarmWidget[_a] = { fqn: "@aws-cdk/aws-cloudwatch.AlarmWidget", version: "1.198.0" };
51/**
52 * Types of view
53 */
54var 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 */
72class 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}
157exports.GraphWidget = GraphWidget;
158_b = JSII_RTTI_SYMBOL_1;
159GraphWidget[_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 */
163class 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}
196exports.SingleValueWidget = SingleValueWidget;
197_c = JSII_RTTI_SYMBOL_1;
198SingleValueWidget[_c] = { fqn: "@aws-cdk/aws-cloudwatch.SingleValueWidget", version: "1.198.0" };
199/**
200 * A CustomWidget shows the result of a AWS lambda function
201 */
202class 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}
236exports.CustomWidget = CustomWidget;
237_d = JSII_RTTI_SYMBOL_1;
238CustomWidget[_d] = { fqn: "@aws-cdk/aws-cloudwatch.CustomWidget", version: "1.198.0" };
239/**
240 * Fill shading options that will be used with an annotation
241 */
242var 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 */
260class Color {
261 constructor() { }
262}
263exports.Color = Color;
264_e = JSII_RTTI_SYMBOL_1;
265Color[_e] = { fqn: "@aws-cdk/aws-cloudwatch.Color", version: "1.198.0" };
266/** blue - hex #1f77b4 */
267Color.BLUE = '#1f77b4';
268/** brown - hex #8c564b */
269Color.BROWN = '#8c564b';
270/** green - hex #2ca02c */
271Color.GREEN = '#2ca02c';
272/** grey - hex #7f7f7f */
273Color.GREY = '#7f7f7f';
274/** orange - hex #ff7f0e */
275Color.ORANGE = '#ff7f0e';
276/** pink - hex #e377c2 */
277Color.PINK = '#e377c2';
278/** purple - hex #9467bd */
279Color.PURPLE = '#9467bd';
280/** red - hex #d62728 */
281Color.RED = '#d62728';
282/**
283 * The position of the legend on a GraphWidget.
284 */
285var 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 = {}));
300function 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