Research
Security News
Threat Actor Exposes Playbook for Exploiting npm to Build Blockchain-Powered Botnets
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
react-json-tree
Advanced tools
The react-json-tree package is a React component for efficiently rendering a JSON tree structure. It is useful for displaying JSON data in a hierarchical format, making it easier to navigate and understand complex JSON objects.
Basic JSON Tree Rendering
This feature allows you to render a basic JSON tree structure. The JSONTree component takes a JSON object as a prop and displays it in a hierarchical format.
import React from 'react';
import JSONTree from 'react-json-tree';
const data = {
name: 'John',
age: 30,
city: 'New York'
};
const App = () => (
<div>
<h1>JSON Tree</h1>
<JSONTree data={data} />
</div>
);
export default App;
Custom Theme
This feature allows you to apply a custom theme to the JSON tree. You can define a theme object and pass it as a prop to the JSONTree component to customize the appearance of the tree.
import React from 'react';
import JSONTree from 'react-json-tree';
const data = {
name: 'John',
age: 30,
city: 'New York'
};
const theme = {
scheme: 'monokai',
author: 'wimer hazenberg (http://www.monokai.nl)',
base00: '#272822',
base01: '#383830',
base02: '#49483e',
base03: '#75715e',
base04: '#a59f85',
base05: '#f8f8f2',
base06: '#f5f4f1',
base07: '#f9f8f5',
base08: '#f92672',
base09: '#fd971f',
base0A: '#f4bf75',
base0B: '#a6e22e',
base0C: '#a1efe4',
base0D: '#66d9ef',
base0E: '#ae81ff',
base0F: '#cc6633'
};
const App = () => (
<div>
<h1>JSON Tree with Custom Theme</h1>
<JSONTree data={data} theme={theme} />
</div>
);
export default App;
Collapsible Nodes
This feature allows you to make the nodes of the JSON tree collapsible. By default, all nodes are expanded, but you can control the expansion state by using the shouldExpandNode prop.
import React from 'react';
import JSONTree from 'react-json-tree';
const data = {
name: 'John',
age: 30,
address: {
city: 'New York',
zip: '10001'
}
};
const App = () => (
<div>
<h1>Collapsible JSON Tree</h1>
<JSONTree data={data} shouldExpandNode={() => false} />
</div>
);
export default App;
react-json-view is a React component for displaying and editing JSON data. It provides a more interactive experience compared to react-json-tree, allowing users to edit JSON values directly within the tree structure. It also supports features like collapsing/expanding nodes, searching, and custom themes.
jsoneditor-react is a wrapper around the JSONEditor library for use in React applications. It offers a rich set of features for viewing, editing, and manipulating JSON data, including a tree view, code view, and text view. It is more feature-rich compared to react-json-tree, providing advanced functionalities like schema validation and history management.
react-json-inspector is a React component for inspecting JSON data. It provides a simple and efficient way to navigate through large JSON objects. Unlike react-json-tree, it focuses more on search and filtering capabilities, making it easier to find specific data within a large JSON structure.
React JSON Viewer Component, Extracted from redux-devtools. Supports iterable objects, such as Immutable.js.
import JSONTree from 'react-json-tree'
// If you're using Immutable.js: `npm i --save immutable`
import { Map } from 'immutable'
// Inside a React component:
const json = {
array: [1, 2, 3],
bool: true,
object: {
foo: 'bar'
},
immutable: Map({ key: 'value' })
}
<JSONTree data={json} />
Check out examples directory for more details.
This component now uses react-base16-styling module, which allows to customize component via theme
property, which can be the following:
{ style, className }
and should return an object with the same structure. Other arguments depend on particular context (and should be described here). See createStylingFromTheme.js for the list of styling object keys. Also, this object can extend base16
theme via extend
property.Every theme has a light version, which is enabled with invertTheme
prop.
const theme = {
scheme: 'monokai',
author: 'wimer hazenberg (http://www.monokai.nl)',
base00: '#272822',
base01: '#383830',
base02: '#49483e',
base03: '#75715e',
base04: '#a59f85',
base05: '#f8f8f2',
base06: '#f5f4f1',
base07: '#f9f8f5',
base08: '#f92672',
base09: '#fd971f',
base0A: '#f4bf75',
base0B: '#a6e22e',
base0C: '#a1efe4',
base0D: '#66d9ef',
base0E: '#ae81ff',
base0F: '#cc6633'
};
<div>
<JSONTree data={data} theme={theme} invertTheme={false} />
</div>
<div>
<JSONTree data={data} theme={{
extend: theme,
// underline keys for literal values
valueLabel: {
textDecoration: 'underline'
},
// switch key for objects to uppercase when object is expanded.
// `nestedNodeLabel` receives additional arguments `expanded` and `keyPath`
nestedNodeLabel: ({ style }, nodeType, expanded) => ({
style: {
...style,
textTransform: expanded ? 'uppercase' : style.textTransform
}
})
}} />
</div>
You can pass getItemString
to customize the way arrays, objects, and iterable nodes are displayed (optional).
By default, it'll be:
<JSONTree getItemString={(type, data, itemType, itemString)
=> <span>{itemType} {itemString}</span>}
But if you pass the following:
const getItemString = (type, data, itemType, itemString)
=> (<span> // {type}</span>);
Then the preview of child elements now look like this:
You can pass the following properties to customize rendered labels and values:
<JSONTree
labelRenderer={raw => <strong>{raw}</strong>}
valueRenderer={raw => <em>{raw}</em>}
/>
In this example the label and value will be rendered with <strong>
and <em>
wrappers respectively.
For labelRenderer
, you can provide a full path - see this PR.
shouldExpandNode: function(keyName, data, level)
- determines if node should be expanded (root is expanded by default)hideRoot: Boolean
- if true
, the root node is hidden.sortObjectKeys: Boolean | function(a, b)
- sorts object keys with compare function (optional). Isn't applied to iterable maps like Immutable.Map
.MIT
FAQs
React JSON Viewer Component, Extracted from redux-devtools
The npm package react-json-tree receives a total of 305,114 weekly downloads. As such, react-json-tree popularity was classified as popular.
We found that react-json-tree demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
Security News
NVD’s backlog surpasses 20,000 CVEs as analysis slows and NIST announces new system updates to address ongoing delays.
Security News
Research
A malicious npm package disguised as a WhatsApp client is exploiting authentication flows with a remote kill switch to exfiltrate data and destroy files.