mirror of
https://github.com/langgenius/dify.git
synced 2026-05-13 08:57:28 +08:00
Follow-up to SSR prefetch migration. Eliminates the Zustand middleman that was syncing TanStack Query data into a separate store. - Remove useGlobalPublicStore Zustand store entirely - Create hooks/use-global-public.ts with useSystemFeatures, useSystemFeaturesQuery, useIsSystemFeaturesPending, useSetupStatusQuery - Migrate all consumers to import from @/hooks/use-global-public - Simplify global-public-context.tsx to a thin provider component - Update test files to mock the new hook interface - Fix SetupStatusResponse.setup_at type from Date to string (JSON) - Fix setup-status.spec.ts mock target to match consoleClient - Regenerate eslint-suppressions.json for main branch BREAKING CHANGE: useGlobalPublicStore is removed. Use useSystemFeatures() from @/hooks/use-global-public instead.
45 lines
1.4 KiB
TypeScript
45 lines
1.4 KiB
TypeScript
'use client'
|
|
import { useFavicon, useTitle } from 'ahooks'
|
|
import { useEffect } from 'react'
|
|
import { useIsSystemFeaturesPending, useSystemFeatures } from '@/hooks/use-global-public'
|
|
import { basePath } from '@/utils/var'
|
|
|
|
export default function useDocumentTitle(title: string) {
|
|
const isPending = useIsSystemFeaturesPending()
|
|
const systemFeatures = useSystemFeatures()
|
|
const prefix = title ? `${title} - ` : ''
|
|
let titleStr = ''
|
|
let favicon = ''
|
|
if (isPending === false) {
|
|
if (systemFeatures.branding.enabled) {
|
|
titleStr = `${prefix}${systemFeatures.branding.application_title}`
|
|
favicon = systemFeatures.branding.favicon
|
|
}
|
|
else {
|
|
titleStr = `${prefix}Dify`
|
|
favicon = `${basePath}/favicon.ico`
|
|
}
|
|
}
|
|
useTitle(titleStr)
|
|
useEffect(() => {
|
|
let apple: HTMLLinkElement | null = null
|
|
if (systemFeatures.branding.favicon) {
|
|
document
|
|
.querySelectorAll(
|
|
'link[rel=\'icon\'], link[rel=\'shortcut icon\'], link[rel=\'apple-touch-icon\'], link[rel=\'mask-icon\']',
|
|
)
|
|
.forEach(n => n.parentNode?.removeChild(n))
|
|
|
|
apple = document.createElement('link')
|
|
apple.rel = 'apple-touch-icon'
|
|
apple.href = systemFeatures.branding.favicon
|
|
document.head.appendChild(apple)
|
|
}
|
|
|
|
return () => {
|
|
apple?.remove()
|
|
}
|
|
}, [systemFeatures.branding.favicon])
|
|
useFavicon(favicon)
|
|
}
|