forked from facebook/react
-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathInspectHostNodesToggle.js
More file actions
50 lines (44 loc) · 1.4 KB
/
InspectHostNodesToggle.js
File metadata and controls
50 lines (44 loc) · 1.4 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/**
* 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
*/
import * as React from 'react';
import {useCallback, useContext, useEffect, useState} from 'react';
import {BridgeContext} from '../context';
import Toggle from '../Toggle';
import ButtonIcon from '../ButtonIcon';
import {logEvent} from 'react-devtools-shared/src/Logger';
export default function InspectHostNodesToggle(): React.Node {
const [isInspecting, setIsInspecting] = useState(false);
const bridge = useContext(BridgeContext);
const handleChange = useCallback(
(isChecked: boolean) => {
setIsInspecting(isChecked);
if (isChecked) {
logEvent({event_name: 'inspect-element-button-clicked'});
bridge.send('startInspectingHost');
} else {
bridge.send('stopInspectingHost');
}
},
[bridge],
);
useEffect(() => {
const onStopInspectingHost = () => setIsInspecting(false);
bridge.addListener('stopInspectingHost', onStopInspectingHost);
return () =>
bridge.removeListener('stopInspectingHost', onStopInspectingHost);
}, [bridge]);
return (
<Toggle
onChange={handleChange}
isChecked={isInspecting}
title="Select an element in the page to inspect it">
<ButtonIcon type="search" />
</Toggle>
);
}