|
|
|
|
1
|
# react-native-autoheight-webview
|
1
|
# react-native-autoheight-webview
|
2
|
An auto height webview for React Native, or even auto width for inline html.
|
2
|
An auto height webview for React Native, or even auto width for inline html.
|
3
|
|
3
|
|
|
|
4
|
+The Current version do not support Android API version 18 and below and the native module has been removed.
|
|
|
5
|
+
|
|
|
6
|
+Cause of javascript execution in webview is not working for Android API version 21 and below (https://github.com/facebook/react-native/issues/14754#issuecomment-361841219), auto width for inline html will not work on Android with API version 22 and below.
|
|
|
7
|
+
|
4
|
Cause of changes to lifecycle methods in React 16.3.0 (https://reactjs.org/blog/2018/03/27/update-on-async-rendering.html), please install react-native-autoheight-webview 0.6.1 for the project with 0.47 <= rn < 0.55
|
8
|
Cause of changes to lifecycle methods in React 16.3.0 (https://reactjs.org/blog/2018/03/27/update-on-async-rendering.html), please install react-native-autoheight-webview 0.6.1 for the project with 0.47 <= rn < 0.55
|
5
|
|
9
|
|
6
|
Cause of removing unused createJSModules calls in React Naitve 0.47 (https://github.com/facebook/react-native/releases/tag/v0.47.2), please install react-native-autoheight-webview 0.3.1 for the project with 0.44 <= rn < 0.47.
|
10
|
Cause of removing unused createJSModules calls in React Naitve 0.47 (https://github.com/facebook/react-native/releases/tag/v0.47.2), please install react-native-autoheight-webview 0.3.1 for the project with 0.44 <= rn < 0.47.
|
|
|
|
|
16
|
`npm install react-native-autoheight-webview@0.2.3 --save` (rn < 0.44)
|
20
|
`npm install react-native-autoheight-webview@0.2.3 --save` (rn < 0.44)
|
17
|
|
21
|
|
18
|
## Android
|
22
|
## Android
|
19
|
-`react-native link react-native-autoheight-webview`
|
|
|
|
|
23
|
+`react-native link react-native-autoheight-webview` (version 0.10.6 and below)
|
20
|
|
24
|
|
21
|
`import AutoHeightWebView from 'react-native-autoheight-webview';`
|
25
|
`import AutoHeightWebView from 'react-native-autoheight-webview';`
|
22
|
|
26
|
|
|
|
|
|
31
|
|
35
|
|
32
|
```javascript
|
36
|
```javascript
|
33
|
<AutoHeightWebView
|
37
|
<AutoHeightWebView
|
34
|
- onMessage={e => console.log(e)},
|
|
|
35
|
- // either height or width updated will trigger this
|
|
|
36
|
- onSizeUpdated={({size => console.log(size.height)})},
|
|
|
37
|
- // set scrollEnabled to true may cause some layout issues
|
|
|
38
|
- scrollEnabled={true},
|
|
|
39
|
- // if page contains iframe on iOS, use a specific script for it
|
|
|
40
|
- hasIframe={true}
|
|
|
41
|
- /*
|
|
|
42
|
- if set to false may cause some layout issues (width of container not fit for screen) on Android
|
|
|
43
|
- if set to true may cause some layout issues (smaller font size) on iOS
|
|
|
44
|
- */
|
|
|
45
|
- scalesPageToFit={Platform.OS === 'Android' ? true : false}
|
|
|
46
|
- // offset of rn webview margin
|
|
|
47
|
- heightOffset={5}
|
|
|
48
|
// default width is the width of screen
|
38
|
// default width is the width of screen
|
49
|
// if there are some text selection issues on iOS, the width should be reduced more than 15 and the marginTop should be added more than 35
|
39
|
// if there are some text selection issues on iOS, the width should be reduced more than 15 and the marginTop should be added more than 35
|
50
|
style={{ width: Dimensions.get('window').width - 15, marginTop: 35 }}
|
40
|
style={{ width: Dimensions.get('window').width - 15, marginTop: 35 }}
|
51
|
- // enable animation by default
|
|
|
52
|
- enableAnimation={true},
|
|
|
|
|
41
|
+ customScript={`document.body.style.background = 'lightyellow';`}
|
|
|
42
|
+ // add custom CSS to the page's <head>
|
|
|
43
|
+ customStyle={`
|
|
|
44
|
+ * {
|
|
|
45
|
+ font-family: 'Times New Roman';
|
|
|
46
|
+ }
|
|
|
47
|
+ p {
|
|
|
48
|
+ font-size: 16px;
|
|
|
49
|
+ }
|
|
|
50
|
+ `}
|
|
|
51
|
+ // animation enabled by default
|
|
|
52
|
+ enableAnimation={false},
|
53
|
// only works on enable animation
|
53
|
// only works on enable animation
|
54
|
animationDuration={255},
|
54
|
animationDuration={255},
|
55
|
- // only on Android for animating size
|
|
|
56
|
- animationEasing={Easing.ease()},
|
|
|
57
|
- // or uri
|
|
|
58
|
- source={{ html: `<p style="font-weight: 400;font-style: normal;font-size: 21px;line-height: 1.58;letter-spacing: -.003em;">Tags are great for describing the essence of your story in a single word or phrase, but stories are rarely about a single thing. <span style="background-color: transparent !important;background-image: linear-gradient(to bottom, rgba(146, 249, 190, 1), rgba(146, 249, 190, 1));">If I pen a story about moving across the country to start a new job in a car with my husband, two cats, a dog, and a tarantula, I wouldn’t only tag the piece with “moving”. I’d also use the tags “pets”, “marriage”, “career change”, and “travel tips”.</span></p>` }}
|
|
|
59
|
- // 'web/' by default on iOS, and 'file:///android_asset/web/' on Android, and baseUrl not work in android 4.3 or below version
|
|
|
|
|
55
|
+ // offset of rn webview margin
|
|
|
56
|
+ heightOffset={5}
|
|
|
57
|
+ onMessage={e => console.log(e)},
|
|
|
58
|
+ // either height or width updated will trigger this
|
|
|
59
|
+ // no support auto width and height will triggered by source changing only on android 5.1 or below version
|
|
|
60
|
+ onSizeUpdated={({size => console.log(size.height)})},
|
|
|
61
|
+ // 'file:///android_asset/web/' by default on android,
|
|
|
62
|
+ // web/' by default on iOS
|
60
|
baseUrl: 'webAssets/',
|
63
|
baseUrl: 'webAssets/',
|
61
|
- // add baseUrl/files... to project root
|
|
|
62
|
/*
|
64
|
/*
|
63
|
use local or remote files
|
65
|
use local or remote files
|
64
|
- local files only works on enable baseUrl on Android,
|
|
|
65
|
- to add local file on Android: rnproject/android/app/src/main/assets/web/,
|
|
|
66
|
- to add local file on iOS: open iOS project with Xcode,
|
|
|
67
|
- add new group named web (with folder) under your project folder, then drag your files into this folder
|
|
|
|
|
66
|
+ to add local files:
|
|
|
67
|
+ add baseUrl/files... to android/app/src/assets/ on android
|
|
|
68
|
+ add baseUrl/files... to project root on iOS
|
68
|
*/
|
69
|
*/
|
69
|
files={[{
|
70
|
files={[{
|
70
|
href: 'cssfileaddress',
|
71
|
href: 'cssfileaddress',
|
71
|
type: 'text/css',
|
72
|
type: 'text/css',
|
72
|
rel: 'stylesheet'
|
73
|
rel: 'stylesheet'
|
73
|
}]}
|
74
|
}]}
|
74
|
- customScript={`document.body.style.background = 'lightyellow';`}
|
|
|
|
|
75
|
+ // if set to true may cause some layout issues (smaller font size) on iOS
|
|
|
76
|
+ // if set to false may cause some layout issues (width of container will be than width of screen) on android
|
|
|
77
|
+ scalesPageToFit={Platform.OS === 'Android' ? true : false}
|
|
|
78
|
+ // or uri
|
|
|
79
|
+ source={{ html: `<p style="font-weight: 400;font-style: normal;font-size: 21px;line-height: 1.58;letter-spacing: -.003em;">Tags are great for describing the essence of your story in a single word or phrase, but stories are rarely about a single thing. <span style="background-color: transparent !important;background-image: linear-gradient(to bottom, rgba(146, 249, 190, 1), rgba(146, 249, 190, 1));">If I pen a story about moving across the country to start a new job in a car with my husband, two cats, a dog, and a tarantula, I wouldn’t only tag the piece with “moving”. I’d also use the tags “pets”, “marriage”, “career change”, and “travel tips”.</span></p>` }}
|
75
|
// rn WebView callbacks
|
80
|
// rn WebView callbacks
|
76
|
onError={() => console.log('on error')}
|
81
|
onError={() => console.log('on error')}
|
77
|
onLoad={() => console.log('on load')}
|
82
|
onLoad={() => console.log('on load')}
|
78
|
onLoadStart={() => console.log('on load start')}
|
83
|
onLoadStart={() => console.log('on load start')}
|
79
|
onLoadEnd={() => console.log('on load end')}
|
84
|
onLoadEnd={() => console.log('on load end')}
|
80
|
onNavigationStateChange={() => console.log('navigation state changed')}
|
85
|
onNavigationStateChange={() => console.log('navigation state changed')}
|
|
|
86
|
+ // set scrollEnabled to true may cause some layout issues
|
|
|
87
|
+ // only on iOS
|
|
|
88
|
+ scrollEnabled={true},
|
|
|
89
|
+ // if page contains iframe on iOS, use a specific script for it
|
|
|
90
|
+ // only on iOS
|
|
|
91
|
+ hasIframe={true}
|
81
|
// only on iOS
|
92
|
// only on iOS
|
82
|
onShouldStartLoadWithRequest={result => {
|
93
|
onShouldStartLoadWithRequest={result => {
|
83
|
console.log(result)
|
94
|
console.log(result)
|
84
|
return true;
|
95
|
return true;
|
85
|
}}
|
96
|
}}
|
86
|
- // add custom CSS to the page's <head>
|
|
|
87
|
- customStyle={`
|
|
|
88
|
- * {
|
|
|
89
|
- font-family: 'Times New Roman';
|
|
|
90
|
- }
|
|
|
91
|
- p {
|
|
|
92
|
- font-size: 16px;
|
|
|
93
|
- }
|
|
|
94
|
- `}
|
|
|
|
|
97
|
+ // only on Android for animating size (>= api 23)
|
|
|
98
|
+ animationEasing={Easing.ease()}
|
|
|
99
|
+ /*
|
|
|
100
|
+ other rn WebView props:
|
|
|
101
|
+ renderError, mediaPlaybackRequiresUserAction, originWhitelist
|
|
|
102
|
+ decelerationRate, allowsInlineMediaPlayback, bounces, dataDetectorTypes on iOS
|
|
|
103
|
+ domStorageEnabled, thirdPartyCookiesEnabled, userAgent, geolocationEnabled, allowUniversalAccessFromFileURLs, mixedContentMode on Android
|
|
|
104
|
+ */
|
95
|
/>
|
105
|
/>
|
96
|
```
|
106
|
```
|
97
|
|
107
|
|
98
|
## demo
|
108
|
## demo
|
99
|
-You may have to copy autoHeightWebView, android, node_modules folders to 'demo/node_modules/react-native-autoheight-webview/', cause of installing a local package with npm will create symlink, but there is no supporting of React Native to symlink (https://github.com/facebook/watchman/issues/105).
|
|
|
|
|
109
|
+You may have to copy autoHeightWebView, node_modules folders and index.js to 'demo/node_modules/react-native-autoheight-webview/', cause of installing a local package with npm will create symlink, but there is no supporting of React Native to symlink (https://github.com/facebook/watchman/issues/105).
|