'use strict' import React, { Component, PropTypes } from 'react'; import { ScrollView, StyleSheet, Text, TouchableOpacity, View } from 'react-native'; import AutoHeightWebView from 'react-native-autoheight-webview'; export default class Explorer extends Component { constructor(props) { super(props); this.html0 = `

Tags are great for describing the essence of your story in a single word or phrase, but stories are rarely about a single thing. 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”.

`; this.html1 = `

Tags are great for describing the essence of your story in a single word or phrase, but stories are rarely about a single thing. 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”.

`; this.script0 = ''; this.script1 = `document.body.style.background = 'cornflowerblue';`; this.changeSource = this.changeSource.bind(this); this.changeScript = this.changeScript.bind(this); this.state = { html: this.html0, script: this.script0, height: 0 }; } changeSource() { this.setState(prevState => ({ html: prevState.html === this.html0 ? this.html1 : this.html0 })); } changeScript() { this.changeSource(); this.setState(prevState => ({ script: prevState.script === this.script0 ? this.script1 : this.script0 })); } render() { return ( this.setState({ height })} source={{ html: this.state.html }} customScript={this.state.script} /> change source change script (have to change source to reload on android) {this.state.height} ); } } const Styles = StyleSheet.create({ button: { marginTop: 15, backgroundColor: 'aliceblue', borderRadius: 5, padding: 5 } });