aboutsummaryrefslogtreecommitdiff
path: root/src/frontend/app/contexts/PageTitleContext.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/frontend/app/contexts/PageTitleContext.tsx')
-rw-r--r--src/frontend/app/contexts/PageTitleContext.tsx46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/frontend/app/contexts/PageTitleContext.tsx b/src/frontend/app/contexts/PageTitleContext.tsx
new file mode 100644
index 0000000..396e409
--- /dev/null
+++ b/src/frontend/app/contexts/PageTitleContext.tsx
@@ -0,0 +1,46 @@
+import React, { createContext, useContext, useEffect, useState } from "react";
+
+interface PageTitleContextProps {
+ title: string;
+ setTitle: (title: string) => void;
+}
+
+const PageTitleContext = createContext<PageTitleContextProps | undefined>(
+ undefined
+);
+
+export const PageTitleProvider: React.FC<{ children: React.ReactNode }> = ({
+ children,
+}) => {
+ const [title, setTitle] = useState("Busurbano");
+
+ return (
+ <PageTitleContext.Provider value={{ title, setTitle }}>
+ {children}
+ </PageTitleContext.Provider>
+ );
+};
+
+export const usePageTitleContext = () => {
+ const context = useContext(PageTitleContext);
+ if (!context) {
+ throw new Error("usePageTitleContext must be used within a PageTitleProvider");
+ }
+ return context;
+};
+
+export const usePageTitle = (title: string) => {
+ const { setTitle } = usePageTitleContext();
+
+ useEffect(() => {
+ setTitle(title);
+ document.title = `${title} - Busurbano`;
+
+ return () => {
+ // Optional: Reset title on unmount?
+ // Usually not needed as the next page will set its own title.
+ // But if we navigate to a page without usePageTitle, it might be stale.
+ // Let's leave it for now.
+ };
+ }, [title, setTitle]);
+};