Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@form8ion/javascript-core

Package Overview
Dependencies
Maintainers
2
Versions
79
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@form8ion/javascript-core

core logic for form8ion tools related to JavaScript, like javascript-scaffolder and lift-javascript

  • 11.0.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
3.8K
decreased by-47.61%
Maintainers
2
Weekly downloads
 
Created
Source

coverageShouldBeReported# javascript-core

core logic for form8ion tools related to JavaScript, like javascript-scaffolder and lift-javascript

Node CI Workflow Status Codecov SLSA Level 2 OpenSSF Scorecard

Table of Contents

Usage

MIT license npm node Try @form8ion/javascript-core on RunKit

Installation

$ npm install @form8ion/javascript-core --save-prod

Example

Import
const {scaffoldChoice} = require('@form8ion/javascript-core');
Execute
(async () => {
  await scaffoldChoice(
    {foo: {scaffolder: options => options}},
    'foo',
    {bar: 'baz'}
  );
})();

API

scaffoldChoice

A generic function that executes the scaffolder function from a provided map of options based on the chosen option name.

Takes three unnamed arguments:

choices object (required)
  • keys: string Name of the choice
  • values: object
    • scaffolder: function (required) scaffolds the choice options
choice string (required)

Name of the choice. SHOULD match a key from the choices object.

options object (optional)

options object to be passed as the only argument to the chosen scaffolder

installDependencies

A function that installs the provided package dependencies.

Takes four unnamed arguments:

dependencies list of strings (required)

The list of package names to be installed.

dependenciesType string (required)

Defines if the provided list of package names should be installed as prod or dev dependencies. If "dev" is provided, the list will be installed with the --save-exact flag.

projectRoot string (optional)

Filesystem path to the root of the project

packageManger string (optional)

Specifies the name of the package manager to be used for dependency installation. Defaults to npm

Dependency-types Constants

Constants to define the valid options for dependenciesType

  • PROD_DEPENDENCY_TYPE
  • DEV_DEPENDENCY_TYPE
projectTypes

Constants defining the types of possible JavaScript projects

  • APPLICATION
  • PACKAGE
  • CLI
packageManagers

Constants defining the available package managers

  • NPM
  • YARN
dialects

Constants defining the available JavaScript source dialects

  • COMMON_JS
  • BABEL
  • ESM
  • TYPESCRIPT
projectTypeShouldBePublished

Predicate function to determine if the project-type is one that should be published

Takes one argument:

projectType string (required)

Should be one of the project-type options

coverageShouldBeReported

Predicate function to determine if coverage should be reported

Takes two arguments:

visibility string (required)

visibility of the project (Public or Private)

tests object (required)
  • unit boolean (optional) Whether the project will be unit-tested
writePackageJson

Writes the provided config to the package.json for the project

Accepts an options object as the only argument, with the following properties:

projectRoot string (required)

Filesystem path to the root of the project

config object (required)

The config to be written to the package.json as the entire contents of the file

mergeIntoExistingPackageJson

Merges the provided config into the existing package.json for the project

Accepts an options object as the only argument, with the following properties:

projectRoot string (required)

Filesystem path to the root of the project

config object (required)

The config to be merged with the existing contents of the package.json

Node version categories

Helpers for determining supported node.js versions in categories defined by package support guidelines. Refer to the release schedule for current statuses.

determineLtsNodeMajorVersions

Returns a list of the major LTS versions currently in active or maintenance status, optionally filtered by a provided semver range.

Accepts an options object as the only argument, with the following properties:

withinRange string (optional)

A semver range, compatible with node-semver, to filter the list of active major LTS versions by.

determineSupportedNodeMajorVersions

Returns a list of the major versions currently not in end-of-life status, optionally filtered by a provided semver range.

Accepts an options object as the only argument, with the following properties:

withinRange string (optional)

A semver range, compatible with node-semver, to filter the list of active major LTS versions by.

Contributing

PRs Welcome Conventional Commits Commitizen friendly semantic-release Renovate

Dependencies

$ nvm install
$ npm install

Verification

$ npm test

FAQs

Package last updated on 18 Jan 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc