-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.stylelintrc.js
108 lines (100 loc) · 2.51 KB
/
.stylelintrc.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
const recessPropertyGroups = require("stylelint-config-recess-order/groups");
const PANORAMA_TYPES = [
"/^DOTA/",
"Button",
"DragZoom",
"DropDown",
"DropDownMenu",
"EdgeScrollBar",
"EdgeScroller",
"HorizontalScrollBar",
"Image",
"Label",
"NumberEntry",
"Panel",
"ProgressBar",
"RadioButton",
"SimpleContextMenu",
"Slider",
"SlottedSlider",
"TextButton",
"TextEntry",
"TextEntryAutocomplete",
"ToggleButton",
"VerticalScrollBar",
];
const PANORAMA_PROPERTY_GROUPS = [
// compose
[],
// all
[],
// position
[],
// display
[],
// flex
["flow-children"],
// grid
[],
// gap
[],
// layout
["align", "horizontal-align"],
// order
[],
// box model
[],
// typography
[],
// accessibility & interactions
["tooltip-body-position", "tooltip-position"],
// images, backgrounds, & borders
["brightness", "blur", "contrast", "saturation", "wash-color"],
// masking
["opacity-mask"],
// svg
[],
// transitions & animation
["pre-transform-scale2d", "sound"],
];
const PANORAMA_PROPERTIES = PANORAMA_PROPERTY_GROUPS.flat();
const PANORAMA_FUNCTIONS = [
"color-stop",
"fill-parent-flow",
"from",
"gaussian",
"gradient",
"to",
"width-percentage",
];
const PANORAMA_PSEUDO_CLASSES = ["selected"];
const propertyGroups = [];
for (const [i, group] of recessPropertyGroups.entries()) {
propertyGroups.push({
...group,
properties: [...group.properties, ...PANORAMA_PROPERTY_GROUPS[i]],
});
}
module.exports = {
plugins: ["stylelint-order"],
extends: ["stylelint-config-standard"],
reportInvalidScopeDisables: true,
reportNeedlessDisables: true,
rules: {
"at-rule-empty-line-before": null,
"at-rule-no-unknown": [true, { ignoreAtRules: ["define"] }],
"alpha-value-notation": "number",
"color-function-notation": "legacy",
"font-family-no-missing-generic-family-keyword": null,
"keyframes-name-pattern": "'[\\w-]+'",
"function-no-unknown": [true, { ignoreFunctions: PANORAMA_FUNCTIONS }],
"property-no-unknown": [true, { ignoreProperties: PANORAMA_PROPERTIES }],
"selector-id-pattern": "[a-zA-Z-]+",
"selector-class-pattern": "[a-zA-Z-]+",
"selector-pseudo-class-no-unknown": [true, { ignorePseudoClasses: PANORAMA_PSEUDO_CLASSES }],
"selector-type-case": ["lower", { ignoreTypes: PANORAMA_TYPES }],
"selector-type-no-unknown": [true, { ignoreTypes: PANORAMA_TYPES }],
"value-keyword-case": null,
"order/properties-order": [propertyGroups, { unspecified: "bottomAlphabetical" }],
},
};