-
Notifications
You must be signed in to change notification settings - Fork 4
/
stylelint.config.js
63 lines (63 loc) · 2.49 KB
/
stylelint.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
module.exports = {
extends: [
// Use the Standard config as the base
// https://github.com/stylelint/stylelint-config-standard
'stylelint-config-standard',
// Enforce a standard order for CSS properties
// https://github.com/stormwarning/stylelint-config-recess-order
'stylelint-config-recess-order',
// Override rules that would interfere with Prettier
// https://github.com/shannonmoeller/stylelint-config-prettier
'stylelint-config-prettier',
// Override rules to allow linting of CSS modules
// https://github.com/pascalduez/stylelint-config-css-modules
'stylelint-config-css-modules',
],
plugins: [
// Bring in some extra rules for SCSS
'stylelint-scss',
],
// Rule lists:
// - https://stylelint.io/user-guide/rules/
// - https://github.com/kristerkari/stylelint-scss#list-of-rules
rules: {
// Allow newlines inside class attribute values
'string-no-newline': null,
// Enforce camelCase for classes and ids, to work better
// with CSS modules
'selector-class-pattern': /^[a-z][a-zA-Z]*(-(enter|leave)(-(active|to))?)?$/,
'selector-id-pattern': /^[a-z][a-zA-Z]*$/,
// Limit the number of universal selectors in a selector,
// to avoid very slow selectors
'selector-max-universal': 1,
// Disallow allow global element/type selectors in scoped modules
'selector-max-type': [0, { ignore: ['child', 'descendant', 'compounded'] }],
// ===
// PRETTIER
// ===
// HACK: to compensate for https://github.com/shannonmoeller/stylelint-config-prettier/issues/4
// Modifying setting from Standard: https://github.com/stylelint/stylelint-config-standard/blob/7b76d7d0060f2e13a331806a09c2096c7536b0a6/index.js#L6
'at-rule-empty-line-before': [
'always',
{
except: ['blockless-after-same-name-blockless', 'first-nested'],
ignore: ['after-comment'],
ignoreAtRules: ['else'],
},
],
// ===
// SCSS
// ===
'scss/dollar-variable-colon-space-after': 'always',
'scss/dollar-variable-colon-space-before': 'never',
'scss/dollar-variable-no-missing-interpolation': true,
'scss/dollar-variable-pattern': /^[a-z-]+$/,
'scss/double-slash-comment-whitespace-inside': 'always',
'scss/operator-no-newline-before': true,
'scss/operator-no-unspaced': true,
'scss/selector-no-redundant-nesting-selector': true,
// Allow SCSS and CSS module keywords beginning with `@`
'at-rule-no-unknown': null,
'scss/at-rule-no-unknown': true,
},
}