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

one

Package Overview
Dependencies
Maintainers
1
Versions
189
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

one

Transform NodeJS packages into single stand-alone script files.

  • 2.0.4
  • npm
  • Socket score

Version published
Weekly downloads
1.7K
decreased by-32.66%
Maintainers
1
Weekly downloads
 
Created
Source

OneJS is a command-line utility for converting CommonJS packages to single, stand-alone JavaScript files that can be run on web browsers.

Current Version: 2.0.2

MOTIVATION

  • Reusability OneJS lets developers code JavaScript for one platform and run everywhere, without requiring any additional effort.
  • Elegant Modularization Modules and packages specs of CommonJS are what web apps exactly needs: a well designed way to structure your source code.
  • NPM OneJS moves the revolution of NPM one step forward and makes it available for client-side projects!
  • No Spaghetti Code No awkward headers, no framework-specific definitions.
  • Reliable code generation OneJS doesn't change your source code. It generates a container that emulates a simple NodeJS environment.
  • Unobtrusive Code OneJS puts all the content into an isolated JS object.

DOCUMENTATION

Install

$ npm install -g one

First Steps

The quickest way of giving OneJS a try is to run "onejs build package.json" command in a project folder. It'll walk through all the directories, find JavaScript files in the "lib" folder (if exists, and by considering .npmignore), and produce an output that can be run by any web browser and NodeJS, as well.

Bundle files produced by OneJS consist of a CommonJS implementation and the throughout package tree wrapped by OneJS' templates. And the produced output will be unobtrusive. Which means, your project will not conflict with any other JavaScript on the page that is embedded.

Once you produce the output, as you expect, it needs to be included by an HTML page, like the below example;

$ one build hello-world/package.json output.js
$ cat > index.html
<html>
    <script src="output.js"></script>
    <script>helloWorld();</script>
</html>

You may notice a function named helloWorld was called. That's what starts running your program by requiring the main module of the project. Besides of that helloWorld refers to the main module, it also exports some utilities that can be useful. See following for an example;

> helloWorld.require('./module');
[object ./module.js]
> helloWorld.require('dependency');
[object node_modules/dependency]

In addition to command-line API, there are two more ways to configure build options. You can have the configuration in a package.json manfest;

{
    "name": "hello-world",
    "version": "1.0.0",
    "directories": {
        "lib": "lib"
    },
    "web": {
        "save": "bundle.js",
        "alias": {
            "crypto": "crypto-browserify"
        },
        "tie": {
            "jquery": "window.jQuery"
        }
    }
}

Or, you can write your own build script using OneJS' chaining API:

// build.js
var one = require('../../../lib');

one('./package.json')
    .alias('crypto', 'crypto-browserify')
    .tie('pi', 'Math.PI')
    .tie('json', 'JSON')
    .exclude('underscore')
    .filter(/^build\.js$/)
    .filter(/^bundle\.js$/)
    .save('bundle.js');

Advanced Usage

Saving Multiple Files & Async Loading

Specified dependencies (including their subdependencies) can be splitted to different files via package.json manifest.

{
    "name": "hello-world",
    "version": "1.0.0",
    "dependencies": {
        "foo": "*",
        "bar": "*"
    },
    "web": {
        "save": {
            "hello-world": "hello-world.js",
            "bar": {
                "to": "bar.js",
                "url: "/js/bar.js"
            }
        }
    }
}

OneJS will be outputting an async require implementation to let you load splitted packages;

// hello-world/index.js
var foo = require('foo');
    
require.async('bar', function(bar)){ // loads "/js/bar.js"
   console.log('dependencies are loaded!');     
   console.log(bar);
   // => [object bar]
});

Watching File Changes

OneJS doesn't have a watching utility since a built-in one becomes useless when you have other build steps.

Recommended way is to create a Makefile, and use the good tools such as visionmedia/watch to , isaacs/node-supervisor build your project when there is a change. Following Makefile example watches files under /lib directory.

