Skip to content

Commit

Permalink
chore(QT): QueryEditor Lazy loading [YTFRONT-3814]
Browse files Browse the repository at this point in the history
  • Loading branch information
Konstantin Shishov authored and shishovKA committed Nov 10, 2023
1 parent b304c2b commit e45218a
Show file tree
Hide file tree
Showing 7 changed files with 40 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,14 @@ import SystemTopRowContent from '../../../pages/system/System/SystemTopRowConten
import DashboardTopRowContent from '../../../pages/dashboard/Dashboard/DashboardTopRowContent';
import ComponentsTopRowContent from '../../../pages/components/Components/ComponentsTopRowContent';
import {makeExtraPageTopRowRoutes} from '../../../containers/ClusterPage/ExtraClusterPageRoutes';
import {QueryTrackerTopRow} from '../../../pages/query-tracker/QueryTrackerTopRow';

import {odinPageInfo} from '../../../pages/odin';
import {hasOdinPage} from '../../../config';
import withLazyLoading from '../../../hocs/withLazyLoading';

const QueryTrackerTopRowLazy = React.lazy(
() => import('../../../pages/query-tracker/QueryTrackerTopRow'),
);

export default function TopRowContent() {
const loadState = useSelector(getGlobalLoadState);
Expand All @@ -45,7 +49,10 @@ export default function TopRowContent() {
<Route path={`/:cluster/${Page.DASHBOARD}`} component={DashboardTopRowContent} />
<Route path={`/:cluster/${Page.COMPONENTS}`} component={ComponentsTopRowContent} />
{(!adminPages.includes(Page.QUERIES) || isAdmin) && (
<Route path={`/:cluster/${Page.QUERIES}`} component={QueryTrackerTopRow} />
<Route
path={`/:cluster/${Page.QUERIES}`}
component={withLazyLoading(QueryTrackerTopRowLazy)}
/>
)}
{hasOdinPage() && (
<Route
Expand Down
12 changes: 12 additions & 0 deletions packages/ui/src/ui/hocs/withLazyLoading.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import React from 'react';
import {Loader} from '@gravity-ui/uikit';

export default function withLazyLoading<P>(Component: React.ComponentType<P>) {
return function WithSuspense(props: P & React.JSX.IntrinsicAttributes) {
return (
<React.Suspense fallback={<Loader />}>
<Component {...props} />
</React.Suspense>
);
};
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@ import {Button} from '@gravity-ui/uikit';
import {QueryEngine} from '../../../../query-tracker/module/api';
import {getPath} from '../../../../../store/selectors/navigation';
import {getCluster} from '../../../../../store/selectors/global';
import {QueryWidget, QueryWidgetProps} from '../../../../query-tracker/QueryWidget';
import type {QueryWidgetProps} from '../../../../query-tracker/QueryWidget';
import withLazyLoading from '../../../../../hocs/withLazyLoading';
import {createQueryFromTablePath} from '../../../../query-tracker/module/query/actions';
import Icon from '../../../../../components/Icon/Icon';
import {createNewQueryUrl} from '../../../../query-tracker/utils/navigation';
Expand All @@ -16,8 +17,10 @@ import './CreateQueryFromTable.scss';

const b = cn('create-query-btn');

const QueryWidgetLazy = React.lazy(() => import('../../../../query-tracker/QueryWidget'));

export const QueryWidgetPortal = withSplit(
QueryWidget,
withLazyLoading<QueryWidgetProps>(QueryWidgetLazy),
) as unknown as ReactElement<QueryWidgetProps>;

export function CreateQueryFromTable({className}: {className: string}) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -190,7 +190,11 @@ const ResultView = React.memo(function ResultView({
});

type ResultMode = 'full' | 'minimized' | 'split';
export function QueryEditor({onStartQuery}: {onStartQuery?: (queryId: string) => boolean | void}) {
export default function QueryEditor({
onStartQuery,
}: {
onStartQuery?: (queryId: string) => boolean | void;
}) {
const query = useCurrentQuery();

const [resultViewMode, setResultViewMode] = useState<ResultMode>('minimized');
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import {
} from '../module/query/actions';
import {getQueryGetParams} from '../module/query/selectors';
import {QueriesList} from '../QueriesList';
import {QueryEditor} from '../QueryEditor/QueryEditor';
import {Loader} from '@gravity-ui/uikit';
import './QueryTracker.scss';

type Props = {
Expand All @@ -28,6 +28,8 @@ type Props = {
};
};

const QueryEditorLazy = React.lazy(() => import('../QueryEditor/QueryEditor'));

const initialSizes = [23, 77];
const minSize = 380; // see history list's cells size

Expand Down Expand Up @@ -113,7 +115,9 @@ export const QueryTracker = ({match}: Props) => {
>
<QueriesList />

<QueryEditor onStartQuery={goToCreatedQuery}></QueryEditor>
<React.Suspense fallback={<Loader />}>
<QueryEditorLazy onStartQuery={goToCreatedQuery}></QueryEditorLazy>
</React.Suspense>
</FlexSplitPane>
</QueriesPooling>
</>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ export function QueryHeader() {
);
}

export function QueryTrackerTopRow() {
export default function QueryTrackerTopRow() {
return (
<RowWithName page={Page.QUERIES}>
<QueryHeader />
Expand Down
4 changes: 2 additions & 2 deletions packages/ui/src/ui/pages/query-tracker/QueryWidget/index.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import React from 'react';
import cn from 'bem-cn-lite';
import {QueryEditor} from '../QueryEditor/QueryEditor';
import QueryEditor from '../QueryEditor/QueryEditor';
import {QueryMetaForm} from '../QueryTrackerTopRow/QueryMetaForm/QueryMetaForm';
import Icon from '../../../components/Icon/Icon';
import {useSelector} from 'react-redux';
Expand All @@ -15,7 +15,7 @@ const block = cn('query-widget');

export type QueryWidgetProps = {onClose: () => void};

export function QueryWidget({onClose}: QueryWidgetProps) {
export default function QueryWidget({onClose}: QueryWidgetProps) {
const cluster = useSelector(getCluster);
const path = useSelector(getPath);
return (
Expand Down

0 comments on commit e45218a

Please sign in to comment.