react-native-webview.git

Scrolling.js 3.2KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /**
  2. * Copyright (c) Facebook, Inc. and its affiliates.
  3. *
  4. * This source code is licensed under the MIT license found in the
  5. * LICENSE file in the root directory of this source tree.
  6. *
  7. * @format
  8. * @flow
  9. */
  10. import React, {Component} from 'react';
  11. import {Button, Text, View} from 'react-native';
  12. import WebView from 'react-native-webview';
  13. const HTML = `
  14. <!DOCTYPE html>\n
  15. <html>
  16. <head>
  17. <title>Hello World</title>
  18. <meta http-equiv="content-type" content="text/html; charset=utf-8">
  19. <meta name="viewport" content="width=320, user-scalable=no">
  20. <style type="text/css">
  21. body {
  22. margin: 0;
  23. padding: 0;
  24. font: 62.5% arial, sans-serif;
  25. background: #ccc;
  26. }
  27. </style>
  28. </head>
  29. <body>
  30. <p>Lorem ipsum dolor sit amet, virtute utroque voluptaria et duo, probo aeque partiendo pri at. Mea ut stet aliquip deterruisset. Inani erroribus principes ei mel, no dicit recteque delicatissimi usu. Ne has dolore nominavi, feugait hendrerit interesset vis ea, amet regione ne pri. Te cum amet etiam.</p>
  31. <p>Ut adipiscing neglegentur mediocritatem sea, suas abhorreant ius cu, ne nostrud feugiat per. Nam paulo facete iudicabit an, an brute mundi suavitate has, ex utamur numquam duo. Sea platonem argumentum instructior in, quo no prima inani perfecto. Ex illum postea copiosae has, ei mea sonet ocurreret.</p>
  32. <p>Has convenire erroribus cu, quo homero facilisis inciderint ea. Vix choro gloriatur definitionem an, te exerci debitis voluptaria pri, mea admodum antiopam neglegentur te. His ea iisque splendide, nam id malorum pertinacia. Iusto tempor in eos, vis debet erant an. An nostrum rationibus sit, et sed dicta delenit suscipiantur. Est dolore vituperatoribus in, ubique explicari est cu. Legere tractatos ut usu, probo atqui vituperata in usu, mazim nemore praesent pro no.</p>
  33. <p>Ei pri facilisi accusamus. Ut partem quaestio sit, an usu audiam quaerendum, ei qui hinc soleat. Fabulas phaedrum erroribus ut est. Intellegebat delicatissimi vis cu. His ea vidit libris facilis. Usu ne scripta legimus intellegam. Hendrerit urbanitas accommodare mei in.</p>
  34. <p>Brute appetere efficiendi has ne. Ei ornatus labores vis. Vel harum fierent no, ad erat partiendo vis, harum democritum duo at. Has no labitur vulputate. Has cu autem aperiam hendrerit, sed eu justo verear menandri.</p>
  35. </body>
  36. </html>
  37. `;
  38. type Props = {};
  39. type State = {
  40. scrollEnabled: boolean,
  41. lastScrollEvent: string
  42. };
  43. export default class Scrolling extends Component<Props, State> {
  44. state = {
  45. scrollEnabled: true,
  46. lastScrollEvent: ''
  47. };
  48. render() {
  49. return (
  50. <View>
  51. <View style={{ height: 120 }}>
  52. <WebView
  53. source={{html: HTML}}
  54. automaticallyAdjustContentInsets={false}
  55. onScroll={this._onScroll}
  56. scrollEnabled={this.state.scrollEnabled}
  57. />
  58. </View>
  59. <Button
  60. title={this.state.scrollEnabled ? 'Scroll enabled' : 'Scroll disabled'}
  61. onPress={() => this.setState({scrollEnabled: !this.state.scrollEnabled})}
  62. />
  63. <Text>Last scroll event:</Text>
  64. <Text>{this.state.lastScrollEvent}</Text>
  65. </View>
  66. );
  67. }
  68. _onScroll = event => {
  69. this.setState({lastScrollEvent: JSON.stringify(event.nativeEvent)});
  70. }
  71. }