|
1 |
| -"use strict" |
| 1 | +'use strict'; |
2 | 2 |
|
3 | 3 | module.exports = {
|
4 |
| - "extends": "stylelint-config-standard", |
5 |
| - "customSyntax": "scss", |
6 |
| - "plugins": [ |
7 |
| - "stylelint-scss" |
8 |
| - ], |
9 |
| - "ignoreFiles": [ |
10 |
| - "sass/vendor/*.scss" |
11 |
| - ], |
12 |
| - "rules": { |
13 |
| - "at-rule-empty-line-before": [ |
14 |
| - "always", |
| 4 | + 'extends': 'stylelint-config-standard-scss', |
| 5 | + 'customSyntax': 'postcss-scss', |
| 6 | + 'rules': { |
| 7 | + 'alpha-value-notation': 'number', |
| 8 | + 'block-no-empty': true, |
| 9 | + 'color-hex-length': 'long', |
| 10 | + 'comment-no-empty': true, |
| 11 | + 'declaration-empty-line-before': 'never', |
| 12 | + 'font-weight-notation': 'numeric', |
| 13 | + 'keyframes-name-pattern': [ |
| 14 | + '^[a-z]+((\\d)|([A-Z0-9][a-z0-9]+))*([A-Z])*$', |
15 | 15 | {
|
16 |
| - "except": [ |
17 |
| - "blockless-after-same-name-blockless", |
18 |
| - "first-nested" |
19 |
| - ], |
20 |
| - "ignore": [ |
21 |
| - "after-comment" |
22 |
| - ], |
23 |
| - "ignoreAtRules": [ |
24 |
| - "extend", |
25 |
| - "include", |
26 |
| - "else", |
27 |
| - "elseif", |
28 |
| - "content" |
29 |
| - ] |
30 |
| - } |
31 |
| - ], |
32 |
| - "at-rule-no-unknown": [ |
33 |
| - true, |
34 |
| - { |
35 |
| - "ignoreAtRules": [ |
36 |
| - "content", |
37 |
| - "extend", |
38 |
| - "include", |
39 |
| - "mixin", |
40 |
| - "container", |
41 |
| - "if", |
42 |
| - "for", |
43 |
| - "forward", |
44 |
| - "else", |
45 |
| - "elseif", |
46 |
| - "error", |
47 |
| - "each", |
48 |
| - "function", |
49 |
| - "return", |
50 |
| - "use", |
51 |
| - "while" |
52 |
| - ] |
53 |
| - } |
| 16 | + message: (name) => `Expected keyframe name '${name}' to be camelCase`, |
| 17 | + }, |
54 | 18 | ],
|
55 |
| - "at-rule-name-space-after": "always", |
56 |
| - "function-comma-newline-before": "never-multi-line", |
57 |
| - "function-name-case": [ |
58 |
| - "lower", |
| 19 | + 'no-descending-specificity': null, |
| 20 | + 'no-duplicate-selectors': true, |
| 21 | + 'no-empty-source': true, |
| 22 | + 'selector-class-pattern': [ |
| 23 | + '^[a-z]([-]?[a-z0-9]+)*(__[a-z0-9]([-]?[a-z0-9]+)*)?(--[a-z0-9]([-]?[a-z0-9]+)*)?$', |
59 | 24 | {
|
60 |
| - "ignoreFunctions": [ |
61 |
| - "/^[a-z][a-z-A-Z0-9]*$/" |
62 |
| - ] |
63 |
| - } |
64 |
| - ], |
65 |
| - "function-no-unknown": null, // https://github.com/stylelint-scss/stylelint-scss/issues/589 |
66 |
| - "block-closing-brace-newline-after": [ |
67 |
| - "always", |
68 |
| - { |
69 |
| - "ignoreAtRules": [ "if", "else", "elseif" ] |
70 |
| - } |
| 25 | + resolveNestedSelectors: true, |
| 26 | + message: (selector) => `Expected class selector '${selector}' to match BEM CSS pattern (https://en.bem.info/methodology/css). Selector validation tool: https://regexr.com/3apms`, |
| 27 | + }, |
71 | 28 | ],
|
72 |
| - "font-weight-notation": "numeric", |
73 |
| - "string-quotes": "single", |
74 |
| - "value-keyword-case": [ |
75 |
| - "lower", |
| 29 | + 'selector-max-compound-selectors': 3, |
| 30 | + 'selector-max-id': 0, |
| 31 | + 'selector-max-type': 2, |
| 32 | + 'selector-max-combinators': 2, |
| 33 | + 'selector-max-universal': 1, |
| 34 | + 'selector-max-specificity': '0,3,0', |
| 35 | + 'value-keyword-case': [ |
| 36 | + 'lower', |
76 | 37 | {
|
77 | 38 | camelCaseSvgKeywords: true,
|
78 | 39 | }
|
79 | 40 | ],
|
80 |
| - "declaration-empty-line-before": "never", |
81 |
| - "selector-attribute-quotes": "always", |
82 |
| - "selector-class-pattern": "^[a-z][a-z-A-Z_0-9]*$", |
83 |
| - "selector-max-compound-selectors": [ |
84 |
| - 3, |
| 41 | + 'scss/at-function-pattern': [ |
| 42 | + '^[a-z]+((\\d)|([A-Z0-9][a-z0-9]+))*([A-Z])*$', |
85 | 43 | {
|
86 |
| - "severity": "warning" |
87 |
| - } |
| 44 | + message: 'Expected function name to be camelCase', |
| 45 | + }, |
88 | 46 | ],
|
89 |
| - "selector-max-id": 0, |
90 |
| - "selector-max-type": [ |
91 |
| - 2, |
| 47 | + 'scss/at-mixin-argumentless-call-parentheses': 'always', |
| 48 | + 'scss/at-mixin-pattern': [ |
| 49 | + '^[a-z]+((\\d)|([A-Z0-9][a-z0-9]+))*([A-Z])*$', |
92 | 50 | {
|
93 |
| - "severity": "warning" |
94 |
| - } |
| 51 | + message: 'Expected mixin to be camelCase', |
| 52 | + }, |
95 | 53 | ],
|
96 |
| - "selector-max-combinators": [ |
97 |
| - 2, |
| 54 | + 'scss/declaration-nested-properties': 'never', |
| 55 | + 'scss/double-slash-comment-empty-line-before': null, |
| 56 | + 'scss/dollar-variable-pattern': [ |
| 57 | + '^[a-z]+((\\d)|([A-Z0-9][a-z0-9]+))*([A-Z])*$', |
98 | 58 | {
|
99 |
| - "severity": "warning" |
100 |
| - } |
| 59 | + message: 'Expected variable to be camelCase', |
| 60 | + }, |
101 | 61 | ],
|
102 |
| - "selector-max-universal": 1, |
103 |
| - "selector-max-specificity": "0,3,0", |
104 |
| - "selector-list-comma-newline-before": "never-multi-line", |
105 |
| - "selector-list-comma-space-after": "always-single-line", |
106 |
| - "custom-media-pattern": "^[a-z][a-z-A-Z0-9]*$", |
107 |
| - "media-feature-parentheses-space-inside": "never", |
108 |
| - "media-query-list-comma-newline-before": "never-multi-line", |
109 |
| - "at-rule-semicolon-space-before": "never", |
110 |
| - "indentation": 4, |
111 |
| - "max-line-length": 120, |
112 |
| - "no-descending-specificity": null, |
113 |
| - "no-duplicate-selectors": true, |
114 |
| - "no-empty-source": true, |
115 |
| - "block-no-empty": true, |
116 |
| - "color-hex-length": "long", |
117 |
| - "color-hex-case": ["upper"], |
118 |
| - "rule-empty-line-before": [ |
119 |
| - "always", |
| 62 | + 'scss/no-global-function-names': null, |
| 63 | + 'scss/percent-placeholder-pattern': [ |
| 64 | + '^[a-z][a-z-A-Z0-9]*$', |
120 | 65 | {
|
121 |
| - "except": [ |
122 |
| - "first-nested" |
123 |
| - ], |
124 |
| - "ignore": [ |
125 |
| - "after-comment" |
126 |
| - ] |
127 |
| - } |
128 |
| - ], |
129 |
| - "shorthand-property-no-redundant-values": true, |
130 |
| - "scss/dollar-variable-pattern": "^[a-z][a-z-A-Z0-9]*$", |
131 |
| - "scss/dollar-variable-colon-space-after": "always-single-line", |
132 |
| - "scss/dollar-variable-colon-space-before": "never", |
133 |
| - "scss/dollar-variable-empty-line-before": [ |
134 |
| - "always", |
135 |
| - { |
136 |
| - "except": [ |
137 |
| - "first-nested", |
138 |
| - "after-comment", |
139 |
| - "after-dollar-variable" |
140 |
| - ] |
141 |
| - } |
| 66 | + message: 'Expected placeholder to be camelCase', |
| 67 | + }, |
142 | 68 | ],
|
143 |
| - "scss/percent-placeholder-pattern": "^[a-z][a-z-A-Z0-9]*$", |
144 |
| - "scss/double-slash-comment-whitespace-inside": "always", |
145 |
| - "scss/declaration-nested-properties": "never", |
146 |
| - "scss/operator-no-newline-after": true, |
147 |
| - "scss/operator-no-newline-before": true, |
148 |
| - "scss/operator-no-unspaced": true, |
149 |
| - "scss/at-else-if-parentheses-space-before": "always", |
150 |
| - "scss/at-function-parentheses-space-before": "never", |
151 |
| - "scss/at-function-pattern": "^[a-z][a-z-A-Z0-9]*$", |
152 |
| - "scss/at-mixin-parentheses-space-before": "never", |
153 |
| - "scss/at-else-closing-brace-newline-after": "always-last-in-chain", |
154 |
| - "scss/at-else-closing-brace-space-after": "always-intermediate", |
155 |
| - "scss/at-else-empty-line-before": "never", |
156 |
| - "scss/at-if-closing-brace-newline-after": "always-last-in-chain", |
157 |
| - "scss/at-if-closing-brace-space-after": "always-intermediate" |
158 | 69 | }
|
159 | 70 | }
|
0 commit comments