npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@acransac/filetree

v1.1.0

Published

A mapping of files organized by name in a file and directory tree with anything of value

Downloads

13

Readme

Introduction

filetree maps file entries in a typical filesystem tree with handles which can be anything relevant to an application. The tree is navigated with a selection. Also, this library exposes some of its internal tooling to allow reimplementation of its logic.

How To Use Filetree

Add filetree to a project with:

    $ npm install @acransac/filetree

and import the needed functionalities:

    const { branches, entryName, insertInFileTree, isDirectoryEntry, isFileSelected, makeFileEntry, makeFileTree, makeSelectionInFileTree, parseFilePath, refreshSelectedFileTree, root, selectedBranch, selectedEntry, selectedEntryBranchName, selectedEntryHandle, selectedEntryLeafName, selectedEntryName, selectNext, selectPrevious, visitChildBranch, visitParentBranch } = require('@acransac/filetree');

Make a File Tree And Selection

Create an empty file tree and selection with makeFileTree and makeSelectionInFileTree. Then, use insertInFileTree to add entries which are created with makeFileEntry. After each insertion, the selection is updated with refreshSelectedFileTree.

A file tree can be inspected with root and branches, and an entry with entryName or isDirectoryEntry though it is preferred to inspect the selection. This is done with selectedBranch, selectedEntry, selectedEntryBranchName, selectedEntryHandle, selectedEntryLeafName, selectedEntryName or isFileSelected:

  • makeFileTree:: (Maybe<String>, Maybe<Branches>) -> FileTree | Parameter | Type | Description | |-----------|-------------------|-------------| | root | Maybe<String> | The path to the root of the file tree, written /path/to/root. Default: the empty string, it is deduced when inserting files. Specify if implementing new behaviour | | branches | Maybe<Branches> | The initial branches of the tree. Default: the empty branch. Specify if implementing new behaviour |

  • makeSelectionInFileTree:: (FileTree, Maybe<Branches>, Maybe<SelectedEntry>) -> Selection | Parameter | Type | Description | |----------------|-----------------------|-------------| | fileTree | FileTree | The file tree on which the selection is made. It has to be the empty file tree unless implementing new behaviour | | selectedBranch | Maybe<Branches> | Not used when the file tree is empty. When defining new behaviour, it is the branch to which the selected entry belongs | | selectedEntry | Maybe<SelectedEntry> | Not used when the file tree is empty. When defining new behaviour, it is the selected entry |

  • insertInFileTree:: (FileTree, String, FileEntry) -> FileTree | Parameter | Type | Description | |-----------|-----------|------------------------------------------------------------------| | fileTree | FileTree | The file tree to insert to | | path | String | The path to the file without the file name, written /some/path | | file | FileEntry | The file entry to insert |

  • makeFileEntry:: (String, Any) -> FileEntry | Parameter | Type | Description | |-----------|--------|-----------------------------------------------------------------------------------------------------| | name | String | The file name read in /path/name | | handle | Any | The handle can be anything relevant in the application's context such as a file id, a callback, etc |

  • refreshSelectedFileTree:: (Selection, FileTree) -> Selection | Parameter | Type | Description | |---------------------|-----------|------------------------------------------------| | selectionInFileTree | Selection | The selection with an outdated referenced tree | | newFileTree | FileTree | The referenced tree after insertion |

  • parseFilePath:: String -> (String, String) | Parameter / Returned | Type | Description | |----------------------|------------------|--------------------------------------------------------------------| | fullPath | String | The path to a file with its name included, written /path/to/file | | returned | (String, String) | An array of two strings. The first one is the path to the file /path/to and the second is the file name |

  • root:: FileTree -> String | Parameter / Returned | Type | Description | |----------------------|----------|-----------------------------------------------| | fileTree | FileTree | A file tree | | returned | String | The path to the root, written /path/to/root |

  • branches:: FileTree -> Branches | Parameter / Returned | Type | Description | |----------------------|----------|--------------------------| | fileTree | FileTree | A file tree | | returned | Branches | The branches of the tree |

  • entryName:: Entry -> String | Parameter / Returned | Type | Description | |----------------------|--------|-----------------------------------------------------------------------| | entry | Entry | An entry, file or directory | | returned | String | The name of the entry, which is the last element of the absolute path |

  • isDirectoryEntry:: Entry -> Boolean | Parameter | Type | Description | |-----------|-------|-------------------| | entry | Entry | The entry checked |

  • selectedBranch:: Selection -> Branches | Parameter / Returned | Type | Description | |----------------------|-----------|-----------------------------------------------------------------------------| | selectionInFileTree | Selection | A selection | | returned | Branches | The branch to which the selection belongs. Use if implementing new behavior |

  • selectedEntry:: Selection -> SelectedEntry | Parameter | Type | Description | |---------------------|-----------|-------------| | selectionInFileTree | Selection | A selection |

  • selectedEntryBranchName:: SelectedEntry -> String | Parameter / Returned | Type | Description | |----------------------|---------------|------------------| | selectedEntry | SelectedEntry | A selected entry | | returned | String | The path to the entry without its name and without the selected file tree's root path, written /pathFromRoot/justBeforeTheEntry |

  • selectedEntryHandle:: SelectedEntry -> Any | Parameter / Returned | Type | Description | |----------------------|---------------|-----------------------| | selectedEntry | SelectedEntry | A selected file | | returned | Any | The associated handle |

  • selectedEntryLeafName:: SelectedEntry -> String | Parameter / Returned | Type | Description | |----------------------|---------------|-----------------------------------------------------------------------| | selectedEntry | SelectedEntry | A selected entry | | returned | String | The name of the entry, which is the last element of the absolute path |

  • selectedEntryName:: SelectedEntry -> String | Parameter / Returned | Type | Description | |----------------------|---------------|-----------------------------------------------------------------------| | selectedEntry | SelectedEntry | A selected entry | | returned | String | The path to the entry with its name but without the selected file tree's root path, written /pathFromRoot/to/entry |

  • isFileSelected:: SelectedEntry -> Boolean | Parameter | Type | Description | |---------------|---------------|------------------| | selectedEntry | SelectedEntry | A selected entry |

