@stylistic/stylelint-plugin
Version:
A collection of stylistic/formatting Stylelint rules
33 lines (27 loc) • 810 B
JavaScript
/**
* Check whether a combinator is standard
*
* @param {import('postcss-selector-parser').Combinator} node postcss-selector-parser node (of type combinator)
* @return {boolean} If `true`, the combinator is standard
*/
export function isStandardSyntaxCombinator (node) {
// if it's not a combinator, then it's not a standard combinator
if (node.type !== `combinator`) {
return false
}
// Ignore reference combinators like `/deep/`
if (node.value.startsWith(`/`) || node.value.endsWith(`/`)) {
return false
}
// ignore the combinators that are the first or last node in their container
if (node.parent !== undefined && node.parent !== null) {
let parent = node.parent
if (node === parent.first) {
return false
}
if (node === parent.last) {
return false
}
}
return true
}