/** * Copyright (c) 2015-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * * @flow */ 'use strict'; var React = require('react-native'); var { StyleSheet, Text, View, } = React; var Entity = React.createClass({ render: function() { return ( {this.props.children} ); } }); var AttributeToggler = React.createClass({ getInitialState: function() { return {fontWeight: '500', fontSize: 15}; }, increaseSize: function() { this.setState({ fontSize: this.state.fontSize + 1 }); }, render: function() { var curStyle = {fontSize: this.state.fontSize}; return ( Tap the controls below to change attributes. See how it will even work on{' '} this nested text {'>> Increase Size <<'} ); } }); exports.title = ''; exports.description = 'Base component for rendering styled text.'; exports.displayName = 'TextExample'; exports.examples = [ { title: 'Wrap', render: function() { return ( The text should wrap if it goes on multiple lines. See, this is going to the next line. ); }, }, { title: 'Font Family', render: function() { return ( Cochin Cochin bold Helvetica Helvetica bold Verdana Verdana bold ); }, }, { title: 'Font Size', render: function() { return ( Size 23 Size 8 ); }, }, { title: 'Color', render: function() { return ( Red color Blue color ); }, }, { title: 'Font Weight', render: function() { return ( Move fast and be ultralight Move fast and be light Move fast and be normal Move fast and be bold Move fast and be ultrabold ); }, }, { title: 'Font Style', render: function() { return ( Normal text Italic text ); }, }, { title: 'Nested', description: 'Nested text components will inherit the styles of their ' + 'parents (only backgroundColor is inherited from non-Text parents). ' + ' only supports other and raw text (strings) as children.', render: function() { return ( (Normal text, (and bold (and tiny inherited bold blue) ) ) Entity Name ); }, }, { title: 'Text Align', render: function() { return ( left left left left left left left left left left left left left left left center center center center center center center center center center center right right right right right right right right right right right right right ); }, }, { title: 'Spaces', render: function() { return ( A {'generated'} {' '} {'string'} and some     spaces ); }, }, { title: 'Line Height', render: function() { return ( A lot of space between the lines of this long passage that should wrap once. ); }, }, { title: 'Empty Text', description: 'It\'s ok to have Text with zero or null children.', render: function() { return ( ); }, }, { title: 'Toggling Attributes', render: function(): ReactElement { return ; }, }, { title: 'backgroundColor attribute', description: 'backgroundColor is inherited from all types of views.', render: function() { return ( Yellow background inherited from View parent, {' '}red background, {' '}blue background, {' '}inherited blue background, {' '}nested green background. ); }, }, { title: 'containerBackgroundColor attribute', render: function() { return ( Default containerBackgroundColor (inherited) + backgroundColor wash {"containerBackgroundColor: 'transparent' + backgroundColor wash"} ); }, }, { title: 'numberOfLines attribute', render: function() { return ( Maximum of one line no matter now much I write here. If I keep writing it{"'"}ll just truncate after one line Maximum of two lines no matter now much I write here. If I keep writing it{"'"}ll just truncate after two lines No maximum lines specified no matter now much I write here. If I keep writing it{"'"}ll just keep going and going ); }, }]; var styles = StyleSheet.create({ backgroundColorText: { left: 5, backgroundColor: 'rgba(100, 100, 100, 0.3)' }, entity: { fontWeight: '500', color: '#527fe4', }, });