lodash-extensions

Lodash Extensions

Usage no npm install needed!

<script type="module">
  import lodashExtensions from 'https://cdn.skypack.dev/lodash-extensions';
</script>

README

lodash-extensions

Build Status Dependency Status devDependency Status

A library of extensions for lodash.js.

Installation

This package can be installed via bower:

bower install lodash-extensions

Installing dependencies

Install node.js and node package manager (npm).

From Debian and Ubuntu based distributions, use the following commands:

sudo apt-get install nodejs
sudo apt-get install nodejs-legacy
sudo apt-get install npm

For other distributions, you will not need the nodejs-legacy package. For information about other distributions, see: Installing node.js via package manager

Install Grunt Client (Optional)

To use the grunt-cli, it is easiest if it is installed globally.

sudo npm install -g grunt-cli

If you do not wish to install the grunt-cli, a script (see grunt file in project root) has been included. This allows you to use the local grunt-cli installation to run grunt commands. To do so, replace grunt in all grunt commands with ./grunt.

e.g. grunt becomes ./grunt, grunt build becomes ./grunt build

Install Project Specific Dependencies

This project has two kinds of dependencies: tools and libraries.

Tools:

  • are for managing and testing the application
  • are specified in package.json.
  • are installed via npm, the node package manager.

Libraries:

  • are the client-side dependencies which actually get shipped with the app.
  • are specified in bower.json.
  • are installed via bower, a client-side code package manager.

In this project, npm install has been configured to automatically run bower install, so we can simply run:

npm install

This will create the following folders:

  • node_modules - contains the npm packages for tools needed.
  • app/bower_components - contains bower packages for libraries needed.

Testing

Unit Tests

Unit tests are written in Jasmine 2.0, and run with the Karma Test Runner. We provide a Karma configuration file to run them.

  • Configuration for karma is found in karma.conf.js
  • Unit tests are to be named as follows: *.spec.coffee

Grunt tasks

Note: if using local grunt (described above), replace grunt in all commands listed below with ./grunt.

e.g. grunt build becomes ./grunt build

grunt build

This tasks compiles Coffeescript source files to Javascript in the build directory. It watches those files for changes, and re-compiles them on change.

This is the default grunt task.

Command: grunt or grunt build.

This task also gives you the option of running unit tests and compiling Coffeescript source files simultaneously. Tests will automatically re-run in response to changes in the source code / specs.

Command: grunt --test or grunt build --test

grunt test

This tasks compiles Coffeescript source files to Javascript in the build directory, and runs a single run of unit tests, outputing the test results to the console. Changes to files are not watched and the task terminates as soon as the unit tests complete.

Command: grunt test