diff --git a/src/plugins/vis_type_tagcloud/public/components/tag_cloud.scss b/src/plugins/vis_type_tagcloud/public/components/tag_cloud.scss index 686e07ac4798d..37867f1ed1c17 100644 --- a/src/plugins/vis_type_tagcloud/public/components/tag_cloud.scss +++ b/src/plugins/vis_type_tagcloud/public/components/tag_cloud.scss @@ -5,8 +5,7 @@ // tgcChart__legend--small // tgcChart__legend-isLoading -.tgcChart__container { - min-height: 0; +.tgcChart__container, .tgcChart__wrapper { flex: 1 1 0; display: flex; } diff --git a/src/plugins/vis_type_tagcloud/public/components/tag_cloud_chart.tsx b/src/plugins/vis_type_tagcloud/public/components/tag_cloud_chart.tsx index 441c5f9e77132..8962f19eb5491 100644 --- a/src/plugins/vis_type_tagcloud/public/components/tag_cloud_chart.tsx +++ b/src/plugins/vis_type_tagcloud/public/components/tag_cloud_chart.tsx @@ -17,8 +17,8 @@ * under the License. */ -import React, { useEffect, useRef } from 'react'; -import * as Rx from 'rxjs'; +import React, { useCallback, useEffect, useRef } from 'react'; +import { EuiResizeObserver } from '@elastic/eui'; import { TagCloudVisDependencies } from '../plugin'; import { TagCloudVisRenderValue } from '../tag_cloud_fn'; @@ -33,30 +33,45 @@ type TagCloudChartProps = TagCloudVisDependencies & renderComplete: () => void; }; -export const TagCloudChart = ({ colors, visData, visParams, fireEvent }: TagCloudChartProps) => { +export const TagCloudChart = ({ + colors, + visData, + visParams, + fireEvent, + renderComplete, +}: TagCloudChartProps) => { const chartDiv = useRef(null); const visController = useRef(null); - const renderSubject = useRef(new Rx.Subject()); useEffect(() => { visController.current = new TagCloudVisualization(chartDiv.current, colors, fireEvent); - renderSubject.current.subscribe((params: any) => { - visController.current.render(params.visData, params.visParams); - }); - return () => { visController.current.destroy(); + visController.current = null; }; }, [colors, fireEvent]); useEffect(() => { - renderSubject.current.next({ - visData, - visParams, - }); - }, [visData, visParams]); + if (visController.current) { + visController.current.render(visData, visParams).then(renderComplete); + } + }, [visData, visParams, renderComplete]); + + const onResize = useCallback(() => { + if (visController.current) { + visController.current.render().then(renderComplete); + } + }, [renderComplete]); - return
; + return ( + + {(resizeRef) => ( +
+
+
+ )} + + ); }; // default export required for React.Lazy diff --git a/src/plugins/vis_type_tagcloud/public/components/tag_cloud_visualization.js b/src/plugins/vis_type_tagcloud/public/components/tag_cloud_visualization.js index 892099ff5675b..5ec22d2c6a4d9 100644 --- a/src/plugins/vis_type_tagcloud/public/components/tag_cloud_visualization.js +++ b/src/plugins/vis_type_tagcloud/public/components/tag_cloud_visualization.js @@ -85,13 +85,16 @@ export class TagCloudVisualization { } async render(data, visParams) { - this._updateParams(visParams); - this._updateData(data); + if (data && visParams) { + this._updateParams(visParams); + this._updateData(data); + } + this._resize(); await this._renderComplete$.pipe(take(1)).toPromise(); - if (data.columns.length !== 2) { + if (data && data.columns.length !== 2 && this._feedbackMessage.current) { this._feedbackMessage.current.setState({ shouldShowTruncate: false, shouldShowIncomplete: false, @@ -99,14 +102,19 @@ export class TagCloudVisualization { return; } - this._label.current.setState({ - label: `${data.columns[0].name} - ${data.columns[1].name}`, - shouldShowLabel: visParams.showLabel, - }); - this._feedbackMessage.current.setState({ - shouldShowTruncate: this._truncated, - shouldShowIncomplete: this._tagCloud.getStatus() === TagCloud.STATUS.INCOMPLETE, - }); + if (data && this._label.current) { + this._label.current.setState({ + label: `${data.columns[0].name} - ${data.columns[1].name}`, + shouldShowLabel: visParams.showLabel, + }); + } + + if (this._feedbackMessage.current) { + this._feedbackMessage.current.setState({ + shouldShowTruncate: this._truncated, + shouldShowIncomplete: this._tagCloud.getStatus() === TagCloud.STATUS.INCOMPLETE, + }); + } } destroy() {