Example:

    const { insertInFileTree, isFileSelected, makeFileEntry, makeFileTree, makeSelectionInFileTree, parseFilePath, refreshSelectedFileTree, selectedEntry, selectedEntryBranchName, selectedEntryHandle, selectedEntryLeafName, selectedEntryName } = require('@acransac/filetree');

    const emptyFileTree = makeFileTree();

    const emptySelection = makeSelectionInFileTree(emptyFileTree);

    const [filePath, fileName] = parseFilePath("/root/file");

    const selection = refreshSelectedFileTree(emptySelection,
                                              insertInFileTree(emptyFileTree,
                                                               filePath,
                                                               makeFileEntry(fileName, () => "File handled")));

    reportOnSelection(selection);

    function reportOnSelection(selection) {
      console.log(`Is the selection a file? ${isFileSelected(selectedEntry(selection)) ? "Yes" : "No"}`);
      console.log(`Full entry name: \"${selectedEntryName(selectedEntry(selection))}\"`);
      console.log(`Entry branch name: \"${selectedEntryBranchName(selectedEntry(selection))}\"`);
      console.log(`Entry leaf name: \"${selectedEntryLeafName(selectedEntry(selection))}\"`);
      console.log(`Using the handle: ${selectedEntryHandle(selectedEntry(selection))()}`);
    }
    $ node example.js
    Is the selection a file? Yes
    Full entry name: "/file"
    Entry branch name: ""
    Entry leaf name: "file"
    Using the handle: File handled

Navigate The File Tree

