@spiracss/stylelint-plugin 0.2.1 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +14 -15
- package/dist/cjs/helpers.d.ts +109 -34
- package/dist/cjs/helpers.d.ts.map +1 -1
- package/dist/cjs/helpers.js +257 -169
- package/dist/cjs/helpers.js.map +1 -1
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +4 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.js +96 -40
- package/dist/cjs/rules/spiracss-class-structure.js.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.messages.d.ts +10 -8
- package/dist/cjs/rules/spiracss-class-structure.messages.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.messages.js +59 -26
- package/dist/cjs/rules/spiracss-class-structure.messages.js.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.options.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.options.js +71 -56
- package/dist/cjs/rules/spiracss-class-structure.options.js.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.patterns.d.ts +4 -4
- package/dist/cjs/rules/spiracss-class-structure.patterns.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.patterns.js +24 -27
- package/dist/cjs/rules/spiracss-class-structure.patterns.js.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.selectors.d.ts +3 -4
- package/dist/cjs/rules/spiracss-class-structure.selectors.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.selectors.js +34 -60
- package/dist/cjs/rules/spiracss-class-structure.selectors.js.map +1 -1
- package/dist/cjs/rules/spiracss-class-structure.types.d.ts +32 -12
- package/dist/cjs/rules/spiracss-class-structure.types.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-properties.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-properties.js +207 -116
- package/dist/cjs/rules/spiracss-interaction-properties.js.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-properties.messages.d.ts +4 -3
- package/dist/cjs/rules/spiracss-interaction-properties.messages.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-properties.messages.js +11 -12
- package/dist/cjs/rules/spiracss-interaction-properties.messages.js.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-properties.options.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-properties.options.js +12 -14
- package/dist/cjs/rules/spiracss-interaction-properties.options.js.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-properties.types.d.ts +9 -5
- package/dist/cjs/rules/spiracss-interaction-properties.types.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.js +21 -21
- package/dist/cjs/rules/spiracss-interaction-scope.js.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.messages.d.ts +4 -3
- package/dist/cjs/rules/spiracss-interaction-scope.messages.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.messages.js +9 -11
- package/dist/cjs/rules/spiracss-interaction-scope.messages.js.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.options.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.options.js +35 -41
- package/dist/cjs/rules/spiracss-interaction-scope.options.js.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.types.d.ts +14 -14
- package/dist/cjs/rules/spiracss-interaction-scope.types.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.utils.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-interaction-scope.utils.js +31 -11
- package/dist/cjs/rules/spiracss-interaction-scope.utils.js.map +1 -1
- package/dist/cjs/rules/spiracss-keyframes-naming.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-keyframes-naming.js +31 -28
- package/dist/cjs/rules/spiracss-keyframes-naming.js.map +1 -1
- package/dist/cjs/rules/spiracss-keyframes-naming.messages.d.ts +6 -4
- package/dist/cjs/rules/spiracss-keyframes-naming.messages.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-keyframes-naming.messages.js +12 -25
- package/dist/cjs/rules/spiracss-keyframes-naming.messages.js.map +1 -1
- package/dist/cjs/rules/spiracss-keyframes-naming.options.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-keyframes-naming.options.js +46 -24
- package/dist/cjs/rules/spiracss-keyframes-naming.options.js.map +1 -1
- package/dist/cjs/rules/spiracss-keyframes-naming.types.d.ts +21 -11
- package/dist/cjs/rules/spiracss-keyframes-naming.types.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-page-layer.constants.d.ts +2 -0
- package/dist/cjs/rules/spiracss-page-layer.constants.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.constants.js +5 -0
- package/dist/cjs/rules/spiracss-page-layer.constants.js.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.d.ts +5 -0
- package/dist/cjs/rules/spiracss-page-layer.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.js +243 -0
- package/dist/cjs/rules/spiracss-page-layer.js.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.messages.d.ts +7 -0
- package/dist/cjs/rules/spiracss-page-layer.messages.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.messages.js +15 -0
- package/dist/cjs/rules/spiracss-page-layer.messages.js.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.options.d.ts +4 -0
- package/dist/cjs/rules/spiracss-page-layer.options.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.options.js +59 -0
- package/dist/cjs/rules/spiracss-page-layer.options.js.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.types.d.ts +19 -0
- package/dist/cjs/rules/spiracss-page-layer.types.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-page-layer.types.js +3 -0
- package/dist/cjs/rules/spiracss-page-layer.types.js.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.constants.d.ts +2 -0
- package/dist/cjs/rules/spiracss-property-placement.constants.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.constants.js +5 -0
- package/dist/cjs/rules/spiracss-property-placement.constants.js.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.d.ts +5 -0
- package/dist/cjs/rules/spiracss-property-placement.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.js +646 -0
- package/dist/cjs/rules/spiracss-property-placement.js.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.messages.d.ts +19 -0
- package/dist/cjs/rules/spiracss-property-placement.messages.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.messages.js +110 -0
- package/dist/cjs/rules/spiracss-property-placement.messages.js.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.options.d.ts +4 -0
- package/dist/cjs/rules/spiracss-property-placement.options.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.options.js +74 -0
- package/dist/cjs/rules/spiracss-property-placement.options.js.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.selectors.d.ts +41 -0
- package/dist/cjs/rules/spiracss-property-placement.selectors.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.selectors.js +983 -0
- package/dist/cjs/rules/spiracss-property-placement.selectors.js.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.types.d.ts +28 -0
- package/dist/cjs/rules/spiracss-property-placement.types.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.types.js +3 -0
- package/dist/cjs/rules/spiracss-property-placement.types.js.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.values.d.ts +19 -0
- package/dist/cjs/rules/spiracss-property-placement.values.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-property-placement.values.js +176 -0
- package/dist/cjs/rules/spiracss-property-placement.values.js.map +1 -0
- package/dist/cjs/rules/spiracss-pseudo-nesting.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-pseudo-nesting.js +18 -18
- package/dist/cjs/rules/spiracss-pseudo-nesting.js.map +1 -1
- package/dist/cjs/rules/spiracss-pseudo-nesting.messages.d.ts +6 -0
- package/dist/cjs/rules/spiracss-pseudo-nesting.messages.d.ts.map +1 -0
- package/dist/cjs/rules/spiracss-pseudo-nesting.messages.js +10 -0
- package/dist/cjs/rules/spiracss-pseudo-nesting.messages.js.map +1 -0
- package/dist/cjs/rules/spiracss-pseudo-nesting.types.d.ts +1 -1
- package/dist/cjs/rules/spiracss-pseudo-nesting.types.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.alias.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.alias.js +59 -11
- package/dist/cjs/rules/spiracss-rel-comments.alias.js.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.js +68 -38
- package/dist/cjs/rules/spiracss-rel-comments.js.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.messages.d.ts +5 -4
- package/dist/cjs/rules/spiracss-rel-comments.messages.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.messages.js +16 -12
- package/dist/cjs/rules/spiracss-rel-comments.messages.js.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.options.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.options.js +62 -34
- package/dist/cjs/rules/spiracss-rel-comments.options.js.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.selectors.d.ts.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.selectors.js +4 -5
- package/dist/cjs/rules/spiracss-rel-comments.selectors.js.map +1 -1
- package/dist/cjs/rules/spiracss-rel-comments.types.d.ts +29 -15
- package/dist/cjs/rules/spiracss-rel-comments.types.d.ts.map +1 -1
- package/dist/cjs/types.d.ts +2 -0
- package/dist/cjs/types.d.ts.map +1 -1
- package/dist/cjs/utils/cache.d.ts +3 -0
- package/dist/cjs/utils/cache.d.ts.map +1 -1
- package/dist/cjs/utils/cache.js +30 -6
- package/dist/cjs/utils/cache.js.map +1 -1
- package/dist/cjs/utils/constants.d.ts +1 -0
- package/dist/cjs/utils/constants.d.ts.map +1 -1
- package/dist/cjs/utils/constants.js +14 -1
- package/dist/cjs/utils/constants.js.map +1 -1
- package/dist/cjs/utils/formatting.d.ts +5 -1
- package/dist/cjs/utils/formatting.d.ts.map +1 -1
- package/dist/cjs/utils/formatting.js +16 -7
- package/dist/cjs/utils/formatting.js.map +1 -1
- package/dist/cjs/utils/messages.d.ts +25 -0
- package/dist/cjs/utils/messages.d.ts.map +1 -0
- package/dist/cjs/utils/messages.js +174 -0
- package/dist/cjs/utils/messages.js.map +1 -0
- package/dist/cjs/utils/naming.d.ts +1 -2
- package/dist/cjs/utils/naming.d.ts.map +1 -1
- package/dist/cjs/utils/naming.js +1 -9
- package/dist/cjs/utils/naming.js.map +1 -1
- package/dist/cjs/utils/normalize.d.ts +1 -0
- package/dist/cjs/utils/normalize.d.ts.map +1 -1
- package/dist/cjs/utils/normalize.js +53 -8
- package/dist/cjs/utils/normalize.js.map +1 -1
- package/dist/cjs/utils/option-schema.d.ts +11 -8
- package/dist/cjs/utils/option-schema.d.ts.map +1 -1
- package/dist/cjs/utils/option-schema.js +12 -9
- package/dist/cjs/utils/option-schema.js.map +1 -1
- package/dist/cjs/utils/options.d.ts +34 -0
- package/dist/cjs/utils/options.d.ts.map +1 -0
- package/dist/cjs/utils/options.js +41 -0
- package/dist/cjs/utils/options.js.map +1 -0
- package/dist/cjs/utils/rule-docs.d.ts +2 -0
- package/dist/cjs/utils/rule-docs.d.ts.map +1 -0
- package/dist/cjs/utils/rule-docs.js +22 -0
- package/dist/cjs/utils/rule-docs.js.map +1 -0
- package/dist/cjs/utils/section.d.ts.map +1 -1
- package/dist/cjs/utils/section.js +32 -39
- package/dist/cjs/utils/section.js.map +1 -1
- package/dist/cjs/utils/selector-policy.d.ts +16 -0
- package/dist/cjs/utils/selector-policy.d.ts.map +1 -0
- package/dist/cjs/utils/selector-policy.js +57 -0
- package/dist/cjs/utils/selector-policy.js.map +1 -0
- package/dist/cjs/utils/selector.d.ts +4 -1
- package/dist/cjs/utils/selector.d.ts.map +1 -1
- package/dist/cjs/utils/selector.js +62 -37
- package/dist/cjs/utils/selector.js.map +1 -1
- package/dist/cjs/utils/stylelint.d.ts +0 -1
- package/dist/cjs/utils/stylelint.d.ts.map +1 -1
- package/dist/cjs/utils/stylelint.js +18 -4
- package/dist/cjs/utils/stylelint.js.map +1 -1
- package/dist/esm/helpers.d.ts +109 -34
- package/dist/esm/helpers.d.ts.map +1 -1
- package/dist/esm/helpers.js +257 -169
- package/dist/esm/helpers.js.map +1 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.js +101 -45
- package/dist/esm/rules/spiracss-class-structure.js.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.messages.d.ts +10 -8
- package/dist/esm/rules/spiracss-class-structure.messages.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.messages.js +59 -23
- package/dist/esm/rules/spiracss-class-structure.messages.js.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.options.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.options.js +73 -58
- package/dist/esm/rules/spiracss-class-structure.options.js.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.patterns.d.ts +4 -4
- package/dist/esm/rules/spiracss-class-structure.patterns.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.patterns.js +25 -28
- package/dist/esm/rules/spiracss-class-structure.patterns.js.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.selectors.d.ts +3 -4
- package/dist/esm/rules/spiracss-class-structure.selectors.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.selectors.js +34 -59
- package/dist/esm/rules/spiracss-class-structure.selectors.js.map +1 -1
- package/dist/esm/rules/spiracss-class-structure.types.d.ts +32 -12
- package/dist/esm/rules/spiracss-class-structure.types.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-properties.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-properties.js +203 -112
- package/dist/esm/rules/spiracss-interaction-properties.js.map +1 -1
- package/dist/esm/rules/spiracss-interaction-properties.messages.d.ts +4 -3
- package/dist/esm/rules/spiracss-interaction-properties.messages.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-properties.messages.js +11 -9
- package/dist/esm/rules/spiracss-interaction-properties.messages.js.map +1 -1
- package/dist/esm/rules/spiracss-interaction-properties.options.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-properties.options.js +13 -15
- package/dist/esm/rules/spiracss-interaction-properties.options.js.map +1 -1
- package/dist/esm/rules/spiracss-interaction-properties.types.d.ts +9 -5
- package/dist/esm/rules/spiracss-interaction-properties.types.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.js +22 -22
- package/dist/esm/rules/spiracss-interaction-scope.js.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.messages.d.ts +4 -3
- package/dist/esm/rules/spiracss-interaction-scope.messages.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.messages.js +9 -8
- package/dist/esm/rules/spiracss-interaction-scope.messages.js.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.options.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.options.js +37 -43
- package/dist/esm/rules/spiracss-interaction-scope.options.js.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.types.d.ts +14 -14
- package/dist/esm/rules/spiracss-interaction-scope.types.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.utils.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-interaction-scope.utils.js +31 -11
- package/dist/esm/rules/spiracss-interaction-scope.utils.js.map +1 -1
- package/dist/esm/rules/spiracss-keyframes-naming.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-keyframes-naming.js +32 -29
- package/dist/esm/rules/spiracss-keyframes-naming.js.map +1 -1
- package/dist/esm/rules/spiracss-keyframes-naming.messages.d.ts +6 -4
- package/dist/esm/rules/spiracss-keyframes-naming.messages.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-keyframes-naming.messages.js +12 -22
- package/dist/esm/rules/spiracss-keyframes-naming.messages.js.map +1 -1
- package/dist/esm/rules/spiracss-keyframes-naming.options.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-keyframes-naming.options.js +47 -25
- package/dist/esm/rules/spiracss-keyframes-naming.options.js.map +1 -1
- package/dist/esm/rules/spiracss-keyframes-naming.types.d.ts +21 -11
- package/dist/esm/rules/spiracss-keyframes-naming.types.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-page-layer.constants.d.ts +2 -0
- package/dist/esm/rules/spiracss-page-layer.constants.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.constants.js +2 -0
- package/dist/esm/rules/spiracss-page-layer.constants.js.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.d.ts +5 -0
- package/dist/esm/rules/spiracss-page-layer.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.js +237 -0
- package/dist/esm/rules/spiracss-page-layer.js.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.messages.d.ts +7 -0
- package/dist/esm/rules/spiracss-page-layer.messages.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.messages.js +12 -0
- package/dist/esm/rules/spiracss-page-layer.messages.js.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.options.d.ts +4 -0
- package/dist/esm/rules/spiracss-page-layer.options.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.options.js +55 -0
- package/dist/esm/rules/spiracss-page-layer.options.js.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.types.d.ts +19 -0
- package/dist/esm/rules/spiracss-page-layer.types.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-page-layer.types.js +2 -0
- package/dist/esm/rules/spiracss-page-layer.types.js.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.constants.d.ts +2 -0
- package/dist/esm/rules/spiracss-property-placement.constants.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.constants.js +2 -0
- package/dist/esm/rules/spiracss-property-placement.constants.js.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.d.ts +5 -0
- package/dist/esm/rules/spiracss-property-placement.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.js +640 -0
- package/dist/esm/rules/spiracss-property-placement.js.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.messages.d.ts +19 -0
- package/dist/esm/rules/spiracss-property-placement.messages.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.messages.js +107 -0
- package/dist/esm/rules/spiracss-property-placement.messages.js.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.options.d.ts +4 -0
- package/dist/esm/rules/spiracss-property-placement.options.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.options.js +70 -0
- package/dist/esm/rules/spiracss-property-placement.options.js.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.selectors.d.ts +41 -0
- package/dist/esm/rules/spiracss-property-placement.selectors.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.selectors.js +970 -0
- package/dist/esm/rules/spiracss-property-placement.selectors.js.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.types.d.ts +28 -0
- package/dist/esm/rules/spiracss-property-placement.types.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.types.js +2 -0
- package/dist/esm/rules/spiracss-property-placement.types.js.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.values.d.ts +19 -0
- package/dist/esm/rules/spiracss-property-placement.values.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-property-placement.values.js +169 -0
- package/dist/esm/rules/spiracss-property-placement.values.js.map +1 -0
- package/dist/esm/rules/spiracss-pseudo-nesting.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-pseudo-nesting.js +18 -18
- package/dist/esm/rules/spiracss-pseudo-nesting.js.map +1 -1
- package/dist/esm/rules/spiracss-pseudo-nesting.messages.d.ts +6 -0
- package/dist/esm/rules/spiracss-pseudo-nesting.messages.d.ts.map +1 -0
- package/dist/esm/rules/spiracss-pseudo-nesting.messages.js +7 -0
- package/dist/esm/rules/spiracss-pseudo-nesting.messages.js.map +1 -0
- package/dist/esm/rules/spiracss-pseudo-nesting.types.d.ts +1 -1
- package/dist/esm/rules/spiracss-pseudo-nesting.types.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.alias.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.alias.js +59 -11
- package/dist/esm/rules/spiracss-rel-comments.alias.js.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.js +72 -42
- package/dist/esm/rules/spiracss-rel-comments.js.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.messages.d.ts +5 -4
- package/dist/esm/rules/spiracss-rel-comments.messages.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.messages.js +16 -9
- package/dist/esm/rules/spiracss-rel-comments.messages.js.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.options.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.options.js +64 -36
- package/dist/esm/rules/spiracss-rel-comments.options.js.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.selectors.d.ts.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.selectors.js +4 -5
- package/dist/esm/rules/spiracss-rel-comments.selectors.js.map +1 -1
- package/dist/esm/rules/spiracss-rel-comments.types.d.ts +29 -15
- package/dist/esm/rules/spiracss-rel-comments.types.d.ts.map +1 -1
- package/dist/esm/types.d.ts +2 -0
- package/dist/esm/types.d.ts.map +1 -1
- package/dist/esm/utils/cache.d.ts +3 -0
- package/dist/esm/utils/cache.d.ts.map +1 -1
- package/dist/esm/utils/cache.js +27 -5
- package/dist/esm/utils/cache.js.map +1 -1
- package/dist/esm/utils/constants.d.ts +1 -0
- package/dist/esm/utils/constants.d.ts.map +1 -1
- package/dist/esm/utils/constants.js +13 -0
- package/dist/esm/utils/constants.js.map +1 -1
- package/dist/esm/utils/formatting.d.ts +5 -1
- package/dist/esm/utils/formatting.d.ts.map +1 -1
- package/dist/esm/utils/formatting.js +14 -6
- package/dist/esm/utils/formatting.js.map +1 -1
- package/dist/esm/utils/messages.d.ts +25 -0
- package/dist/esm/utils/messages.d.ts.map +1 -0
- package/dist/esm/utils/messages.js +160 -0
- package/dist/esm/utils/messages.js.map +1 -0
- package/dist/esm/utils/naming.d.ts +1 -2
- package/dist/esm/utils/naming.d.ts.map +1 -1
- package/dist/esm/utils/naming.js +2 -10
- package/dist/esm/utils/naming.js.map +1 -1
- package/dist/esm/utils/normalize.d.ts +1 -0
- package/dist/esm/utils/normalize.d.ts.map +1 -1
- package/dist/esm/utils/normalize.js +51 -7
- package/dist/esm/utils/normalize.js.map +1 -1
- package/dist/esm/utils/option-schema.d.ts +11 -8
- package/dist/esm/utils/option-schema.d.ts.map +1 -1
- package/dist/esm/utils/option-schema.js +12 -9
- package/dist/esm/utils/option-schema.js.map +1 -1
- package/dist/esm/utils/options.d.ts +34 -0
- package/dist/esm/utils/options.d.ts.map +1 -0
- package/dist/esm/utils/options.js +36 -0
- package/dist/esm/utils/options.js.map +1 -0
- package/dist/esm/utils/rule-docs.d.ts +2 -0
- package/dist/esm/utils/rule-docs.d.ts.map +1 -0
- package/dist/esm/utils/rule-docs.js +18 -0
- package/dist/esm/utils/rule-docs.js.map +1 -0
- package/dist/esm/utils/section.d.ts.map +1 -1
- package/dist/esm/utils/section.js +31 -38
- package/dist/esm/utils/section.js.map +1 -1
- package/dist/esm/utils/selector-policy.d.ts +16 -0
- package/dist/esm/utils/selector-policy.d.ts.map +1 -0
- package/dist/esm/utils/selector-policy.js +51 -0
- package/dist/esm/utils/selector-policy.js.map +1 -0
- package/dist/esm/utils/selector.d.ts +4 -1
- package/dist/esm/utils/selector.d.ts.map +1 -1
- package/dist/esm/utils/selector.js +59 -36
- package/dist/esm/utils/selector.js.map +1 -1
- package/dist/esm/utils/stylelint.d.ts +0 -1
- package/dist/esm/utils/stylelint.d.ts.map +1 -1
- package/dist/esm/utils/stylelint.js +17 -2
- package/dist/esm/utils/stylelint.js.map +1 -1
- package/package.json +6 -5
|
@@ -3,41 +3,54 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.normalizeOptions = void 0;
|
|
4
4
|
const cache_1 = require("../utils/cache");
|
|
5
5
|
const normalize_1 = require("../utils/normalize");
|
|
6
|
+
const options_1 = require("../utils/options");
|
|
7
|
+
const selector_policy_1 = require("../utils/selector-policy");
|
|
6
8
|
const defaultValueNaming = {
|
|
7
9
|
case: 'kebab',
|
|
8
10
|
maxWords: 2
|
|
9
11
|
};
|
|
12
|
+
const baseSelectorPolicy = (0, selector_policy_1.createDefaultSelectorPolicyBase)();
|
|
10
13
|
const defaultSelectorPolicy = {
|
|
11
14
|
valueNaming: defaultValueNaming,
|
|
12
15
|
variant: {
|
|
13
|
-
|
|
14
|
-
dataKeys: ['data-variant'],
|
|
16
|
+
...baseSelectorPolicy.variant,
|
|
15
17
|
valueNaming: defaultValueNaming
|
|
16
18
|
},
|
|
17
19
|
state: {
|
|
18
|
-
|
|
19
|
-
dataKey: 'data-state',
|
|
20
|
-
ariaKeys: ['aria-expanded', 'aria-selected', 'aria-disabled'],
|
|
20
|
+
...baseSelectorPolicy.state,
|
|
21
21
|
valueNaming: defaultValueNaming
|
|
22
22
|
}
|
|
23
23
|
};
|
|
24
24
|
const ERROR_PREFIX = '[spiracss]';
|
|
25
25
|
const defaultOptions = {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
26
|
+
element: {
|
|
27
|
+
// SpiraCSS recommends up to ~4 levels, so default to 4.
|
|
28
|
+
depth: 4
|
|
29
|
+
},
|
|
30
|
+
external: {
|
|
31
|
+
classes: [],
|
|
32
|
+
prefixes: []
|
|
33
|
+
},
|
|
34
|
+
child: {
|
|
35
|
+
combinator: true,
|
|
36
|
+
nesting: true
|
|
37
|
+
},
|
|
38
|
+
root: {
|
|
39
|
+
single: true,
|
|
40
|
+
file: true,
|
|
41
|
+
case: 'preserve'
|
|
42
|
+
},
|
|
43
|
+
paths: {
|
|
44
|
+
childDir: 'scss',
|
|
45
|
+
components: ['components']
|
|
46
|
+
},
|
|
36
47
|
naming: undefined,
|
|
37
|
-
|
|
38
|
-
|
|
48
|
+
comments: {
|
|
49
|
+
shared: /--shared/i,
|
|
50
|
+
interaction: /--interaction/i
|
|
51
|
+
},
|
|
39
52
|
selectorPolicy: defaultSelectorPolicy,
|
|
40
|
-
|
|
53
|
+
cache: cache_1.DEFAULT_CACHE_SIZES
|
|
41
54
|
};
|
|
42
55
|
const isWordCase = (value) => value === 'kebab' || value === 'snake' || value === 'camel' || value === 'pascal';
|
|
43
56
|
const normalizeFileNameCase = (value, fallback) => {
|
|
@@ -47,24 +60,30 @@ const normalizeFileNameCase = (value, fallback) => {
|
|
|
47
60
|
return value;
|
|
48
61
|
return fallback;
|
|
49
62
|
};
|
|
50
|
-
const normalizeValueNaming = (raw, fallback, fieldName) => {
|
|
63
|
+
const normalizeValueNaming = (raw, fallback, fieldName, reportInvalid) => {
|
|
51
64
|
if (!raw || typeof raw !== 'object')
|
|
52
65
|
return { ...fallback };
|
|
53
66
|
const value = raw;
|
|
54
|
-
|
|
55
|
-
|
|
67
|
+
const normalized = { ...fallback };
|
|
68
|
+
if (value.case !== undefined) {
|
|
69
|
+
if (!isWordCase(value.case)) {
|
|
70
|
+
reportInvalid?.(`${fieldName}.case`, value.case, `${ERROR_PREFIX} ${fieldName}.case must be "kebab" | "snake" | "camel" | "pascal".`);
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
normalized.case = value.case;
|
|
74
|
+
}
|
|
56
75
|
}
|
|
57
76
|
if (value.maxWords !== undefined) {
|
|
58
77
|
if (typeof value.maxWords !== 'number' ||
|
|
59
78
|
!Number.isInteger(value.maxWords) ||
|
|
60
79
|
value.maxWords < 1) {
|
|
61
|
-
|
|
80
|
+
reportInvalid?.(`${fieldName}.maxWords`, value.maxWords, `${ERROR_PREFIX} ${fieldName}.maxWords must be a positive integer.`);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
normalized.maxWords = value.maxWords;
|
|
62
84
|
}
|
|
63
85
|
}
|
|
64
|
-
return
|
|
65
|
-
case: value.case ?? fallback.case,
|
|
66
|
-
maxWords: value.maxWords ?? fallback.maxWords
|
|
67
|
-
};
|
|
86
|
+
return normalized;
|
|
68
87
|
};
|
|
69
88
|
const normalizeSelectorPolicy = (raw, reportInvalid) => {
|
|
70
89
|
const defaults = {
|
|
@@ -78,13 +97,13 @@ const normalizeSelectorPolicy = (raw, reportInvalid) => {
|
|
|
78
97
|
ariaKeys: defaultSelectorPolicy.state.ariaKeys
|
|
79
98
|
}
|
|
80
99
|
};
|
|
81
|
-
const base = (0, normalize_1.
|
|
100
|
+
const base = (0, normalize_1.safeNormalizeSelectorPolicyBase)(raw, defaults, reportInvalid);
|
|
82
101
|
const policy = (raw && typeof raw === 'object' ? raw : {});
|
|
83
102
|
const variant = policy.variant || {};
|
|
84
103
|
const state = policy.state || {};
|
|
85
|
-
const baseValueNaming = normalizeValueNaming(policy.valueNaming, defaultSelectorPolicy.valueNaming, 'selectorPolicy.valueNaming');
|
|
86
|
-
const variantValueNaming = normalizeValueNaming(variant.valueNaming, baseValueNaming, 'selectorPolicy.variant.valueNaming');
|
|
87
|
-
const stateValueNaming = normalizeValueNaming(state.valueNaming, baseValueNaming, 'selectorPolicy.state.valueNaming');
|
|
104
|
+
const baseValueNaming = normalizeValueNaming(policy.valueNaming, defaultSelectorPolicy.valueNaming, 'selectorPolicy.valueNaming', reportInvalid);
|
|
105
|
+
const variantValueNaming = normalizeValueNaming(variant.valueNaming, baseValueNaming, 'selectorPolicy.variant.valueNaming', reportInvalid);
|
|
106
|
+
const stateValueNaming = normalizeValueNaming(state.valueNaming, baseValueNaming, 'selectorPolicy.state.valueNaming', reportInvalid);
|
|
88
107
|
return {
|
|
89
108
|
valueNaming: baseValueNaming,
|
|
90
109
|
variant: {
|
|
@@ -104,34 +123,30 @@ const normalizeOptions = (raw, reportInvalid) => {
|
|
|
104
123
|
if (!raw || typeof raw !== 'object')
|
|
105
124
|
return { ...defaultOptions };
|
|
106
125
|
const opt = raw;
|
|
126
|
+
const selectorPolicy = opt.selectorPolicy;
|
|
107
127
|
const safeNormalizeKeyList = (value, fallback, fieldName) => (0, normalize_1.normalizeKeyList)(value, fallback, fieldName, reportInvalid);
|
|
108
|
-
const
|
|
109
|
-
try {
|
|
110
|
-
return normalizeSelectorPolicy(value, reportInvalid);
|
|
111
|
-
}
|
|
112
|
-
catch (error) {
|
|
113
|
-
const detail = error instanceof Error ? error.message : String(error);
|
|
114
|
-
reportInvalid?.('selectorPolicy', value, detail);
|
|
115
|
-
return { ...defaultOptions.selectorPolicy };
|
|
116
|
-
}
|
|
117
|
-
};
|
|
128
|
+
const common = (0, options_1.normalizeCommonOptions)(opt, (0, options_1.pickCommonDefaults)(defaultOptions), reportInvalid);
|
|
118
129
|
return {
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
130
|
+
element: {
|
|
131
|
+
depth: typeof opt.elementDepth === 'number'
|
|
132
|
+
? opt.elementDepth
|
|
133
|
+
: defaultOptions.element.depth
|
|
134
|
+
},
|
|
135
|
+
child: {
|
|
136
|
+
combinator: (0, normalize_1.normalizeBoolean)(opt.childCombinator, defaultOptions.child.combinator),
|
|
137
|
+
nesting: (0, normalize_1.normalizeBoolean)(opt.childNesting, defaultOptions.child.nesting)
|
|
138
|
+
},
|
|
139
|
+
root: {
|
|
140
|
+
single: (0, normalize_1.normalizeBoolean)(opt.rootSingle, defaultOptions.root.single),
|
|
141
|
+
file: (0, normalize_1.normalizeBoolean)(opt.rootFile, defaultOptions.root.file),
|
|
142
|
+
case: normalizeFileNameCase(opt.rootCase, defaultOptions.root.case)
|
|
143
|
+
},
|
|
144
|
+
paths: {
|
|
145
|
+
childDir: (0, normalize_1.normalizeString)(opt.childDir, defaultOptions.paths.childDir),
|
|
146
|
+
components: safeNormalizeKeyList(opt.componentsDirs, defaultOptions.paths.components, 'componentsDirs')
|
|
147
|
+
},
|
|
148
|
+
selectorPolicy: normalizeSelectorPolicy(selectorPolicy, reportInvalid),
|
|
149
|
+
...common
|
|
135
150
|
};
|
|
136
151
|
};
|
|
137
152
|
exports.normalizeOptions = normalizeOptions;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spiracss-class-structure.options.js","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.options.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"spiracss-class-structure.options.js","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.options.ts"],"names":[],"mappings":";;;AACA,0CAAoD;AACpD,kDAM2B;AAC3B,8CAA6E;AAC7E,8DAA0E;AAU1E,MAAM,kBAAkB,GAAgB;IACtC,IAAI,EAAE,OAAO;IACb,QAAQ,EAAE,CAAC;CACZ,CAAA;AAED,MAAM,kBAAkB,GAAG,IAAA,iDAA+B,GAAE,CAAA;AAE5D,MAAM,qBAAqB,GAA6B;IACtD,WAAW,EAAE,kBAAkB;IAC/B,OAAO,EAAE;QACP,GAAG,kBAAkB,CAAC,OAAO;QAC7B,WAAW,EAAE,kBAAkB;KAChC;IACD,KAAK,EAAE;QACL,GAAG,kBAAkB,CAAC,KAAK;QAC3B,WAAW,EAAE,kBAAkB;KAChC;CACF,CAAA;AAED,MAAM,YAAY,GAAG,YAAY,CAAA;AAEjC,MAAM,cAAc,GAAY;IAC9B,OAAO,EAAE;QACP,wDAAwD;QACxD,KAAK,EAAE,CAAC;KACT;IACD,QAAQ,EAAE;QACR,OAAO,EAAE,EAAE;QACX,QAAQ,EAAE,EAAE;KACb;IACD,KAAK,EAAE;QACL,UAAU,EAAE,IAAI;QAChB,OAAO,EAAE,IAAI;KACd;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,IAAI;QACZ,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,UAAU;KACjB;IACD,KAAK,EAAE;QACL,QAAQ,EAAE,MAAM;QAChB,UAAU,EAAE,CAAC,YAAY,CAAC;KAC3B;IACD,MAAM,EAAE,SAAS;IACjB,QAAQ,EAAE;QACR,MAAM,EAAE,WAAW;QACnB,WAAW,EAAE,gBAAgB;KAC9B;IACD,cAAc,EAAE,qBAAqB;IACrC,KAAK,EAAE,2BAAmB;CAC3B,CAAA;AAED,MAAM,UAAU,GAAG,CAAC,KAAc,EAAqB,EAAE,CACvD,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,QAAQ,CAAA;AAEnF,MAAM,qBAAqB,GAAG,CAAC,KAAc,EAAE,QAAsB,EAAgB,EAAE;IACrF,IAAI,KAAK,KAAK,UAAU;QAAE,OAAO,KAAK,CAAA;IACtC,IAAI,UAAU,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAA;IACnC,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAED,MAAM,oBAAoB,GAAG,CAC3B,GAAY,EACZ,QAAqB,EACrB,SAAiB,EACjB,aAAqC,EACxB,EAAE;IACf,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ;QAAE,OAAO,EAAE,GAAG,QAAQ,EAAE,CAAA;IAC3D,MAAM,KAAK,GAAG,GAAyB,CAAA;IACvC,MAAM,UAAU,GAAgB,EAAE,GAAG,QAAQ,EAAE,CAAA;IAC/C,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YAC5B,aAAa,EAAE,CACb,GAAG,SAAS,OAAO,EACnB,KAAK,CAAC,IAAI,EACV,GAAG,YAAY,IAAI,SAAS,uDAAuD,CACpF,CAAA;QACH,CAAC;aAAM,CAAC;YACN,UAAU,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAA;QAC9B,CAAC;IACH,CAAC;IACD,IAAI,KAAK,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;QACjC,IACE,OAAO,KAAK,CAAC,QAAQ,KAAK,QAAQ;YAClC,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC;YACjC,KAAK,CAAC,QAAQ,GAAG,CAAC,EAClB,CAAC;YACD,aAAa,EAAE,CACb,GAAG,SAAS,WAAW,EACvB,KAAK,CAAC,QAAQ,EACd,GAAG,YAAY,IAAI,SAAS,uCAAuC,CACpE,CAAA;QACH,CAAC;aAAM,CAAC;YACN,UAAU,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAA;QACtC,CAAC;IACH,CAAC;IACD,OAAO,UAAU,CAAA;AACnB,CAAC,CAAA;AAED,MAAM,uBAAuB,GAAG,CAC9B,GAAY,EACZ,aAAqC,EACX,EAAE;IAC5B,MAAM,QAAQ,GAAG;QACf,OAAO,EAAE;YACP,IAAI,EAAE,qBAAqB,CAAC,OAAO,CAAC,IAAI;YACxC,QAAQ,EAAE,qBAAqB,CAAC,OAAO,CAAC,QAAQ;SACjD;QACD,KAAK,EAAE;YACL,IAAI,EAAE,qBAAqB,CAAC,KAAK,CAAC,IAAI;YACtC,OAAO,EAAE,qBAAqB,CAAC,KAAK,CAAC,OAAO;YAC5C,QAAQ,EAAE,qBAAqB,CAAC,KAAK,CAAC,QAAQ;SAC/C;KACF,CAAA;IACD,MAAM,IAAI,GAAG,IAAA,2CAA+B,EAAC,GAAG,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAA;IAC1E,MAAM,MAAM,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAmB,CAAA;IAC5E,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,EAAE,CAAA;IACpC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,EAAE,CAAA;IAEhC,MAAM,eAAe,GAAG,oBAAoB,CAC1C,MAAM,CAAC,WAAW,EAClB,qBAAqB,CAAC,WAAW,EACjC,4BAA4B,EAC5B,aAAa,CACd,CAAA;IACD,MAAM,kBAAkB,GAAG,oBAAoB,CAC7C,OAAO,CAAC,WAAW,EACnB,eAAe,EACf,oCAAoC,EACpC,aAAa,CACd,CAAA;IACD,MAAM,gBAAgB,GAAG,oBAAoB,CAC3C,KAAK,CAAC,WAAW,EACjB,eAAe,EACf,kCAAkC,EAClC,aAAa,CACd,CAAA;IAED,OAAO;QACL,WAAW,EAAE,eAAe;QAC5B,OAAO,EAAE;YACP,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI;YACvB,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;YAC/B,WAAW,EAAE,kBAAkB;SAChC;QACD,KAAK,EAAE;YACL,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI;YACrB,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO;YAC3B,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ;YAC7B,WAAW,EAAE,gBAAgB;SAC9B;KACF,CAAA;AACH,CAAC,CAAA;AAEM,MAAM,gBAAgB,GAAG,CAC9B,GAAY,EACZ,aAAqC,EAC5B,EAAE;IACX,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ;QAAE,OAAO,EAAE,GAAG,cAAc,EAAE,CAAA;IACjE,MAAM,GAAG,GAAG,GAcX,CAAA;IACD,MAAM,cAAc,GAAG,GAAG,CAAC,cAAc,CAAA;IACzC,MAAM,oBAAoB,GAAG,CAC3B,KAAc,EACd,QAAkB,EAClB,SAAiB,EACP,EAAE,CAAC,IAAA,4BAAgB,EAAC,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,CAAC,CAAA;IAC1E,MAAM,MAAM,GAAG,IAAA,gCAAsB,EACnC,GAAG,EACH,IAAA,4BAAkB,EAAC,cAAc,CAAC,EAClC,aAAa,CACd,CAAA;IAED,OAAO;QACL,OAAO,EAAE;YACP,KAAK,EACH,OAAO,GAAG,CAAC,YAAY,KAAK,QAAQ;gBAClC,CAAC,CAAC,GAAG,CAAC,YAAY;gBAClB,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,KAAK;SACnC;QACD,KAAK,EAAE;YACL,UAAU,EAAE,IAAA,4BAAgB,EAC1B,GAAG,CAAC,eAAe,EACnB,cAAc,CAAC,KAAK,CAAC,UAAU,CAChC;YACD,OAAO,EAAE,IAAA,4BAAgB,EACvB,GAAG,CAAC,YAAY,EAChB,cAAc,CAAC,KAAK,CAAC,OAAO,CAC7B;SACF;QACD,IAAI,EAAE;YACJ,MAAM,EAAE,IAAA,4BAAgB,EACtB,GAAG,CAAC,UAAU,EACd,cAAc,CAAC,IAAI,CAAC,MAAM,CAC3B;YACD,IAAI,EAAE,IAAA,4BAAgB,EACpB,GAAG,CAAC,QAAQ,EACZ,cAAc,CAAC,IAAI,CAAC,IAAI,CACzB;YACD,IAAI,EAAE,qBAAqB,CAAC,GAAG,CAAC,QAAQ,EAAE,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC;SACpE;QACD,KAAK,EAAE;YACL,QAAQ,EAAE,IAAA,2BAAe,EACvB,GAAG,CAAC,QAAQ,EACZ,cAAc,CAAC,KAAK,CAAC,QAAQ,CAC9B;YACD,UAAU,EAAE,oBAAoB,CAC9B,GAAG,CAAC,cAAc,EAClB,cAAc,CAAC,KAAK,CAAC,UAAU,EAC/B,gBAAgB,CACjB;SACF;QACD,cAAc,EAAE,uBAAuB,CAAC,cAAc,EAAE,aAAa,CAAC;QACtE,GAAG,MAAM;KACV,CAAA;AACH,CAAC,CAAA;AA1EY,QAAA,gBAAgB,oBA0E5B"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import type { NormalizedCacheSizes } from '../types';
|
|
2
2
|
import type { InvalidOptionReporter } from '../utils/normalize';
|
|
3
|
-
import type { Kind, NormalizedSelectorPolicy,
|
|
4
|
-
type NamingHintOptions = Pick<
|
|
3
|
+
import type { ClassifyOptions, Kind, NormalizedSelectorPolicy, Patterns, SelectorPolicyData } from './spiracss-class-structure.types';
|
|
4
|
+
type NamingHintOptions = Pick<ClassifyOptions, 'naming'>;
|
|
5
5
|
export declare const formatNamingHint: (options: NamingHintOptions) => string;
|
|
6
|
-
export declare const buildPatterns: (options:
|
|
6
|
+
export declare const buildPatterns: (options: ClassifyOptions, cacheSizes: NormalizedCacheSizes, reportInvalid?: InvalidOptionReporter) => Patterns;
|
|
7
7
|
export declare const buildSelectorPolicyData: (policy: NormalizedSelectorPolicy) => SelectorPolicyData;
|
|
8
8
|
/**
|
|
9
9
|
* Classifies a class name using SpiraCSS patterns and external class allowances.
|
|
@@ -12,6 +12,6 @@ export declare const buildSelectorPolicyData: (policy: NormalizedSelectorPolicy)
|
|
|
12
12
|
* @param patterns - Compiled naming patterns for Block/Element/Modifier.
|
|
13
13
|
* @returns Classification kind for the class name.
|
|
14
14
|
*/
|
|
15
|
-
export declare const classify: (name: string, options:
|
|
15
|
+
export declare const classify: (name: string, options: ClassifyOptions, patterns: Patterns) => Kind;
|
|
16
16
|
export {};
|
|
17
17
|
//# sourceMappingURL=spiracss-class-structure.patterns.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spiracss-class-structure.patterns.d.ts","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.patterns.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAY,MAAM,UAAU,CAAA;
|
|
1
|
+
{"version":3,"file":"spiracss-class-structure.patterns.d.ts","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.patterns.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAY,MAAM,UAAU,CAAA;AAQ9D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAA;AAC/D,OAAO,KAAK,EACV,eAAe,EACf,IAAI,EACJ,wBAAwB,EACxB,QAAQ,EACR,kBAAkB,EAEnB,MAAM,kCAAkC,CAAA;AAEzC,KAAK,iBAAiB,GAAG,IAAI,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAA;AA2CxD,eAAO,MAAM,gBAAgB,GAAI,SAAS,iBAAiB,KAAG,MAkC7D,CAAA;AAED,eAAO,MAAM,aAAa,GACxB,SAAS,eAAe,EACxB,YAAY,oBAAoB,EAChC,gBAAgB,qBAAqB,KACpC,QAwGF,CAAA;AAED,eAAO,MAAM,uBAAuB,GAClC,QAAQ,wBAAwB,KAC/B,kBAMD,CAAA;AAEF;;;;;;GAMG;AACH,eAAO,MAAM,QAAQ,GACnB,MAAM,MAAM,EACZ,SAAS,eAAe,EACxB,UAAU,QAAQ,KACjB,IASF,CAAA"}
|
|
@@ -3,16 +3,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.classify = exports.buildSelectorPolicyData = exports.buildPatterns = exports.formatNamingHint = void 0;
|
|
4
4
|
const cache_1 = require("../utils/cache");
|
|
5
5
|
const naming_1 = require("../utils/naming");
|
|
6
|
+
const messages_1 = require("../utils/messages");
|
|
6
7
|
const serializePattern = (pattern) => pattern ? `${pattern.source}/${pattern.flags}` : '';
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
return cached;
|
|
12
|
-
const created = (0, cache_1.createLruCache)(maxSize);
|
|
13
|
-
patternsCaches.set(maxSize, created);
|
|
14
|
-
return created;
|
|
15
|
-
};
|
|
8
|
+
const normalizeWordCase = (value, fallback) => value === 'kebab' || value === 'snake' || value === 'camel' || value === 'pascal'
|
|
9
|
+
? value
|
|
10
|
+
: fallback;
|
|
11
|
+
const getPatternsCache = (0, cache_1.createSharedCacheAccessor)();
|
|
16
12
|
const buildValuePattern = (naming) => {
|
|
17
13
|
const maxWords = naming.maxWords;
|
|
18
14
|
switch (naming.case) {
|
|
@@ -45,37 +41,38 @@ const buildValuePattern = (naming) => {
|
|
|
45
41
|
};
|
|
46
42
|
const formatNamingHint = (options) => {
|
|
47
43
|
const naming = options?.naming || {};
|
|
48
|
-
const blockCase = naming.blockCase
|
|
49
|
-
const elementCase = naming.elementCase
|
|
50
|
-
const modifierCase = naming.modifierCase
|
|
44
|
+
const blockCase = normalizeWordCase(naming.blockCase, 'kebab');
|
|
45
|
+
const elementCase = normalizeWordCase(naming.elementCase, 'kebab');
|
|
46
|
+
const modifierCase = normalizeWordCase(naming.modifierCase, 'kebab');
|
|
51
47
|
const modifierPrefix = naming.modifierPrefix ?? '-';
|
|
48
|
+
const prefixLabel = modifierPrefix === '' ? '(none)' : modifierPrefix;
|
|
52
49
|
const blockMaxWords = (0, naming_1.normalizeBlockMaxWords)(naming.blockMaxWords);
|
|
53
50
|
const parts = [
|
|
54
|
-
`blockCase=${blockCase}`,
|
|
55
|
-
`blockMaxWords=${blockMaxWords}`,
|
|
56
|
-
`elementCase=${elementCase}`,
|
|
57
|
-
`modifierCase=${modifierCase}`,
|
|
58
|
-
`modifierPrefix
|
|
51
|
+
`blockCase=${(0, messages_1.formatCode)(blockCase)}`,
|
|
52
|
+
`blockMaxWords=${(0, messages_1.formatCode)(String(blockMaxWords))}`,
|
|
53
|
+
`elementCase=${(0, messages_1.formatCode)(elementCase)}`,
|
|
54
|
+
`modifierCase=${(0, messages_1.formatCode)(modifierCase)}`,
|
|
55
|
+
`modifierPrefix=${(0, messages_1.formatCode)(prefixLabel)}`
|
|
59
56
|
];
|
|
60
57
|
const customParts = [];
|
|
61
58
|
const customBlock = (0, naming_1.normalizeCustomPattern)(naming.customPatterns?.block, 'naming.customPatterns.block');
|
|
62
59
|
const customElement = (0, naming_1.normalizeCustomPattern)(naming.customPatterns?.element, 'naming.customPatterns.element');
|
|
63
60
|
const customModifier = (0, naming_1.normalizeCustomPattern)(naming.customPatterns?.modifier, 'naming.customPatterns.modifier');
|
|
64
61
|
if (customBlock)
|
|
65
|
-
customParts.push(`block=${customBlock}`);
|
|
62
|
+
customParts.push(`block=${(0, messages_1.formatPattern)(customBlock)}`);
|
|
66
63
|
if (customElement)
|
|
67
|
-
customParts.push(`element=${customElement}`);
|
|
64
|
+
customParts.push(`element=${(0, messages_1.formatPattern)(customElement)}`);
|
|
68
65
|
if (customModifier)
|
|
69
|
-
customParts.push(`modifier=${customModifier}`);
|
|
66
|
+
customParts.push(`modifier=${(0, messages_1.formatPattern)(customModifier)}`);
|
|
70
67
|
const customHint = customParts.length > 0 ? ` Custom patterns: ${customParts.join(', ')}.` : '';
|
|
71
68
|
return `Naming: ${parts.join(', ')}.${customHint}`;
|
|
72
69
|
};
|
|
73
70
|
exports.formatNamingHint = formatNamingHint;
|
|
74
71
|
const buildPatterns = (options, cacheSizes, reportInvalid) => {
|
|
75
72
|
const naming = options.naming || {};
|
|
76
|
-
const blockCase = naming.blockCase
|
|
77
|
-
const elementCase = naming.elementCase
|
|
78
|
-
const modifierCase = naming.modifierCase
|
|
73
|
+
const blockCase = normalizeWordCase(naming.blockCase, 'kebab');
|
|
74
|
+
const elementCase = normalizeWordCase(naming.elementCase, 'kebab');
|
|
75
|
+
const modifierCase = normalizeWordCase(naming.modifierCase, 'kebab');
|
|
79
76
|
const modifierPrefix = naming.modifierPrefix ?? '-';
|
|
80
77
|
const blockMaxWords = (0, naming_1.normalizeBlockMaxWords)(naming.blockMaxWords);
|
|
81
78
|
// Support partial customPatterns overrides (only specified ones replace defaults).
|
|
@@ -92,11 +89,11 @@ const buildPatterns = (options, cacheSizes, reportInvalid) => {
|
|
|
92
89
|
serializePattern(customElement),
|
|
93
90
|
serializePattern(customModifier)
|
|
94
91
|
].join('|');
|
|
95
|
-
const patternsCache = getPatternsCache(cacheSizes
|
|
92
|
+
const patternsCache = getPatternsCache(cacheSizes.patterns);
|
|
96
93
|
const cached = patternsCache.get(cacheKey);
|
|
97
94
|
if (cached)
|
|
98
95
|
return cached;
|
|
99
|
-
const blockRe = (0, naming_1.buildBlockPattern)(naming, cacheSizes
|
|
96
|
+
const blockRe = (0, naming_1.buildBlockPattern)(naming, cacheSizes.naming, reportInvalid, {
|
|
100
97
|
customBlock,
|
|
101
98
|
skipCustomPatternValidation: true
|
|
102
99
|
});
|
|
@@ -171,8 +168,8 @@ exports.buildSelectorPolicyData = buildSelectorPolicyData;
|
|
|
171
168
|
* @returns Classification kind for the class name.
|
|
172
169
|
*/
|
|
173
170
|
const classify = (name, options, patterns) => {
|
|
174
|
-
const
|
|
175
|
-
if (
|
|
171
|
+
const external = options.external;
|
|
172
|
+
if (external.classes.includes(name) || external.prefixes.some((p) => name.startsWith(p))) {
|
|
176
173
|
return 'external';
|
|
177
174
|
}
|
|
178
175
|
if (patterns.modifierRe.test(name))
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spiracss-class-structure.patterns.js","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.patterns.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"file":"spiracss-class-structure.patterns.js","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.patterns.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import type { Node as PostcssNode, Rule } from 'postcss';
|
|
2
1
|
import type { Selector } from 'postcss-selector-parser';
|
|
3
|
-
import type { Kind, Options, Patterns, SelectorPolicyData } from './spiracss-class-structure.types';
|
|
4
|
-
export declare const collectRootBlockNames: (selectors: Selector[], options:
|
|
2
|
+
import type { ClassifyOptions, Kind, Options, Patterns, SelectorPolicyData } from './spiracss-class-structure.types';
|
|
3
|
+
export declare const collectRootBlockNames: (selectors: Selector[], options: ClassifyOptions, patterns: Patterns) => string[];
|
|
5
4
|
export declare const hasValidSpiraClass: (selectors: Selector[], options: Options, patterns: Patterns) => boolean;
|
|
6
5
|
export declare const analyzeRootSelector: (sel: Selector, rootBlockName: string, options: Options, patterns: Patterns) => {
|
|
7
6
|
hasSpiraClass: boolean;
|
|
@@ -20,6 +19,7 @@ type ProcessContext = {
|
|
|
20
19
|
namingHint: string;
|
|
21
20
|
isShared: boolean;
|
|
22
21
|
isInteraction: boolean;
|
|
22
|
+
hasBlockAncestor: boolean;
|
|
23
23
|
};
|
|
24
24
|
/**
|
|
25
25
|
* Analyze a selector in context and emit structure/naming violations.
|
|
@@ -29,7 +29,6 @@ type ProcessContext = {
|
|
|
29
29
|
*/
|
|
30
30
|
export declare const processSelector: (sel: Selector, ctx: ProcessContext) => Kind | null;
|
|
31
31
|
export declare const mergeRuleKinds: (kinds: Kind[]) => Kind | null;
|
|
32
|
-
export declare const findNearestParentRule: (node: PostcssNode) => Rule | null;
|
|
33
32
|
export declare const hasSegmentSequence: (segments: string[], sequence: string[]) => boolean;
|
|
34
33
|
export {};
|
|
35
34
|
//# sourceMappingURL=spiracss-class-structure.selectors.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spiracss-class-structure.selectors.d.ts","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.selectors.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"spiracss-class-structure.selectors.d.ts","sourceRoot":"","sources":["../../../src/rules/spiracss-class-structure.selectors.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAmC,QAAQ,EAAE,MAAM,yBAAyB,CAAA;AAYxF,OAAO,KAAK,EACV,eAAe,EACf,IAAI,EACJ,OAAO,EACP,QAAQ,EACR,kBAAkB,EACnB,MAAM,kCAAkC,CAAA;AAIzC,eAAO,MAAM,qBAAqB,GAChC,WAAW,QAAQ,EAAE,EACrB,SAAS,eAAe,EACxB,UAAU,QAAQ,KACjB,MAAM,EAcR,CAAA;AAED,eAAO,MAAM,kBAAkB,GAC7B,WAAW,QAAQ,EAAE,EACrB,SAAS,OAAO,EAChB,UAAU,QAAQ,KACjB,OAUF,CAAA;AAED,eAAO,MAAM,mBAAmB,GAC9B,KAAK,QAAQ,EACb,eAAe,MAAM,EACrB,SAAS,OAAO,EAChB,UAAU,QAAQ,KACjB;IAAE,aAAa,EAAE,OAAO,CAAC;IAAC,YAAY,EAAE,OAAO,CAAC;IAAC,aAAa,EAAE,OAAO,CAAA;CAkBzE,CAAA;AAED,KAAK,cAAc,GAAG;IACpB,UAAU,CAAC,EAAE,IAAI,CAAA;IACjB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,gBAAgB,EAAE,MAAM,CAAA;IACxB,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAA;IACjC,OAAO,EAAE,OAAO,CAAA;IAChB,QAAQ,EAAE,QAAQ,CAAA;IAClB,UAAU,EAAE,kBAAkB,CAAA;IAC9B,UAAU,EAAE,MAAM,CAAA;IAClB,QAAQ,EAAE,OAAO,CAAA;IACjB,aAAa,EAAE,OAAO,CAAA;IACtB,gBAAgB,EAAE,OAAO,CAAA;CAC1B,CAAA;AAqSD;;;;;GAKG;AACH,eAAO,MAAM,eAAe,GAAI,KAAK,QAAQ,EAAE,KAAK,cAAc,KAAG,IAAI,GAAG,IAuF3E,CAAA;AAED,eAAO,MAAM,cAAc,GAAI,OAAO,IAAI,EAAE,KAAG,IAAI,GAAG,IAOrD,CAAA;AAED,eAAO,MAAM,kBAAkB,GAAI,UAAU,MAAM,EAAE,EAAE,UAAU,MAAM,EAAE,KAAG,OAa3E,CAAA"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.hasSegmentSequence = exports.
|
|
3
|
+
exports.hasSegmentSequence = exports.mergeRuleKinds = exports.processSelector = exports.analyzeRootSelector = exports.hasValidSpiraClass = exports.collectRootBlockNames = void 0;
|
|
4
4
|
const selector_1 = require("../utils/selector");
|
|
5
|
+
const selector_policy_1 = require("../utils/selector-policy");
|
|
5
6
|
const spiracss_class_structure_messages_1 = require("./spiracss-class-structure.messages");
|
|
6
7
|
const spiracss_class_structure_patterns_1 = require("./spiracss-class-structure.patterns");
|
|
8
|
+
const isClassNode = (node) => node.type === 'class';
|
|
7
9
|
const collectRootBlockNames = (selectors, options, patterns) => {
|
|
8
10
|
const names = new Set();
|
|
9
11
|
const rootPseudos = new Set([':is', ':where']);
|
|
@@ -40,44 +42,14 @@ const analyzeRootSelector = (sel, rootBlockName, options, patterns) => {
|
|
|
40
42
|
let hasRootBlock = false;
|
|
41
43
|
let hasOtherBlock = false;
|
|
42
44
|
const sameElementPseudos = new Set([':is', ':where']);
|
|
43
|
-
const isContainer = (node) => Boolean(node && 'nodes' in node && Array.isArray(node.nodes));
|
|
44
|
-
const hasCombinator = (container) => {
|
|
45
|
-
const nodes = container?.nodes;
|
|
46
|
-
if (!nodes || nodes.length === 0)
|
|
47
|
-
return false;
|
|
48
|
-
return nodes.some((node) => {
|
|
49
|
-
if (node.type === 'combinator')
|
|
50
|
-
return true;
|
|
51
|
-
if (isContainer(node))
|
|
52
|
-
return hasCombinator(node);
|
|
53
|
-
return false;
|
|
54
|
-
});
|
|
55
|
-
};
|
|
56
|
-
const isInsideNonSameElementPseudo = (node) => {
|
|
57
|
-
let current = node.parent;
|
|
58
|
-
let selectorInPseudo = null;
|
|
59
|
-
while (current) {
|
|
60
|
-
if (current.type === 'selector')
|
|
61
|
-
selectorInPseudo = current;
|
|
62
|
-
if (current.type === 'pseudo') {
|
|
63
|
-
const pseudo = typeof current.value === 'string' ? current.value.toLowerCase() : '';
|
|
64
|
-
if (!sameElementPseudos.has(pseudo))
|
|
65
|
-
return true;
|
|
66
|
-
if (selectorInPseudo && hasCombinator(selectorInPseudo))
|
|
67
|
-
return true;
|
|
68
|
-
}
|
|
69
|
-
current = current.parent;
|
|
70
|
-
}
|
|
71
|
-
return false;
|
|
72
|
-
};
|
|
73
45
|
sel.walk((node) => {
|
|
74
|
-
if (node
|
|
46
|
+
if (!isClassNode(node))
|
|
75
47
|
return;
|
|
76
48
|
const name = node.value;
|
|
77
49
|
const kind = (0, spiracss_class_structure_patterns_1.classify)(name, options, patterns);
|
|
78
50
|
if (kind !== 'external')
|
|
79
51
|
hasSpiraClass = true;
|
|
80
|
-
if (isInsideNonSameElementPseudo(node))
|
|
52
|
+
if ((0, selector_1.isInsideNonSameElementPseudo)(node, sameElementPseudos))
|
|
81
53
|
return;
|
|
82
54
|
if (name === rootBlockName)
|
|
83
55
|
hasRootBlock = true;
|
|
@@ -89,6 +61,8 @@ const analyzeRootSelector = (sel, rootBlockName, options, patterns) => {
|
|
|
89
61
|
exports.analyzeRootSelector = analyzeRootSelector;
|
|
90
62
|
const MAX_BLOCK_NESTING_DEPTH = 1;
|
|
91
63
|
const getModifierExample = (options) => {
|
|
64
|
+
if (options.naming?.customPatterns?.modifier)
|
|
65
|
+
return '';
|
|
92
66
|
const naming = options.naming ?? {};
|
|
93
67
|
const prefix = naming.modifierPrefix ?? '-';
|
|
94
68
|
const modifierCase = naming.modifierCase ?? 'kebab';
|
|
@@ -97,9 +71,12 @@ const getModifierExample = (options) => {
|
|
|
97
71
|
};
|
|
98
72
|
const reportAttributeViolations = (compounds, ctx) => {
|
|
99
73
|
const { parentKind, report, options, patterns, policyData } = ctx;
|
|
100
|
-
const
|
|
74
|
+
const selectorPolicy = options.selectorPolicy;
|
|
75
|
+
const variantValueNaming = selectorPolicy.variant.valueNaming;
|
|
76
|
+
const stateValueNaming = selectorPolicy.state.valueNaming;
|
|
101
77
|
const { reservedVariantKeys, reservedStateKey, reservedAriaKeys, variantValuePattern, stateValuePattern } = policyData;
|
|
102
78
|
const modifierExample = getModifierExample(options);
|
|
79
|
+
const customModifierPattern = options.naming?.customPatterns?.modifier;
|
|
103
80
|
compounds.forEach((compound) => {
|
|
104
81
|
if (compound.attributes.length === 0)
|
|
105
82
|
return;
|
|
@@ -115,27 +92,27 @@ const reportAttributeViolations = (compounds, ctx) => {
|
|
|
115
92
|
return;
|
|
116
93
|
if (name.startsWith('data-')) {
|
|
117
94
|
if (reservedVariantKeys.has(name)) {
|
|
118
|
-
if (
|
|
119
|
-
report(spiracss_class_structure_messages_1.messages.invalidVariantAttribute(name, modifierExample));
|
|
95
|
+
if (selectorPolicy.variant.mode === 'class') {
|
|
96
|
+
report(spiracss_class_structure_messages_1.messages.invalidVariantAttribute(name, modifierExample, customModifierPattern));
|
|
120
97
|
return;
|
|
121
98
|
}
|
|
122
99
|
if (attrValue && !variantValuePattern.test(attrValue)) {
|
|
123
|
-
report(spiracss_class_structure_messages_1.messages.invalidDataValue(name, attrValue));
|
|
100
|
+
report(spiracss_class_structure_messages_1.messages.invalidDataValue(name, attrValue, variantValueNaming.case, variantValueNaming.maxWords));
|
|
124
101
|
}
|
|
125
102
|
}
|
|
126
103
|
else if (name === reservedStateKey) {
|
|
127
|
-
if (
|
|
128
|
-
report(spiracss_class_structure_messages_1.messages.invalidStateAttribute(name, modifierExample));
|
|
104
|
+
if (selectorPolicy.state.mode !== 'data') {
|
|
105
|
+
report(spiracss_class_structure_messages_1.messages.invalidStateAttribute(name, modifierExample, customModifierPattern));
|
|
129
106
|
return;
|
|
130
107
|
}
|
|
131
108
|
if (attrValue && !stateValuePattern.test(attrValue)) {
|
|
132
|
-
report(spiracss_class_structure_messages_1.messages.invalidDataValue(name, attrValue));
|
|
109
|
+
report(spiracss_class_structure_messages_1.messages.invalidDataValue(name, attrValue, stateValueNaming.case, stateValueNaming.maxWords));
|
|
133
110
|
}
|
|
134
111
|
}
|
|
135
112
|
}
|
|
136
113
|
else if (name.startsWith('aria-')) {
|
|
137
|
-
if (reservedAriaKeys.has(name) &&
|
|
138
|
-
report(spiracss_class_structure_messages_1.messages.invalidStateAttribute(name, modifierExample));
|
|
114
|
+
if (reservedAriaKeys.has(name) && selectorPolicy.state.mode !== 'data') {
|
|
115
|
+
report(spiracss_class_structure_messages_1.messages.invalidStateAttribute(name, modifierExample, customModifierPattern));
|
|
139
116
|
}
|
|
140
117
|
}
|
|
141
118
|
});
|
|
@@ -197,8 +174,8 @@ const reportElementHierarchyViolations = (ctx, kind, baseKind, baseValue, depth)
|
|
|
197
174
|
return true;
|
|
198
175
|
}
|
|
199
176
|
if (baseKind === 'element') {
|
|
200
|
-
if (depth > options.
|
|
201
|
-
report(spiracss_class_structure_messages_1.messages.elementChainTooDeep(parentLabel, baseValue, depth, options.
|
|
177
|
+
if (depth > options.element.depth) {
|
|
178
|
+
report(spiracss_class_structure_messages_1.messages.elementChainTooDeep(parentLabel, baseValue, depth, options.element.depth));
|
|
202
179
|
}
|
|
203
180
|
return true;
|
|
204
181
|
}
|
|
@@ -217,12 +194,12 @@ const reportBlockCombinatorViolations = (ctx, kind, baseValue, hasNesting, first
|
|
|
217
194
|
const { parentKind, parentSelector, options, report, isShared, isInteraction } = ctx;
|
|
218
195
|
if (parentKind !== 'block' || kind === 'modifier')
|
|
219
196
|
return;
|
|
220
|
-
if (!options.
|
|
197
|
+
if (!options.child.combinator || isShared || isInteraction)
|
|
221
198
|
return;
|
|
222
199
|
const missingChild = !hasNesting && !firstCombinator;
|
|
223
200
|
const wrongCombinator = firstCombinator && firstCombinator !== '>';
|
|
224
201
|
if (missingChild || wrongCombinator) {
|
|
225
|
-
report(spiracss_class_structure_messages_1.messages.needChild(baseValue));
|
|
202
|
+
report(spiracss_class_structure_messages_1.messages.needChild(baseValue, options.comments.shared, options.comments.interaction));
|
|
226
203
|
return;
|
|
227
204
|
}
|
|
228
205
|
if (combinatorCount > 1 && parentSelector) {
|
|
@@ -273,16 +250,23 @@ const processSelector = (sel, ctx) => {
|
|
|
273
250
|
reportInvalidClassNames(classes, invalidNestingClasses, options, patterns, namingHint, report);
|
|
274
251
|
const modifierClasses = classes.filter((c) => patterns.modifierRe.test(c.value));
|
|
275
252
|
const modifierClass = modifierClasses[0];
|
|
276
|
-
const modifiersAllowed = !(options.selectorPolicy.variant.mode === 'data' &&
|
|
253
|
+
const modifiersAllowed = !(options.selectorPolicy.variant.mode === 'data' &&
|
|
254
|
+
options.selectorPolicy.state.mode === 'data');
|
|
277
255
|
if (!modifiersAllowed && modifierClasses.length > 0) {
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
256
|
+
// Display lowercase keys in messages to match actual selector matching behavior.
|
|
257
|
+
const { variantKeys, stateKeys } = (0, selector_policy_1.getLowercasePolicyKeys)(options.selectorPolicy);
|
|
258
|
+
report(spiracss_class_structure_messages_1.messages.disallowedModifier(variantKeys, stateKeys));
|
|
281
259
|
}
|
|
282
260
|
// Ignore selectors that are purely external, but still catch SpiraCSS classes
|
|
283
261
|
// even if the last segment is external.
|
|
284
262
|
const base = resolveBaseClass(classes, modifierClass, options, patterns);
|
|
285
263
|
const baseKind = (0, spiracss_class_structure_patterns_1.classify)(base.value, options, patterns);
|
|
264
|
+
if (options.child.nesting && combinatorCount > 0 && !ctx.hasBlockAncestor) {
|
|
265
|
+
const rootBlocks = (0, exports.collectRootBlockNames)([sel], options, patterns);
|
|
266
|
+
if (rootBlocks.length > 0) {
|
|
267
|
+
report(spiracss_class_structure_messages_1.messages.needChildNesting(sel.toString().trim()));
|
|
268
|
+
}
|
|
269
|
+
}
|
|
286
270
|
// Kind resolution:
|
|
287
271
|
// 1. If a Modifier exists -> 'modifier'
|
|
288
272
|
// 2. If hasNesting:
|
|
@@ -321,16 +305,6 @@ const mergeRuleKinds = (kinds) => {
|
|
|
321
305
|
return null;
|
|
322
306
|
};
|
|
323
307
|
exports.mergeRuleKinds = mergeRuleKinds;
|
|
324
|
-
const findNearestParentRule = (node) => {
|
|
325
|
-
let current = node.parent;
|
|
326
|
-
while (current) {
|
|
327
|
-
if (current.type === 'rule')
|
|
328
|
-
return current;
|
|
329
|
-
current = current.parent;
|
|
330
|
-
}
|
|
331
|
-
return null;
|
|
332
|
-
};
|
|
333
|
-
exports.findNearestParentRule = findNearestParentRule;
|
|
334
308
|
const hasSegmentSequence = (segments, sequence) => {
|
|
335
309
|
if (sequence.length === 0 || segments.length < sequence.length)
|
|
336
310
|
return false;
|