import { useState, useEffect } from 'react'; import { usePathname, useRouter, useSearchParams } from 'next/navigation'; import { buildUrl } from '@/lib/url'; export function useNavigation() { const router = useRouter(); const pathname = usePathname(); const searchParams = useSearchParams(); const [, teamId] = pathname.match(/\/teams\/([a-f0-9-]+)/) || []; const [, websiteId] = pathname.match(/\/websites\/([a-f0-9-]+)/) || []; const [queryParams, setQueryParams] = useState(Object.fromEntries(searchParams)); const updateParams = (params?: Record) => { return buildUrl(pathname, { ...queryParams, ...params }); }; const replaceParams = (params?: Record) => { return buildUrl(pathname, params); }; useEffect(() => { setQueryParams(Object.fromEntries(searchParams)); }, [searchParams.toString()]); const renderUrl = (path: string, params?: Record | false) => { return buildUrl( teamId ? `/teams/${teamId}${path}` : path, params === false ? {} : { ...queryParams, ...params }, ); }; return { router, pathname, searchParams, query: queryParams, teamId, websiteId, updateParams, replaceParams, renderUrl, }; }