Skip to content

An ESlint plugin that provides set of rules for Ember Applications based on commonly known good practices.

License

Notifications You must be signed in to change notification settings

rrenno/eslint-plugin-ember

Β 
Β 

Repository files navigation

eslint-plugin-ember

NPM version NPM downloads CI

An ESlint plugin that provides set of rules for Ember Applications based on commonly known good practices.

❗️Requirements

πŸš€ Usage

1. Install plugin

yarn add --dev eslint-plugin-ember

Or

npm install --save-dev eslint-plugin-ember

2. Modify your .eslintrc.js

// .eslintrc.js
module.exports = {
  plugins: ['ember'],
  extends: [
    'eslint:recommended',
    'plugin:ember/recommended' // or other configuration
  ],
  rules: {
    // override rule settings here
    'ember/no-jquery': 'error'
  }
};

🧰 Configurations

Name Description
base contains no rules settings, but the basic eslint configuration suitable for any ember project. You can use it to configure rules as you wish.
βœ… recommended extends the base configuration by enabling the recommended rules.
πŸš— octane extends the recommended configuration by enabling octane rules. This ruleset is currently considered unstable and experimental ⚠️ as rules may be added and removed until the final ruleset is settled upon.

🍟 Rules

Rules are grouped by category to help you understand their purpose. Each rule has emojis denoting:

  • What configuration it belongs to
  • πŸ”§ if some problems reported by the rule are automatically fixable by the --fix command line option

Components

Rule ID Description
βœ… no-attrs-in-components disallow usage of this.attrs in components
βœ… no-attrs-snapshot disallow use of attrs snapshot in the didReceiveAttrs and didUpdateAttrs component hooks
πŸš— no-classic-components enforce using Glimmer components
πŸš— no-component-lifecycle-hooks disallow usage of "classic" ember component lifecycle hooks. Render modifiers or custom functional modifiers should be used instead.
βœ… no-on-calls-in-components disallow usage of on to call lifecycle hooks in components
πŸš— require-tagless-components disallow using the wrapper element of a component

Computed Properties

Rule ID Description
computed-property-getters enforce the consistent use of getters in computed properties
βœ… no-arrow-function-computed-properties disallow arrow functions in computed properties
πŸ”§ no-assignment-of-untracked-properties-used-in-tracking-contexts disallow assignment of untracked properties that are used as computed property dependencies
πŸš— no-computed-properties-in-native-classes disallow using computed properties in native classes
βœ… no-deeply-nested-dependent-keys-with-each disallow usage of deeply-nested computed property dependent keys with @each
βœ…πŸ”§ no-duplicate-dependent-keys disallow repeating computed property dependent keys
βœ…πŸ”§ no-incorrect-computed-macros disallow incorrect usage of computed property macros
βœ…πŸ”§ no-invalid-dependent-keys disallow invalid dependent keys in computed properties
βœ… no-side-effects disallow unexpected side effects in computed properties
βœ… no-volatile-computed-properties disallow volatile computed properties
βœ…πŸ”§ require-computed-macros require using computed property macros when possible
βœ…πŸ”§ require-computed-property-dependencies require dependencies to be declared statically in computed properties
βœ… require-return-from-computed disallow missing return statements in computed properties
βœ… use-brace-expansion enforce usage of brace expansion in computed property dependent keys

Controllers

Rule ID Description
alias-model-in-controller enforce aliasing model in controllers
βœ… avoid-using-needs-in-controllers disallow using needs in controllers
no-controllers disallow non-essential controllers

Deprecations

Rule ID Description
βœ… closure-actions enforce usage of closure actions
βœ… new-module-imports enforce using "New Module Imports" from Ember RFC #176
βœ… no-function-prototype-extensions disallow usage of Ember's function prototype extensions
βœ… no-mixins disallow the usage of mixins
βœ… no-new-mixins disallow the creation of new mixins
βœ… no-observers disallow usage of observers
βœ…πŸ”§ no-old-shims disallow usage of old shims for modules

Ember Data

Rule ID Description
no-empty-attrs disallow usage of empty attributes in Ember Data models
βœ…πŸ”§ use-ember-data-rfc-395-imports enforce usage of @ember-data/ package imports instead ember-data

Ember Object

