From fadb97ef52427a6222ab8943c26f89973390690d Mon Sep 17 00:00:00 2001 From: "Thomas F. K. Jorna" Date: Sun, 17 Oct 2021 02:30:01 +0200 Subject: fix(#118): link bugfixes --- components/Sidebar/Link.tsx | 26 +++++++++++++++++++++----- components/Sidebar/TagBar.tsx | 4 ++-- 2 files changed, 23 insertions(+), 7 deletions(-) (limited to 'components/Sidebar') diff --git a/components/Sidebar/Link.tsx b/components/Sidebar/Link.tsx index 61235c7..7e966a4 100644 --- a/components/Sidebar/Link.tsx +++ b/components/Sidebar/Link.tsx @@ -46,6 +46,7 @@ export interface NodeLinkProps { children: any setSidebarHighlightedNode: any openContextMenu: any + id?: string } export interface NormalLinkProps { href: string @@ -59,16 +60,25 @@ import { Scrollbars } from 'react-custom-scrollbars-2' import { ExternalLinkIcon } from '@chakra-ui/icons' export const NodeLink = (props: NodeLinkProps) => { - const { setSidebarHighlightedNode, setPreviewNode, nodeById, openContextMenu, href, children } = - props + const { + id, + setSidebarHighlightedNode, + setPreviewNode, + nodeById, + openContextMenu, + href, + children, + } = props const { highlightColor } = useContext(ThemeContext) const theme = useTheme() const coolHighlightColor = getThemeColor(highlightColor, theme) - const [whatever, type, uri] = [...href.matchAll(/(.*?)\:(.*)/g)][0] + const type = href.replaceAll(/(.*?)\:?.*/g, '$1') + const uri = href.replaceAll(/.*?\:(.*)/g, '$1') + const ID = id ?? uri return ( setSidebarHighlightedNode(nodeById[uri])} + onMouseEnter={() => setSidebarHighlightedNode(nodeById[ID])} onMouseLeave={() => setSidebarHighlightedNode({})} tabIndex={0} display="inline" @@ -115,8 +125,8 @@ export const PreviewLink = (props: LinkProps) => { // TODO figure out how to properly type this // see https://github.com/rehypejs/rehype-react/issues/25 const [orgText, setOrgText] = useState(null) - const [whatever, type, uri] = [...href.matchAll(/(.*?)\:(.*)/g)][0] const [hover, setHover] = useState(false) + const type = href.replaceAll(/(.*?)\:.*/g, '$1') const getText = () => { fetch(`http://localhost:35901/file/${file}`) @@ -147,10 +157,15 @@ export const PreviewLink = (props: LinkProps) => { } getText() }, [hover, orgText]) + if (!type) { + return {children} + } if (type.replaceAll(/(http)?.*/g, '$1')) { return {children} } + + const uri = href.replaceAll(/.*?\:(.*)/g, '$1') const getId = (type: string, uri: string) => { if (type === 'id') { return uri @@ -211,6 +226,7 @@ export const PreviewLink = (props: LinkProps) => { { const { filter, setFilter, tagColors, setTagColors, openContextMenu, previewNode } = props const node = previewNode as OrgRoamNode - if (!node.tags || node?.tags[0] === null) { + if (!node?.tags || node?.tags?.[0] === null) { return null } return ( - {node?.tags?.map((tag: string) => { + {node?.tags?.map?.((tag: string) => { const bl: string[] = filter.tagsBlacklist ?? [] const wl: string[] = filter.tagsWhitelist ?? [] const blackList: boolean = bl.includes(tag) -- cgit v1.2.3