-
Notifications
You must be signed in to change notification settings - Fork 3
/
stylelint.config.js
84 lines (84 loc) · 2.44 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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
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",
],
plugins: [
// Bring in some extra rules for SCSS
"stylelint-scss",
"stylelint-declaration-use-variable",
],
// 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,
"selector-class-pattern": /^[a-z][a-z0-9-_]+$/,
"selector-id-pattern": /^[a-z][a-z0-9-_]+$/,
// Limit the number of universal selectors in a selector,
// to avoid very slow selectors
"selector-max-universal": 1,
// enforce variable usage
"sh-waqar/declaration-use-variable": [
[
"/color/",
"font-family",
"font-size",
"font-weight",
"line-height",
"/padding/",
"/margin/",
"z-index",
"border-radius",
{
ignoreValues: [
"transparent",
"inherit",
"initial",
"0",
"100%",
"/100v/",
"auto",
"0 auto",
"none",
],
},
],
],
// ===
// 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][a-z0-9-_]+$/,
"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,
},
};