Saltar al contenido principal

Cómo agregar dependencias en plugins Capacitor

Aprenda a gestionar las dependencias de manera eficiente en plugins Capacitor a través de plataformas con pasos prácticos y mejores prácticas.

Martin Donadieu

Martin Donadieu

Gerente de Contenido

Cómo agregar dependencias en plugins Capacitor

Agregar dependencias a __CAPGO_KEEP_0__ Cómo agregar dependencias a plugins Capacitor Los plugins pueden sentirse abrumadores, pero es más fácil cuando se dividen en pasos claros. Aquí está lo que necesita saber:

  1. Entienda las herramientas:

    • JavaScript: Utilice npm para gestionar dependencias.
    • iOS: Utilice CocoaPods o Swift Package Manager (SPM).
    • Android: Utilice Gradle para el manejo de dependencias.
  2. Configura tu entorno de desarrollo:

  3. Inicia tu Capacitor proyecto de plugin:

    • Utiliza npm init @capacitor/plugin para crear un nuevo plugin.
  4. Agregar dependencias de JavaScript:

    • Utilice npm install para dependencias de producción y desarrollo.
    • Actualizar package.json para incluir dependencias de pares como @capacitor/core.
  5. Gestionar dependencias específicas de plataforma:

    • iOS: Configure CocoaPods o SPM con bibliotecas como Alamofire o SwiftyJSON.
    • Android: Utilice Gradle para agregar dependencias como Gson o AppCompat.
  6. Mejora de rendimiento:

    • Pin versions, audit dependencies, y resuelve conflictos para garantizar la estabilidad.
  7. Use herramientas como Capgo para actualizaciones en vivo:

    • Actualiza instantáneamente sin revisiones de la tienda de aplicaciones.

Comparación rápida de herramientas:

PlataformaHerramientaEjemplo de dependencia
JavaScriptnpmnpm install lodash --save
iOSCocoaPods/SPMpod 'Alamofire', '~> 5.6.4'
AndroidGradleimplementation 'com.google.code.gson:gson:2.10.1'

¿Por qué importa?: Gestiona las dependencias de manera efectiva para que tu plugin funcione sin problemas en varias plataformas, ahorre tiempo y evite errores. Vamos a profundizar en los pasos.

Cómo crear un Capacitor plugin para iOS/Android

Capacitor Documentación del marco de trabajo del sitio web

Configuración de su Entorno de Desarrollo

Prepare su configuración con las herramientas necesarias para manejar Capacitor plugin las dependencias de manera efectiva.

Herramientas de Desarrollo Requeridas

Aquí tienes una lista de herramientas que necesitarás:

HerramientaVersiónPropósito
Node.js16.0.0+Entorno de ejecución de JavaScript
npm8.0.0+Gestión de paquetes
Xcode14.0+Desarrollo de iOS (solo para Mac)
Android StudioElectric Eel+Desarrollo de Android
CocoaPods1.11.0+Gestión de dependencias de iOS
JDK11+Herramientas de compilación de Android

Iniciando un Nuevo Plugin

Use los Capacitor CLI para iniciar su proyecto de plugin. Esto incluye la configuración de plataformas y el nombre de su plugin utilizando un formato de dominio inverso (por ejemplo, com.mycompany.plugin):

  1. Ejecuta el siguiente comando:
    npm init @capacitor/plugin
  2. Elige tus plataformas objetivo (iOS/Android).
  3. Asigna un nombre a tu plugin en formato de dominio inverso.

Pasos de configuración del proyecto

  1. Actualizar package.json

    Modifica package.json para que incluya lo siguiente:

    {
      "capacitor": {
        "ios": {
          "src": "ios"
        },
        "android": {
          "src": "android"
        }
      },
      "peerDependencies": {
        "@capacitor/core": "^5.0.0"
      }
    }
  2. Configuración específica de plataforma

    • Para iOS, asegúrate de que tu archivo Podfile incluya:

      platform :ios, '13.0'
      use_frameworks!
    • Para Android, verifica tu build.gradle contiene:

      android {
          compileSdkVersion 33
          defaultConfig {
              minSdkVersion 22
          }
      }
  3. Configura las siguientes variables de entorno para tus herramientas de desarrollo:

    Variable

    PropósitoValor de ejemploANDROID_HOME
    Ubicación de Android __CAPGO_KEEP_0__/Users/username/Library/Android/SDK/Users/username/Library/Android/sdk
    Configura JAVA_HOMERuta de instalación de JDK/Library/Java/JavaVirtualMachines/jdk-11.0.12.jdk/Contents/Home
    XCODE_SELECTHerramientas de línea de comandos de Xcode/Applications/Xcode.app/Contents/Developer

