mirror of
https://github.com/linsa-io/linsa.git
synced 2026-01-12 12:20:23 +01:00
* chore: memoize sorted pages * chore: make link size more precise * fix(link): disable enter press on create mode * fix(onboarding): move is base logic and use escape for single quote * fix(page): on delete success redirect to pages * fix(sntry): sentry client error report * chore(page): dynamic focus on title/content * chore(link): tweak badge class * chore(link): use nuqs for handling create mode * fix(link): refs * feat(palette): implement new link
67 lines
2.0 KiB
TypeScript
67 lines
2.0 KiB
TypeScript
"use client"
|
|
|
|
import React, { useEffect, useState, useCallback, useRef } from "react"
|
|
import { LinkHeader } from "@/components/routes/link/header"
|
|
import { LinkList } from "@/components/routes/link/list"
|
|
import { LinkManage } from "@/components/routes/link/manage"
|
|
import { parseAsBoolean, useQueryState } from "nuqs"
|
|
import { atom, useAtom } from "jotai"
|
|
import { LinkBottomBar } from "./bottom-bar"
|
|
import { commandPaletteOpenAtom } from "@/components/custom/command-palette/command-palette"
|
|
|
|
export const isDeleteConfirmShownAtom = atom(false)
|
|
|
|
export function LinkRoute(): React.ReactElement {
|
|
const [nuqsEditId] = useQueryState("editId")
|
|
const [activeItemIndex, setActiveItemIndex] = useState<number | null>(null)
|
|
const [isInCreateMode] = useQueryState("create", parseAsBoolean)
|
|
const [isCommandPaletteOpen] = useAtom(commandPaletteOpenAtom)
|
|
const [isDeleteConfirmShown] = useAtom(isDeleteConfirmShownAtom)
|
|
const [disableEnterKey, setDisableEnterKey] = useState(false)
|
|
const timeoutRef = useRef<NodeJS.Timeout | null>(null)
|
|
|
|
const handleCommandPaletteClose = useCallback(() => {
|
|
if (timeoutRef.current) {
|
|
clearTimeout(timeoutRef.current)
|
|
}
|
|
|
|
setDisableEnterKey(true)
|
|
timeoutRef.current = setTimeout(() => {
|
|
setDisableEnterKey(false)
|
|
timeoutRef.current = null
|
|
}, 100)
|
|
}, [])
|
|
|
|
useEffect(() => {
|
|
if (isDeleteConfirmShown || isCommandPaletteOpen || isInCreateMode) {
|
|
setDisableEnterKey(true)
|
|
if (timeoutRef.current) {
|
|
clearTimeout(timeoutRef.current)
|
|
timeoutRef.current = null
|
|
}
|
|
} else if (!isCommandPaletteOpen) {
|
|
handleCommandPaletteClose()
|
|
}
|
|
|
|
return () => {
|
|
if (timeoutRef.current) {
|
|
clearTimeout(timeoutRef.current)
|
|
}
|
|
}
|
|
}, [isDeleteConfirmShown, isCommandPaletteOpen, isInCreateMode, handleCommandPaletteClose])
|
|
|
|
return (
|
|
<div className="flex h-full flex-auto flex-col overflow-hidden">
|
|
<LinkHeader />
|
|
<LinkManage />
|
|
<LinkList
|
|
key={nuqsEditId}
|
|
activeItemIndex={activeItemIndex}
|
|
setActiveItemIndex={setActiveItemIndex}
|
|
disableEnterKey={disableEnterKey}
|
|
/>
|
|
<LinkBottomBar />
|
|
</div>
|
|
)
|
|
}
|