/**
* Copyright 2004-present Facebook. All Rights Reserved.
* @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: 'bold', 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.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 bold
);
},
}, {
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: 'bold',
color: '#527fe4',
},
});