import { borderColorName, emptyBGName } from "@git-diff-view/utils"; import * as React from "react"; import { SplitSide } from ".."; import { useDiffViewContext } from "./DiffViewContext"; import { useDiffWidgetContext } from "./DiffWidgetContext"; import type { DiffFile } from "@git-diff-view/core"; const InternalDiffSplitWidgetLine = ({ index, diffFile, lineNumber, }: { index: number; diffFile: DiffFile; lineNumber: number; }) => { const { useWidget } = useDiffWidgetContext(); const setWidget = useWidget.getReadonlyState().setWidget; const { useDiffContext } = useDiffViewContext(); const renderWidgetLine = useDiffContext.useShallowStableSelector((s) => s.renderWidgetLine); const oldLine = diffFile.getSplitLeftLine(index); const newLine = diffFile.getSplitRightLine(index); const widgetSide = useWidget.useShallowStableSelector((s) => s.widgetSide); const widgetLineNumber = useWidget.getReadonlyState().widgetLineNumber; const oldLineWidget = oldLine.lineNumber && widgetSide === SplitSide.old && widgetLineNumber === oldLine.lineNumber; const newLineWidget = newLine.lineNumber && widgetSide === SplitSide.new && widgetLineNumber === newLine.lineNumber; const oldWidgetRendered = oldLineWidget && renderWidgetLine?.({ diffFile, side: SplitSide.old, lineNumber: oldLine.lineNumber ?? -1, onClose: () => setWidget({}), }); const newWidgetRendered = newLineWidget && renderWidgetLine?.({ diffFile, side: SplitSide.new, lineNumber: newLine.lineNumber ?? -1, onClose: () => setWidget({}), }); if (!renderWidgetLine) return null; return (