Files
react/packages/react-devtools-shared/src/devtools/views/Components/InspectHostNodesToggle.js
Sebastian Markbåge 09348798a9 Codemod to import * as React from "react"; (#18102)
* import * as React from "react";

This is the correct way to import React from an ES module since the ES
module will not have a default export. Only named exports.

* import * as ReactDOM from "react-dom"
2020-02-21 19:45:20 -08:00

49 lines
1.3 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.
*
* @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';
export default function InspectHostNodesToggle() {
const [isInspecting, setIsInspecting] = useState(false);
const bridge = useContext(BridgeContext);
const handleChange = useCallback(
(isChecked: boolean) => {
setIsInspecting(isChecked);
if (isChecked) {
bridge.send('startInspectingNative');
} else {
bridge.send('stopInspectingNative', false);
}
},
[bridge],
);
useEffect(() => {
const onStopInspectingNative = () => setIsInspecting(false);
bridge.addListener('stopInspectingNative', onStopInspectingNative);
return () =>
bridge.removeListener('stopInspectingNative', onStopInspectingNative);
}, [bridge]);
return (
<Toggle
onChange={handleChange}
isChecked={isInspecting}
title="Select an element in the page to inspect it">
<ButtonIcon type="search" />
</Toggle>
);
}