-
Notifications
You must be signed in to change notification settings - Fork 131
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
Proposal 0001 - Extract WebView From Core #3
Proposal 0001 - Extract WebView From Core #3
Conversation
proposals/0001-template.md
Outdated
|
||
## Motivation | ||
|
||
The current WebView implementation is (to my knowledge) not used by Facebook internally. This leads (understandably) to a lack of first-class support for this core API. By moving the component to a third party that is more invested in supporting it, there will be better support. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually, we do use WebView internally, but have not been maintaining it as much. However, I still believe that it makes sense if the community maintains it, since the number of PRs/Issues in the community are possibly higher.
This comment was marked as spam.
This comment was marked as spam.
Sorry, something went wrong.
This comment was marked as spam.
This comment was marked as spam.
Sorry, something went wrong.
This comment was marked as spam.
This comment was marked as spam.
Sorry, something went wrong.
proposals/0001-template.md
Outdated
|
||
For the first release, the goal is to provide the same API, only replacing the import statement and otherwise backwards compatible. | ||
|
||
We will also want to update generated project boilerplates, such as create-react-native-app and Ignite, to use the new package. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we do it in the first add more features/bigs and then look at a replacement ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm definitely open to that. I mainly wanted to keep the surface area of the change smaller for those who have to migrate their existing apps.
proposals/0001-template.md
Outdated
|
||
## Unresolved questions | ||
|
||
None so far. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we also need to talk about how we move existing bugs and PRs over to the new location ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right, I'll add that.
proposals/0001-template.md
Outdated
This would move it to an external package, like so: | ||
|
||
```jsx | ||
import { WebView } from '@infinitered/react-native-webview'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What should be the right source ? Should this be in infinitered, or should it be in react-native-community ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm open to react-native-community, but am more motivated to devote my company resources toward it if it lives in infinitered
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
packages get handed off as companies/individuals either lose interest in a tool, close their doors, no longer want to maintain the package itself, the primary maintainer moves to another organization, or a handful of other reasons. this has downstream consequences - for example, if react-native-maps was scoped under @airbnb
on npm, we'd be stuck with that or have to force consumers to change their imports and package.json just because of a change in project maintainer structure.
I understand your concern about wanting to get some return for the time you invest, but I think there are better ways we can do this than brand the package name itself.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@brentvatne Thanks for the feedback. I've removed the namespace and went with just react-native-webview
.
To give some extra context:
|
I'm personally not a fan of moving My reasoning builds on two things: 1) There are a lot of small useful modules which uses WebView behind the scenes for things to work. Some quick examples are If we move Having dependencies on modules that requires manual setup provides a very poor user experience for your users. You basically have to duplicate the other library's setup instructions in your own readme, and hope that the users are paying attention. Until React Native has a way to import native dependencies which require zero input from the user (kind of like how prebuilt native modules works in Node.js) I don't think it's a good idea to move this out. and also 2) there is nothing stopping anyone from developing a user-land Just my 2¢ |
I should read other comments first. I'm onboard with @LinusU here! |
There have been a few user-land WebView implementations, and we've used them at Infinite Red (they're not bad). As long as there's an "official" one, though, it'll get the benefit of being the default (like how Apple Maps has higher usage on iPhones than Google Maps, despite the latter being generally better). I'm open to this discussion, for sure, but just want to point out that so far, none of the other webviews have attracted enough attention to become the overwhelming favorite. |
There are a number of user-land WebView implementations out there. On iOS, react-native-wkwebview has a clear mission statement (UIWebView deprecation) that makes it an obvious alternative. The landscape isn't so clear on Android, where there's: react-native-webview-android, react-native-webview-file-upload-android, react-native-advanced-android-webview, react-native-custom-android-webview - and likely more I'm omitting - each of which describe a very specific feature (e.g. file upload) as their goal. Perhaps the Android landscape shows that there aren't significant issues preventing use of the built-in WebView for most purposes, but it's clear that a user-land implementation hasn't been able to prove itself on Android. The combination of a clear - and well established - alternative on iOS and the lack of one on Android makes it very unlikely that a user-land cross-platform alternative will prove itself enough to replace the built-in version.
Does |
I think the goal here is to enable a WebView that is maintained and supported well. I am agnostic to picking any existing community packages, or creating a new one, as long it is well maintained and owned in the community. I think that we have not been able to give web views enough attention, and thats the reason I would like use to move this out. Regarding other modules depending on WebView - I think we don't have a story for React-native modules depending on each other. Folks from Artsy were working on a proposal for better |
The Right now, if the module depends solely on its own files and contains no extraneous native dependencies, things work just fine. We also support the use of Cocoapods. On Android, this is not an issue since Gradle is a preferred build tool. The need of linking the module itself shouldn't be an issue since I guess everyone got used to this process over time already. |
I think you are underestimating the impact this proposal would have on existing source bases. Many apps, RN extensions, and shared components make use of RN.WebView, and this change will break all of them. I strongly urge you to reconsider this. |
It's not going to happen without a deprecation path. And most the current |
Deprecation of core components and features results in varying degrees of pain for those who have built code on top of the existing RN core. Breaking changes like this shouldn't be done cavalierly, even if there is a well-articulated deprecation path. This one would be quite painful for developers who have built apps using ReactXP. I appreciate that there are times when breaking changes are needed to move the platform forward, but this doesn't seem like one of them. The reasons provided above don't appear to justify the pain. Why not continue to support RN.WebView and switch over to WKWebView on iOS? Are there any good technical reasons? |
That's exactly the problem. The core team doesn't support the WebView components and has other high priority tasks, so it's not going to change very soon. There are several bugs and missing features in the Regarding how much pain it causes, it should be minimal if we just publish it as a standalone package and will only require changing some import statements. I don't think this one is as massive as many previous breaking changes. |
Note that This should NOT be a breaking change. The way I am envisioning this happening is that react-native init would simply refer to the other module eventually. We are also working on a greater "slimmening" proposal (which I propose to write up here), so that we move many of the modules outside core. The hope is that we reduce React Native's surface area and merge issues and PRs faster. |
@axe-fb if it's still referenced by |
Created a generic "overview" of the Slimmening discussion to create a context for this PR and avoid to go too "outside" the purpose of this PR #6 |
@gwmccull - The goal of "the slimmening" is not to reduce bundle size, but to make components more maintainable. We could start moving things out of the bundle, but thats a different discussion |
Don't think |
@satya164 is correct here, this will be a breaking change for existing apps that use WebView. In another life, I built a RubyMotion library that had an integrated maps and webview. I eventually moved maps into its own repo, but kept webview as a part of core because 1) it wasn't very big (same here), and 2) many people depended on it (same here). However, the reality with React Native core is that the WebView as it currently stands is not sufficiently maintained, unlike my library's WebView.* So the overall goal is to reach a place where we have a WebView that is well maintained and reliable. And with the upcoming deprecation of UIWebView in iOS 12, the need has become more urgent.
I hear you @erictraut -- I'd like to see some examples so we can examine what the migration path looks like to those apps, extensions, and shared components. If it's as simple as adding a new import statement to the external legacy package, is that sufficient? * I don't blame Facebook for this at all -- they are providing an amazing community service by open sourcing React Native in the first place, and should be expected to focus on the things that mostly serve them. Just as Infinite Red focuses on the things, like Ignite, that we need. |
Please make the extracted component compatible with Expo 🙏 |
I've been working on many apps recently that involve heavy-loaded interactions encapsulated inside a WebView and in most cases, I ended up using alternative packages provided by the community from superior performance. I understand and agree with others that this is definitely going to be a breaking change, but at the same time, it's going to improve collaboration between different WebView projects out there, resulting in better performance for everyone. Once the package is extracted and fully tested to be working with |
I would like to propose that we move this proposal forward. Action items
For backward compat, people can continue to use the webview in the main repo. However, note that we will ONLY FIX critical issues. If this proposal sounds ok, please vote with a thumbs up. If you still think this proposal has issues, please comment on this thread with the reasons |
@ide heads up that we should start evaluating what we're going to do with WebView. |
For Expo: At minimum, for a smooth migration path and to help developers get to a good place, we'd work hard to maintain compatibility with the existing ReactNative.WebView API in Expo (including the import syntax, with perhaps a deprecation warning to give people advance notice about changing their import syntax). On naming: I think it sets a better precedent if company-scoped modules aren't under the react-native-community GitHub org unless the module is specifically for integration with that company's services (e.g. (With regard to Expo, if this component were published under the Ideal outcome: From my experiences working at/on Facebook & React Native & Expo one thing I keep coming back to is that the more we can focus the React Native repo on the bridge and set clear expectations that Facebook is responsible primarily for the actual core of React Native and not the very long tail of modules, the healthier the React Native repo will become and the greater the chance React Native has at succeeding. @axe-fb has mentioned maintenance cost several times in this discussion and, in my experience, the tradeoffs are much more natural to understand by working at companies like Facebook. In that light, I agree with @axe-fb's proposal and think we should add a fifth step to even more clearly set expectations for the maintenance and responsibility of the React Native repo by eventually pointing developers towards this repo in a doc or |
I'm all for going with WKWebView. Performance, maintained by Apple, not deprecated, don't have weird JS/browser quirks, probably less crash prone (most of my app crashes trace back to webview native code based on Sentry reports) and all that. But perhaps have a phase out period (after spinout) so it's more battle tested before dropping UIWebView code? |
@fungilation I have UIWebView and WKWebView both working in my third-party package, now. It makes sense to support them both for at least a short while. |
I've published an initial draft of https://github.com/react-native-community/react-native-webview Notes:
I'd like people to test it out in real world apps and see what they run into, and report the issues on the repo. Known issues with the existing RN core WebView are not going to be addressed, yet -- the goal is to make sure it's stable enough to release as-is. I'm looking for bugs I introduced in the conversion/extraction process. Note: I've reached out to the owner of the abandoned |
Awesome work @jamonholmgren , we'll make sure to link it into the Changelog :) |
I think Flow is a better choice because RN core uses Flow. But I also think ideally we should have both. |
Does what RN uses matter for WebView after it is spun out? If not, TypeScript have my vote. |
I'm using typescript too but better solution would be to support both I guess |
I've migrated (with @Titozzz's help) the issues labeled We plan to go through pull requests at a later date. |
I think the solution for these implementations is to not use a webview (e.g., the QR code thing can also be achieved using React ART), or include a custom implementation of a native webview themselves. |
Merging this PR, since this is now approved. Thanks a lot @jamonholmgren for the amazing work !! |
How to use camera through Webview? can anyone help ? it always says permission denied. |
This proposes that we extract the current WebView implementation from React Native Core and move it into a third party package.