Una vez que su proyecto esté configurado, está listo para pasar a la gestión de dependencias de JavaScript.

Dependencias de JavaScript

La gestión efectiva de dependencias de JavaScript es clave para mantener el rendimiento estable de los complementos.

npm Instalación de paquetes

npm

Para instalar dependencias, utilice los siguientes comandos:

# Add a production dependency
npm install lodash --save

# Add a development dependency
npm install @types/lodash --save-dev

Asegúrese de incluir manualmente las dependencias de pares en su archivo. package.json Pruebe todas las dependencias para confirmar la compatibilidad en ambas plataformas web y nativas.

Gestionar package.json

Aquí hay un ejemplo package.json Configuración:

{
  "name": "my-capacitor-plugin",
  "version": "1.0.0",
  "dependencies": {
    "lodash": "^4.17.21"
  },
  "devDependencies": {
    "@types/lodash": "^4.14.195",
    "@capacitor/core": "^5.0.0"
  },
  "peerDependencies": {
    "@capacitor/core": "^5.0.0"
  }
}

Para mantener la consistencia, bloquee las versiones de las dependencias de manera adecuada:

Tipo de restricciónEjemploUso
Exacto”5.0.0”Para dependencias críticas que requieren una versión específica
Caret”^5.0.0”Permite actualizaciones menores y parches
Tilde”~5.0.0”Usando bibliotecas de JavaScript

Cuando importas bibliotecas, enfócate en reducir el tamaño del paquete:

Además, asegúrate de tener un manejo de errores y comprobación de tipos adecuados:

// Import only the required function
import { isEqual } from 'lodash';

export class MyPlugin {
  async compare(options: { value1: any, value2: any }): Promise<boolean> {
    return isEqual(options.value1, options.value2);
  }
}

A continuación, explora cómo manejar dependencias específicas de plataforma para iOS.

import { Plugin } from '@capacitor/core';
import { validate } from 'your-validation-library';

@Plugin({
  name: 'MyPlugin',
  platforms: ['web', 'ios', 'android']
})
export class MyPlugin {
  async validateData(data: unknown): Promise<void> {
    try {
      if (!validate(data)) {
        throw new Error('Invalid data format');
      }
      // Continue processing if valid
    } catch (error) {
      throw new Error(`Validation failed: ${error.message}`);
    }
  }
}

Dependencias de iOS

Esta sección explica cómo gestionar dependencias nativas de iOS en

__CAPGO_KEEP_0__ plugins Capacitor pluginsCocoaPods

Permite actualizaciones menores y parches Configuración

CocoaPods

Comience inicializando CocoaPods en su directorio de iOS:

cd ios
pod init

Luego, actualice su Plugin.podspec archivo con las siguientes configuraciones:

Pod::Spec.new do |s|
  s.name = 'MyCapacitorPlugin'
  s.version = '1.0.0'
  s.summary = 'Your plugin description'
  s.platform = :ios, '13.0'
  s.dependency 'Capacitor'
  # Include your iOS dependencies here
  s.dependency 'Alamofire', '~> 5.6.4'
end

Configuración de Podfile

Después de inicializar CocoaPods, configure el archivo Podfile para incluir Capacitor y cualquier biblioteca de terceros adicional:

platform :ios, '13.0'
use_frameworks!

def capacitor_pods
  pod 'Capacitor', :path => '../../node_modules/@capacitor/ios'
  pod 'CapacitorCordova', :path => '../../node_modules/@capacitor/ios'
end

target 'Plugin' do
  capacitor_pods
  # Add third-party dependencies
  pod 'KeychainAccess', '~> 4.2.2'
  pod 'SwiftyJSON', '~> 5.0.1'
end

target 'PluginTests' do
  capacitor_pods
end

Aquí hay algunos patrones de configuración de dependencias comunes:

Tipo de RestricciónEjemploUso
Versión Exactapod 'KeychainAccess', '4.2.2'Cuando se necesita un control preciso, como para componentes de seguridad
Versión Menorpod 'Alamofire', '~> 5.6'Para APIs establecidas que pueden recibir actualizaciones de parche
Versión Mayorpod 'SwiftyJSON', '> 5.0'Cuando se acepta la flexibilidad a lo largo de las actualizaciones

