article illustration Mise à jour de Capacitor 4 vers Capacitor 5 : Un guide étape par étape
Capacitor
Last update: June 29, 2023

Mise à jour de Capacitor 4 vers Capacitor 5 : Un guide étape par étape

Apprenez comment mettre à jour votre projet Capacitor 4 vers Capacitor 5 avec un minimum de changements perturbateurs, y compris la mise à jour des plugins officiels et des outils nécessaires.

Par rapport aux mises à jour précédentes, la transition de Capacitor 4 à Capacitor 5 implique des changements minimes. Ce guide fournit des instructions étape par étape pour mettre à jour votre projet vers Capacitor 5, ainsi qu’une liste des changements importants pour les plugins officiels.

Note : Capacitor 5 nécessite NodeJS 16 ou supérieur, car Node 12 a atteint sa fin de vie et Node 14 atteindra sa fin de vie le 30 avril 2023. Il est recommandé d’utiliser la dernière version LTS de NodeJS.

  1. Installez la version latest du CLI Capacitor dans votre projet :

    npm i -D @capacitor/cli@latest
  2. Exécutez la commande suivante pour laisser le CLI gérer la migration :

    npx cap migrate

    Si certaines étapes de migration ne peuvent pas être réalisées, des informations supplémentaires seront fournies dans la sortie du terminal. Les étapes de migration manuelle sont listées ci-dessous.

  3. Si vous avez l’extension VS Code installée, vérifiez la section des recommandations de l’extension pour trouver l’option de migration de votre projet vers Capacitor 5.

Mise à niveau du projet iOS Capacitor 4 vers Capacitor 5

  1. Mise à niveau de Xcode : Capacitor 5 nécessite Xcode 14.1+.

  2. Mise à jour du gitignore : Effectuez les modifications suivantes dans votre fichier gitignore :

    - App/Podfile.lock
    + App/output
  3. Mise à jour des ressources pour utiliser une seule icône d’application : Xcode 14 prend en charge une seule icône d’application de 1024x1024. Nettoyez votre AppIcon.appiconset en supprimant toutes les tailles inutiles.

