Dibandingkan dengan pembaruan sebelumnya, transisi dari Capacitor 4 ke Capacitor 5 melibatkan perubahan yang minimal. Panduan ini menyediakan instruksi langkah demi langkah untuk mengupdate proyek Anda ke Capacitor 5, serta daftar perubahan yang memecahkan plugin resmi.
Perhatian: Capacitor 5 memerlukan NodeJS 16 atau lebih tinggi, karena Node 12 telah mencapai akhir masa pakai dan Node 14 akan mencapai akhir masa pakai pada April 30th, 2023. Disarankan untuk menggunakan versi LTS terbaru dari NodeJS.
-
Pasang
latestversi dari Capacitor CLI di proyek Anda:npm i -D @capacitor/cli@latest -
Jalankan perintah berikut untuk membiarkan CLI mengelola migrasi:
npx cap migrateJika ada langkah migrasi yang tidak dapat dicapai, informasi tambahan akan disediakan dalam output terminal. Langkah migrasi manual tercantum di bawah ini.
-
Jika Anda memiliki ekstensi VS Code terinstal, periksa bagian rekomendasi ekstensi untuk menemukan opsi untuk memigrasikan proyek Anda ke Capacitor 5.
Mengupgrade Capacitor 4 Proyek iOS ke Capacitor 5
-
Upgrade XcodeCapacitor 5 memerlukan Xcode 14.1+.
-
Update .gitignoreJika Anda ingin mengupdate __CAPGO_KEEP_0__
.gitignorefile:- App/Podfile.lock + App/output -
Update Assets untuk menggunakan ikon aplikasi tunggal: Xcode 14 mendukung ikon aplikasi tunggal berukuran 1024x1024. Bersihkan AppIcon.appiconset Anda dengan menghapus semua ukuran yang tidak perlu.
Mengupgrade Capacitor 4 Proyek Android ke Capacitor 5
-
Upgrade Android Studio: Capacitor 5 memerlukan Android Studio Flamingo | 2022.2.1 atau lebih baru karena penggunaan Gradle 8, yang memerlukan Java JDK 17. Java 17 dilengkapi dengan Android Studio Flamingo, sehingga tidak perlu download tambahan.
-
Jalankan Asisten Upgrade AGP: Android Studio dapat membantu dengan beberapa update terkait Gradle dan memindahkan paket ke file build. Untuk memulai, jalankan
Tools -> AGP Upgrade Assistant. -
Perbarui Variabel Proyek Android: Dalam file Anda, perbarui nilai-nilai Anda ke minimum baru sebagai berikut:
variables.gradlePerbarui Layanan GoogleminSdkVersion = 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' -
Perbarui Plugin Gradle ke 8.0.0:
# build.gradle dependencies { - classpath 'com.google.gms:google-services:4.3.13' + classpath 'com.google.gms:google-services:4.3.15' } -
Perbarui Penggabung Gradle ke 8.0.2:
# build.gradle dependencies { - classpath 'com.android.tools.build:gradle:7.2.1' + classpath 'com.android.tools.build:gradle:8.0.0' } -
Nonaktifkan Jetifier:
# 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 -
Mengupgrade __CAPGO_KEEP_1__ 5:
# gradle.properties android.useAndroidX=true - android.enableJetifier=true -
Pindahkan paket ke
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 -
Update androidScheme: Di Capacitor 6,
httpsakan menjadi pengaturan default untukandroidSchemeuntuk aplikasi yang sudah ada untuk memungkinkan aplikasi Capacitor menggunakan fitur Autofill sistem. Untuk menghindari kehilangan data akibat perubahan ini, atur scheme kehttpsaat ini, bahkan jika itu sudah menjadi pengaturan default sekarang.{ server: { androidScheme: "http" } } -
Update versi Kotlin: Jika proyek Anda menggunakan Kotlin, update
kotlin_versionke'1.8.20'.
Perubahan Fungsi Plugin
Fungsi plugin berikut telah diubah atau dihapus. Perbarui code Anda sesuai:
- Action Sheet
- Pengguna Browser
- Kamera
- Perangkat
- Lokasi Geografis
- Peta Google
- Pemberitahuan Lokal
- Pemberitahuan Push
- Balkong Status
Tangkapan Aksi
- Perbarui
androidxMaterialVersionvariabel ke1.8.0.
Pengguna Browser
- Perbarui variabel ke
androidxBrowserVersionuntuk Camera1.5.0.
Untuk Android 13, tambahkan izin membaca gambar media (
- ) di
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES"/>Perbarui variabel keAndroidManifest.xml. - untuk Camera
androidxMaterialVersionPerbarui variabel ke1.8.0. - untuk Camera
androidxExifInterfaceVersionPerangkat1.3.6.
Ubah ke
- ke
DeviceId.uuidkeDeviceId.identifier. - Pada iOS 16+
DeviceInfo.nameakan mengembalikan nama perangkat umum kecuali Anda menambahkan hak istimewa yang tepat Hak Istimewa Geolocation.
Lokasi
- Perbarui ke
playServicesLocationVersionGoogle Maps21.0.1.
Perbarui variabel-variabel berikut:
- ke
googleMapsPlayServicesVersionke18.1.0.googleMapsUtilsVersionke3.4.0.googleMapsKtxVersionke3.4.0.googleMapsUtilsKtxVersionke3.4.0.kotlinxCoroutinesVersionke1.6.4.androidxCoreKTXVersionke1.10.0.kotlin_versionke1.8.20.
Pemberitahuan Lokal
- Untuk Android 13, perlu dilakukan pengecekan izin runtime baru untuk mengatur pemberitahuan lokal ketika menghadap SDK 33. Panggil
checkPermissions()danrequestPermissions()sesuai.
Pemberitahuan Push
- Untuk Android 13, perlu dilakukan pengecekan izin runtime baru untuk menerima pemberitahuan push ketika menghadap SDK 33. Panggil
checkPermissions()danrequestPermissions()sesuai. - Perbarui
firebaseMessagingVersionvariabel untuk23.1.2.
Status Bar
- Pada iOS, animasi status bar bawaan telah berubah menjadi
FADE.
Dengan mengikuti langkah-langkah ini dan memperbarui code Anda sesuai, Anda seharusnya sudah berhasil memperbarui proyek Anda dari Capacitor 4 ke Capacitor 5. Pastikan untuk menguji aplikasi Anda secara menyeluruh untuk memastikan bahwa semua fitur dan plugin berfungsi seperti yang diharapkan.