Dependencias de Paquetes Swift

Si prefieres no usar CocoaPods, Swift Package Manager (SPM) es una buena alternativa. Agrega dependencias de SPM directamente en Xcode con la siguiente configuración en tu Package.swift archivo:

// Package.swift
dependencies: [
    .package(url: "https://github.com/Alamofire/Alamofire.git", .upToNextMajor(from: "5.6.4")),
    .package(url: "https://github.com/SwiftyJSON/SwiftyJSON.git", from: "5.0.1")
]

Para usar dependencias de SPM en tu plugin code, importa y integra según sea necesario. Por ejemplo:

import Capacitor
import Alamofire

@objc(MyPlugin)
public class MyPlugin: CAPPlugin {
    @objc func makeRequest(_ call: CAPPluginCall) {
        AF.request("https://api.example.com/data").response { response in
            // Process the response
            call.resolve([
                "data": response.data
            ])
        }
    }
}

Esta aproximación te permite elegir entre CocoaPods y Swift Package Manager según las necesidades de tu proyecto

Dependencias de Android

Configura las dependencias de Android para garantizar una integración nativa suave. Aquí's cómo gestionar dependencias para tu plugin Capacitor

Gradle Dependencias

Gradle Build Tool Interface

Agregue las siguientes configuraciones a su build.gradle archivo:

android {
    defaultConfig {
        minSdkVersion 22
        targetSdkVersion 33
    }
}

dependencies {
    implementation "androidx.appcompat:appcompat:1.6.1"
    implementation "com.google.code.gson:gson:2.10.1"
    implementation "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
    implementation project(':capacitor-android')
}

Defina versiones adicionales en el buildscript bloque:

buildscript {
    ext {
        androidxCoreVersion = '1.10.1'
        kotlinVersion = '1.8.20'
    }
}

Una vez configuradas las dependencias, asegúrese de configurar los repositorios necesarios.

Configuración de Repositorio

En su nivel de proyecto build.gradle, incluya los repositorios Maven requeridos:

allprojects {
    repositories {
        google()
        mavenCentral()
        maven { url "https://jitpack.io" }
    }
}

Si está utilizando repositorios Maven personalizados o privados, agregue credenciales de la siguiente manera:

maven {
    url "https://maven.example.com/releases"
    credentials {
        username = project.findProperty("mavenUsername") ?: System.getenv("MAVEN_USERNAME")
        password = project.findProperty("mavenPassword") ?: System.getenv("MAVEN_PASSWORD")
    }
}

Con los repositorios configurados, aborde cualquier conflicto de dependencias que pueda surgir.

Resolviendo Problemas de Compatibilidad

Para manejar conflictos de dependencias, aplique resoluciones de versiones en su build.gradle:

configurations.all {
    resolutionStrategy {
        force "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
        force "androidx.core:core-ktx:1.10.1"
    }
}

Aquí hay estrategias para resolver problemas de dependencias comunes:

Tipo de problemaEstrategiaEjemplo
Conflicto de versiónForzar una versión específicaforce 'com.google.code.gson:gson:2.10.1'
Versión múltipleExcluir un móduloexclude group: 'org.json', module: 'json'
Problemas transitoriosUse versiones estrictasstrictly 'androidx.core:core-ktx:1.10.1'

Por ejemplo, puedes excluir módulos conflictivos de esta manera:

dependencies {
    implementation('library:name:1.0.0') {
        exclude group: 'com.conflicting.dependency'
    }
}

Finalmente, optimiza tu proceso de compilación habilitando la caché y la ejecución en paralelo en gradle.properties:

org.gradle.caching=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx2048m

Capgo Integración

Capgo Dashboard de Actualización en Vivo Interface

Usar Capgo junto con la gestión de dependencias nativas y de JavaScript hace que actualizar tu plugin sea más rápido y fácil.

Sobre Capgo

Capgo es una plataforma de actualización en vivo diseñada para plugins y aplicaciones Capacitor. Con más de 23,5 millones de actualizaciones entregadas en 750 aplicaciones de producción [1], Capgo permite a los desarrolladores enviar actualizaciones para dependencias y code de manera instantánea - sin necesidad de revisión de la tienda de aplicaciones. Las actualizaciones están seguras con cifrado de extremo a extremo y cumplen con los estándares de cumplimiento de Apple y Android.

