Skip to content

Commit

Permalink
Don't select URI cell when clicking the link
Browse files Browse the repository at this point in the history
  • Loading branch information
ivoelbert committed Mar 14, 2024
1 parent 68de152 commit 0f7a3ca
Showing 1 changed file with 34 additions and 18 deletions.
52 changes: 34 additions & 18 deletions packages/core/src/cells/uri-cell.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,32 @@ function getTextRect(
return { x, y, width, height };
}

function isOverLinkText(e: {
readonly cell: UriCell;
readonly posX: number;
readonly posY: number;
readonly bounds: Rectangle;
readonly theme: FullTheme;
}): boolean {
const { cell, bounds, posX, posY, theme } = e;
const txt = cell.displayData ?? cell.data;
if (cell.hoverEffect !== true || cell.onClickUri === undefined) return false;

const m = getMeasuredTextCache(txt, theme.baseFontFull);
if (m === undefined) return false;
const textRect = getTextRect(m, bounds, theme, cell.contentAlign);
return pointInRect(
{
x: textRect.x - 4,
y: textRect.y - 4,
width: textRect.width + 8,
height: textRect.height + 8,
},
posX,
posY
);
}

export const uriCellRenderer: InternalCellRenderer<UriCell> = {
getAccessibilityString: c => c.data?.toString() ?? "",
kind: GridCellKind.Uri,
Expand Down Expand Up @@ -82,26 +108,16 @@ export const uriCellRenderer: InternalCellRenderer<UriCell> = {
ctx.fillStyle = isLinky ? theme.linkColor : theme.textDark;
drawTextCell(a, txt, cell.contentAlign);
},
onSelect: e => {
if (isOverLinkText(e)) {
e.preventDefault();
}
},
onClick: a => {
const { cell, bounds, posX, posY, theme } = a;
const txt = cell.displayData ?? cell.data;
if (cell.hoverEffect !== true || cell.onClickUri === undefined) return;

const m = getMeasuredTextCache(txt, theme.baseFontFull);
if (m === undefined) return;
const textRect = getTextRect(m, bounds, theme, cell.contentAlign);
const didClick = pointInRect(
{
x: textRect.x - 4,
y: textRect.y - 4,
width: textRect.width + 8,
height: textRect.height + 8,
},
posX,
posY
);
const { cell } = a;
const didClick = isOverLinkText(a);
if (didClick) {
cell.onClickUri(a);
cell.onClickUri?.(a);
}
return undefined;
},
Expand Down

0 comments on commit 0f7a3ca

Please sign in to comment.