Skip to content

croct-tech/coding-standard-js

 
 

Repository files navigation

Croct
JavaScript Coding Standard
A set of ESLint rules applied to all Croct JavaScript projects.

Version Build Maintainability Coverage

📦 Releases · 🐞 Report Bug · ✨ Request Feature

Installation

The recommended way to install the package is via NPM. It pairs nicely with module bundlers such as Webpack or Browserify:

npm i -D @croct/eslint-plugin

Then, add the following to your .eslintrc.js file:

// Workaround for https://github.com/eslint/eslint/issues/3458
require("@rushstack/eslint-patch/modern-module-resolution");

module.exports = {
   "plugins": ["@croct"]
}

Note the require call at the top of the file. This is a workaround to avoid adding the transitive dependencies of the plugin to the project, which is currently not supported by the ESLint plugin system.

TypeScript

For TypeScript projects, you need first to install the TypeScript parser:

npm i -D @typescript-eslint/parser

Then, add the following to your .eslintrc.js file:

// Workaround for https://github.com/eslint/eslint/issues/3458
require("@rushstack/eslint-patch/modern-module-resolution");

module.exports = {
    "parser": "@typescript-eslint/parser",
    "plugins": [
      "@croct"
    ],
    "extends": [
      "plugin:@croct/typescript"
    ],
    "parserOptions": {
      "extends": "./tsconfig.json",
      "project": ["./tsconfig.json"]
    },
}

For the list for available presets and rules, see the reference documentation.

Basic usage

Run the following command to check if the project adheres to the coding standard:

eslint

Contributing

Contributions to the package are always welcome!

  • Report any bugs or issues on the issue tracker.
  • For major changes, please open an issue first to discuss what you would like to change.
  • Please make sure to update tests as appropriate.

Testing

Before running the test suites, the development dependencies must be installed:

npm i

Then, to run all tests:

npm run test

Copyright Notice

Copyright © 2015-2021 Croct Limited, All Rights Reserved.

All information contained herein is, and remains the property of Croct Limited. The intellectual, design and technical concepts contained herein are proprietary to Croct Limited s and may be covered by U.S. and Foreign Patents, patents in process, and are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is strictly forbidden unless prior written permission is obtained from Croct Limited.