Skip to content

MomsFriendlyDevCo/ES6

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

@MomsFriendlyDevCo/ES6

Various ES6 utilities.

  • dirname - Fetch the directory path of the current file
  • discover() - Find other ES6 compliant NPM modules by various query options
  • importAll() - Import various ES6 modules using a glob
  • sortPaths() - Sort input paths in a logical way

API

All methods are importable directly or via a default object:

// Import everything as es6
import es6 from '@momsfriendlydevco';
es6.importAll(...);
es6.$FUNC(...);

// Import individual functions
import {dirName, importAll, sortPaths} from '@momsfriendlydevco/es6';
dirName(...);
importAll(...);
sortPaths(...);

// Direct import via path
import importAll from '@momsfriendlydevco/es6/importAll';
importAll(...);

backport(path, extract)

Convert an ESM module into CJS, optionally extracting a subkey. Returns a promise.

const {backport} = require('@momsfriendlydevco/es6');

// Import an ESM module into CJS
let {execa} = await backport('execa');

// Just extract one key
let {execa} = await backport('execa', 'execaSync'));

dirName(options)

If called as a string the value of options.relativeTo is assumed. e.g. dirName('..') gets the parent directory. Returns a string. Fetch the directory of the calling function.

Option Type Default Description
relativeTo String Compute the dirname + the relative path (e.g. '..' to get the parent dir)
stackDepth Number 1 How far down the call stack to search for a path
translateFileProtocol Boolean true Whether to replace the file:// prefix with a simple on-disk path
includeFilename Boolean false Whether to include the actual filename, if false only the directory is returned

Notes:

  • stackDepth is the number of functions in the stack to look upwards from the actual dirName worker. The default of 1 means look to the callee. If you wish to look higher up the stack increase this value.
import {dirName} from '@momsfriendlydevco/es6';

let myPath = dirName(); //=~ the directory the saved script file exists in

let myFile = dirName({includeFilename: true}); //=~ Full path including file

discover(options)

Find other ES6 compliant NPM modules by various query options.

Options are:

Option Type Default Description
filter RegExp / Function Optional filter function to query modules. If a function this is called as (npmName, npmAttrs), if a RegExp its used to match the npm.id
local Boolean false Query local repositories
global Boolean true Query global repositories
want String 'collection' Desired output type. ENUM: 'collection', 'object', 'set'

Returns a list of modules as an array (depending on want)

importAll(paths, options)

Import various ES6 modules using a glob. Returns a promise. This module uses the sortPaths API to return paths in a logical order (i.e. ./lib/a.js is included before ./lib/a.a.js).

Options are:

Option Type Default Description
imports Various* [] Alternate way to specify the paths input, see notes
includePath Boolean false Include an additonal {path:String} property per output
glob Boolean true Support globbing in paths
method String, Array<String> If specified run the method or array of methods after each import
methodPerCycle Boolean false Run each method in an outer loop rather than importing all methods at once
args Array [] Arguments to pass to the method on run
root String Auto* Root path of the project to resolve modules from
sort Function ES6.sortPaths Function to use to sort evaluated glob paths per run
sortOptions Object {} Options passed to the sort function
sortWhen String perGlob When to sort. ENUM: perGlob or preImport
uniq Boolean true Include each eventual path only once, avoiding duplicates

Notes:

  • imports can be a single string glob, array of globs or a single function / array of functions which (async eventually) returns the strings / globs to include
  • sortWhen determines when the sorting algorithm should operate. perGlob sorts each glob evaluation, meaning that the order of paths is preserved except globs that "expand" into multiple files. preImport Expands all globs first then sorts all files which could potentially destroy any preferred order
  • methodPerCycle can be used to run imports in a logical order (e.g. all init() imports then all default() imports). All Async methods are resolved in order when used.
// Glob include all files specified (in a logical order) running the 'init' method for each
await importAll([
	'./libs/*.js',
	'./middleware/*.js',
], {
	method: 'init',
})

sortPaths(paths, options)

Sort input paths in a logical way.

Sorts an array of paths in a logical, "human" order.

Options are:

Option Type Default Description
stripDir Boolean false Whether to ignore the path component when sorting
stripExt Boolean true Whether to ignore the file extension when sorting
rewritePath Function See code The path rewrite function (uses the strip* options)
locale String 'en' The locale region when sorting
localeOptions Object See code Locale options when sorting
uniq Boolean true Whether to de-duplicate the calculated paths
sortPaths([
	'./lib/a.js',
	'./lib/a.a.js', // Expects to extend 'a'
	'./lib/a.b.js',
	'./lib/a.c.js',
	'
	'./lib/z.js',
	'./lib/z-1.js',
	'./lib/z-2.js',
	'./lib/z-3.js',
	'./lib/z-10.js', // Numerics are correctly evaluated in order
]); //= The above "ideal" order

About

Various ES6 utilities

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published