Características de actualización de Capgo

Capgo simplifica la gestión de dependencias de plugins con estas características:

Característica¿Qué hace?Métrica clave
Actualizaciones en vivoEnvía actualizaciones en minutos95% de tasa de actualización de usuarios en 24 horas
Actualizaciones parcialesDescarga solo archivos modificados434ms tiempo de respuesta promedio API
Control de versionesAdministra varias versiones82% de tasa de éxito global
Sistema de canalesDirigirse a grupos de usuarios específicosSoporta múltiples canales de despliegue

Fuente: [1]

Capgo funciona de manera fluida con herramientas de CI/CD como GitHub Actions, GitLab CI y Jenkins, automatizando actualizaciones de dependencias y asegurando versiones consistentes de plugins. Estas herramientas facilitan la integración de Capgo en tu flujo de trabajo.

Configuración de Capgo

Sigue estos pasos para integrar Capgo en tu proyecto:

  1. Instala el Capgo CLI

    Ejecuta el siguiente comando en tu terminal:

    npx @capgo/cli init
  2. Configuración de Preferencias de Actualización

    Utiliza la consola de Capgo para configurar canales de despliegue y preferencias. Se admiten tanto configuraciones alojadas en la nube como autoalojadas.

  3. Agregar Lógica de Actualización

    Agregue este code a su archivo principal de plugin para habilitar actualizaciones:

    import { Capgo } from '@capgo/capacitor-updater';
    
    // Initialize Capgo
    const capgo = new Capgo({
      appId: 'YOUR_APP_ID',
      channel: 'production'
    });
    
    // Check for updates
    await capgo.checkForUpdate();

“La práctica de desarrollo ágil y @Capgo es crucial para entregar de manera continua a nuestros usuarios!” - Rodrigo Mantica

Capgo también proporciona una consola de análisis para obtener información en tiempo real sobre las tasas de éxito de las actualizaciones y la actividad de los usuarios. Características como el deshacer clic en una sola acción y el seguimiento de errores ayudan a resolver cualquier problema rápidamente, manteniendo las actualizaciones de su plugin funcionando suavemente.

Conclusión

Revisión del Proceso

El manejo de dependencias para los plugins Capacitor implica alinear los componentes nativos (iOS y Android) con sus contrapartes de JavaScript para asegurar una integración suave. Este proceso incluye configuraciones específicas de plataforma y el manejo de paquetes de JavaScript para lograr el mejor rendimiento. Siguendo los pasos indicados ayudará a mantener la funcionalidad del plugin estable y eficiente.

Prácticas recomendadas

Para gestionar las dependencias de manera efectiva, considere estas prácticas:

PrácticaBeneficioCómo implementar
Pin de versiónEvita problemas inesperadosUtiliza versiones fijas en package.json
Aislamiento de plataformaMinimiza conflictosDependencias nativas separadas
Actualizaciones regularesMejora la seguridadAplica parches críticos con prontitud
Auditoría de dependenciasDetecta riesgosEjecuta npm audit con frecuencia

Usando herramientas de actualización en vivo como Capgo puede simplificar aún más y mejorar estas prácticas habilitando actualizaciones en tiempo real.

Capgo Beneficios

Capgo simplifica el proceso de gestión de dependencias mientras ofrece una excelente rendimiento. Logra una impresionante tasa de actualización de usuarios del 95% en 24 horas y mantiene un tiempo de respuesta global de API de 434ms [1]. Con cifrado de extremo a extremo, garantiza actualizaciones seguras que cumplen con las directrices tanto de Apple como de Android. Para equipos que gestionan varias versiones de complementos, el sistema de canales de Capgo permite despliegues dirigidos para grupos de usuarios específicos.

Aquí hay una visión rápida del rendimiento de Capgo:

MétricaValor
Tiempo de respuesta global de API434ms
Tasa de Actualización Exitosa82%
Tasa de Actualización de Usuarios (24 Horas)95%
Actualizaciones en vivo para aplicaciones Capacitor

Cuando un error en la capa web está activo, envíe la corrección a través de Capgo en lugar de esperar días para la aprobación de la tienda de aplicaciones. Los usuarios reciben la actualización en segundo plano mientras los cambios nativos siguen en el camino de revisión normal.

Comience ahora

Últimas noticias de nuestro Blog

Capgo te brinda las mejores perspectivas que necesitas para crear una aplicación móvil verdaderamente profesional.