mirror of
https://github.com/status-im/react-native.git
synced 2025-01-14 19:44:13 +00:00
50a481d23a
Summary: Refines `StyleSheet.compose` so that subtypes of `DangerouslyImpreciseStyleProp` can flow through the function call without losing their type. This makes it so that if you supply two `ViewStyleProp` types, you will get a `ViewStyleProp` type out of it. Reviewed By: TheSavior Differential Revision: D8851699 fbshipit-source-id: e38e572e363a71fddf63d6b6bf5a96b3cdae5915
83 lines
1.6 KiB
JavaScript
83 lines
1.6 KiB
JavaScript
/**
|
|
* 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.
|
|
*
|
|
* @flow strict-local
|
|
* @format
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const StyleSheet = require('StyleSheet');
|
|
|
|
import type {ImageStyleProp, TextStyleProp} from 'StyleSheet';
|
|
|
|
const imageStyle = {tintColor: 'rgb(0, 0, 0)'};
|
|
const textStyle = {color: 'rgb(0, 0, 0)'};
|
|
|
|
module.exports = {
|
|
testGoodCompose() {
|
|
(StyleSheet.compose(
|
|
imageStyle,
|
|
imageStyle,
|
|
): ImageStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
textStyle,
|
|
textStyle,
|
|
): TextStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
null,
|
|
null,
|
|
): TextStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
textStyle,
|
|
null,
|
|
): TextStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
textStyle,
|
|
Math.random() < 0.5 ? textStyle : null,
|
|
): TextStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
[textStyle],
|
|
null,
|
|
): TextStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
[textStyle],
|
|
null,
|
|
): TextStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
[textStyle],
|
|
[textStyle],
|
|
): TextStyleProp);
|
|
},
|
|
|
|
testBadCompose() {
|
|
// $FlowExpectedError - Incompatible type.
|
|
(StyleSheet.compose(
|
|
textStyle,
|
|
textStyle,
|
|
): ImageStyleProp);
|
|
|
|
(StyleSheet.compose(
|
|
// $FlowExpectedError - Incompatible type.
|
|
[textStyle],
|
|
null,
|
|
): ImageStyleProp);
|
|
|
|
// $FlowExpectedError - Incompatible type.
|
|
(StyleSheet.compose(
|
|
Math.random() < 0.5 ? textStyle : null,
|
|
null,
|
|
): ImageStyleProp);
|
|
},
|
|
};
|