A file tree which has multiple entries can be navigated with a selection. The latter can visit the content of a directory or inspect parent or nested directories. At any point, the selection refers to a selected branch to which the selected entry belongs. The navigation is realized with selectNext, selectPrevious, visitChildBranch and visitParentBranch:

  • selectNext:: Selection -> Selection | Parameter / Returned | Type | Description | |----------------------|-----------|-------------| | selectionInFileTree | Selection | A selection | | returned | Selection | A new selection set on the next entry in the selected branch. If the input selection is the last entry of the branch, it is returned |

  • selectPrevious:: Selection -> Selection | Parameter / Returned | Type | Description | |----------------------|-----------|-------------| | selectionInFileTree | Selection | A selection | | returned | Selection | A new selection set on the previous entry in the selected branch. If the input selection is the first entry of the branch, it is returned |

  • visitChildBranch:: Selection -> Selection | Parameter / Returned | Type | Description | |----------------------|-----------|-------------| | selectionInFileTree | Selection | A selection | | returned | Selection | If the input selection is a directory, the new selection has its selected branch changed to the content of this directory and is set on its first entry. If the input selection is a file, it is returned |

  • visitParentBranch:: Selection -> Selection | Parameter / Returned | Type | Description | |----------------------|-----------|-------------| | selectionInFileTree | Selection | A selection | | returned | Selection | If the input selection has a parent directory, the new selection has its selected branch changed to the content of this directory and is set on its first entry. Otherwise, the selection is set on the first entry in the current directory, and the selected branch remains unchanged |

Example:

    const { insertInFileTree, isFileSelected, makeFileEntry, makeFileTree, makeSelectionInFileTree, parseFilePath, refreshSelectedFileTree, selectedEntry, selectedEntryBranchName, selectedEntryHandle, selectedEntryLeafName, selectedEntryName, selectNext, selectPrevious, visitChildBranch, visitParentBranch } = require('@acransac/filetree');

    const [fileTree, selection] = insertFile(makeFileTree(),
                                             makeSelectionInFileTree(makeFileTree()),
                                             ...parseFilePath("/root/fileA"));

    const [newFileTree, newSelection] = insertFile(fileTree, selection, ...parseFilePath("/root/dir/fileB"));

    reportOnSelection(selectNext(newSelection));

    reportOnSelection(selectPrevious(selectNext(newSelection)));

    reportOnSelection(visitChildBranch(selectNext(newSelection)));

    reportOnSelection(visitParentBranch(visitChildBranch(selectNext(newSelection))));

    function insertFile(fileTree, selection, filePath, fileName) {
      return (fileTree => [fileTree, refreshSelectedFileTree(selection, fileTree)])
               (insertInFileTree(fileTree, filePath, makeFileEntry(fileName, () => `${fileName} handled`)));
    }

    function reportOnSelection(selection) {
      console.log(`Is the selection a file? ${isFileSelected(selectedEntry(selection)) ? "Yes" : "No"}`);
      console.log(`Full entry name: \"${selectedEntryName(selectedEntry(selection))}\"`);
      console.log(`Entry branch name: \"${selectedEntryBranchName(selectedEntry(selection))}\"`);
      console.log(`Entry leaf name: \"${selectedEntryLeafName(selectedEntry(selection))}\"`);

      if (isFileSelected(selectedEntry(selection))) {
        console.log(`Using the handle: ${selectedEntryHandle(selectedEntry(selection))()}`);
      }

      console.log("\n");
    }
    $ node example.js
    Is the selection a file? No
    Full entry name: "/dir"
    Entry branch name: ""
    Entry leaf name: "dir"


    Is the selection a file? Yes
    Full entry name: "/fileA"
    Entry branch name: ""
    Entry leaf name: "fileA"
    Using the handle: fileA handled


    Is the selection a file? Yes
    Full entry name: "/dir/fileB"
    Entry branch name: "/dir"
    Entry leaf name: "fileB"
    Using the handle: fileB handled


    Is the selection a file? Yes
    Full entry name: "/fileA"
    Entry branch name: ""
    Entry leaf name: "fileA"
    Using the handle: fileA handled