diff --git a/packages/react-devtools-fusebox/src/frontend.d.ts b/packages/react-devtools-fusebox/src/frontend.d.ts index f17639a88c7be..c0277ecd806ac 100644 --- a/packages/react-devtools-fusebox/src/frontend.d.ts +++ b/packages/react-devtools-fusebox/src/frontend.d.ts @@ -5,23 +5,17 @@ * LICENSE file in the root directory of this source tree. */ -export type MessagePayload = - | null - | string - | number - | boolean - | {[key: string]: MessagePayload} - | MessagePayload[]; -export type Message = {event: string; payload?: MessagePayload}; +export type MessagePayload = null | string | number | boolean | { [key: string]: MessagePayload } | MessagePayload[]; +export type Message = { event: string, payload?: MessagePayload }; export type WallListener = (message: Message) => void; export type Wall = { - listen: (fn: WallListener) => Function; - send: (event: string, payload?: MessagePayload) => void; + listen: (fn: WallListener) => Function, + send: (event: string, payload?: MessagePayload) => void, }; export type Bridge = { - shutdown: () => void; + shutdown: () => void, }; export type Store = Object; export type BrowserTheme = 'dark' | 'light'; @@ -29,12 +23,26 @@ export type BrowserTheme = 'dark' | 'light'; export function createBridge(wall: Wall): Bridge; export function createStore(bridge: Bridge): Store; +export type ViewElementSource = ( + source: Source, + symbolicatedSource: Source | null, +) => void; +export type ViewAttributeSource = ( + id: number, + path: Array, +) => void; +export type CanViewElementSource = ( + source: Source, + symbolicatedSource: Source | null, +) => boolean; + export type InitializationOptions = { - bridge: Bridge; - store: Store; - theme?: BrowserTheme; + bridge: Bridge, + store: Store, + theme?: BrowserTheme, + viewAttributeSourceFunction?: ViewAttributeSource, + viewElementSourceFunction?: ViewElementSource, + canViewElementSourceFunction?: CanViewElementSource, }; -export function initialize( - node: Element | Document, - options: InitializationOptions, -): void; + +export function initialize(node: Element | Document, options: InitializationOptions): void; diff --git a/packages/react-devtools-fusebox/src/frontend.js b/packages/react-devtools-fusebox/src/frontend.js index 9a7a6b9ea90d9..d8a019b36a3ec 100644 --- a/packages/react-devtools-fusebox/src/frontend.js +++ b/packages/react-devtools-fusebox/src/frontend.js @@ -18,6 +18,11 @@ import type { Wall, } from 'react-devtools-shared/src/frontend/types'; import type {FrontendBridge} from 'react-devtools-shared/src/bridge'; +import type { + ViewAttributeSource, + ViewElementSource, + CanViewElementSource, +} from 'react-devtools-shared/src/devtools/views/DevTools'; type Config = { checkBridgeProtocolCompatibility?: boolean, @@ -46,13 +51,23 @@ type InitializationOptions = { bridge: FrontendBridge, store: Store, theme?: BrowserTheme, + viewAttributeSourceFunction?: ViewAttributeSource, + viewElementSourceFunction?: ViewElementSource, + canViewElementSourceFunction?: CanViewElementSource, }; export function initialize( contentWindow: Element | Document, options: InitializationOptions, ): void { - const {bridge, store, theme = 'light'} = options; + const { + bridge, + store, + theme = 'light', + viewAttributeSourceFunction, + viewElementSourceFunction, + canViewElementSourceFunction, + } = options; const root = createRoot(contentWindow); root.render( @@ -63,6 +78,9 @@ export function initialize( showTabBar={true} warnIfLegacyBackendDetected={true} enabledInspectedElementContextMenu={true} + viewAttributeSourceFunction={viewAttributeSourceFunction} + viewElementSourceFunction={viewElementSourceFunction} + canViewElementSourceFunction={canViewElementSourceFunction} />, ); }