SRC = $(wildcard lib/*/*.js)

build: $(SRC)
   @one build package.json bundle.js

Below command will be updating bundle.js when lib/ has a change.

$ watch make

Package Aliases

Registers a new name for specified package. It can be configured via command-line, package.json and NodeJS APIs.

$ one build package.json output.js --alias request:superagent,crypto:crypto-browserify

package.json

{
    "name": "hello-world",
    "web": {
        "alias": {
            "crypto": "crypto-browserify"
        }
    }
}

NodeJS

one('./package.json')
    .alias('crypto', 'crypto-browserify')
    .save('foo.js');

Accessing Global Browser Variables

OneJS doesn't stop you from accessing globals. However, you may want to use require for accessing some global variables, such as jQuery, for some purposes like keeping your source-code self documented.

OneJS may tie some package names to global variables if demanded. And it can be configured via command-line, package.json and NodeJS APIs.

$ one build package.json output.js --tie jquery:jQuery,google:goog

package.json

{
    "name": "hello-world",
    "web": {
        "tie": {
            "jquery": "jQuery",
            "google": "goog"
        }
    }
}

NodeJS

one('./package.json')
    .tie('jquery', 'jQuery')
    .tie('google', 'goog')
    .save('foo.js');

Excluding Packages

Excludes specified packages from your bundle.

$ one build package.json output.js --excude underscore

package.json

{
    "name": "hello-world",
    "web": {
        "exclude": ["underscore"]
    }
}

NodeJS

one('./package.json')
    .exclude('underscore')
    .save('foo.js');

Filtering Modules/Files

OneJS reads .npmignore to ignore anything not wanted to have in the bundle. In addition to .npmignore, you may also define your own Regex filters to ignore files. This config is only provided for only NodeJS scripts.

one('./package.json')
    .filter(/^build\.js$/)
    .filter(/^bundle\.js$/)
    .save('bundle.js');

Customizing Global Variable

OneJS defines the global variable that wraps the bundle by default. For example, a project named "hello-world" lies under "helloWorld" object on the browsers.

To customize it, define "name" field on your package.json;

{
    "name": "hello-world",
    "web": {
        "name": "HelloWorld"
    }
}

API Reference

OneJS lets you pick any of the following ways to configure your build.

package.json

{
    "name": "hello-world",
    "version": "1.0.0",
    "directories": {
        "lib": "lib"
    },
    "web": {
        "name":"HelloWorld",
        "save": "bundle.js",
        "alias": {
            "crypto": "crypto-browserify"
        },
        "tie": {
            "jquery": "window.jQuery"
        }
    }
}

Command-Line

usage: onejs [action] [manifest] [options]

Transforms NodeJS packages into single, stand-alone JavaScript files that can be run at other platforms. See the documentation at http://github.com/azer/onejs for more information.

actions:
  build      <manifest> <target>          Generate a stand-alone JavaScript file from specified package. Write output to <target> if given any.
  server     <manifest> <port> <host>     Publish generated JavaScript file on web. Uses 127.0.0.1:1338 by default.

options:
  --debug                                 Enable SourceURLs.

  --alias <alias>:<package name>          Register an alias name for given package. e.g: request:superagent,crypto:crypto-browserify
  --tie <package name>:<global object>    Create package links to specified global variables. e.g; --tie dom:window.document,jquery:jQuery
  --exclude <package name>                Do not contain specified dependencies. e.g: --exclude underscore,request 
  --plain                                 Builds the package within a minimalistic template for the packages with single module and no dependencies.

  --quiet                                 Make console output less verbose.
  --verbose                               Tell what's going on by being verbose.
  --version                               Show version and exit.
  --help                                  Show help.

NodeJS

// build.js
var one = require('../../../lib');

one('./package.json')
    .alias('crypto', 'crypto-browserify')
    .tie('pi', 'Math.PI')
    .tie('json', 'JSON')
    .exclude('underscore')
    .filter(/^build\.js$/)
    .filter(/^bundle\.js$/)
    .save('bundle.js');

Examples

// Following examples are out of date. Will be updated soon.

Troubleshooting

  • The most common issue is to lack some dependencies. In that case, make sure that the missing dependency is located under node_modules/ properly.
  • Enabling verbose mode might be helpful: onejs build package.json --verbose
  • See the content of projectName.map object if it contains the missing dependency

TESTING

Run npm test for running all test modules. And run make test module=? for specific test modules;

> make test module=build

Keywords

FAQs

Package last updated on 13 Feb 2013

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