2018-01-06 07:06:22 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2013-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.
|
|
|
|
*
|
|
|
|
* @providesModule TextProps
|
|
|
|
* @flow
|
|
|
|
* @format
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
import type {Node} from 'react';
|
|
|
|
|
|
|
|
import type {LayoutEvent} from 'CoreEventTypes';
|
|
|
|
import type {TextStyleProp} from 'StyleSheetTypes';
|
|
|
|
|
|
|
|
type PressRetentionOffset = {
|
|
|
|
top: number,
|
|
|
|
left: number,
|
|
|
|
bottom: number,
|
|
|
|
right: number,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @see https://facebook.github.io/react-native/docs/text.html#reference
|
|
|
|
*/
|
|
|
|
export type TextProps = {|
|
|
|
|
accessible?: boolean,
|
|
|
|
allowFontScaling?: boolean,
|
2018-02-08 01:23:43 +00:00
|
|
|
children?: Node,
|
2018-01-06 07:06:22 +00:00
|
|
|
ellipsizeMode?: 'clip' | 'head' | 'middle' | 'tail',
|
|
|
|
nativeID?: string,
|
|
|
|
numberOfLines?: number,
|
|
|
|
onLayout?: ?(event: LayoutEvent) => void,
|
|
|
|
onLongPress?: ?() => void,
|
|
|
|
onPress?: ?() => void,
|
|
|
|
pressRetentionOffset?: PressRetentionOffset,
|
|
|
|
selectable?: boolean,
|
|
|
|
style?: TextStyleProp,
|
|
|
|
testID?: string,
|
|
|
|
|
|
|
|
// Android Only
|
|
|
|
disabled?: boolean,
|
|
|
|
selectionColor?: string,
|
|
|
|
textBreakStrategy?: 'balanced' | 'highQuality' | 'simple',
|
|
|
|
|
|
|
|
// iOS Only
|
|
|
|
adjustsFontSizeToFit?: boolean,
|
|
|
|
minimumFontScale?: number,
|
|
|
|
suppressHighlighting?: boolean,
|
|
|
|
|};
|