Мне нужно создать плагин, чтобы перехватывать события, происходящие в Cordova webView моего приложения iOS, и запускать действия в собственной части приложения, и наоборот.
Я следил за этим руководством, и оно отлично работает .
Когда я пытаюсь адаптировать его к другому приложению (я хотел, чтобы оно было более общим, чем учебник), оно работает из веб-представления в нативную часть, но не наоборот.
Я просто пытаюсь нажать кнопку на панели навигации, чтобы изменить цвет фона моего веб-представления. На данный момент кажется, что код javascript плагина не получает событие, потому что отображаются только логи iOS.
Весь мой код находится в XCode, поэтому я не вижу никаких предупреждений/ошибок в веб-части.
Вот часть плагина для iOS:
@interface HybridBridge()
@property (nonatomic, retain) NSString *listenerCallbackId;
@end
@implementation HybridBridge
-(void)bindAction:(CDVInvokedUrlCommand*) command{
self.listenerCallbackId = command.callbackId;
CDVPluginResult *pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK];
[pluginResult setKeepCallbackAsBool:true];
[self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
}
-(void)reportEvent:(NSDictionary*)eventData{
CDVPluginResult *pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK messageAsDictionary:eventData];
[pluginResult setKeepCallbackAsBool:true];
[self.commandDelegate sendPluginResult:pluginResult callbackId:self.listenerCallbackId];
}
Вот часть javascript плагина:
var HybridBridge = (function() {
var PLUGIN_NAME = "HybridBridge";
var ACTION_BIND_LISTENER = "bindAction";
this.bindListener = function(listener) {
cordova.exec(listener, listener, PLUGIN_NAME, ACTION_BIND_LISTENER, []);
};
return this;
}());
Вот прослушиватель событий javascript:
var NativeEventsListener = (function() {
this.onReceivedEvent = function(eventData) {
var eventHandler = function(){};
switch (eventData.eventType){
case "colorButtonClicked":
eventHandler = colorButtonClickEvent;
break;
default:
}
eventHandler(eventData);
};
function colorButtonClickEvent(eventData){
changeBackgroundColor(eventData.color);
}
function changeBackground(color) {
document.body.style.background = color;
}
return this;
}());
Вот файл main.js, в котором можно привязать прослушиватель событий к плагину:
function wlCommonInit(){
HybridBridge.bindListener(NativeEventsListener.onReceivedEvent);
}
function wlEnvInit(){
wlCommonInit();
}
И, наконец, вот вызов плагина в Objective-C:
- (IBAction)changeWebPageColor {
redColor = !redColor;
NSString *color = redColor ? @"red" : @"white";
HybridBridge *bridge = [self.pluginObjects objectForKey:@"HybridBridge"];
NSDictionary *eventData = [NSDictionary dictionaryWithObjectsAndKeys:
@"colorButtonClicked", @"eventType",
color, @"color",
nil];
[bridge reportEvent:eventData];
}
Спасибо за помощь!