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

typed-directory

v1.0.5

Published

Generate a Typescript file that loads all files contained in a directory hierarchically with a specified type

Downloads

14

Readme

Typed directory

NPM version Build Status

typed-directory is a utility that will generate a strongly typed hierarchy of a specific folder. It is useful for typescript projects that need dynamic imports but don't want to give-up type annotation.

Installation

# Install globally
npm install -g typed-directory

# or
# Add to your own module
npm install --save-dev typed-directory

Usage

Basic usage takes an input directory and a typescript file and output a hierarchy of the file.

typed-directory -d examples/classes -t examples/classes/BaseClass.ts -o examples/classes/output.ts

Configuration file

Format

The configuration file must export an Array of Object.

Each object represents a directory that needs to be compiled and must have the following keys:

  • dir:String - Path to the directory containing your source files (relative to project root)
  • type:String - Path to the typescript file exporting the type description of all files contained in the source directory (relative to project root)
  • output:String - Path to the typescript file that must be generated (relative to project root)
  • [instance:Boolean] (Optional: default=false) - See section is instance
// typed-directory.config.js
module.exports = [
	{
		dir: "examples/classes",
		type: "examples/classes/BaseClass.ts",
		output: "examples/classes/output.ts"
	}
];

Note: It is also possible to use json format for your config file.

Default config

While it is possible to specify your own config filename, it is recommended to use the default config.

It must be named typed-directory.config.js (or .json) and be located at the root of your project (with package.json).

Command-line tool

# Use default config
typed-directory

# Use specific config
typed-directory -c examples/config/typed-directory.config.json

# Use specified path
typed-directory -d examples/classes -t examples/classes/BaseClass.ts -o examples/classes/output.ts

# Use specified path (export as instance with -i)
typed-directory -i -d examples/animals -t examples/animals/Animal.ts -o examples/animals/output.ts

# Print the full documentation for the command-line tool
typed-directory --help

Use as a module

typed-directory can also be used as a standard node module.

const compiler = require("typed-directory");

// Run with default config
compiler();

Parameters

compiler()

Run compiler using default config file

compiler(configFilename)

Run compiler using a custom config file

  • configFilename:String - Path to the configuration file (relative to project root)

compiler(outputFilename, typeFilename, contentDirectory[, isInstance=false])

Run compiler by specifying the paths for one entry

  • outputFilename:String - Path to the typescript file that must be generated (relative to project root)
  • typeFilename:String - Path to the typescript file exporting the type description of all files contained in the source directory (relative to project root)
  • contentDirectory:String - Path to the directory containing your source files (relative to project root)
  • [isInstance:Boolean] (Optional: default=false) - See section is instance

compiler(entries)

Run compiler by specifying the paths for multiple entries

  • entries:Array - List of entries
  • entries[n].dir:String - Path to the directory containing your source files (relative to project root)
  • entries[n].type:String - Path to the typescript file exporting the type description of all files contained in the source directory (relative to project root)
  • entries[n].output:String - Path to the typescript file that must be generated (relative to project root)
  • [entries[n].instance:Boolean] (Optional: default=false) - See section is instance

Watch

It is also possible to watch the source directory and the type file for change and recompile when any.

Source watching is available in command-line or module mode.

Command-line

Add the -w or --watch flag to your command.

See command-line tool section for more information on how to use the command-line tool.

# Watch using default config
typed-directory -w

Module

Load the /watch module instead of the default one. The parameters are the same as the usual compiler.

See use as a module for more information on how to use it as a module.

const compiler = require("typed-directory/watch");

// Run with default config
compiler();

Using with third-party libraries

Nodemon

Integrating typed-directory with nodemon can be done by adding a start event in your nodemon.json and calling the command-line tool in it.

It is good practice to add your output files to the ignore list (otherwise nodemon will be stuck in an perpetual compilation loop).

Just remember that you DON'T need the --watch flag since nodemon already take care of all the watching of files.

{
	"events": {
		// Using the default config
		"start": "typed-directory"
	},
	"ignore": [
		// NOTE: Adding all output files here is good practice (to avoid perpetual compilation loop)
	],
	// The rest of your nodemon.json is up to you...
}

Webpack

To integrate with webpack, check typed-directory-webpack-plugin

Is instance

Import content as sub-classes (default)

Use instance=false if the source files export a class that extends the specified type

Example: Type is {new(): BaseClass}, therefore Something is a class that extends BaseClass

import BaseClass from "./BaseClass";

import _Something from "./Something";

// Casting as sub-class of BaseClass
const Something:{new(): BaseClass} = _Something;

export default {
	"Something": Something
};

Import content as instances

Use instance=true if the source files export an instance of the specified type

Example: Type is Animal, therefore cat is an instance of Animal

import Animal from "./Animal";

import _cat from "./domestic/cat";

// Casting as instance of Animal
const cat:Animal = _cat;

export default {
	"domestic": {
		"cat": cat
	}
};

Ignoring files

To ignore a file, add the following comment to the line 1 of the file:

/* typed-directory ignore */

Tests

The tests can be run by using the test command:

npm run test

Coverage data can also be generated by running the coverage command:

npm run coverage

To view the coverage report, open coverage/lcov-report/index.html in the browser of your choice.