From a55537ddac02d14397902a2c68a5e3cbbff09894 Mon Sep 17 00:00:00 2001 From: Lily Kuang Date: Mon, 1 Nov 2021 15:13:56 -0700 Subject: [PATCH] update ui configuration --- .../src/components/Menu/Menu.tsx | 6 ++-- .../{Emmbedded => UiConfigContext}/index.tsx | 33 ++++++++++--------- superset-frontend/src/constants.ts | 4 +-- .../DashboardBuilder/DashboardBuilder.tsx | 12 +++---- .../components/SliceHeader/index.tsx | 8 ++--- superset-frontend/src/views/App.tsx | 10 ++---- 6 files changed, 35 insertions(+), 38 deletions(-) rename superset-frontend/src/components/{Emmbedded => UiConfigContext}/index.tsx (61%) diff --git a/superset-frontend/src/components/Menu/Menu.tsx b/superset-frontend/src/components/Menu/Menu.tsx index 3337bc84a6ef8..01e0c1c5e3dd6 100644 --- a/superset-frontend/src/components/Menu/Menu.tsx +++ b/superset-frontend/src/components/Menu/Menu.tsx @@ -29,7 +29,7 @@ import Icons from 'src/components/Icons'; import { URL_PARAMS } from 'src/constants'; import RightMenu from './MenuRight'; import { Languages } from './LanguagePicker'; -import { useEmbedded } from '../Emmbedded'; +import { useUiConfig } from '../UiConfigContext'; interface BrandProps { path: string; @@ -178,7 +178,7 @@ export function Menu({ }: MenuProps) { const [showMenu, setMenu] = useState('horizontal'); const screens = useBreakpoint(); - const embedded = useEmbedded(); + const uiConig = useUiConfig(); useEffect(() => { function handleResize() { @@ -193,7 +193,7 @@ export function Menu({ }, []); const standalone = getUrlParam(URL_PARAMS.standalone); - if (standalone || embedded.hideNav) return <>; + if (standalone || uiConig.hideNav) return <>; const renderSubMenu = ({ label, diff --git a/superset-frontend/src/components/Emmbedded/index.tsx b/superset-frontend/src/components/UiConfigContext/index.tsx similarity index 61% rename from superset-frontend/src/components/Emmbedded/index.tsx rename to superset-frontend/src/components/UiConfigContext/index.tsx index 9eca8ccd697f0..b5c2f53f27dc1 100644 --- a/superset-frontend/src/components/Emmbedded/index.tsx +++ b/superset-frontend/src/components/UiConfigContext/index.tsx @@ -17,41 +17,42 @@ * under the License. */ import React, { createContext, useContext, useState } from 'react'; +import { URL_PARAMS } from 'src/constants'; +import { getUrlParam } from 'src/utils/urlUtils'; -interface EmbeddedConfigType { +interface UiConfigType { hideTitle: boolean; hideTab: boolean; hideNav: boolean; - hideChartFilter: boolean; + hideChartControls: boolean; } -interface EmbeddedProviderProps { +interface EmbeddedUiConfigProviderProps { children: JSX.Element; - config: number; } -export const EmbeddedContext = createContext({ +export const UiConfigContext = createContext({ hideTitle: false, hideTab: false, hideNav: false, - hideChartFilter: false, + hideChartControls: false, }); -export const useEmbedded = () => useContext(EmbeddedContext); +export const useUiConfig = () => useContext(UiConfigContext); -export const EmbeddedProvider: React.FC = ({ +export const EmbeddedUiConfigProvider: React.FC = ({ children, - config, }) => { - const formattedConfig = (config >>> 0).toString(2); + const config = getUrlParam(URL_PARAMS.uiConfig); const [embeddedConfig] = useState({ - hideTitle: formattedConfig[0] === '1', - hideTab: formattedConfig[1] === '1', - hideNav: formattedConfig[2] === '1', - hideChartFilter: formattedConfig[3] === '1', + hideTitle: (config & 1) !== 0, + hideTab: (config & 2) !== 0, + hideNav: (config & 4) !== 0, + hideChartControls: (config & 8) !== 0, }); + return ( - + {children} - + ); }; diff --git a/superset-frontend/src/constants.ts b/superset-frontend/src/constants.ts index cf04875ad7a2d..25ca890a1e062 100644 --- a/superset-frontend/src/constants.ts +++ b/superset-frontend/src/constants.ts @@ -27,8 +27,8 @@ export const URL_PARAMS = { name: 'standalone', type: 'number', }, - embedded: { - name: 'embedded', + uiConfig: { + name: 'uiConfig', type: 'number', }, preselectFilters: { diff --git a/superset-frontend/src/dashboard/components/DashboardBuilder/DashboardBuilder.tsx b/superset-frontend/src/dashboard/components/DashboardBuilder/DashboardBuilder.tsx index ce03d0320aa13..db5c0a60475d8 100644 --- a/superset-frontend/src/dashboard/components/DashboardBuilder/DashboardBuilder.tsx +++ b/superset-frontend/src/dashboard/components/DashboardBuilder/DashboardBuilder.tsx @@ -49,7 +49,7 @@ import { import FilterBar from 'src/dashboard/components/nativeFilters/FilterBar'; import Loading from 'src/components/Loading'; import { Global } from '@emotion/react'; -import { useEmbedded } from 'src/components/Emmbedded'; +import { useUiConfig } from 'src/components/UiConfigContext'; import { shouldFocusTabs, getRootLevelTabsComponent } from './utils'; import DashboardContainer from './DashboardContainer'; import { useNativeFilters } from './state'; @@ -200,7 +200,7 @@ const StyledDashboardContent = styled.div<{ const DashboardBuilder: FC = () => { const dispatch = useDispatch(); - const embedded = useEmbedded(); + const uiConfig = useUiConfig(); const dashboardLayout = useSelector( state => state.dashboardLayout.present, @@ -246,8 +246,8 @@ const DashboardBuilder: FC = () => { const standaloneMode = getUrlParam(URL_PARAMS.standalone); const isReport = standaloneMode === DashboardStandaloneMode.REPORT; const hideDashboardHeader = - embedded.hideTitle || - StandaloneMode === DashboardStandaloneMode.HIDE_NAV_AND_TITLE || + uiConfig.hideTitle || + standaloneMode === DashboardStandaloneMode.HIDE_NAV_AND_TITLE || isReport; const barTopOffset = @@ -293,7 +293,7 @@ const DashboardBuilder: FC = () => {
{!hideDashboardHeader && } {dropIndicatorProps &&
} - {!isReport && topLevelTabs && embedded.hideNav && ( + {!isReport && topLevelTabs && uiConfig.hideNav && ( = () => { hideDashboardHeader, isReport, topLevelTabs, - embedded.hideNav, + uiConfig.hideNav, ], ); diff --git a/superset-frontend/src/dashboard/components/SliceHeader/index.tsx b/superset-frontend/src/dashboard/components/SliceHeader/index.tsx index 1cdf539b04722..a92fcc47a6683 100644 --- a/superset-frontend/src/dashboard/components/SliceHeader/index.tsx +++ b/superset-frontend/src/dashboard/components/SliceHeader/index.tsx @@ -18,7 +18,7 @@ */ import React, { FC, useMemo } from 'react'; import { styled, t } from '@superset-ui/core'; -import { useEmbedded } from 'src/components/Emmbedded'; +import { useUiConfig } from 'src/components/UiConfigContext'; import { Tooltip } from 'src/components/Tooltip'; import { useDispatch, useSelector } from 'react-redux'; import EditableTitle from 'src/components/EditableTitle'; @@ -84,7 +84,7 @@ const SliceHeader: FC = ({ formData, }) => { const dispatch = useDispatch(); - const embedded = useEmbedded(); + const uiConfig = useUiConfig(); // TODO: change to indicator field after it will be implemented const crossFilterValue = useSelector( state => state.dataMask[slice?.slice_id]?.filterState?.value, @@ -158,10 +158,10 @@ const SliceHeader: FC = ({ /> )} - {!embedded.hideChartFilter && ( + {!uiConfig.hideChartControls && ( )} - {!embedded.hideChartFilter && ( + {!uiConfig.hideChartControls && ( { lastLocationPathname = location.pathname; }, [location.pathname]); - const config = getUrlParam(URL_PARAMS.embedded); - return ( - + { {children} - +