mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
61e95e5cbf
Summary: `WithDefault` appears not to be required to be prefixed with `?` because it's option value per se. Fixed tests, removed `?` where needed, updated snapshots and review them. Added mechanism fro throwing error when `?WithDefault` found. Add tests for it. Reviewed By: rubennorte Differential Revision: D16048463 fbshipit-source-id: f55ed7454aacf0b8c42944a9b5c1037ad1b360fe
40 lines
1.2 KiB
JavaScript
40 lines
1.2 KiB
JavaScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* 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';
|
|
|
|
import type {SyntheticEvent} from './CoreEventTypes';
|
|
|
|
// Event types
|
|
// We're not using the PaperName, it is only used to codegen view config settings
|
|
|
|
export type BubblingEventHandler<
|
|
T,
|
|
PaperName: string | empty = empty, // eslint-disable-line no-unused-vars
|
|
> = (event: SyntheticEvent<T>) => mixed;
|
|
export type DirectEventHandler<
|
|
T,
|
|
PaperName: string | empty = empty, // eslint-disable-line no-unused-vars
|
|
> = (event: SyntheticEvent<T>) => mixed;
|
|
|
|
// Prop types
|
|
export type Float = number;
|
|
export type Int32 = number;
|
|
|
|
type DefaultTypes = number | boolean | string | $ReadOnlyArray<string>;
|
|
// Default handling, ignore the unused value
|
|
// we're only using it for type checking
|
|
//
|
|
// TODO: (rickhanlonii) T44881457 If a default is provided, it should always be optional
|
|
// but that is currently not supported in the codegen since we require a default
|
|
//
|
|
// eslint-disable-next-line no-unused-vars
|
|
export type WithDefault<Type: DefaultTypes, Value: ?Type | string> = ?Type;
|