1.1.14 • Published 3 years ago
@dizmo/functions-tree2json v1.1.14
@dizmo/functions-tree2json
Provides two functions tree2array and tree2object, where:
tree2array: maps a hierarchical tree recursively to an array via theget(returning the value for a node) andsee(returning the sub-nodes for a node) callback functions, until the tree is completely mapped (orseereturning an empty list[]for the node).
The array is a recursive description of a tree, where the value of a given node is at index 0 of the array followed optionally by other arrays, each containing the name followed by a sub-tree for any given sub-nodes. Each sub-tree is again yet another array according to the same recursive description.
tree2object: maps a hierarchical tree recursively to a JSON-like object via teget(returning the value for a node) andsee(returning the sub-nodes for a node) callback functions, until the tree is completely mapped (orseereturning an empty list[]for the node).
The object conforms to the same rules like any regular JSON or JavaScript object, with the addition that the values of nodes can be directly represented using an underscore _ for the key value.
Usage
Install
npm install @dizmo/functions-tree2json --saveRequire
const { tree2array, tree2object } = require('@dizmo/functions-tree2json');Examples
import { tree2array, tree2object } from '@dizmo/functions-tree2json';declare const db: {
// db should return value for given path (or root)
get: (path: string | null) => any;
// db should return nodes for given path (or root)
see: (path: string | null) => string[];
};
const root_array
= tree2array(null, db.get, db.see);
const node_array
= tree2array('path/to/node', db.get, db.see);
const root_object
= tree2object(null, db.get, db.see);
const node_object
= tree2object('path/to/node', db.get, db.see);Development
Clean
npm run cleanBuild
npm run buildwithout linting and cleaning:
npm run -- build --no-lint --no-cleanwith UMD bundling (incl. minimization):
npm run -- build --prepackwith UMD bundling (excl. minimization):
npm run -- build --prepack --no-minifyLint
npm run lintwith auto-fixing:
npm run -- lint --fixTest
npm run testwithout linting, cleaning and (re-)building:
npm run -- test --no-lint --no-clean --no-buildCover
npm run coverwithout linting, cleaning and (re-)building:
npm run -- cover --no-lint --no-clean --no-buildDocumentation
npm run docsPublish
npm publishinitially (if public):
npm publish --access=publicCopyright
© 2020 dizmo AG, Switzerland