/**
* Copyright (c) 2015-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @format
* @flow
*/
'use strict';
const Platform = require('Platform');
var React = require('react');
var createReactClass = require('create-react-class');
var ReactNative = require('react-native');
var {
Image,
Text,
TextInput,
View,
LayoutAnimation,
Button,
Picker,
} = ReactNative;
type TextAlignExampleRTLState = {|
isRTL: boolean,
|};
class TextAlignRTLExample extends React.Component<*, TextAlignExampleRTLState> {
constructor(...args: Array<*>) {
super(...args);
this.state = {
isRTL: false,
};
}
render() {
const {isRTL} = this.state;
const toggleRTL = () => this.setState({isRTL: !isRTL});
return (
auto (default) - english LTR
{'\u0623\u062D\u0628 \u0627\u0644\u0644\u063A\u0629 ' +
'\u0627\u0644\u0639\u0631\u0628\u064A\u0629 auto (default) - arabic RTL'}
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
justify: this text component{"'"}s contents are laid out with
"textAlign: justify" and as you can see all of the lines except the
last one span the available width of the parent container.
);
}
}
class Entity extends React.Component<$FlowFixMeProps> {
render() {
return (
{this.props.children}
);
}
}
class AttributeToggler extends React.Component<{}, $FlowFixMeState> {
state = {fontWeight: 'bold', fontSize: 15};
toggleWeight = () => {
this.setState({
fontWeight: this.state.fontWeight === 'bold' ? 'normal' : 'bold',
});
};
increaseSize = () => {
this.setState({
fontSize: this.state.fontSize + 1,
});
};
render() {
var curStyle = {
fontWeight: this.state.fontWeight,
fontSize: this.state.fontSize,
};
return (
Tap the controls below to change attributes.
See how it will even work on{' '}
this nested text
Toggle Weight
Increase Size
);
}
}
var AdjustingFontSize = createReactClass({
displayName: 'AdjustingFontSize',
getInitialState: function() {
return {dynamicText: '', shouldRender: true};
},
reset: function() {
LayoutAnimation.easeInEaseOut();
this.setState({
shouldRender: false,
});
setTimeout(() => {
LayoutAnimation.easeInEaseOut();
this.setState({
dynamicText: '',
shouldRender: true,
});
}, 300);
},
addText: function() {
this.setState({
dynamicText:
this.state.dynamicText +
(Math.floor((Math.random() * 10) % 2) ? ' foo' : ' bar'),
});
},
removeText: function() {
this.setState({
dynamicText: this.state.dynamicText.slice(
0,
this.state.dynamicText.length - 4,
),
});
},
render: function() {
if (!this.state.shouldRender) {
return ;
}
return (
Truncated text is baaaaad.
Shrinking to fit available space is much better!
{'Add text to me to watch me shrink!' + ' ' + this.state.dynamicText}
{'Multiline text component shrinking is supported, watch as this reeeeaaaally loooooong teeeeeeext grooooows and then shriiiinks as you add text to me! ioahsdia soady auydoa aoisyd aosdy ' +
' ' +
this.state.dynamicText}
{'Differently sized nested elements will shrink together. '}
{'LARGE TEXT! ' + this.state.dynamicText}
Reset
Remove Text
Add Text
);
},
});
class TextBaseLineLayoutExample extends React.Component<*, *> {
render() {
var texts = [];
for (var i = 9; i >= 0; i--) {
texts.push(
{i}
,
);
}
const marker = (
);
const subtitleStyle = {fontSize: 16, marginTop: 8, fontWeight: 'bold'};
return (
{'Nested s:'}
{marker}
{texts}
{marker}
{'Array of s in :'}
{marker}
{texts}
{marker}
{':'}
{marker}
{texts}
{marker}
{':'}
{marker}
{texts}
{marker}
);
}
}
class TextRenderInfoExample extends React.Component<*, *> {
state = {
textMetrics: {
x: 0,
y: 0,
width: 0,
height: 0,
capHeight: 0,
descender: 0,
ascender: 0,
xHeight: 0,
},
numberOfTextBlocks: 1,
fontSize: 14,
};
render() {
const topOfBox =
this.state.textMetrics.y +
this.state.textMetrics.height -
(this.state.textMetrics.descender + this.state.textMetrics.capHeight);
return (
{
const {lines} = event.nativeEvent;
if (lines.length > 0) {
this.setState({textMetrics: lines[lines.length - 1]});
}
}}>
{new Array(this.state.numberOfTextBlocks)
.fill('A tiny block of text.')
.join(' ')}
this.setState({
numberOfTextBlocks: this.state.numberOfTextBlocks + 1,
})
}>
More text
this.setState({fontSize: this.state.fontSize + 1})}>
Increase size
this.setState({fontSize: this.state.fontSize - 1})}>
Decrease size
);
}
}
class TextWithCapBaseBox extends React.Component<*, *> {
state = {
textMetrics: {
x: 0,
y: 0,
width: 0,
height: 0,
capHeight: 0,
descender: 0,
ascender: 0,
xHeight: 0,
},
};
render() {
return (
{
const {lines} = event.nativeEvent;
if (lines.length > 0) {
this.setState({textMetrics: lines[0]});
}
}}
style={[
{
marginTop: Math.ceil(
-(
this.state.textMetrics.ascender -
this.state.textMetrics.capHeight
),
),
marginBottom: Math.ceil(-this.state.textMetrics.descender),
},
this.props.style,
]}>
{this.props.children}
);
}
}
class TextLegend extends React.Component<*, *> {
state = {
textMetrics: [],
language: 'english',
};
render() {
const PANGRAMS = {
arabic:
'صِف خَلقَ خَودِ كَمِثلِ الشَمسِ إِذ بَزَغَت — يَحظى الضَجيعُ بِها نَجلاءَ مِعطارِ',
chinese: 'Innovation in China 中国智造,慧及全球 0123456789',
english: 'The quick brown fox jumps over the lazy dog.',
emoji: '🙏🏾🚗💩😍🤯👩🏽🔧🇨🇦💯',
german: 'Falsches Üben von Xylophonmusik quält jeden größeren Zwerg',
greek: 'Ταχίστη αλώπηξ βαφής ψημένη γη, δρασκελίζει υπέρ νωθρού κυνός',
hebrew: 'דג סקרן שט בים מאוכזב ולפתע מצא חברה',
hindi:
'ऋषियों को सताने वाले दुष्ट राक्षसों के राजा रावण का सर्वनाश करने वाले विष्णुवतार भगवान श्रीराम, अयोध्या के महाराज दशरथ के बड़े सपुत्र थे।',
igbo:
'Nne, nna, wepụ he’l’ụjọ dum n’ime ọzụzụ ụmụ, vufesi obi nye Chukwu, ṅụrịanụ, gbakọọnụ kpaa, kwee ya ka o guzoshie ike; ọ ghaghị ito, nwapụta ezi agwa',
irish:
'D’fhuascail Íosa Úrmhac na hÓighe Beannaithe pór Éava agus Ádhaimh',
japanese:
'色は匂へど 散りぬるを 我が世誰ぞ 常ならむ 有為の奥山 今日越えて 浅き夢見じ 酔ひもせず',
korean:
'키스의 고유조건은 입술끼리 만나야 하고 특별한 기술은 필요치 않다',
norwegian:
'Vår sære Zulu fra badeøya spilte jo whist og quickstep i min taxi.',
polish: 'Jeżu klątw, spłódź Finom część gry hańb!',
romanian: 'Muzicologă în bej vând whisky și tequila, preț fix.',
russian: 'Эх, чужак, общий съём цен шляп (юфть) – вдрызг!',
swedish: 'Yxskaftbud, ge vår WC-zonmö IQ-hjälp.',
thai:
'เป็นมนุษย์สุดประเสริฐเลิศคุณค่า กว่าบรรดาฝูงสัตว์เดรัจฉาน จงฝ่าฟันพัฒนาวิชาการ อย่าล้างผลาญฤๅเข่นฆ่าบีฑาใคร ไม่ถือโทษโกรธแช่งซัดฮึดฮัดด่า หัดอภัยเหมือนกีฬาอัชฌาสัย ปฏิบัติประพฤติกฎกำหนดใจ พูดจาให้จ๊ะๆ จ๋าๆ น่าฟังเอยฯ',
};
return (
this.setState({language: itemValue})}>
{Object.keys(PANGRAMS).map(x => (
))}
{this.state.textMetrics.map(
({
x,
y,
width,
height,
capHeight,
ascender,
descender,
xHeight,
}) => {
return [
,
Baseline
,
,
Capheight
,
,
X-height
,
,
Descender
,
,
End of text
,
];
},
)}
this.setState({textMetrics: event.nativeEvent.lines})
}
style={{fontSize: 50}}>
{PANGRAMS[this.state.language]}
);
}
}
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: 'Text metrics',
render: function() {
return ;
},
},
{
title: 'Text metrics legend',
render: () => ,
},
{
title: 'Baseline capheight box',
render: () => (
Some example text.
),
},
{
title: 'Padding',
render: function() {
return (
This text is indented by 10px padding on all sides.
);
},
},
{
title: 'Font Family',
render: function() {
return (
Cochin
Cochin bold
Helvetica
Helvetica bold
Verdana
Verdana bold
);
},
},
{
title: 'Font Size',
render: function() {
return (
Size 23Size 8
);
},
},
{
title: 'Color',
render: function() {
return (
Red colorBlue 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 textItalic text
);
},
},
{
title: 'Selectable',
render: function() {
return (
This text is selectable if
you click-and-hold.
);
},
},
{
title: 'Text Decoration',
render: function() {
return (
Solid underline
Double underline with custom color
Dashed underline with custom color
Dotted underline with custom color
None textDecoration
Solid line-through
Double line-through with custom color
Dashed line-through with custom color
Dotted line-through with custom color
Both underline and line-through
);
},
},
{
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)
)
)
(opacity
(is inherited
(and accumulated
(and also applies to the background)
)
)
)
Entity Name
);
},
},
{
title: 'Text Align',
render: function() {
return (
auto (default) - english LTR
{'\u0623\u062D\u0628 \u0627\u0644\u0644\u063A\u0629 ' +
'\u0627\u0644\u0639\u0631\u0628\u064A\u0629 auto (default) - arabic ' +
'RTL'}
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
justify: this text component{"'"}s contents are laid out with
"textAlign: justify" and as you can see all of the lines except the
last one span the available width of the parent container.
);
},
},
{
title: 'Letter Spacing',
render: function() {
return (
letterSpacing = 0
letterSpacing = 2
letterSpacing = 9
With size and background color
letterSpacing = -1
[letterSpacing = 3]
[Nested letterSpacing = 0]
[Nested letterSpacing = 6]
);
},
},
{
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(): React.Element {
return ;
},
},
{
title: 'backgroundColor attribute',
description: 'backgroundColor is inherited from all types of views.',
render: function() {
return (
Yellow container background,
{' '}
red background,
{' '}
blue background,
{' '}
inherited blue background,
{' '}
nested green background.
);
},
},
{
title: 'numberOfLines attribute',
render: function() {
return (
Maximum of one line, no matter how much I write here. If I keep
writing, it{"'"}ll just truncate after one line.
Maximum of two lines, no matter how much I write here. If I keep
writing, it{"'"}ll just truncate after two lines.
No maximum lines specified, no matter how much I write here. If I
keep writing, it{"'"}ll just keep going and going.
);
},
},
{
title: 'Text highlighting (tap the link to see highlight)',
render: function() {
return (
Lorem ipsum dolor sit amet,{' '}
null}>
consectetur adipiscing elit, sed do eiusmod tempor incididunt ut
labore et dolore magna aliqua. Ut enim ad minim veniam, quis
nostrud
{' '}
exercitation ullamco laboris nisi ut aliquip ex ea commodo
consequat.
);
},
},
{
title: 'allowFontScaling attribute',
render: function() {
return (
By default, text will respect Text Size accessibility setting on
iOS. It means that all font sizes will be increased or descreased
depending on the value of Text Size setting in{' '}
Settings.app - Display & Brightness - Text Size
You can disable scaling for your Text component by passing {'"'}allowFontScaling={
'{'
}false{'}"'} prop.
This text will not scale.
);
},
},
{
title: 'Text shadow',
render: function() {
return (
Demo text shadow
);
},
},
{
title: 'Ellipsize mode',
render: function() {
return (
This very long text should be truncated with dots in the end.
This very long text should be truncated with dots in the middle.
This very long text should be truncated with dots in the beginning.
This very looooooooooooooooooooooooooooong text should be clipped.
);
},
},
{
title: 'Font variants',
render: function() {
return (
Small Caps{'\n'}
Old Style nums 0123456789{'\n'}
Lining nums 0123456789{'\n'}
Tabular nums{'\n'}
1111{'\n'}
2222{'\n'}
Proportional nums{'\n'}
1111{'\n'}
2222{'\n'}
);
},
},
{
title: 'Dynamic Font Size Adjustment',
render: function(): React.Element {
return ;
},
},
{
title: 'Text Align with RTL',
render: function() {
return ;
},
},
{
title: "Text `alignItems: 'baseline'` style",
render: function() {
return ;
},
},
{
title: 'Transform',
render: function() {
return (
This text should be uppercased.
This TEXT SHOULD be lowercased.
This text should be CAPITALIZED.
Mixed: uppercase LoWeRcAsE
capitalize each word
Should be "ABC":
abc
Should be "AbC":
abc
);
},
},
];