Files
react-native/Libraries/Events/CustomEvent.js
T
Joshua Gross 6abbef1200 CustomEvent and Event polyfills for React Native
Summary:
In preparation for upcoming changes, it is useful / necessary to have a CustomEvent and Event polyfill for React Native.

In browser environments, both of those are expected to be accessible in the global scope, so we do the same here.

Changelog: [Added][JS] Event and CustomEvent W3C-compatible polyfills

Reviewed By: necolas

Differential Revision: D34462447

fbshipit-source-id: 5efdad6f24c268a6d248d4e3351fc96715ee3fdf
2022-03-02 11:39:00 -08:00

33 lines
802 B
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.
*
* @format
* @flow strict-local
*/
// Make sure global Event is defined
import EventPolyfill from './EventPolyfill';
type CustomEvent$Options = $ReadOnly<{|
bubbles?: boolean,
cancelable?: boolean,
composed?: boolean,
detail?: {...},
|}>;
class CustomEvent extends EventPolyfill {
detail: ?{...};
constructor(typeArg: string, options: CustomEvent$Options) {
const {bubbles, cancelable, composed} = options;
super(typeArg, {bubbles, cancelable, composed});
this.detail = options.detail; // this would correspond to `NativeEvent` in SyntheticEvent
}
}
export default CustomEvent;