mirror of
https://github.com/reduxjs/redux-devtools.git
synced 2024-11-16 06:36:48 +03:00
a46b43209d
* dock-monitor * log-monitor * serialize * slider-monitor * inspector-monitor * chart-monitor * test-tab * trace-tab * Fix
90 lines
2.2 KiB
Markdown
Executable File
90 lines
2.2 KiB
Markdown
Executable File
A pure function to convert a map into a tree structure. Created by [@romseguy](https://github.com/romseguy) and merged from [`romseguy/map2tree`](https://github.com/romseguy/map2tree).
|
|
|
|
The following opinions must be taken into account since the primary use case of this library is [redux-devtools-chart-monitor](https://github.com/reduxjs/redux-devtools/tree/master/packages/redux-devtools-chart-monitor):
|
|
|
|
- Objects and arrays deeply nested within collections are not converted into a tree structure. See `someNestedObject` and `someNestedArray` in the [output](https://github.com/romseguy/map2tree#output) below, or the [corresponding test](https://github.com/romseguy/map2tree/blob/master/test/map2tree.js#L140).
|
|
- Provides support for [Immutable.js](https://github.com/facebook/immutable-js) data structures (only List and Map though).
|
|
|
|
# Usage
|
|
|
|
```javascript
|
|
map2tree(
|
|
someMap,
|
|
(options = {
|
|
key: 'state', // the name you want for as the root node of the output tree
|
|
pushMethod: 'push', // use 'unshift' to change the order children nodes are added
|
|
})
|
|
);
|
|
```
|
|
|
|
# Input
|
|
|
|
```javascript
|
|
const someMap = {
|
|
someReducer: {
|
|
todos: [
|
|
{ title: 'map', someNestedObject: { foo: 'bar' } },
|
|
{ title: 'to', someNestedArray: ['foo', 'bar'] },
|
|
{ title: 'tree' },
|
|
{ title: 'map2tree' },
|
|
],
|
|
completedCount: 1,
|
|
},
|
|
otherReducer: {
|
|
foo: 0,
|
|
bar: { key: 'value' },
|
|
},
|
|
};
|
|
```
|
|
|
|
# Output
|
|
|
|
```javascript
|
|
{
|
|
name: `${options.key}`,
|
|
children: [
|
|
{
|
|
name: 'someReducer',
|
|
children: [
|
|
{
|
|
name: 'todos',
|
|
children: [
|
|
{
|
|
name: 'todo[0]',
|
|
object: {
|
|
title: 'map',
|
|
someNestedObject: {foo: 'bar'}
|
|
}
|
|
},
|
|
{
|
|
name: 'todo[1]',
|
|
object: {
|
|
title: 'to',
|
|
someNestedArray: ['foo', 'bar']
|
|
}
|
|
},
|
|
// ...
|
|
]
|
|
},
|
|
// ...
|
|
]
|
|
},
|
|
{
|
|
name: 'otherReducer',
|
|
children: [
|
|
{
|
|
name: 'foo',
|
|
value: 0
|
|
},
|
|
{
|
|
name: 'bar',
|
|
object: {
|
|
key: 'value'
|
|
}
|
|
}
|
|
]
|
|
}
|
|
]
|
|
}
|
|
```
|