Я установил на свой компьютер Cordova 7.0 и Ionic 3.4.0. Я создал собственный плагин с помощью plugman, и он имеет следующую структуру:
src - ios & android folders with the native files
www - .js file
plugin.xml
package.json
Добавление его в проект Ionic 2 (который использует cordova-ios 4.4.0) работает нормально, он генерируется должным образом, и я могу его использовать.
Теперь мне нужно добавить фреймворк Alamofire в качестве зависимости к моему плагину. Мне нужно, чтобы это обрабатывалось автоматически при установке плагина. Я видел из документации (Как добавить фреймворк как зависимость), что я должен добавить:
<framework src="GoogleCloudMessaging" type="podspec" spec="~> 1.2.0" />
К plugin.xml в настраиваемом плагине. Я добавил его, но когда я повторно добавляю плагин в проект ionic2, он не устанавливает также framework / pod.
Я видел другие темы, связанные с моей, но ни одна из них мне не помогает. Я все перепробовал, но не могу.
Кроме того, что-то странное с тегом из plugin.xml, согласно документации:
В паре с type = "podspec" это строка спецификации для CocoaPod, который вы хотите установить (только статическая библиотека). Поддержка CocoaPod существует только в cordova-ios 4.3.0 и cordova-cli 6.4.0. Убедитесь, что вы добавили в свой плагин соответствующие теги и зависимости package.json, чтобы обеспечить обратную совместимость.
Разве это не странно, подойдёт ли это на более новых версиях cordova-ios?
Плагин - содержимое package.json:
{
"name": "cordova-plugin-requestService",
"version": "1.0.0",
"author": "*******",
"private": true,
"engines": {
"cordovaDependencies": {
"1.0.0": { "cordova-ios": ">=4.4.0" }
}
}
}
содержимое plugin.xml:
<!-- iOS -->
<platform name="ios">
<dependency id="cordova-plugin-add-swift-support" version="^1.6.0" />
<framework src="Alamofire" type="podspec" spec="~> 4.4.0" />
<config-file target="config.xml" parent="/*">
<feature name="requestService">
<param name="ios-package" value="requestService" />
</feature>
</config-file>
<source-file src="src/ios/requestService.swift" />
</platform>