mirror of
https://github.com/langgenius/dify.git
synced 2026-05-13 08:57:28 +08:00
Follow-up to SSR prefetch migration (2833965). 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 93 consumers to import from @/hooks/use-global-public
- Simplify global-public-context.tsx to a thin provider component
- Update 18 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
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)
|
|
}
|