|
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- 'use strict';
-
- const isScssVariable = require('./isScssVariable');
- const { isRoot } = require('./typeGuards');
-
- /**
- * @param {string} [lang]
- */
- function isStandardSyntaxLang(lang) {
- return lang && (lang === 'css' || lang === 'custom-template' || lang === 'template-literal');
- }
-
- /**
- * Check whether a declaration is standard
- *
- * @param {import('postcss').Declaration | import('postcss-less').Declaration} decl
- */
- module.exports = function (decl) {
- const prop = decl.prop;
- const parent = decl.parent;
-
- // Declarations belong in a declaration block or standard CSS source
- if (
- isRoot(parent) &&
- parent.source &&
- !isStandardSyntaxLang(
- /** @type {import('postcss').NodeSource & {lang?: string}} */ (parent.source).lang,
- )
- ) {
- return false;
- }
-
- // SCSS var
- if (isScssVariable(prop)) {
- return false;
- }
-
- // Less var (e.g. @var: x), but exclude variable interpolation (e.g. @{var})
- if (prop[0] === '@' && prop[1] !== '{') {
- return false;
- }
-
- // Sass nested properties (e.g. border: { style: solid; color: red; })
- if (
- // @ts-ignore TODO TYPES selector does not exists
- parent.selector &&
- // @ts-ignore
- parent.selector[parent.selector.length - 1] === ':' &&
- // @ts-ignore
- parent.selector.substring(0, 2) !== '--'
- ) {
- return false;
- }
-
- // Less &:extend
- if ('extend' in decl && decl.extend) {
- return false;
- }
-
- return true;
- };
|