Rule ID Description
βœ… avoid-leaking-state-in-ember-objects disallow state leakage
βœ…πŸ”§ no-get-with-default disallow usage of the Ember's getWithDefault function
βœ…πŸ”§ no-get require using ES5 getters instead of Ember's get / getProperties functions
no-proxies disallow using array or object proxies
βœ… require-super-in-init require this._super to be called in init hooks
πŸ”§ use-ember-get-and-set enforce usage of Ember.get and Ember.set

Ember Octane

Rule ID Description
πŸš— classic-decorator-hooks enforce using correct hooks for both classic and non-classic classes
πŸš— classic-decorator-no-classic-methods disallow usage of classic APIs such as get/set in classes that aren't explicitly decorated with @classic
πŸš— no-actions-hash disallow the actions hash in components, controllers, and routes
πŸš— no-classic-classes disallow "classic" classes in favor of native JS classes
βœ…πŸ”§ no-ember-super-in-es-classes disallow use of this._super in ES class methods

jQuery

Rule ID Description
βœ… jquery-ember-run disallow usage of jQuery without an Ember run loop
βœ… no-global-jquery disallow usage of global jQuery object
βœ… no-jquery disallow any usage of jQuery

Miscellaneous

Rule ID Description
named-functions-in-promises enforce usage of named functions in promises
βœ… no-incorrect-calls-with-inline-anonymous-functions disallow inline anonymous functions as arguments to debounce, once, and scheduleOnce
βœ… no-invalid-debug-function-arguments disallow usages of Ember's assert() / warn() / deprecate() functions that have the arguments passed in the wrong order.
no-restricted-service-injections disallow injecting certain services under certain paths

Routes

Rule ID Description
βœ… no-capital-letters-in-routes disallow routes with uppercased letters in router.js
βœ… no-private-routing-service disallow injecting the private routing service
no-unnecessary-index-route disallow unnecessary index route definition
βœ…πŸ”§ no-unnecessary-route-path-option disallow unnecessary usage of the route path option
route-path-style enforce usage of kebab-case (instead of snake_case or camelCase) in route paths
βœ… routes-segments-snake-case enforce usage of snake_cased dynamic segments in routes

Stylistic Issues

Rule ID Description
πŸ”§ no-unnecessary-service-injection-argument disallow unnecessary argument when injecting services
πŸ”§ order-in-components enforce proper order of properties in components
πŸ”§ order-in-controllers enforce proper order of properties in controllers
πŸ”§ order-in-models enforce proper order of properties in models
πŸ”§ order-in-routes enforce proper order of properties in routes

Testing

Rule ID Description
βœ… no-ember-testing-in-module-scope disallow use of Ember.testing in module scope
no-invalid-test-waiters disallow incorrect usage of test waiter APIs
βœ… no-legacy-test-waiters disallow the use of the legacy test waiter APIs
βœ… no-pause-test disallow usage of the pauseTest helper in tests
no-replace-test-comments disallow 'Replace this with your real tests' comments in test files
βœ… no-restricted-resolver-tests disallow the use of patterns that use the restricted resolver in tests
βœ… no-test-and-then disallow usage of the andThen test wait helper
βœ… no-test-import-export disallow importing of "-test.js" in a test file and exporting from a test file
βœ… no-test-module-for disallow usage of moduleFor, moduleForComponent, etc
no-test-this-render disallow usage of the this.render in tests, recommending to use @ember/test-helpers' render instead.
prefer-ember-test-helpers enforce usage of @ember/test-helpers methods over native window methods

For the simplified list of rules, go here.

🍻 Contribution Guide

If you have any suggestions, ideas, or problems, feel free to create an issue, but first please make sure your question does not repeat previous ones.

Creating a New Rule

  • Create an issue with a description of the proposed rule
  • Create files for the new rule:
    • lib/rules/new-rule.js (implementation, see no-proxies for an example)
    • docs/rules/new-rule.md (documentation, start from the template -- raw, rendered)
    • tests/lib/rules/new-rule.js (tests, see no-proxies for an example)
  • Run yarn update to automatically update the README and other files (and re-run this if you change the rule name or description)
  • Make sure your changes will pass CI by running:
    • yarn test
    • yarn lint (yarn lint:js --fix can fix many errors)
  • Create a PR and link the created issue in the description

Note that new rules should not immediately be added to the recommended configuration, as we only consider such breaking changes during major version updates.

πŸ”“ License

See the LICENSE file for license rights and limitations (MIT).

About

An ESlint plugin that provides set of rules for Ember Applications based on commonly known good practices.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%