UNPKG

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
exports.id = 67; exports.ids = [67]; exports.modules = { /***/ 1521: /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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__) => { "use strict"; __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