Server IP : 66.29.132.124 / Your IP : 18.216.167.229 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/cynthiaadediran.com/wp-content/plugins/extendify/src/HelpCenter/hooks/ |
Upload File : |
import apiFetch from '@wordpress/api-fetch'; import { useCallback, useEffect } from '@wordpress/element'; import { safeParseJson } from '@shared/lib/parsing'; import { useActivityStore } from '@shared/state/activity'; import { create } from 'zustand'; import { devtools, persist, createJSONStorage } from 'zustand/middleware'; import { routes as aiRoutes } from '@help-center/pages/AIChat'; import { routes as dashRoutes } from '@help-center/pages/Dashboard'; import { routes as kbRoutes } from '@help-center/pages/KnowledgeBase'; import { routes as tourRoutes } from '@help-center/pages/Tours'; const pages = [...dashRoutes, ...kbRoutes, ...tourRoutes, ...aiRoutes]; const initialState = { history: [], viewedPages: [], current: null, }; const state = (set, get) => ({ ...initialState, // initialize the state with default values ...(safeParseJson(window.extHelpCenterData.userData.routerData)?.state ?? {}), goBack: () => { if (get().history.length < 2) return; const nextPage = get().history[1]; useActivityStore.getState().incrementActivity(`hc-${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; const state = get(); const lastViewedAt = new Date().toISOString(); const firstViewedAt = lastViewedAt; const visited = state.viewedPages.find((a) => a.slug === page.slug); const 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: Number(visited.count) + 1, lastViewedAt } : { slug: page.slug, firstViewedAt, lastViewedAt, count: 1, }, ]; // Persist the detailed history to the server (don't wait for response) apiFetch({ path: '/extendify/v1/help-center/router-data', method: 'POST', data: { state: { viewedPages } }, }); set({ history: [page, ...state.history].filter(Boolean), current: page, viewedPages, }); }, reset: () => set({ ...initialState }), }); const useRouterState = create( persist(devtools(state, { name: 'Extendify Help Center Router' }), { name: 'extendify-help-center-router', storage: createJSONStorage(() => sessionStorage), partialize: ({ history, current }) => { // remove the component from the current page return { history, current: { ...current, component: null } }; }, }), ); export const useRouter = () => { const { current, setCurrent, history, goBack, reset } = useRouterState(); const Component = current?.component ?? pages.find((a) => a.slug === current?.slug)?.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(`hc-${page.slug}`); setCurrent(page); }, goBack, history, reset, }; };