Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

inject Javascript to GeckoView #27

Open
Theeyn opened this issue Mar 4, 2022 · 3 comments
Open

inject Javascript to GeckoView #27

Theeyn opened this issue Mar 4, 2022 · 3 comments

Comments

@Theeyn
Copy link

Theeyn commented Mar 4, 2022

hi,
How to call with this script?
"javascript:(function() { document.getElementsByClassName('sqdOP')[1].click(); })()"

I have this solution: (But I do not understand)
You can use the WebExtension API to inject javascript into pages, please follow this guide: mozilla.github.io/geckoview/consumer/docs/web-extensions

@Daddoon
Copy link
Owner

Daddoon commented Mar 6, 2022

I'm not sure you can do this on the current GeckoView bindings. The current GeckoView API is pretty old, and i'm not sure theses kind of things were available. I may be wrong. Can you try to find a documentation of GeckoView 67 API ?

@Theeyn
Copy link
Author

Theeyn commented Mar 12, 2022

Thank you for your answer
Unfortunately I didn't find anything and completely gave up. I continue using webview.

@Daddoon
Copy link
Owner

Daddoon commented Mar 12, 2022

On my, now legacy project BlazorMobile, as i was unable to directly call Javascript code through a read-to-use helper, i used two kinds of mecanism with GeckoView, but the usage depend if you are in control or partially in control the app you are rendering.

One way was to expose a little webserver locally on the phone through embed.io package (https://unosquare.github.io/embedio/) , and then, when your web app load , manage it to connect through Websocket to a Websocket endpoint you would have exposed on the phone. This way you would have a bidirectional communication available to do whatever you want, and so, implement your own behavior logic on web-end / internal end.

That was the way i used in order to call code from Blazor Web to native device, and then return datas when things finished processing.

There was also another tricky way to catch some Web page events i used: You can actually load WebExtensions in GeckoView ! For my needs, i developped a mini WebExtension that fire an event when a Navigation or iFrame Navigation occur (so a possible page change or page load), respectively, frame and sub_frame from a webextension point of view.

When i needed to validate if the navigation should occur on the page from the native side logic, i juste forwarded the event through a Http endpoint on the device (still thanks to embed.io) , and when the result returned, i just validated or denied the behavior of the page from the WebExtension event i was still in.

But yes, in the current stage, there is no "direct" way to call the web end.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants