Skip to content

Commit

Permalink
[Visualize] Lazy load default editor, fix duplicated styles (elastic#…
Browse files Browse the repository at this point in the history
…66732)

* Lazy load bundle, fix duplicated styles

* Add EuiLoadingChart and EuiErrorBoundary

* Return localStorage service

* Use mono spinner

* Get rid of loading the editor outside of visualize mounting
# Conflicts:
#	src/plugins/visualize/public/kibana_services.ts
#	src/plugins/visualize/public/plugin.ts
  • Loading branch information
sulemanof committed May 20, 2020
1 parent 37d5307 commit 8aeed5a
Show file tree
Hide file tree
Showing 7 changed files with 74 additions and 54 deletions.
80 changes: 51 additions & 29 deletions src/plugins/vis_default_editor/public/default_editor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,16 +17,23 @@
* under the License.
*/

import './index.scss';

import React, { useEffect, useRef, useState, useCallback } from 'react';

import { EditorRenderProps } from 'src/plugins/visualize/public';
import { PanelsContainer, Panel } from '../../kibana_react/public';
import { KibanaContextProvider, PanelsContainer, Panel } from '../../kibana_react/public';
import { Storage } from '../../kibana_utils/public';

import { DefaultEditorSideBar } from './components/sidebar';
import { DefaultEditorControllerState } from './default_editor_controller';
import { getInitialWidth } from './editor_size';

const localStorage = new Storage(window.localStorage);

