fix(windows): Fixes ScriptNotify and InvokeScript (#1354 by @benhamlin)
[skip ci]
This commit is contained in:
parent
b10b97646b
commit
81e0360ede
|
@ -97,7 +97,7 @@ namespace winrt::ReactNativeWebView::implementation {
|
||||||
eventDataWriter.WriteObjectEnd();
|
eventDataWriter.WriteObjectEnd();
|
||||||
});
|
});
|
||||||
|
|
||||||
winrt::hstring windowAlert = L"window.alert = function (msg) {window.external.notify(`{\"type\":\"alert\",\"message\":\"${msg}\"}`)};";
|
winrt::hstring windowAlert = L"window.alert = function (msg) {window.external.notify(`{\"type\":\"__alert\",\"message\":\"${msg}\"}`)};";
|
||||||
winrt::hstring postMessage = L"window.ReactNativeWebView = {postMessage: function (data) {window.external.notify(String(data))}};";
|
winrt::hstring postMessage = L"window.ReactNativeWebView = {postMessage: function (data) {window.external.notify(String(data))}};";
|
||||||
m_webView.InvokeScriptAsync(L"eval", { windowAlert + postMessage });
|
m_webView.InvokeScriptAsync(L"eval", { windowAlert + postMessage });
|
||||||
}
|
}
|
||||||
|
@ -119,15 +119,16 @@ namespace winrt::ReactNativeWebView::implementation {
|
||||||
|
|
||||||
void ReactWebView::OnScriptNotify(winrt::IInspectable const& /*sender*/, winrt::Windows::UI::Xaml::Controls::NotifyEventArgs const& args) {
|
void ReactWebView::OnScriptNotify(winrt::IInspectable const& /*sender*/, winrt::Windows::UI::Xaml::Controls::NotifyEventArgs const& args) {
|
||||||
winrt::JsonObject jsonObject;
|
winrt::JsonObject jsonObject;
|
||||||
if (winrt::JsonObject::TryParse(args.Value(), jsonObject)) {
|
if (winrt::JsonObject::TryParse(args.Value(), jsonObject) && jsonObject.HasKey(L"type")) {
|
||||||
auto type = jsonObject.GetNamedString(L"type");
|
auto type = jsonObject.GetNamedString(L"type");
|
||||||
if (type == L"alert") {
|
if (type == L"__alert") {
|
||||||
auto dialog = winrt::MessageDialog(jsonObject.GetNamedString(L"message"));
|
auto dialog = winrt::MessageDialog(jsonObject.GetNamedString(L"message"));
|
||||||
dialog.Commands().Append(winrt::UICommand(L"OK"));
|
dialog.Commands().Append(winrt::UICommand(L"OK"));
|
||||||
dialog.ShowAsync();
|
dialog.ShowAsync();
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
m_reactContext.DispatchEvent(
|
m_reactContext.DispatchEvent(
|
||||||
m_webView,
|
m_webView,
|
||||||
L"topMessage",
|
L"topMessage",
|
||||||
|
@ -139,6 +140,5 @@ namespace winrt::ReactNativeWebView::implementation {
|
||||||
eventDataWriter.WriteObjectEnd();
|
eventDataWriter.WriteObjectEnd();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace winrt::ReactNativeWebView::implementation
|
} // namespace winrt::ReactNativeWebView::implementation
|
|
@ -116,6 +116,7 @@ namespace winrt::ReactNativeWebView::implementation {
|
||||||
FrameworkElement const& view,
|
FrameworkElement const& view,
|
||||||
int64_t commandId,
|
int64_t commandId,
|
||||||
winrt::IJSValueReader const& commandArgsReader) noexcept {
|
winrt::IJSValueReader const& commandArgsReader) noexcept {
|
||||||
|
auto commandArgs = JSValue::ReadArrayFrom(commandArgsReader);
|
||||||
if (auto webView = view.try_as<winrt::WebView>()) {
|
if (auto webView = view.try_as<winrt::WebView>()) {
|
||||||
switch (commandId) {
|
switch (commandId) {
|
||||||
case static_cast<int64_t>(WebViewCommands::GoForward) :
|
case static_cast<int64_t>(WebViewCommands::GoForward) :
|
||||||
|
@ -135,7 +136,7 @@ namespace winrt::ReactNativeWebView::implementation {
|
||||||
webView.Stop();
|
webView.Stop();
|
||||||
break;
|
break;
|
||||||
case static_cast<int64_t>(WebViewCommands::InjectJavaScript) :
|
case static_cast<int64_t>(WebViewCommands::InjectJavaScript) :
|
||||||
webView.InvokeScriptAsync(L"eval", { commandArgsReader.GetString() });
|
webView.InvokeScriptAsync(L"eval", { winrt::to_hstring(commandArgs[0].AsString()) });
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue