️(frontend) dynamic tab title when connected to meeting
Some checks failed
Docker Hub Workflow / build-and-push-backend (push) Has been cancelled
Docker Hub Workflow / build-and-push-frontend-generic (push) Has been cancelled
meet Workflow / lint-git (push) Has been cancelled
Docker Hub Workflow / build-and-push-frontend-dinum (push) Has been cancelled
Docker Hub Workflow / build-and-push-summary (push) Has been cancelled
Docker Hub Workflow / build-and-push-agents (push) Has been cancelled
Docker Hub Workflow / notify-argocd (push) Has been cancelled
meet Workflow / lint-front (push) Has been cancelled
meet Workflow / check-changelog (push) Has been cancelled
meet Workflow / lint-changelog (push) Has been cancelled
meet Workflow / build-mails (push) Has been cancelled
meet Workflow / lint-back (push) Has been cancelled
meet Workflow / lint-agents (push) Has been cancelled
meet Workflow / lint-summary (push) Has been cancelled
meet Workflow / test-back (push) Has been cancelled
meet Workflow / lint-sdk (push) Has been cancelled
meet Workflow / build-sdk (push) Has been cancelled

Display room name, date and app title in browser tab
This commit is contained in:
Cyril
2026-03-03 13:31:56 +01:00
parent b564044e70
commit c72c5cae1a
4 changed files with 33 additions and 1 deletions

View File

@@ -29,6 +29,7 @@ and this project adheres to
- 🐛(migrations) use settings in migrations #1058 - 🐛(migrations) use settings in migrations #1058
- 💄(frontend) truncate pinned participant name with ellipsis on overflow #1056 - 💄(frontend) truncate pinned participant name with ellipsis on overflow #1056
- ♿(frontend) prevent focus ring clipping on invite dialog #1078 - ♿(frontend) prevent focus ring clipping on invite dialog #1078
- ♿(frontend) dynamic tab title when connected to meeting #1060
## [1.9.0] - 2026-03-02 ## [1.9.0] - 2026-03-02

View File

@@ -4,7 +4,7 @@ import { Suspense } from 'react'
import { ReactQueryDevtools } from '@tanstack/react-query-devtools' import { ReactQueryDevtools } from '@tanstack/react-query-devtools'
import { QueryClientProvider } from '@tanstack/react-query' import { QueryClientProvider } from '@tanstack/react-query'
import { useTranslation } from 'react-i18next' import { useTranslation } from 'react-i18next'
import { useLang } from 'hoofd' import { useLang, useTitle } from 'hoofd'
import { Switch, Route } from 'wouter' import { Switch, Route } from 'wouter'
import { I18nProvider } from 'react-aria-components' import { I18nProvider } from 'react-aria-components'
import { Layout } from './layout/Layout' import { Layout } from './layout/Layout'
@@ -18,6 +18,7 @@ import { useIsSdkContext } from '@/features/sdk/hooks/useIsSdkContext'
function App() { function App() {
const { i18n } = useTranslation() const { i18n } = useTranslation()
useLang(i18n.language) useLang(i18n.language)
useTitle(import.meta.env.VITE_APP_TITLE ?? '')
const isSDKContext = useIsSdkContext() const isSDKContext = useIsSdkContext()

View File

@@ -0,0 +1,28 @@
import { useTitle } from 'hoofd'
import { useRoomData } from './useRoomData'
import { useMemo } from 'react'
const APP_TITLE = import.meta.env.VITE_APP_TITLE ?? ''
/**
* Updates the browser tab title with the room name to help users easily find
* the meeting tab among many open tabs. Works on both the join screen and
* once connected.
*/
export const useRoomPageTitle = () => {
const roomData = useRoomData()
const pageTitle = useMemo(() => {
if (!roomData) {
return APP_TITLE
}
const roomLabel = roomData.name || roomData.slug || ''
if (!roomLabel) return APP_TITLE
return `${APP_TITLE} - ${roomLabel} `
}, [roomData])
useTitle(pageTitle)
}

View File

@@ -30,6 +30,7 @@ import { useSidePanel } from '../hooks/useSidePanel'
import { RecordingProvider } from '@/features/recording' import { RecordingProvider } from '@/features/recording'
import { ScreenShareErrorModal } from '../components/ScreenShareErrorModal' import { ScreenShareErrorModal } from '../components/ScreenShareErrorModal'
import { useConnectionObserver } from '../hooks/useConnectionObserver' import { useConnectionObserver } from '../hooks/useConnectionObserver'
import { useRoomPageTitle } from '../hooks/useRoomPageTitle'
import { useNoiseReduction } from '../hooks/useNoiseReduction' import { useNoiseReduction } from '../hooks/useNoiseReduction'
import { useRegisterKeyboardShortcut } from '@/features/shortcuts/useRegisterKeyboardShortcut' import { useRegisterKeyboardShortcut } from '@/features/shortcuts/useRegisterKeyboardShortcut'
import { useSettingsDialog } from '@/features/settings' import { useSettingsDialog } from '@/features/settings'
@@ -113,6 +114,7 @@ export function VideoConference({ ...props }: VideoConferenceProps) {
) )
useConnectionObserver() useConnectionObserver()
useRoomPageTitle()
useVideoResolutionSubscription() useVideoResolutionSubscription()
useRegisterKeyboardShortcut({ useRegisterKeyboardShortcut({