function DefaultEditor({
core,
data,
vis,
uiState,
timeRange,
Expand All @@ -37,7 +44,7 @@ function DefaultEditor({
eventEmitter,
linked,
savedSearch,
}: DefaultEditorControllerState & Omit<EditorRenderProps, 'data' | 'core'>) {
}: DefaultEditorControllerState & EditorRenderProps) {
const visRef = useRef<HTMLDivElement>(null);
const [isCollapsed, setIsCollapsed] = useState(false);

Expand Down Expand Up @@ -69,34 +76,49 @@ function DefaultEditor({
const editorInitialWidth = getInitialWidth(vis.type.editorConfig.defaultSize);

return (
<PanelsContainer
className="visEditor--default"
resizerClassName={`visEditor__resizer ${isCollapsed ? 'visEditor__resizer-isHidden' : ''}`}
>
<Panel className="visEditor__visualization" initialWidth={100 - editorInitialWidth}>
<div className="visEditor__canvas" ref={visRef} data-shared-items-container />
</Panel>

<Panel
className={`visEditor__collapsibleSidebar ${
isCollapsed ? 'visEditor__collapsibleSidebar-isClosed' : ''
}`}
initialWidth={editorInitialWidth}
<core.i18n.Context>
<KibanaContextProvider
services={{
appName: 'vis_default_editor',
storage: localStorage,
data,
...core,
}}
>
<DefaultEditorSideBar
isCollapsed={isCollapsed}
onClickCollapse={onClickCollapse}
optionTabs={optionTabs}
vis={vis}
uiState={uiState}
isLinkedSearch={linked}
savedSearch={savedSearch}
timeRange={timeRange}
eventEmitter={eventEmitter}
/>
</Panel>
</PanelsContainer>
<PanelsContainer
className="visEditor--default"
resizerClassName={`visEditor__resizer ${
isCollapsed ? 'visEditor__resizer-isHidden' : ''
}`}
>
<Panel className="visEditor__visualization" initialWidth={100 - editorInitialWidth}>
<div className="visEditor__canvas" ref={visRef} data-shared-items-container />
</Panel>

<Panel
className={`visEditor__collapsibleSidebar ${
isCollapsed ? 'visEditor__collapsibleSidebar-isClosed' : ''
}`}
initialWidth={editorInitialWidth}
>
<DefaultEditorSideBar
isCollapsed={isCollapsed}
onClickCollapse={onClickCollapse}
optionTabs={optionTabs}
vis={vis}
uiState={uiState}
isLinkedSearch={linked}
savedSearch={savedSearch}
timeRange={timeRange}
eventEmitter={eventEmitter}
/>
</Panel>
</PanelsContainer>
</KibanaContextProvider>
</core.i18n.Context>
);
}

export { DefaultEditor };
// default export required for React.Lazy
// eslint-disable-next-line import/no-default-export
export { DefaultEditor as default };
36 changes: 20 additions & 16 deletions src/plugins/vis_default_editor/public/default_editor_controller.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,19 +17,17 @@
* under the License.
*/

import React from 'react';
import React, { Suspense, lazy } from 'react';
import { render, unmountComponentAtNode } from 'react-dom';
import { i18n } from '@kbn/i18n';
import { EventEmitter } from 'events';
import { EuiErrorBoundary, EuiLoadingChart } from '@elastic/eui';

import { EditorRenderProps } from 'src/plugins/visualize/public';
import { Vis, VisualizeEmbeddableContract } from 'src/plugins/visualizations/public';
import { Storage } from '../../kibana_utils/public';
import { KibanaContextProvider } from '../../kibana_react/public';
import { DefaultEditor } from './default_editor';
import { DefaultEditorDataTab, OptionTab } from './components/sidebar';

const localStorage = new Storage(window.localStorage);
const DefaultEditor = lazy(() => import('./default_editor'));

export interface DefaultEditorControllerState {
vis: Vis;
Expand Down Expand Up @@ -80,20 +78,26 @@ class DefaultEditorController {
};
}

render({ data, core, ...props }: EditorRenderProps) {
render(props: EditorRenderProps) {
render(
<core.i18n.Context>
<KibanaContextProvider
services={{
appName: 'vis_default_editor',
storage: localStorage,
data,
...core,
}}
<EuiErrorBoundary>
<Suspense
fallback={
<div
style={{
display: 'flex',
flex: '1 1 auto',
justifyContent: 'center',
alignItems: 'center',
}}
>
<EuiLoadingChart size="xl" mono />
</div>
}
>
<DefaultEditor {...this.state} {...props} />
</KibanaContextProvider>
</core.i18n.Context>,
</Suspense>
</EuiErrorBoundary>,
this.el
);
}
Expand Down
2 changes: 0 additions & 2 deletions src/plugins/vis_default_editor/public/index.scss
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
@import 'src/legacy/ui/public/styles/styling_constants';

$vis-editor-sidebar-min-width: 350px;

// Main layout
Expand Down
2 changes: 0 additions & 2 deletions src/plugins/vis_default_editor/public/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,6 @@
* under the License.
*/

import './index.scss';

export { DefaultEditorController } from './default_editor_controller';
export { useValidation } from './components/controls/utils';
export { RangesParamEditor, RangeValues } from './components/controls/ranges';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@
* under the License.
*/

import { DefaultEditorController } from '../../../../vis_default_editor/public';

export function initVisEditorDirective(app, deps) {
app.directive('visualizationEditor', function($timeout) {
return {
Expand All @@ -32,7 +34,7 @@ export function initVisEditorDirective(app, deps) {
eventEmitter: '=',
},
link: function($scope, element) {
const Editor = $scope.vis.type.editor || deps.DefaultVisualizationEditor;
const Editor = $scope.vis.type.editor || DefaultEditorController;
const editor = new Editor(
element[0],
$scope.vis,
Expand Down
2 changes: 0 additions & 2 deletions src/plugins/visualize/public/kibana_services.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@ import { DataPublicPluginStart } from '../../data/public';
import { VisualizationsStart } from '../../visualizations/public';
import { SavedVisualizations } from './application/types';
import { KibanaLegacyStart } from '../../kibana_legacy/public';
import { DefaultEditorController } from '../../vis_default_editor/public';

export interface VisualizeKibanaServices {
pluginInitializerContext: PluginInitializerContext;
Expand All @@ -52,7 +51,6 @@ export interface VisualizeKibanaServices {
visualizations: VisualizationsStart;
I18nContext: I18nStart['Context'];
setActiveUrl: (newUrl: string) => void;
DefaultVisualizationEditor: typeof DefaultEditorController;
createVisEmbeddableFromObject: VisualizationsStart['__LEGACY']['createVisEmbeddableFromObject'];
}

Expand Down
2 changes: 0 additions & 2 deletions src/plugins/visualize/public/plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@ import { VisualizationsStart } from '../../visualizations/public';
import { VisualizeConstants } from './application/visualize_constants';
import { setServices, VisualizeKibanaServices } from './kibana_services';
import { FeatureCatalogueCategory, HomePublicPluginSetup } from '../../home/public';
import { DefaultEditorController } from '../../vis_default_editor/public';

export interface VisualizePluginStartDependencies {
data: DataPublicPluginStart;
Expand Down Expand Up @@ -117,7 +116,6 @@ export class VisualizePlugin
visualizations: pluginsStart.visualizations,
I18nContext: coreStart.i18n.Context,
setActiveUrl,
DefaultVisualizationEditor: DefaultEditorController,
createVisEmbeddableFromObject:
pluginsStart.visualizations.__LEGACY.createVisEmbeddableFromObject,
};
Expand Down

0 comments on commit 8aeed5a

Please sign in to comment.