/** * 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 {copy} from 'clipboard-js'; import * as React from 'react'; import Button from '../Button'; import ButtonIcon from '../ButtonIcon'; import KeyValue from './KeyValue'; import {alphaSortEntries, serializeDataForCopy} from '../utils'; import Store from '../../store'; import styles from './InspectedElementSharedStyles.css'; import { ElementTypeClass, ElementTypeFunction, } from 'react-devtools-shared/src/types'; import type {InspectedElement} from './types'; import type {FrontendBridge} from 'react-devtools-shared/src/bridge'; import type {Element} from 'react-devtools-shared/src/devtools/views/Components/types'; type Props = {| bridge: FrontendBridge, element: Element, inspectedElement: InspectedElement, store: Store, |}; export default function InspectedElementContextTree({ bridge, element, inspectedElement, store, }: Props) { const {hasLegacyContext, context, type} = inspectedElement; const isReadOnly = type !== ElementTypeClass && type !== ElementTypeFunction; const entries = context != null ? Object.entries(context) : null; if (entries !== null) { entries.sort(alphaSortEntries); } const isEmpty = entries === null || entries.length === 0; const handleCopy = () => copy(serializeDataForCopy(((context: any): Object))); // We add an object with a "value" key as a wrapper around Context data // so that we can use the shared component to display it. // This wrapper object can't be renamed. const canRenamePathsAtDepth = depth => depth > 1; if (isEmpty) { return null; } else { return (
{hasLegacyContext ? 'legacy context' : 'context'}
{!isEmpty && ( )}
{isEmpty &&
None
} {!isEmpty && (entries: any).map(([name, value]) => (
); } }