From 6e88a52f109fc98f54ad0c947a4a9d38a125ba03 Mon Sep 17 00:00:00 2001 From: JoseAlvesdev Date: Sun, 8 Sep 2024 10:15:53 -0300 Subject: [PATCH] refactor: Hash mode implementation on router, reason: Incompatibility issues with GitHub pages. --- index.html | 6 +-- public/views/home.view.html | 4 +- public/views/not-found.view.html | 2 +- public/views/signin.view.html | 4 +- src/router.ts | 73 +++++++++++++++++--------------- 5 files changed, 48 insertions(+), 41 deletions(-) diff --git a/index.html b/index.html index f99eadf..53dbc45 100644 --- a/index.html +++ b/index.html @@ -14,11 +14,11 @@ - - assine agora - entrar + assine agora + entrar diff --git a/public/views/home.view.html b/public/views/home.view.html index 4a6af76..eb831d9 100644 --- a/public/views/home.view.html +++ b/public/views/home.view.html @@ -78,7 +78,7 @@

Mobile

- + Escolher o Plano Mobile @@ -113,7 +113,7 @@

Multitelas

- + Escolher o Plano Multitelas diff --git a/public/views/not-found.view.html b/public/views/not-found.view.html index 5271fbc..fea37f2 100644 --- a/public/views/not-found.view.html +++ b/public/views/not-found.view.html @@ -3,7 +3,7 @@

404

desculpe, mas a página que você solicitou não foi implementada

- go home + go home contact us
diff --git a/public/views/signin.view.html b/public/views/signin.view.html index 0744240..2e60cf7 100644 --- a/public/views/signin.view.html +++ b/public/views/signin.view.html @@ -18,8 +18,8 @@

Entrar

minlength="8" />
- - + +
diff --git a/src/router.ts b/src/router.ts index a8ae510..97ea30a 100644 --- a/src/router.ts +++ b/src/router.ts @@ -12,26 +12,23 @@ import getElement from './utils/get-element.util'; import setClasses from './utils/set-classes.util'; import sleep from './utils/sleep.util'; -// Base URL -import viteConfig from '../vite.config' - const navigateTo = (url: string): void => { - history.pushState(null, '', url); + window.location.hash = url; // Muda o hash da URL router(); }; const router: () => Promise = async (): Promise => { const routes: IRoute[] = [ - { path: "/", view: HomeView }, - { path: "/signin", view: SignInView }, - { path: '/404', view: NotFoundView } + { path: "#/", view: HomeView }, + { path: "#/signin", view: SignInView }, + { path: '#/404', view: NotFoundView } ]; // Test each route potential match const potentialMatches: IPotentialMatch[] = routes.map((route: IRoute): IPotentialMatch => { return { route: route, - isMatch: location.pathname === `${viteConfig.base.substring(0, 7)}${route.path}` + isMatch: location.hash === route.path // Verifica o hash } }); @@ -39,12 +36,21 @@ const router: () => Promise = async (): Promise => { .find((potentialMatch: IPotentialMatch): boolean => potentialMatch.isMatch); if (!match) { - match = { - route: routes.find((route: IRoute): boolean => route.path === '/404') || routes[routes.length - 1], - isMatch: true - }; + // Verifica se o hash corresponde a um ID existente + const hashId = location.hash.substring(1); + const element = document.getElementById(hashId); + + if (element) { + // Se o ID existir, não redireciona para 404 + match = { route: { path: '', view: HomeView }, isMatch: true }; // Usa uma view padrão + } else { + match = { + route: routes.find((route: IRoute): boolean => route.path === '#/404') || routes[routes.length - 1], + isMatch: true + }; + } } - + const root: HTMLElement = getElement('#root'); const view = new match.route.view(); @@ -61,42 +67,43 @@ const router: () => Promise = async (): Promise => { await sleep(.3); setClasses(['#root'], false, 'is-show'); } + + // Rolagem para o ID especificado no hash + const hash: string = window.location.hash.substring(1); // Remove o '#' - const route: string = match.route.path; + if (hash) { + const element: HTMLElement | null = document.getElementById(hash); - if (route !== '/') - getElement('.ts-assign-link').setAttribute('data-link', ''); - else - getElement('.ts-assign-link').removeAttribute('data-link'); + if (element) element.scrollIntoView({ behavior: 'smooth' }); // Rola suavemente para o elemento + else console.warn(`Elemento com ID "${hash}" não encontrado.`); + } } init(); }; -window.addEventListener('popstate', router); +window.addEventListener('hashchange', router); // Escuta mudanças no hash document.addEventListener('DOMContentLoaded', (): void => { + // Defina o hash padrão se estiver vazio + if (!window.location.hash) window.location.hash = "#/"; // Defina o hash inicial como a página inicial + document.body.addEventListener('click', (e: MouseEvent): void => { - // const exit: () => void = async (): Promise => { - // await sleep(.3); - // setClasses(['#root'], true, 'is-show--exit'); - // } - const target = e.target as HTMLElement; - + if (target.matches('[data-link]')) { e.preventDefault(); // Sempre prevenir o comportamento padrão - - const currentUrl: string = window.location.href; - const linkUrl: string = (target as HTMLAnchorElement).href; + const currentUrl: string = window.location.hash; // Obtém o hash atual + const linkUrl: string = (target as HTMLAnchorElement).href.split('#')[1]; // Obtém o hash do link - if (currentUrl !== linkUrl) { - //exit(); - navigateTo(linkUrl); - } + // Navega para o novo hash + if (`#${linkUrl}` !== currentUrl) navigateTo(linkUrl); } }); - router(); + router(); // Chama o router na inicialização }); + + +