Aller directement au contenu

Démarrage

  1. Prêt à utiliser avec l'IA

    Fenêtre de terminal
    npm install @capgo/capacitor-transitions
  2. Enregistrer les composants web

    import '@capgo/capacitor-transitions';
  3. Envelopper les pages routées

    <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>
  4. Définir la direction avant que votre routeur change de route

    import { setDirection } from '@capgo/capacitor-transitions/react';
    setDirection('forward');
    router.push('/message/42');
    setDirection('back');
    router.back();
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}>
{/* Your router renders cap-page children here. */}
</cap-router-outlet>
);
}
export function InboxPage() {
const navigate = useNavigate();
const pageRef = useRef<HTMLElement>(null);
useEffect(() => {
if (!pageRef.current) return;
return setupPage(pageRef.current, {
onDidEnter: () => console.log('Inbox visible'),
});
}, []);
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>
);
}

Importation de @capgo/capacitor-transitions/react comprend les déclarations de type JSX pour cap-router-outlet, cap-page, cap-header, cap-content, et cap-footer. Dans la plupart des projets React, cette importation rend les éléments personnalisés valides automatiquement dans TSX.

Si TypeScript signale toujours Property 'cap-router-outlet' does not exist on type 'JSX.IntrinsicElements', ajoutez un fichier de déclaration de projet :

src/capgo-transitions.d.ts
import '@capgo/capacitor-transitions/react';

For Vite, Create React App et la plupart des applications React webpack, placer ce fichier à l'intérieur src/ est suffisant. Pour Next.js, placez-le dans src/ ou le répertoire racine du projet et assurez-vous que tsconfig.json le contienne :

{
"include": ["src", "src/capgo-transitions.d.ts"]
}

Pour les configurations TypeScript ou webpack personnalisées qui utilisent un dossier séparé types/ « folder », incluez ce dossier à la place :

{
"include": ["src", "types"]
}

Activer ou désactiver la gestuelle de bordure iOS à partir de la balise :

<cap-router-outlet swipe-gesture="auto"></cap-router-outlet>
<cap-router-outlet swipe-gesture="true"></cap-router-outlet>
<cap-router-outlet swipe-gesture="false"></cap-router-outlet>

Ou depuis JavaScript :

const outlet = document.querySelector('cap-router-outlet');
outlet?.setSwipeGesture('auto');
outlet?.setSwipeGesture(true);
outlet?.setSwipeGesture(false);

auto active le geste uniquement lorsque Capacitor signale un runtime iOS natif. Pendant le geste, la transition de page suit le doigt. Lorsque l'utilisateur libère, la transition se termine et demande à l'historique du navigateur de revenir, ou annule et restaure la page actuelle.

Pour empêcher un élément de démarrer le geste, ajoutez data-swipe-gesture-ignore:

<button data-swipe-gesture-ignore>Open drawer</button>

Utilisez @capgo/capacitor-transitions avec @capgo/native-navigation lorsque la navigation native doit contrôler les barres supérieure et inférieure, tandis que le contenu web conserve la motion de page Ionic.

  1. Installez et synchronisez le package de navigation native :

    Fenêtre de terminal
    npm install @capgo/native-navigation
    npx cap sync
  2. Configurer le navigateur natif :

    import { NativeNavigation } from '@capgo/native-navigation';
    await NativeNavigation.configure({
    contentInsetMode: 'css',
    });
    await NativeNavigation.setNavbar({
    title: 'Inbox',
    backButton: { visible: false },
    });
  3. Gardez l'entrée de transition web responsable uniquement des pages :

    <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);
    }
  4. Faites fonctionner les deux systèmes à partir des mêmes événements de routeur :

    import { NativeNavigation } from '@capgo/native-navigation';
    import { setDirection } from '@capgo/capacitor-transitions/react';
    import { router } from './router';
    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' },
    });
    }

N'affichez pas la barre supérieure native à nouveau comme un élément en mouvement. <cap-header>Laissez @capgo/native-navigation garder la barre native et utilisez-la @capgo/capacitor-transitions pour le contenu de la page WebView en dessous d'elle.

AttributTypeDéfautDescription
platform'ios' | 'android' | 'auto''auto'Style d'animation
durationnumberPar défaut du plateformeDurée d'animation en millisecondes
keep-in-dombooleantrueConserver les pages inactives dans le DOM
max-cachednumber10Nombre maximal de pages mises en cache
swipe-gestureboolean | 'auto''auto'Activer, désactiver ou détecter nativement le geste de bordure iOS

Méthodes :

  • push(element, config?)
  • pop(config?)
  • setRoot(element, config?)
  • setSwipeGesture(true | false | 'auto')

Enveloppe une page et émet des événements de cycle de vie :

  • cap-will-enter
  • cap-did-enter
  • cap-will-leave
  • cap-did-leave
AttributTypePar défautDescription
fullscreenbooleanfalsePermettre au contenu de défilement derrière l'en-tête
scroll-xbooleantrueActiver le défilement horizontal
scroll-ybooleantrueActiver le défilement vertical

Les points d'entrée du framework exposent les mêmes aides de base :

import { initTransitions, setDirection, setupPage, setupRouterOutlet } from '@capgo/capacitor-transitions/react';
initTransitions({ platform: 'auto' });
setDirection('forward');
setupRouterOutlet(element, { platform: 'auto', swipeGesture: 'auto' });
setupPage(element, { onWillEnter, onDidEnter, onWillLeave, onDidLeave });

Points d'entrée disponibles :

  • @capgo/capacitor-transitions/react
  • @capgo/capacitor-transitions/vue
  • @capgo/capacitor-transitions/angular
  • @capgo/capacitor-transitions/svelte
  • @capgo/capacitor-transitions/solid

Si vous utilisez Démarrage pour planifier la migration et les opérations d'entreprise, connectez-le avec Utilisation de @capgo/capacitor-transitions pour la capacité native dans Utilisation de @capgo/capacitor-transitions Capgo Entreprise pour le flux de travail du produit dans Capgo Entreprise, Alternatives de plugin d'entreprise Ionic pour le flux de travail du produit dans Alternatives de plugin d'entreprise Ionic, Alternatives de Capgo pour le flux de travail du produit dans Alternatives de Capgo, et Consultation de Capgo pour le flux de travail du produit dans Consultation de Capgo.