Implement folding (use '+' key), clean up code
This commit is contained in:
@ -47,12 +47,14 @@ class TreeList implements Countable
|
||||
|
||||
if ($node instanceof ArrayNode) {
|
||||
$index = 0;
|
||||
if ($node->isCollapsed()) return;
|
||||
foreach ($node->items as $item) {
|
||||
$this->parseNode($item, [ ...$path, $key ], $index++);
|
||||
}
|
||||
if (!Settings::$compactGroups)
|
||||
$this->list[$entryKey.'$'] = new Entry(depth: $level, key: $key, node: $node, closer: true);
|
||||
} elseif ($node instanceof ObjectNode) {
|
||||
if ($node->isCollapsed()) return;
|
||||
foreach ($node->properties as $nodekey=>$item) {
|
||||
$this->parseNode($item, [ ...$path, $key ], $nodekey);
|
||||
}
|
||||
@ -172,8 +174,18 @@ class TreeList implements Countable
|
||||
}
|
||||
if ($entry->node instanceof ArrayNode) {
|
||||
echo "[" . (Settings::$compactGroups ? "…]":"");
|
||||
if ($entry->node->isCollapsed()) {
|
||||
echo " \e[90m\u{25ba} \e[2m".count($entry->node->items)."\e[22m";
|
||||
} else {
|
||||
echo " \e[90m\u{25bc}";
|
||||
}
|
||||
} elseif ($entry->node instanceof ObjectNode) {
|
||||
echo "{" . (Settings::$compactGroups ? "…}":"");
|
||||
if ($entry->node->isCollapsed()) {
|
||||
echo " \e[90m\u{25ba} \e[2m".count($entry->node->properties)."\e[22m";
|
||||
} else {
|
||||
echo " \e[90m\u{25bc}";
|
||||
}
|
||||
} elseif ($entry->node instanceof ValueNode) {
|
||||
$value = $entry->node->value;
|
||||
echo match (gettype($value)) {
|
||||
|
Reference in New Issue
Block a user