From a27d36294ce59f7de84b43a78ec10bb189e0b026 Mon Sep 17 00:00:00 2001 From: Kamil Gabryjelski Date: Wed, 13 Apr 2022 11:48:34 +0200 Subject: [PATCH 1/3] fix(dashboard): fix(plugin-chart-echarts): Fix BigNumber causing dashboard to crash when overflowing --- .../dashboard/components/gridComponents/Chart.jsx | 15 ++++++++++++--- .../src/dashboard/stylesheets/dashboard.less | 4 ++++ 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/superset-frontend/src/dashboard/components/gridComponents/Chart.jsx b/superset-frontend/src/dashboard/components/gridComponents/Chart.jsx index 134e026d7a38f..754b125605913 100644 --- a/superset-frontend/src/dashboard/components/gridComponents/Chart.jsx +++ b/superset-frontend/src/dashboard/components/gridComponents/Chart.jsx @@ -113,6 +113,12 @@ const ChartOverlay = styled.div` } `; +const SliceContainer = styled.div` + display: flex; + flex-direction: column; + max-height: 100%; +`; + export default class Chart extends React.Component { constructor(props) { super(props); @@ -210,7 +216,10 @@ export default class Chart extends React.Component { getChartHeight() { const headerHeight = this.getHeaderHeight(); - return this.state.height - headerHeight - this.state.descriptionHeight; + return Math.max( + this.state.height - headerHeight - this.state.descriptionHeight, + 20, + ); } getHeaderHeight() { @@ -370,7 +379,7 @@ export default class Chart extends React.Component { }) : {}; return ( -
- + ); } } diff --git a/superset-frontend/src/dashboard/stylesheets/dashboard.less b/superset-frontend/src/dashboard/stylesheets/dashboard.less index a3409c4d48bd8..f8c8d495238f1 100644 --- a/superset-frontend/src/dashboard/stylesheets/dashboard.less +++ b/superset-frontend/src/dashboard/stylesheets/dashboard.less @@ -63,12 +63,16 @@ body { display: flex; max-width: 100%; align-items: flex-start; + min-height: 0; & > .header-title { overflow: hidden; text-overflow: ellipsis; max-width: 100%; flex-grow: 1; + display: -webkit-box; + -webkit-line-clamp: 2; + -webkit-box-orient: vertical; } & > .header-controls { From 7671a9e7c31dfcb520d2258ca4b1f83b4f1b2183 Mon Sep 17 00:00:00 2001 From: Kamil Gabryjelski Date: Wed, 13 Apr 2022 12:45:40 +0200 Subject: [PATCH 2/3] Add tooltips for truncated titles --- .../src/components/EditableTitle/index.tsx | 9 ++-- .../components/SliceHeader/index.tsx | 49 +++++++++++++------ .../components/gridComponents/Chart.jsx | 2 + .../src/dashboard/stylesheets/dashboard.less | 4 ++ 4 files changed, 45 insertions(+), 19 deletions(-) diff --git a/superset-frontend/src/components/EditableTitle/index.tsx b/superset-frontend/src/components/EditableTitle/index.tsx index 6839b45c7d902..ddd85875568af 100644 --- a/superset-frontend/src/components/EditableTitle/index.tsx +++ b/superset-frontend/src/components/EditableTitle/index.tsx @@ -57,6 +57,8 @@ export default function EditableTitle({ placeholder = '', certifiedBy, certificationDetails, + // rest is related to title tooltip + ...rest }: EditableTitleProps) { const [isEditing, setIsEditing] = useState(editing); const [currentTitle, setCurrentTitle] = useState(title); @@ -214,11 +216,7 @@ export default function EditableTitle({ } if (!canEdit) { // don't actually want an input in this case - titleComponent = ( - - {value} - - ); + titleComponent = {value}; } return ( {certifiedBy && ( <> diff --git a/superset-frontend/src/dashboard/components/SliceHeader/index.tsx b/superset-frontend/src/dashboard/components/SliceHeader/index.tsx index 88e9a4c69f300..44ddf7b5adef8 100644 --- a/superset-frontend/src/dashboard/components/SliceHeader/index.tsx +++ b/superset-frontend/src/dashboard/components/SliceHeader/index.tsx @@ -16,7 +16,7 @@ * specific language governing permissions and limitations * under the License. */ -import React, { FC, useMemo } from 'react'; +import React, { FC, useEffect, useMemo, useRef, useState } from 'react'; import { styled, t } from '@superset-ui/core'; import { useUiConfig } from 'src/components/UiConfigContext'; import { Tooltip } from 'src/components/Tooltip'; @@ -41,6 +41,8 @@ type SliceHeaderProps = SliceHeaderControlsProps & { filters: object; handleToggleFullSize: () => void; formData: object; + width: number; + height: number; }; const annotationsLoading = t('Annotation layers are still loading.'); @@ -82,9 +84,13 @@ const SliceHeader: FC = ({ isFullSize, chartStatus, formData, + width, + height, }) => { const dispatch = useDispatch(); const uiConfig = useUiConfig(); + const [headerTooltip, setHeaderTooltip] = useState(null); + const headerRef = useRef(null); // TODO: change to indicator field after it will be implemented const crossFilterValue = useSelector( state => state.dataMask[slice?.slice_id]?.filterState?.value, @@ -98,21 +104,36 @@ const SliceHeader: FC = ({ [crossFilterValue], ); + useEffect(() => { + const headerElement = headerRef.current; + if ( + headerElement && + (headerElement.scrollWidth > headerElement.offsetWidth || + headerElement.scrollHeight > headerElement.offsetHeight) + ) { + setHeaderTooltip(sliceName ?? null); + } else { + setHeaderTooltip(null); + } + }, [sliceName, width, height]); + return (
-
- +
+ + + {!!Object.values(annotationQuery).length && ( {/* diff --git a/superset-frontend/src/dashboard/stylesheets/dashboard.less b/superset-frontend/src/dashboard/stylesheets/dashboard.less index f8c8d495238f1..b9b2b0aab92f8 100644 --- a/superset-frontend/src/dashboard/stylesheets/dashboard.less +++ b/superset-frontend/src/dashboard/stylesheets/dashboard.less @@ -73,6 +73,10 @@ body { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; + + & > span.ant-tooltip-open { + display: inline; + } } & > .header-controls { From be3f4029115a2d4e077fd8cda43b966dc8f8b9ac Mon Sep 17 00:00:00 2001 From: Kamil Gabryjelski Date: Wed, 13 Apr 2022 13:06:36 +0200 Subject: [PATCH 3/3] Fix type --- .../src/dashboard/components/SliceHeader/SliceHeader.test.tsx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/superset-frontend/src/dashboard/components/SliceHeader/SliceHeader.test.tsx b/superset-frontend/src/dashboard/components/SliceHeader/SliceHeader.test.tsx index b1a2efc7b87ad..fd5892f427635 100644 --- a/superset-frontend/src/dashboard/components/SliceHeader/SliceHeader.test.tsx +++ b/superset-frontend/src/dashboard/components/SliceHeader/SliceHeader.test.tsx @@ -157,6 +157,8 @@ const createProps = () => ({ exportCSV: jest.fn(), onExploreChart: jest.fn(), formData: { slice_id: 1, datasource: '58__table' }, + width: 100, + height: 100, }); test('Should render', () => {