import { emptyBGName } from "@git-diff-view/utils"; import * as React from "react"; import { SplitSide } from ".."; import { useDomWidth } from "../hooks/useDomWidth"; import { useSyncHeight } from "../hooks/useSyncHeight"; import { useDiffViewContext } from "./DiffViewContext"; import { useDiffWidgetContext } from "./DiffWidgetContext"; import type { DiffFile } from "@git-diff-view/core"; const InternalDiffSplitWidgetLine = ({ index, side, diffFile, lineNumber, }: { index: number; side: SplitSide; diffFile: DiffFile; lineNumber: number; }) => { const { useWidget } = useDiffWidgetContext(); const { useDiffContext } = useDiffViewContext(); const oldLine = diffFile.getSplitLeftLine(index); const newLine = diffFile.getSplitRightLine(index); const widgetSide = useWidget.useShallowStableSelector((s) => s.widgetSide); const widgetLineNumber = useWidget.getReadonlyState().widgetLineNumber; const setWidget = useWidget.getReadonlyState().setWidget; const oldLineWidget = oldLine.lineNumber && widgetSide === SplitSide.old && widgetLineNumber === oldLine.lineNumber; const newLineWidget = newLine.lineNumber && widgetSide === SplitSide.new && widgetLineNumber === newLine.lineNumber; const currentLine = side === SplitSide.old ? oldLine : newLine; const otherSide = side === SplitSide.old ? SplitSide.new : SplitSide.old; const currentHasWidget = side === SplitSide.old ? oldLineWidget : newLineWidget; const hasWidget = oldLineWidget || newLineWidget; const renderWidgetLine = useDiffContext.useShallowStableSelector((s) => s.renderWidgetLine); const currentWidgetRendered = currentHasWidget && renderWidgetLine?.({ diffFile, side, lineNumber: currentLine.lineNumber ?? -1, onClose: () => setWidget({}), }); useSyncHeight({ selector: `div[data-line="${lineNumber}-widget-content"]`, wrapper: `tr[data-line="${lineNumber}-widget"]`, side: SplitSide[currentHasWidget ? side : otherSide], enable: !!hasWidget && typeof renderWidgetLine === "function", }); const width = useDomWidth({ selector: side === SplitSide.old ? ".old-diff-table-wrapper" : ".new-diff-table-wrapper", enable: !!currentHasWidget && typeof renderWidgetLine === "function", }); if (!renderWidgetLine) return null; return (