Skip to content

Commit

Permalink
[Metric Vis] Shim new platform (#42240) (#42577)
Browse files Browse the repository at this point in the history
* Add New Platform mocks for data plugin

* [Metric Vis] Shim new platform

* move metric_vis_controller to components folder

* fix PR comments

* change interpreter type for colorRange and font

* change interpreter type for colorRange and font
  • Loading branch information
alexwizp authored Aug 5, 2019
1 parent 593d1ca commit 92a3e2b
Show file tree
Hide file tree
Showing 18 changed files with 432 additions and 123 deletions.
44 changes: 44 additions & 0 deletions src/legacy/core_plugins/metric_vis/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
/*
* Licensed to Elasticsearch B.V. under one or more contributor
* license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright
* ownership. Elasticsearch B.V. licenses this file to you under
* the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/

import { resolve } from 'path';
import { Legacy } from 'kibana';

import { LegacyPluginApi, LegacyPluginInitializer } from '../../../../src/legacy/types';

const metricPluginInitializer: LegacyPluginInitializer = ({ Plugin }: LegacyPluginApi) =>
new Plugin({
id: 'metric_vis',
require: ['kibana', 'elasticsearch', 'visualizations', 'interpreter', 'data'],
publicDir: resolve(__dirname, 'public'),
uiExports: {
styleSheetPaths: resolve(__dirname, 'public/index.scss'),
hacks: [resolve(__dirname, 'public/legacy')],
injectDefaultVars: server => ({}),
},
init: (server: Legacy.Server) => ({}),
config(Joi: any) {
return Joi.object({
enabled: Joi.boolean().default(true),
}).default();
},
} as Legacy.PluginSpecOptions);

// eslint-disable-next-line import/no-default-export
export default metricPluginInitializer;
13 changes: 10 additions & 3 deletions src/legacy/core_plugins/metric_vis/public/__tests__/metric_vis.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,17 +23,24 @@ import expect from '@kbn/expect';

import { VisProvider } from 'ui/vis';
import LogstashIndexPatternStubProvider from 'fixtures/stubbed_logstash_index_pattern';
import MetricVisProvider from '../metric_vis';

describe('metric vis', () => {
import { visualizations } from '../../../visualizations/public';
import { createMetricVisTypeDefinition } from '../metric_vis_type';

describe('metric_vis - createMetricVisTypeDefinition', () => {
let setup = null;
let vis;

beforeEach(ngMock.module('kibana'));
beforeEach(ngMock.inject((Private) => {
setup = () => {
const Vis = Private(VisProvider);
const metricVisType = Private(MetricVisProvider);
const metricVisType = createMetricVisTypeDefinition();

visualizations.types.VisTypesRegistryProvider.register(() =>
metricVisType
);

const indexPattern = Private(LogstashIndexPatternStubProvider);

indexPattern.stubSetFieldFormat('ip', 'url', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,9 @@
*/

import expect from '@kbn/expect';
import { MetricVisComponent } from '../metric_vis_controller';
import { MetricVisComponent } from '../components/metric_vis_controller';

describe('metric vis controller', function () {
describe('metric_vis - controller', function () {

const vis = {
params: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,21 +17,21 @@
* under the License.
*/

import _ from 'lodash';
import { last, findIndex, isNaN } from 'lodash';
import React, { Component } from 'react';
import { isColorDark } from '@elastic/eui';
import { getHeatmapColors } from 'ui/vislib/components/color/heatmap_color';
import { getFormat } from 'ui/visualize/loader/pipeline_helpers/utilities';
import { isColorDark } from '@elastic/eui';

import { MetricVisValue } from './components/metric_vis_value';
import { MetricVisValue } from './metric_vis_value';

export class MetricVisComponent extends Component {

_getLabels() {
const config = this.props.visParams.metric;
const isPercentageMode = config.percentageMode;
const colorsRange = config.colorsRange;
const max = _.last(colorsRange).to;
const max = last(colorsRange).to;
const labels = [];
colorsRange.forEach(range => {
const from = isPercentageMode ? Math.round(100 * range.from / max) : range.from;
Expand Down Expand Up @@ -59,7 +59,7 @@ export class MetricVisComponent extends Component {

_getBucket(val) {
const config = this.props.visParams.metric;
let bucket = _.findIndex(config.colorsRange, range => {
let bucket = findIndex(config.colorsRange, range => {
return range.from <= val && range.to > val;
});

Expand All @@ -86,7 +86,7 @@ export class MetricVisComponent extends Component {
}

_getFormattedValue = (fieldFormatter, value, format = 'text') => {
if (_.isNaN(value)) return '-';
if (isNaN(value)) return '-';
return fieldFormatter.convert(value, format);
};

Expand All @@ -95,7 +95,7 @@ export class MetricVisComponent extends Component {
const dimensions = this.props.visParams.dimensions;
const isPercentageMode = config.percentageMode;
const min = config.colorsRange[0].from;
const max = _.last(config.colorsRange).to;
const max = last(config.colorsRange).to;
const colors = this._getColors();
const labels = this._getLabels();
const metrics = [];
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
/*
* Licensed to Elasticsearch B.V. under one or more contributor
* license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright
* ownership. Elasticsearch B.V. licenses this file to you under
* the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/

export { MetricVisParams } from './metric_vis_params';
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,11 @@
* under the License.
*/

import { uiModules } from 'ui/modules';
import _ from 'lodash';
import { i18n } from '@kbn/i18n';
import 'ui/directives/inequality';
import metricVisParamsTemplate from './metric_vis_params.html';
import _ from 'lodash';
const module = uiModules.get('kibana');

module.directive('metricVisParams', function () {
export function MetricVisParams() {
return {
restrict: 'E',
template: metricVisParamsTemplate,
Expand Down Expand Up @@ -84,6 +81,6 @@ module.directive('metricVisParams', function () {

$scope.editorState.requiredDescription = i18n.translate(
'metricVis.params.ranges.warning.requiredDescription', { defaultMessage: 'Required:' });
}
},
};
});
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,20 +17,9 @@
* under the License.
*/

import { resolve } from 'path';

export default function (kibana) {

return new kibana.Plugin({

uiExports: {
visTypes: [
'plugins/metric_vis/metric_vis'
],
interpreter: ['plugins/metric_vis/metric_vis_fn'],
styleSheetPaths: resolve(__dirname, 'public/index.scss'),
}

});
import { PluginInitializerContext } from '../../../../core/public';
import { MetricVisPlugin as Plugin } from './plugin';

export function plugin(initializerContext: PluginInitializerContext) {
return new Plugin(initializerContext);
}
40 changes: 40 additions & 0 deletions src/legacy/core_plugins/metric_vis/public/legacy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
/*
* Licensed to Elasticsearch B.V. under one or more contributor
* license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright
* ownership. Elasticsearch B.V. licenses this file to you under
* the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/

import { PluginInitializerContext } from 'kibana/public';
import { npSetup, npStart } from 'ui/new_platform';

import { visualizations } from '../../visualizations/public';
import { MetricVisPluginSetupDependencies } from './plugin';
import { LegacyDependenciesPlugin } from './shim';
import { plugin } from '.';

const plugins: Readonly<MetricVisPluginSetupDependencies> = {
visualizations,
data: npSetup.plugins.data,

// Temporary solution
// It will be removed when all dependent services are migrated to the new platform.
__LEGACY: new LegacyDependenciesPlugin(),
};

const pluginInstance = plugin({} as PluginInitializerContext);

export const setup = pluginInstance.setup(npSetup.core, plugins);
export const start = pluginInstance.start(npStart.core);
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,15 @@
* under the License.
*/

import { createMetricVisFn } from './metric_vis_fn';

// @ts-ignore
import { functionWrapper } from '../../interpreter/test_helpers';
import { metric } from './metric_vis_fn';

jest.mock('ui/new_platform');

describe('interpreter/functions#metric', () => {
const fn = functionWrapper(metric);
const fn = functionWrapper(createMetricVisFn);
const context = {
type: 'kibana_datatable',
rows: [{ 'col-0-1': 0 }],
Expand All @@ -38,7 +40,7 @@ describe('interpreter/functions#metric', () => {
{
from: 0,
to: 10000,
}
},
],
labels: {
show: true,
Expand All @@ -56,16 +58,17 @@ describe('interpreter/functions#metric', () => {
{
accessor: 0,
format: {
id: 'number'
id: 'number',
},
params: {},
aggType: 'count',
}
]
},
],
};

it('returns an object with the correct structure', () => {
const actual = fn(context, args);

expect(actual).toMatchSnapshot();
});
});
Loading

0 comments on commit 92a3e2b

Please sign in to comment.