From b4487e28eca558ce70b19ce4934f8713f38b6910 Mon Sep 17 00:00:00 2001 From: Luna Li Date: Mon, 2 Oct 2023 16:39:31 +0200 Subject: [PATCH] fix container width, delete button segmentation --- media/style.css | 7 ++++++ src/viewer/App.tsx | 8 +++++- src/viewer/hooks/useRowProperty.ts | 6 ++++- src/viewer/log/LogView.tsx | 40 +++++++++++++++++++++++------- 4 files changed, 50 insertions(+), 11 deletions(-) diff --git a/media/style.css b/media/style.css index ce50bfb..06c4f46 100644 --- a/media/style.css +++ b/media/style.css @@ -82,4 +82,11 @@ div.vertical-line { /* Causes the line to float to right of content. You can instead use position:absolute or display:inline-block if this fits better with your design */ +} + +.box { + display: flex; + align-items: center; + justify-content: center; + height: 40px; } \ No newline at end of file diff --git a/src/viewer/App.tsx b/src/viewer/App.tsx index d4b7b04..2091580 100644 --- a/src/viewer/App.tsx +++ b/src/viewer/App.tsx @@ -125,7 +125,8 @@ export default class App extends React.Component { } componentDidUpdate(prevProps: Props, prevState: State) { - if (this.state.logFile !== prevState.logFile) { + if (this.state.logFile !== prevState.logFile || + this.state.collapsibleRows !== prevState.collapsibleRows) { this.render(); } } @@ -420,6 +421,10 @@ export default class App extends React.Component { this.setState({ collapsibleRows }); } + clearSegmentation() { + this.setState({ collapsibleRows : {} }); + } + switchBooleanState(name: string) { if (name === "coloredTable") this.setState(({ coloredTable }) => ({ coloredTable: !coloredTable })); @@ -588,6 +593,7 @@ export default class App extends React.Component { onSelectedRowsChanged={(index, e) => this.handleSelectedLogRow(index, e)} onRowPropsChanged={(index, isRendered) => this.handleRowCollapse(index, isRendered)} collapsibleRows={this.state.collapsibleRows} + clearSegmentation={() => this.clearSegmentation()} />
{ const levels = Object.values(segments).map((segment) => segment.level); - return Math.max(...levels); + if (levels !== undefined && levels.length > 0) { + return Math.min(4, Math.max(...levels)); + } else { + return -1; + } }; export const getSegment = (segments: Segment[], start: number) => { diff --git a/src/viewer/log/LogView.tsx b/src/viewer/log/LogView.tsx index 312902a..0a4a7c0 100644 --- a/src/viewer/log/LogView.tsx +++ b/src/viewer/log/LogView.tsx @@ -24,6 +24,7 @@ import LogFile from "../LogFile"; import ReactResizeDetector from "react-resize-detector"; import { VSCodeButton } from "@vscode/webview-ui-toolkit/react"; import { getSegmentMaxLevel } from "../hooks/useRowProperty"; +import Tooltip from "@mui/material/Tooltip"; interface Props { logFile: LogFile; @@ -37,6 +38,7 @@ interface Props { structureMatches: number[][]; structureMatchesLogRows: number[]; collapsibleRows: { [key: number]: Segment }; + clearSegmentation: () => void; } interface State { state: LogViewState | undefined; @@ -82,9 +84,6 @@ export default class LogView extends React.Component { if (prevProps.currentStructureMatch[0] !== this.props.currentStructureMatch[0]) { this.updateState(this.props.currentStructureMatch[0]); } - // if (prevState.columnWidth !== this.state.columnWidth) { - // this.render(); //TODO: Discuss whether this is redundant. - // } } renderColumn( @@ -149,7 +148,7 @@ export default class LogView extends React.Component { let counter = firstRender; const maxLevel = Math.min(4, getSegmentMaxLevel(collapsibleRows)); - const segmentWidth: number = (this.getMaxLevel() + 1) * 30 + BORDER_SIZE; + const segmentWidth: number = (getSegmentMaxLevel(this.props.collapsibleRows) + 1) * 30 + BORDER_SIZE; for (let r = firstRender; counter <= lastRender; r++) { if (rowProperties[r].isSearchResult && rowProperties[r].isRendered) { let rowStyle; @@ -388,8 +387,9 @@ export default class LogView extends React.Component { return visibleRows.length; } - getMaxLevel() { - return Math.min(4, getSegmentMaxLevel(this.props.collapsibleRows)); + deleteSegmentAnnotations(){ + this.setState({collapsed : []}); + this.props.clearSegmentation(); } renderHeader(width: number) { @@ -399,11 +399,28 @@ export default class LogView extends React.Component { position: "absolute", left: this.state.state ? this.state.state.scrollLeft * -1 : 0, }; - const segmentWidth: number = (this.getMaxLevel() + 1) * 30 + BORDER_SIZE; + const segmentWidth: number = (getSegmentMaxLevel(this.props.collapsibleRows) + 1) * 30 + BORDER_SIZE; return (
-
+
+ {Object.keys(this.props.collapsibleRows).length > 0 && +
+ Delete all the segment annotations} + placement="bottom" + arrow + > + {this.deleteSegmentAnnotations()}} + > + + + +
} +
{this.props.logFile .getSelectedHeader() .map((h, i) => this.renderHeaderColumn(h.name, i, true, this.columnWidth(h.name)))} @@ -433,7 +450,12 @@ export default class LogView extends React.Component { render() { const { logFile } = this.props; const containerHeight = this.getVisibleRows() * LOG_ROW_HEIGHT; - const containerWidth = + const containerWidth = Object.keys(this.props.collapsibleRows).length > 0 ? + logFile.amountOfColumns() * BORDER_SIZE + + logFile.headers.reduce( + (partialSum: number, h) => partialSum + this.state.columnWidth[h.name], + 0, + ) + (getSegmentMaxLevel(this.props.collapsibleRows) + 1) * 30 + BORDER_SIZE : logFile.amountOfColumns() * BORDER_SIZE + logFile.headers.reduce( (partialSum: number, h) => partialSum + this.state.columnWidth[h.name],