ocrmnav
Version:
DevStack - The Complete Developer Toolkit - Virtual file system, workflow automation, and more than 65+ other development tools / features in one seamless extension. Cutting down dev times never before seen.
671 lines (516 loc) • 19.4 kB
JavaScript
exports.id = 67;
exports.ids = [67];
exports.modules = {
/***/ 1521:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ getRuleSelector)
/* harmony export */ });
/**
* @param {import('postcss').Rule} ruleNode
* @returns {string}
*/
function getRuleSelector(ruleNode) {
const raws = ruleNode.raws;
return (raws.selector && raws.selector.raw) || ruleNode.selector;
}
/***/ }),
/***/ 1524:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ hasInterpolation)
/* harmony export */ });
/* harmony import */ var _hasLessInterpolation_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1525);
/* harmony import */ var _hasPsvInterpolation_mjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1526);
/* harmony import */ var _hasScssInterpolation_mjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1527);
/* harmony import */ var _hasTplInterpolation_mjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1528);
/**
* Check whether a string has interpolation
*
* @param {string} string
* @returns {boolean} If `true`, a string has interpolation
*/
function hasInterpolation(string) {
// SCSS or Less interpolation
if (
(0,_hasLessInterpolation_mjs__WEBPACK_IMPORTED_MODULE_0__["default"])(string) ||
(0,_hasScssInterpolation_mjs__WEBPACK_IMPORTED_MODULE_2__["default"])(string) ||
(0,_hasTplInterpolation_mjs__WEBPACK_IMPORTED_MODULE_3__["default"])(string) ||
(0,_hasPsvInterpolation_mjs__WEBPACK_IMPORTED_MODULE_1__["default"])(string)
) {
return true;
}
return false;
}
/***/ }),
/***/ 1525:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ hasLessInterpolation)
/* harmony export */ });
const HAS_LESS_INTERPOLATION = /@\{.+?\}/;
/**
* Check whether a string has less interpolation
*
* @param {string} string
* @returns {boolean} If `true`, a string has less interpolation
*/
function hasLessInterpolation(string) {
return HAS_LESS_INTERPOLATION.test(string);
}
/***/ }),
/***/ 1526:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ hasPsvInterpolation)
/* harmony export */ });
const HAS_PSV_INTERPOLATION = /\$\(.+?\)/;
/**
* Check whether a string has postcss-simple-vars interpolation
*
* @param {string} string
* @returns {boolean}
*/
function hasPsvInterpolation(string) {
return HAS_PSV_INTERPOLATION.test(string);
}
/***/ }),
/***/ 1527:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ hasScssInterpolation)
/* harmony export */ });
const HAS_SCSS_INTERPOLATION = /#\{.+?\}/s;
/**
* Check whether a string has scss interpolation
*
* @param {string} string
* @returns {boolean}
*/
function hasScssInterpolation(string) {
return HAS_SCSS_INTERPOLATION.test(string);
}
/***/ }),
/***/ 1528:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ hasTplInterpolation)
/* harmony export */ });
const HAS_TPL_INTERPOLATION = /\{.+?\}/s;
/**
* Check whether a string has JS template literal interpolation or HTML-like template
*
* @param {string} string
* @returns {boolean} If `true`, a string has template literal interpolation
*/
function hasTplInterpolation(string) {
return HAS_TPL_INTERPOLATION.test(string);
}
/***/ }),
/***/ 1568:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ isStandardSyntaxRule)
/* harmony export */ });
/* harmony import */ var _isStandardSyntaxSelector_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1569);
/**
* Check whether a Node is a standard rule
*
* @param {import('postcss').Rule | import('postcss-less').Rule} rule
* @returns {boolean}
*/
function isStandardSyntaxRule(rule) {
if (rule.type !== 'rule') {
return false;
}
// Ignore Less &:extend rule
if ('extend' in rule && rule.extend) {
return false;
}
if (!(0,_isStandardSyntaxSelector_mjs__WEBPACK_IMPORTED_MODULE_0__["default"])(rule.selector)) {
return false;
}
return true;
}
/***/ }),
/***/ 1569:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ isStandardSyntaxSelector)
/* harmony export */ });
/* harmony import */ var _hasInterpolation_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1524);
/**
* Check whether a selector is standard
*
* @param {string} selector
* @returns {boolean}
*/
function isStandardSyntaxSelector(selector) {
// SCSS or Less interpolation
if ((0,_hasInterpolation_mjs__WEBPACK_IMPORTED_MODULE_0__["default"])(selector)) {
return false;
}
// SCSS placeholder selectors
if (selector.startsWith('%')) {
return false;
}
// SCSS nested properties
if (selector.endsWith(':')) {
return false;
}
// Less :extend()
if (/:extend(?:\(.*?\))?/.test(selector)) {
return false;
}
// Less mixin with resolved nested selectors (e.g. .foo().bar or .foo(@a, @b)[bar])
if (/\.[\w-]+\(.*\).+/.test(selector)) {
return false;
}
// Less non-outputting mixin definition (e.g. .mixin() {})
if (selector.endsWith(')') && !selector.includes(':')) {
return false;
}
// Less Parametric mixins (e.g. .mixin(@variable: x) {})
if (/\(@.*\)$/.test(selector)) {
return false;
}
// ERB template tags
if (selector.includes('<%') || selector.includes('%>')) {
return false;
}
// SCSS and Less comments
if (selector.includes('//')) {
return false;
}
return true;
}
/***/ }),
/***/ 1623:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ isNonNegativeInteger)
/* harmony export */ });
/**
* @param {unknown} value
*/
function isNonNegativeInteger(value) {
return Number.isInteger(value) && typeof value === 'number' && value >= 0;
}
/***/ }),
/***/ 1665:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ getStrippedSelectorSource)
/* harmony export */ });
/* harmony import */ var postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1666);
const { isComment } = postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__;
/**
* Get the source of a selector, excluding surrounding whitespace and comments.
*
* @param {import('postcss-selector-parser').Selector} node
*
* @returns {{selector: string, index: number, endIndex: number}}
*/
function getStrippedSelectorSource(node) {
const firstIndex = node.nodes.findIndex((x) => !isComment(x));
const lastIndex = node.nodes.findLastIndex((x) => !isComment(x));
const first = node.nodes[firstIndex];
let last = node.nodes[lastIndex];
if (!first || !last) {
const selector = node.toString().trim();
const index = node.sourceIndex ?? 0;
const endIndex = index + selector.length;
return {
selector,
index,
endIndex,
};
}
last = last.rawSpaceAfter.length ? last.clone() : last;
last.rawSpaceAfter = '';
let selector = node.nodes.slice(firstIndex, lastIndex).map(String).join('');
selector += last.toString();
selector = selector.trim();
const index = first.sourceIndex ?? 0;
const endIndex = index + selector.length;
return {
selector,
index,
endIndex,
};
}
/***/ }),
/***/ 1698:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ parseSelector)
/* harmony export */ });
/* harmony import */ var postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1666);
/**
* @param {string} selector
* @param {import('stylelint').PostcssResult} result
* @param {import('postcss').Node} node
* @param {(root: import('postcss-selector-parser').Root) => void} [callback] - Deprecated. It will be removed in the future.
* @returns {import('postcss-selector-parser').Root | undefined}
*/
function parseSelector(selector, result, node, callback) {
if (!selector) return undefined;
try {
// TODO: Remove `callback` in the future. See #7647.
if (callback) {
// @ts-expect-error -- TS2322: Type 'string' is not assignable to type 'Root'.
return postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__(callback).processSync(selector);
}
return postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__().astSync(selector);
} catch (err) {
result.warn(`Cannot parse selector (${err})`, { node, stylelintType: 'parseError' });
return undefined;
}
}
/***/ }),
/***/ 1730:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ flattenNestedSelectorsForRule)
/* harmony export */ });
/* harmony import */ var postcss_resolve_nested_selector__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1731);
/* harmony import */ var postcss_selector_parser__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1666);
/* harmony import */ var _getRuleSelector_mjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1521);
/* harmony import */ var _isStandardSyntaxSelector_mjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1569);
/* harmony import */ var _parseSelector_mjs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1698);
/** @import { Selector, Root } from 'postcss-selector-parser' */
/** @import { Rule } from 'postcss' */
/** @import { PostcssResult } from 'stylelint' */
/**
* Flatten the selectors of the current rule against it's parent rules and at-rules.
*
* The selectors for the current rule are assumed to be standard CSS selectors.
*
* @typedef {{selector: Selector, resolvedSelectors: Root, nested: boolean}} FlattenedSelector
*
* @param {Rule} rule
* @param {PostcssResult} result
* @returns {Array<FlattenedSelector>}
*/
function flattenNestedSelectorsForRule(rule, result) {
const ownAST = (0,_parseSelector_mjs__WEBPACK_IMPORTED_MODULE_4__["default"])((0,_getRuleSelector_mjs__WEBPACK_IMPORTED_MODULE_2__["default"])(rule), result, rule);
if (!ownAST) return [];
/** @type {Array<FlattenedSelector>} */
const flattenedSelectors = [];
for (const selectorAST of ownAST.nodes) {
const selector = selectorAST.toString();
const resolvedSelectors = postcss_resolve_nested_selector__WEBPACK_IMPORTED_MODULE_0__(selector, rule);
if (resolvedSelectors.length === 1 && resolvedSelectors[0] === selector) {
flattenedSelectors.push({
selector: selectorAST,
resolvedSelectors: postcss_selector_parser__WEBPACK_IMPORTED_MODULE_1__.root({
value: '',
nodes: [selectorAST],
}),
nested: false,
});
continue;
}
for (const resolvedSelector of resolvedSelectors) {
if (!(0,_isStandardSyntaxSelector_mjs__WEBPACK_IMPORTED_MODULE_3__["default"])(resolvedSelector)) return [];
const resolvedRoot = (0,_parseSelector_mjs__WEBPACK_IMPORTED_MODULE_4__["default"])(resolvedSelector, result, rule);
if (!resolvedRoot) {
continue;
}
flattenedSelectors.push({
selector: selectorAST,
resolvedSelectors: resolvedRoot,
nested: true,
});
}
}
return flattenedSelectors;
}
/***/ }),
/***/ 1731:
/***/ ((module) => {
module.exports = function resolveNestedSelector(selector, node) {
var parent = node.parent;
var parentIsNestAtRule = parent.type === 'atrule' && parent.name === 'nest';
if (parent.type === 'root') return [selector];
if (parent.type !== 'rule' && !parentIsNestAtRule) return resolveNestedSelector(selector, parent);
var parentSelectors = (parentIsNestAtRule)
? split(parent.params, ',', false).map((x) => x.trim())
: parent.selectors;
var resolvedSelectors = parentSelectors.reduce(function(result, parentSelector) {
if (selector.indexOf('&') !== -1) {
var newlyResolvedSelectors = resolveNestedSelector(parentSelector, parent).map(function(resolvedParentSelector) {
return split(selector, '&', true).join(resolvedParentSelector);
});
return result.concat(newlyResolvedSelectors);
}
var combinedSelector = [ parentSelector, selector ].join(' ');
return result.concat(resolveNestedSelector(combinedSelector, parent));
}, []);
return resolvedSelectors;
}
var blockPairs = {
'(': ')',
'[': ']',
'{': '}'
};
function split(string, separator, splitFunctions) {
var array = [];
var current = '';
var split = false;
var blockClose = [];
var inQuote = false;
var prevQuote = '';
var escape = false;
for (var letter of string) {
if (escape) {
escape = false;
} else if (letter === '\\') {
escape = true;
} else if (inQuote) {
if (letter === prevQuote) {
inQuote = false;
}
} else if (letter === '"' || letter === "'") {
inQuote = true;
prevQuote = letter;
} else if (letter === '(' || letter === '[' || letter === '{') {
blockClose.push(blockPairs[letter]);
} else if (letter === blockClose[blockClose.length - 1]) {
blockClose.pop();
} else if (blockClose.length === 0 || (splitFunctions && blockClose.every((x) => x === ')'))) {
if (letter === separator) split = true;
}
if (split) {
array.push(current);
current = '';
split = false;
} else {
current += letter;
}
}
array.push(current);
return array;
}
/***/ }),
/***/ 1792:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
;
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1666);
/* harmony import */ var _utils_flattenNestedSelectorsForRule_mjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1730);
/* harmony import */ var _utils_getStrippedSelectorSource_mjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1665);
/* harmony import */ var _utils_isNonNegativeInteger_mjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1623);
/* harmony import */ var _utils_isStandardSyntaxRule_mjs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1568);
/* harmony import */ var _utils_validateTypes_mjs__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(579);
/* harmony import */ var _utils_optionsMatches_mjs__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(869);
/* harmony import */ var _utils_report_mjs__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(945);
/* harmony import */ var _utils_ruleMessages_mjs__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(950);
/* harmony import */ var _utils_validateOptions_mjs__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(873);
const { isSelector } = postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__;
const ruleName = 'selector-max-universal';
const messages = (0,_utils_ruleMessages_mjs__WEBPACK_IMPORTED_MODULE_8__["default"])(ruleName, {
expected: (selector, max) =>
`Expected "${selector}" to have no more than ${max} universal ${
max === 1 ? 'selector' : 'selectors'
}`,
});
const meta = {
url: 'https://stylelint.io/user-guide/rules/selector-max-universal',
};
/** @type {import('stylelint').CoreRules[ruleName]} */
const rule = (primary, secondaryOptions) => {
return (root, result) => {
const validOptions = (0,_utils_validateOptions_mjs__WEBPACK_IMPORTED_MODULE_9__["default"])(
result,
ruleName,
{
actual: primary,
possible: _utils_isNonNegativeInteger_mjs__WEBPACK_IMPORTED_MODULE_3__["default"],
},
{
actual: secondaryOptions,
possible: {
ignoreAfterCombinators: [_utils_validateTypes_mjs__WEBPACK_IMPORTED_MODULE_5__.isString],
},
optional: true,
},
);
if (!validOptions) {
return;
}
/**
* @param {import('postcss-selector-parser').Selector} resolvedSelectorNode
* @param {import('postcss-selector-parser').Selector} selectorNode
* @param {import('postcss').Rule} ruleNode
*/
function checkSelector(resolvedSelectorNode, selectorNode, ruleNode) {
const count = resolvedSelectorNode.reduce((total, childNode) => {
const prevChildNode = childNode.prev();
const prevChildNodeValue = prevChildNode && prevChildNode.value;
if (childNode.type === 'universal') {
if (!(0,_utils_optionsMatches_mjs__WEBPACK_IMPORTED_MODULE_6__["default"])(secondaryOptions, 'ignoreAfterCombinators', prevChildNodeValue)) {
total += 1;
}
}
return total;
}, 0);
if (count > primary) {
const { index, endIndex, selector: selectorStr } = (0,_utils_getStrippedSelectorSource_mjs__WEBPACK_IMPORTED_MODULE_2__["default"])(selectorNode);
(0,_utils_report_mjs__WEBPACK_IMPORTED_MODULE_7__["default"])({
ruleName,
result,
node: ruleNode,
message: messages.expected,
messageArgs: [selectorStr, primary],
index,
endIndex,
});
}
}
root.walkRules((ruleNode) => {
if (!(0,_utils_isStandardSyntaxRule_mjs__WEBPACK_IMPORTED_MODULE_4__["default"])(ruleNode)) return;
(0,_utils_flattenNestedSelectorsForRule_mjs__WEBPACK_IMPORTED_MODULE_1__["default"])(ruleNode, result).forEach(({ selector, resolvedSelectors }) => {
resolvedSelectors.walk((childSelector) => {
if (!isSelector(childSelector)) return;
checkSelector(childSelector, selector, ruleNode);
});
});
});
};
};
rule.ruleName = ruleName;
rule.messages = messages;
rule.meta = meta;
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (rule);
/***/ })
};
;
//# sourceMappingURL=67.extension.js.map