Mise à niveau du projet Android Capacitor 4 vers Capacitor 5

  1. Mise à niveau d’Android Studio : Capacitor 5 nécessite Android Studio Flamingo | 2022.2.1 ou plus récent en raison de l’utilisation de Gradle 8, qui nécessite Java JDK 17. Java 17 est livré avec Android Studio Flamingo, donc aucun téléchargement supplémentaire n’est nécessaire.

  2. Exécution de l’Assistant de mise à niveau AGP : Android Studio peut aider avec certaines mises à jour liées à Gradle et au déplacement des packages dans les fichiers de build. Pour commencer, exécutez Tools -> AGP Upgrade Assistant.

  3. Mise à jour des variables du projet Android : Dans votre fichier variables.gradle, mettez à jour vos valeurs aux nouveaux minimums suivants :

    minSdkVersion = 22
    compileSdkVersion = 33
    targetSdkVersion = 33
    androidxActivityVersion = '1.7.0'
    androidxAppCompatVersion = '1.6.1'
    androidxCoordinatorLayoutVersion = '1.2.0'
    androidxCoreVersion = '1.10.0'
    androidxFragmentVersion = '1.5.6'
    coreSplashScreenVersion = '1.0.0'
    androidxWebkitVersion = '1.6.1'
    junitVersion = '4.13.2'
    androidxJunitVersion = '1.1.5'
    androidxEspressoCoreVersion = '3.5.1'
    cordovaAndroidVersion = '10.1.1'
  4. Mise à jour des services Google :

    build.gradle
    dependencies {
    - classpath 'com.google.gms:google-services:4.3.13'
    + classpath 'com.google.gms:google-services:4.3.15'
    }
  5. Mise à jour du plugin Gradle vers 8.0.0 :

    build.gradle
    dependencies {
    - classpath 'com.android.tools.build:gradle:7.2.1'
    + classpath 'com.android.tools.build:gradle:8.0.0'
    }
  6. Mise à jour du wrapper Gradle vers 8.0.2 :

    gradle-wrapper.properties
    distributionBase=GRADLE_USER_HOME
    distributionPath=wrapper/dists
    - distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.2-all.zip
    + distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.2-all.zip
    zipStoreBase=GRADLE_USER_HOME
    zipStorePath=wrapper/dists
  7. Désactivation de Jetifier :

    gradle.properties
    android.useAndroidX=true
    - android.enableJetifier=true
  8. Déplacement du package vers build.gradle :

    AndroidManifest.xml
    <?xml version="1.0" encoding="utf-8"?>
    - <manifest xmlns:android="http://schemas.android.com/apk/res/android"
    - package="[YOUR_PACKAGE_ID]">
    + <manifest xmlns:android="http://schemas.android.com/apk/res/android">
    build.gradle
    android {
    + namespace "[YOUR_PACKAGE_ID]"
    compileSdkVersion rootProject.ext.compileSdkVersion
  9. Mise à jour de androidScheme : Dans Capacitor 6, https sera le paramètre par défaut pour androidScheme pour les applications existantes afin de mieux permettre aux applications Capacitor d’utiliser la fonction Autofill du système. Pour éviter la perte de données suite à ce changement, définissez le schéma sur http maintenant, même si c’est la valeur par défaut actuelle.

    {
    server: {
    androidScheme: "http"
    }
    }
  10. Mise à jour de la version Kotlin : Si votre projet utilise Kotlin, mettez à jour la variable kotlin_version à '1.8.20'.

Changements de fonctionnalité des plugins

Les fonctionnalités suivantes des plugins ont été modifiées ou supprimées. Mettez à jour votre code en conséquence :

  • Action Sheet
  • Browser
  • Camera
  • Device
  • Geolocation
  • Google Maps
  • Local Notifications
  • Push Notifications
  • Status Bar

Action Sheet

  • Mettez à jour la variable androidxMaterialVersion à 1.8.0.

Browser

  • Mettez à jour la variable androidxBrowserVersion à 1.5.0.

Camera

  • Pour Android 13, ajoutez la permission de lecture des images médias (<?xml version="1.0" encoding="utf-8"?>) dans AndroidManifest.xml.
  • Mettez à jour la variable androidxMaterialVersion à 1.8.0.
  • Mettez à jour la variable androidxExifInterfaceVersion à 1.3.6.

Device

  • Changez Device.id.uuid en Device.id.identifier.
  • Sur iOS 16+, Device.info.name renverra un nom d’appareil générique, sauf si vous ajoutez les droits appropriés.

Geolocation

  • Mettez à jour playServicesLocationVersion à 21.0.1.

Google Maps

  • Mettez à jour les variables suivantes :

    • googleMapsPlayServicesVersion à 18.1.0
    • googleMapsUtilsVersion à 3.4.0
    • googleMapsKtxVersion à 3.4.0
    • googleMapsUtilsKtxVersion à 3.4.0
    • kotlinxCoroutinesVersion à 1.6.4
    • androidxCoreKTXVersion à 1.10.0
    • kotlin_version à 1.8.20### Notifications locales
  • Pour Android 13, une nouvelle vérification d’autorisation d’exécution est nécessaire pour planifier des notifications locales lors du ciblage du SDK 33. Appelez checkPermissions() et requestPermissions() en conséquence.

Notifications push

  • Pour Android 13, une nouvelle vérification d’autorisation d’exécution est nécessaire pour recevoir des notifications push lors du ciblage du SDK 33. Appelez checkPermissions() et requestPermissions() en conséquence.
  • Mettez à jour la variable firebaseMessagingVersion à 23.1.2.

Barre d’état

  • Sur iOS, l’animation par défaut de la barre d’état a été modifiée pour FADE.

En suivant ces étapes et en mettant à jour votre code en conséquence, vous devriez maintenant avoir réussi à mettre à jour votre projet de Capacitor 4 vers Capacitor 5. Assurez-vous de tester votre application de manière approfondie pour vous assurer que toutes les fonctionnalités et les plugins fonctionnent comme prévu.

Authored By