Guía
Tutorial sobre transiciones
Usando @capgo/capacitor-transiciones
@capgo/capacitor-transitions agrega transiciones de rutas estilo Ionic a aplicaciones Capacitor sin adoptar la interfaz de usuario de Ionic. Se ejecuta en la capa web, mantiene tu router existente y puede habilitar automáticamente un gesto de retroceso en el borde izquierdo de iOS solo dentro de Capacitor iOS nativo.
Instalar
npm install @capgo/capacitor-transitions
No hay un paso de sincronización nativa porque el paquete no agrega un plugin nativo code.
Registrar los elementos
import '@capgo/capacitor-transitions';
Envuelve tus páginas
<cap-router-outlet platform="auto" swipe-gesture="auto">
<cap-page>
<cap-header slot="header">
<h1>Inbox</h1>
</cap-header>
<cap-content slot="content">
<button>Open message</button>
</cap-content>
<cap-footer slot="footer">
<nav>Tabs</nav>
</cap-footer>
</cap-page>
</cap-router-outlet>
Conéctalo a un router
Establece la dirección de la transición antes de tu actualización de ruta normal:
import { setDirection } from '@capgo/capacitor-transitions/react';
setDirection('forward');
router.push('/message/42');
setDirection('back');
router.back();
Ejemplo de React
import { useEffect, useRef } from 'react';
import { useNavigate } from 'react-router-dom';
import { initTransitions, setDirection, setupPage, setupRouterOutlet } from '@capgo/capacitor-transitions/react';
import '@capgo/capacitor-transitions';
initTransitions({ platform: 'auto' });
export function AppShell() {
const outletRef = useRef<HTMLElement>(null);
useEffect(() => {
if (!outletRef.current) return;
setupRouterOutlet(outletRef.current, { platform: 'auto', swipeGesture: 'auto' });
}, []);
return <cap-router-outlet ref={outletRef}>{/* routes */}</cap-router-outlet>;
}
export function InboxPage() {
const navigate = useNavigate();
const pageRef = useRef<HTMLElement>(null);
useEffect(() => {
if (!pageRef.current) return;
return setupPage(pageRef.current);
}, []);
return (
<cap-page ref={pageRef}>
<cap-header slot="header">
<h1>Inbox</h1>
</cap-header>
<cap-content slot="content">
<button
onClick={() => {
setDirection('forward');
navigate('/message/42');
}}
>
Open message
</button>
</cap-content>
</cap-page>
);
}
El subcaminho de React incluye definiciones de tipos JSX para los elementos personalizados. Si TypeScript aún informa que cap-router-outlet no existe en JSX.IntrinsicElementsagrega este archivo:
// src/capgo-transitions.d.ts
import '@capgo/capacitor-transitions/react';
Para Vite, Create React App y la mayoría de las aplicaciones React con webpack, mantén ese archivo bajo src/ es suficiente. Asegúrese de que esté incluido en Next.js o configuraciones de TypeScript personalizadas por tsconfig.json:
{
"include": ["src", "src/capgo-transitions.d.ts"]
}
Habilitar retroceso por deslizamiento
Usar swipe-gesture="auto" Para habilitar el gesto solo cuando Capacitor informe un tiempo de ejecución nativo de iOS:
<cap-router-outlet swipe-gesture="auto"></cap-router-outlet>
También puede forzarlo desde JavaScript:
const outlet = document.querySelector('cap-router-outlet');
outlet?.setSwipeGesture(true);
outlet?.setSwipeGesture(false);
outlet?.setSwipeGesture('auto');
El gesto sigue al dedo durante la transición, luego completa o cancela cuando el usuario libera. Agregar data-swipe-gesture-ignore a botones, deslizadores o cajones que no deben iniciar el gesto de borde.
Usar con navegación nativa
Instalar @capgo/native-navigation cuando el capa nativa debe ser dueña del menú de navegación o de la pestaña:
npm install @capgo/native-navigation
npx cap sync
Configurar el navegador nativo, luego mantener las transiciones enfocadas en las páginas de WebView:
import { NativeNavigation } from '@capgo/native-navigation';
import { setDirection } from '@capgo/capacitor-transitions/react';
import { router } from './router';
await NativeNavigation.configure({
contentInsetMode: 'css',
});
await NativeNavigation.setNavbar({
title: 'Inbox',
backButton: { visible: false },
});
await NativeNavigation.addListener('navbarBack', () => {
setDirection('back');
router.back();
});
async function openMessage(id: string) {
setDirection('forward');
router.push(`/message/${id}`);
await NativeNavigation.setNavbar({
title: 'Message',
backButton: { visible: true, title: 'Inbox' },
});
}
Usar cap-content para el cuerpo de la página animada y las variables CSS de navegación nativa para insets:
<cap-router-outlet platform="auto" swipe-gesture="auto">
<cap-page>
<cap-content slot="content" fullscreen>
<main class="native-page">Inbox content</main>
</cap-content>
</cap-page>
</cap-router-outlet>
.native-page {
padding-top: var(--cap-native-navigation-top);
padding-bottom: var(--cap-native-navigation-bottom);
}
No duplique la barra de navegación nativa como un encabezado web móvil. @capgo/native-navigation mantiene la barra nativa; @capgo/capacitor-transitions animar el contenido de la página debajo de ella.
Referencia completa
- GitHub https://github.com/Cap-go/capacitor-transiciones/
- Documentación: /docs/plugins/transiciones/
Sigue adelante desde Usando @capgo/capacitor-transiciones
Si estás utilizando Usando @capgo/capacitor-transiciones para planificar el comportamiento de medios y interfaz nativa, conectarlo con @capgo/capacitor-transiciones para los detalles de implementación en @capgo/capacitor-transiciones, Inicio para los detalles de implementación en Inicio, Usando @capgo/capacitor-actividades-en-vivo para la capacidad nativa en Usando @capgo/capacitor-actividades-en-vivo, @capgo/capacitor-actividades-en-vivo para los detalles de implementación en @capgo/capacitor-actividades-en-vivo, y Usando @capgo/capacitor-reproductor-de-video para la capacidad nativa en Usando @capgo/capacitor-reproductor-de-video.