summaryrefslogtreecommitdiff
path: root/components/Sidebar
diff options
context:
space:
mode:
authorThomas F. K. Jorna <[email protected]>2021-10-17 15:31:44 +0200
committerGitHub <[email protected]>2021-10-17 15:31:44 +0200
commit92f465fbe2dd66576f902b65171da6116e29f1c2 (patch)
tree8a06a99ac81d12b5078129873442e2b106042ea4 /components/Sidebar
parent6ed792c982991b679d1c50060f4ca25b2eb1b9ca (diff)
parentfadb97ef52427a6222ab8943c26f89973390690d (diff)
Merge pull request #121 from org-roam/fix/500
fix(#118): link bugfixes
Diffstat (limited to 'components/Sidebar')
-rw-r--r--components/Sidebar/Link.tsx26
-rw-r--r--components/Sidebar/TagBar.tsx4
2 files changed, 23 insertions, 7 deletions
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 (
<Text
- onMouseEnter={() => 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<any>(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 <Text color="gray.700">{children}</Text>
+ }
if (type.replaceAll(/(http)?.*/g, '$1')) {
return <NormalLink href={href}>{children}</NormalLink>
}
+
+ 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) => {
<NodeLink
key={nodeById[id]?.title ?? id}
{...{
+ id,
setSidebarHighlightedNode,
setPreviewNode,
nodeById,
diff --git a/components/Sidebar/TagBar.tsx b/components/Sidebar/TagBar.tsx
index 0fe0a18..f58fe38 100644
--- a/components/Sidebar/TagBar.tsx
+++ b/components/Sidebar/TagBar.tsx
@@ -18,12 +18,12 @@ export const TagBar = (props: TagBarProps) => {
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 (
<Flex mb={2} flexWrap="wrap">
- {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)