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

eslint-config-exchange-solutions

v7.0.0

Published

ESLint Default configurations for Towers Watson Exchange Solutions

Downloads

9

Readme

Towers Watson Exchange Solutions JavaScript Style Guide

Build Status

We are extending the Airbnb Style Guide, with overrides for things we do not plan to prescribe to.

Table of Contents

  1. Usage
  2. With React Style
  3. Without React Style
  4. Es5
  5. Rules
  6. Commas

Usage

With React Style

  1. npm install --save-dev eslint-config-exchange-solutions babel-eslint eslint-plugin-react
  2. add "extends": "exchange-solutions" to your .eslintrc

Without React Style

  1. npm install --save-dev eslint-config-exchange-solutions babel-eslint
  2. add "extends": "exchange-solutions/base" to your .eslintrc

ES5 - Rule Documenation

  1. npm install --save-dev eslint-config-exchange-solutions
  2. add "extends": "exchange-solutions/es5" to your .eslintrc

See Airbnb's Javascript styleguide, Towers Watson Exchange Solutions styleguide and the ESlint config docs for more information.

Rules

Commas

  • 1 Additional trailing comma: Nope.

Airbnb [states] that this rule makes git diffs cleaner, though we don't really see any significant value in this especially for Arrays or Objects that only have one item.

// bad const hero = { firstName: 'Dana', lastName: 'Scully', };

const heroes = [ 'Batman', 'Superman', ];

// good const hero = { firstName: 'Dana', lastName: 'Scully' };

const heroes = [ 'Batman', 'Superman' ];

⬆ back to top

Curly braces around objects

⬆ back to top

Unary increments and decrements

  • 1 You can use ++ for loops, but otherwise use += 1 or -= 1 syntax.

The Airbnb example suggests that array methods such as filter and reduce should be used over traditional loops. We agree that those options are often better. However, we find value, in cases where loops are necessary, to be allowed the convenience of unary increment statements for the loop declaration. Otherwise, we agree with their reasoning about unary increment and decrement statements.

// bad

const array = [1, 2, 3];
let num = 1;
num++;
--num;


// good

const array = [1, 2, 3];
let num = 1;
num += 1;
num -= 1;

for (let i = 0; i < array.length; i++) {
  console.log(`The value at ${i} is ${array[i]}`);
}

⬆ back to top