Files
react-native/packages/rn-tester/js/examples/Cursor/CursorExample.js
Sam Zhou 23c8787fe2 Add annotations to fix future errors after fix for unsound array types (#52691)
Summary:
Pull Request resolved: https://github.com/facebook/react-native/pull/52691

Unannotated array literals are unsound in Flow right now. This diff adds in annotations and makes a few things readonly, to reduce future errors.

Changelog: [Internal]

Reviewed By: marcoww6

Differential Revision: D78519638

fbshipit-source-id: d98a7668ecf97bcc87dcb3fad25ade736d885d9a
2025-07-17 17:30:43 -07:00

113 lines
2.6 KiB
JavaScript

/**
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* 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
*/
import type {RNTesterModuleExample} from '../../types/RNTesterTypes';
import * as React from 'react';
import {StyleSheet, Text, View} from 'react-native';
const styles = StyleSheet.create({
invisibleBox: {
width: 100,
height: 100,
},
box: {
width: 100,
height: 100,
borderWidth: 2,
},
circle: {
width: 100,
height: 100,
borderWidth: 2,
borderRadius: 100,
},
halfcircle: {
width: 100,
height: 100,
borderWidth: 2,
borderTopStartRadius: 100,
borderBottomStartRadius: 100,
},
solid: {
backgroundColor: 'blue',
},
pointer: {
cursor: 'pointer',
},
row: {
flexDirection: 'row',
flexWrap: 'wrap',
gap: 10,
},
centerContent: {
justifyContent: 'center',
alignItems: 'center',
},
});
function CursorExampleAuto(): React.Node {
return (
<View style={styles.row}>
<View style={styles.box} />
<View style={styles.circle} />
<View style={styles.halfcircle} />
<View style={[styles.box, styles.solid]} />
<View style={[styles.circle, styles.solid]} />
<View style={[styles.halfcircle, styles.solid]} />
</View>
);
}
function CursorExamplePointer(): React.Node {
return (
<View style={styles.row}>
<View style={[styles.box, styles.pointer]} />
<View style={[styles.circle, styles.pointer]} />
<View style={[styles.halfcircle, styles.pointer]} />
<View style={[styles.box, styles.solid, styles.pointer]} />
<View style={[styles.circle, styles.solid, styles.pointer]} />
<View style={[styles.halfcircle, styles.solid, styles.pointer]} />
</View>
);
}
function CursorExampleViewFlattening(): React.Node {
return (
<View style={styles.row}>
<View style={[styles.invisibleBox, styles.centerContent, styles.pointer]}>
<Text>pointer</Text>
</View>
</View>
);
}
exports.title = 'Cursor';
exports.category = 'UI';
exports.description =
'Demonstrates setting a cursor, which affects the appearance when a pointer is over the View.';
exports.examples = [
{
title: 'Default',
description: "Cursor: 'auto' or no cursor set ",
render: CursorExampleAuto,
},
{
title: 'Pointer',
description: 'cursor: pointer',
render: CursorExamplePointer,
},
{
title: 'View flattening',
description: 'Views with a cursor do not get flattened',
render: CursorExampleViewFlattening,
},
] as Array<RNTesterModuleExample>;