From adf93740f0fa459d1d18a3bb18d90b17fd074109 Mon Sep 17 00:00:00 2001 From: Uladzislau Lasitsa Date: Wed, 24 Feb 2021 12:51:25 +0300 Subject: [PATCH] [TSVB] Markdown variables not working for empty labels (#91838) (#92387) * Fix markdown for empty values * Fix ci * Fix eslint Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../vis_type_timeseries/common/empty_label.ts | 13 +++++++++++++ .../components/lib/convert_series_to_vars.js | 10 +++++----- .../application/components/lib/replace_vars.js | 7 ++++++- .../components/vis_types/table/vis.js | 9 ++------- .../application/components/vis_with_splits.js | 9 ++------- .../visualizations/views/timeseries/index.js | 16 +++------------- .../application/visualizations/views/top_n.js | 7 ++----- 7 files changed, 33 insertions(+), 38 deletions(-) create mode 100644 src/plugins/vis_type_timeseries/common/empty_label.ts diff --git a/src/plugins/vis_type_timeseries/common/empty_label.ts b/src/plugins/vis_type_timeseries/common/empty_label.ts new file mode 100644 index 0000000000000..d55a58f17dbf3 --- /dev/null +++ b/src/plugins/vis_type_timeseries/common/empty_label.ts @@ -0,0 +1,13 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; + +export const emptyLabel = i18n.translate('visTypeTimeseries.emptyTextValue', { + defaultMessage: '(empty)', +}); diff --git a/src/plugins/vis_type_timeseries/public/application/components/lib/convert_series_to_vars.js b/src/plugins/vis_type_timeseries/public/application/components/lib/convert_series_to_vars.js index 3e5de5ea0f14c..478b41810719c 100644 --- a/src/plugins/vis_type_timeseries/public/application/components/lib/convert_series_to_vars.js +++ b/src/plugins/vis_type_timeseries/public/application/components/lib/convert_series_to_vars.js @@ -9,6 +9,7 @@ import { set } from '@elastic/safer-lodash-set'; import _ from 'lodash'; import { getLastValue } from '../../../../common/get_last_value'; +import { emptyLabel } from '../../../../common/empty_label'; import { createTickFormatter } from './tick_formatter'; import { labelDateFormatter } from './label_date_formatter'; import moment from 'moment'; @@ -19,9 +20,8 @@ export const convertSeriesToVars = (series, model, dateFormat = 'lll', getConfig series .filter((row) => _.startsWith(row.id, seriesModel.id)) .forEach((row) => { - const varName = [_.snakeCase(row.label), _.snakeCase(seriesModel.var_name)] - .filter((v) => v) - .join('.'); + const label = row.label ? _.snakeCase(row.label) : emptyLabel; + const varName = [label, _.snakeCase(seriesModel.var_name)].filter((v) => v).join('.'); const formatter = createTickFormatter( seriesModel.formatter, @@ -43,7 +43,7 @@ export const convertSeriesToVars = (series, model, dateFormat = 'lll', getConfig }, }; set(variables, varName, data); - set(variables, `${_.snakeCase(row.label)}.label`, row.label); + set(variables, `${label}.label`, row.label); /** * Handle the case when a field has "key_as_string" value. @@ -54,7 +54,7 @@ export const convertSeriesToVars = (series, model, dateFormat = 'lll', getConfig */ if (row.labelFormatted) { const val = labelDateFormatter(row.labelFormatted, dateFormat); - set(variables, `${_.snakeCase(row.label)}.formatted`, val); + set(variables, `${label}.formatted`, val); } }); }); diff --git a/src/plugins/vis_type_timeseries/public/application/components/lib/replace_vars.js b/src/plugins/vis_type_timeseries/public/application/components/lib/replace_vars.js index 50cf135bbc8e9..6e5e423d86807 100644 --- a/src/plugins/vis_type_timeseries/public/application/components/lib/replace_vars.js +++ b/src/plugins/vis_type_timeseries/public/application/components/lib/replace_vars.js @@ -8,11 +8,16 @@ import _ from 'lodash'; import handlebars from 'handlebars/dist/handlebars'; +import { emptyLabel } from '../../../../common/empty_label'; import { i18n } from '@kbn/i18n'; export function replaceVars(str, args = {}, vars = {}) { try { - const template = handlebars.compile(str, { strict: true, knownHelpersOnly: true }); + // we need add '[]' for emptyLabel because this value contains special characters. (https://handlebarsjs.com/guide/expressions.html#literal-segments) + const template = handlebars.compile(str.replace(emptyLabel, `[${emptyLabel}]`), { + strict: true, + knownHelpersOnly: true, + }); const string = template(_.assign({}, vars, { args })); diff --git a/src/plugins/vis_type_timeseries/public/application/components/vis_types/table/vis.js b/src/plugins/vis_type_timeseries/public/application/components/vis_types/table/vis.js index 24d0ca1b588f7..faf6fef0aa549 100644 --- a/src/plugins/vis_type_timeseries/public/application/components/vis_types/table/vis.js +++ b/src/plugins/vis_type_timeseries/public/application/components/vis_types/table/vis.js @@ -8,7 +8,6 @@ import _, { isArray, last, get } from 'lodash'; import React, { Component } from 'react'; -import { i18n } from '@kbn/i18n'; import PropTypes from 'prop-types'; import { RedirectAppLinks } from '../../../../../../kibana_react/public'; import { createTickFormatter } from '../../lib/tick_formatter'; @@ -18,6 +17,7 @@ import { replaceVars } from '../../lib/replace_vars'; import { fieldFormats } from '../../../../../../../plugins/data/public'; import { FormattedMessage } from '@kbn/i18n/react'; import { getFieldFormats, getCoreStart } from '../../../../services'; +import { emptyLabel } from '../../../../../common/empty_label'; function getColor(rules, colorKey, value) { let color; @@ -89,12 +89,7 @@ class TableVis extends Component { }); return ( - - {rowDisplay || - i18n.translate('visTypeTimeseries.emptyTextValue', { - defaultMessage: '(empty)', - })} - + {rowDisplay || emptyLabel} {columns} ); diff --git a/src/plugins/vis_type_timeseries/public/application/components/vis_with_splits.js b/src/plugins/vis_type_timeseries/public/application/components/vis_with_splits.js index fbec412c30f48..59f4724c1394c 100644 --- a/src/plugins/vis_type_timeseries/public/application/components/vis_with_splits.js +++ b/src/plugins/vis_type_timeseries/public/application/components/vis_with_splits.js @@ -7,10 +7,10 @@ */ import React from 'react'; -import { i18n } from '@kbn/i18n'; import { getDisplayName } from './lib/get_display_name'; import { labelDateFormatter } from './lib/label_date_formatter'; import { findIndex, first } from 'lodash'; +import { emptyLabel } from '../../../common/empty_label'; export function visWithSplits(WrappedComponent) { function SplitVisComponent(props) { @@ -81,12 +81,7 @@ export function visWithSplits(WrappedComponent) { model={model} visData={newVisData} onBrush={props.onBrush} - additionalLabel={ - additionalLabel || - i18n.translate('visTypeTimeseries.emptyTextValue', { - defaultMessage: '(empty)', - }) - } + additionalLabel={additionalLabel || emptyLabel} backgroundColor={props.backgroundColor} getConfig={props.getConfig} /> diff --git a/src/plugins/vis_type_timeseries/public/application/visualizations/views/timeseries/index.js b/src/plugins/vis_type_timeseries/public/application/visualizations/views/timeseries/index.js index 4ec60661ffed2..d306704463c2e 100644 --- a/src/plugins/vis_type_timeseries/public/application/visualizations/views/timeseries/index.js +++ b/src/plugins/vis_type_timeseries/public/application/visualizations/views/timeseries/index.js @@ -9,7 +9,6 @@ import React, { useEffect, useRef } from 'react'; import PropTypes from 'prop-types'; import classNames from 'classnames'; -import { i18n } from '@kbn/i18n'; import { labelDateFormatter } from '../../../components/lib/label_date_formatter'; import { @@ -31,6 +30,7 @@ import { AreaSeriesDecorator } from './decorators/area_decorator'; import { BarSeriesDecorator } from './decorators/bar_decorator'; import { getStackAccessors } from './utils/stack_format'; import { getBaseTheme, getChartClasses } from './utils/theme'; +import { emptyLabel } from '../../../../../common/empty_label'; const generateAnnotationData = (values, formatter) => values.map(({ key, docs }) => ({ @@ -189,12 +189,7 @@ export const TimeSeries = ({ key={key} seriesId={id} seriesGroupId={groupId} - name={ - seriesName || - i18n.translate('visTypeTimeseries.emptyTextValue', { - defaultMessage: '(empty)', - }) - } + name={seriesName || emptyLabel} data={data} hideInLegend={hideInLegend} bars={bars} @@ -219,12 +214,7 @@ export const TimeSeries = ({ key={key} seriesId={id} seriesGroupId={groupId} - name={ - seriesName || - i18n.translate('visTypeTimeseries.emptyTextValue', { - defaultMessage: '(empty)', - }) - } + name={seriesName || emptyLabel} data={data} hideInLegend={hideInLegend} lines={lines} diff --git a/src/plugins/vis_type_timeseries/public/application/visualizations/views/top_n.js b/src/plugins/vis_type_timeseries/public/application/visualizations/views/top_n.js index 542ee0871fdcb..2559ed543e543 100644 --- a/src/plugins/vis_type_timeseries/public/application/visualizations/views/top_n.js +++ b/src/plugins/vis_type_timeseries/public/application/visualizations/views/top_n.js @@ -8,9 +8,9 @@ import PropTypes from 'prop-types'; import React, { Component } from 'react'; -import { i18n } from '@kbn/i18n'; import { getLastValue } from '../../../../common/get_last_value'; import { labelDateFormatter } from '../../components/lib/label_date_formatter'; +import { emptyLabel } from '../../../../common/empty_label'; import reactcss from 'reactcss'; const RENDER_MODES = { @@ -130,10 +130,7 @@ export class TopN extends Component { return ( - {label || - i18n.translate('visTypeTimeseries.emptyTextValue', { - defaultMessage: '(empty)', - })} + {label || emptyLabel}