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.

571 lines (440 loc) 17.1 kB
exports.id = 135; exports.ids = [135]; exports.modules = { /***/ 1537: /***/ ((__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 */ uniteSets) /* harmony export */ }); /** * Unite two or more sets * * @param {Iterable<string>[]} args * @see {@link https://github.com/microsoft/TypeScript/issues/57228|GitHub} */ function uniteSets(...args) { return new Set([...args].reduce((result, set) => [...result, ...set], [])); } /***/ }), /***/ 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; } /***/ }), /***/ 1739: /***/ ((__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 */ isKeyframeRule) /* harmony export */ }); /* harmony import */ var _typeGuards_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(886); /** * Check if a rule is a keyframe one * * @param {import('postcss').Rule} rule * @returns {boolean} */ function isKeyframeRule(rule) { const parent = rule.parent; if (!parent) { return false; } return (0,_typeGuards_mjs__WEBPACK_IMPORTED_MODULE_0__.isAtRule)(parent) && parent.name.toLowerCase() === 'keyframes'; } /***/ }), /***/ 1791: /***/ ((__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 */ isStandardSyntaxTypeSelector) /* harmony export */ }); /* harmony import */ var _reference_selectors_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1734); /** * Check whether a type selector is standard * * @param {import('postcss-selector-parser').Tag} node postcss-selector-parser node (of type tag) * @returns {boolean} If `true`, the type selector is standard */ function isStandardSyntaxTypeSelector(node) { // postcss-selector-parser includes the arguments to nth-child() functions // as "tags", so we need to ignore them ourselves. // The fake-tag's "parent" is actually a selector node, whose parent // should be the :nth-child pseudo node. if (!node.parent || !node.parent.parent) { return false; } const _node$parent$parent = node.parent.parent; const parentType = _node$parent$parent.type; const parentValue = _node$parent$parent.value; if (parentValue) { const normalisedParentName = parentValue.toLowerCase().replace(/:+/, ''); if ( parentType === 'pseudo' && (_reference_selectors_mjs__WEBPACK_IMPORTED_MODULE_0__.aNPlusBNotationPseudoClasses.has(normalisedParentName) || _reference_selectors_mjs__WEBPACK_IMPORTED_MODULE_0__.aNPlusBOfSNotationPseudoClasses.has(normalisedParentName) || _reference_selectors_mjs__WEBPACK_IMPORTED_MODULE_0__.linguisticPseudoClasses.has(normalisedParentName) || _reference_selectors_mjs__WEBPACK_IMPORTED_MODULE_0__.shadowTreePseudoElements.has(normalisedParentName)) ) { return false; } } // &-bar is a nesting selector combined with a suffix if (node.prev()?.type === 'nesting') { return false; } if (node.value.startsWith('%')) { return false; } // Reference combinators like `/deep/` if (node.value.startsWith('/') && node.value.endsWith('/')) { return false; } return true; } /***/ }), /***/ 1794: /***/ ((__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_isKeyframeRule_mjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1739); /* harmony import */ var _utils_isStandardSyntaxRule_mjs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1568); /* harmony import */ var _utils_isStandardSyntaxTypeSelector_mjs__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(1791); /* 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 ruleName = 'selector-no-qualifying-type'; const messages = (0,_utils_ruleMessages_mjs__WEBPACK_IMPORTED_MODULE_8__["default"])(ruleName, { rejected: (selector) => `Unexpected qualifying type selector "${selector}"`, }); const meta = { url: 'https://stylelint.io/user-guide/rules/selector-no-qualifying-type', }; const HAS_ID_CLASS_ATTRIBUTE_PREFIXES = /[#.[]/; /** @import { Tag, Node, Selector, Container } from 'postcss-selector-parser' */ /** * @param {Tag} node * @returns {Array<Node>} */ function getRightNodes(node) { /** @type {Array<Node>} */ const result = []; /** @type {Node | undefined} */ let rightNode = node; while ((rightNode = rightNode.next())) { if (postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__.isCombinator(rightNode) || postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__.isPseudoElement(rightNode)) { break; } result.push(rightNode); } while ((rightNode = result.at(-1))) { if ( postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__.isIdentifier(rightNode) || postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__.isClassName(rightNode) || postcss_selector_parser__WEBPACK_IMPORTED_MODULE_0__.isAttribute(rightNode) ) { break; } result.splice(-1, 1); } return result; } /** @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: [true], }, { actual: secondaryOptions, possible: { ignore: ['attribute', 'class', 'id'], }, optional: true, }, ); if (!validOptions) { return; } const ignoreId = (0,_utils_optionsMatches_mjs__WEBPACK_IMPORTED_MODULE_6__["default"])(secondaryOptions, 'ignore', 'id'); const ignoreClass = (0,_utils_optionsMatches_mjs__WEBPACK_IMPORTED_MODULE_6__["default"])(secondaryOptions, 'ignore', 'class'); const ignoreAttribute = (0,_utils_optionsMatches_mjs__WEBPACK_IMPORTED_MODULE_6__["default"])(secondaryOptions, 'ignore', 'attribute'); root.walkRules((ruleNode) => { if (!(0,_utils_isStandardSyntaxRule_mjs__WEBPACK_IMPORTED_MODULE_4__["default"])(ruleNode)) { return; } if ((0,_utils_isKeyframeRule_mjs__WEBPACK_IMPORTED_MODULE_3__["default"])(ruleNode)) { return; } if (!HAS_ID_CLASS_ATTRIBUTE_PREFIXES.test(ruleNode.selector)) { return; } /** * @param {Container<string | undefined>} resolvedSelectorNode * @param {Selector} selectorNode * @param {boolean} nested */ function checkSelector(resolvedSelectorNode, selectorNode, nested) { resolvedSelectorNode.walkTags((tagNode) => { if (!(0,_utils_isStandardSyntaxTypeSelector_mjs__WEBPACK_IMPORTED_MODULE_5__["default"])(tagNode)) return; const selectorParent = tagNode.parent; if (selectorParent && selectorParent.nodes.length === 1) { return; } const rightNodes = getRightNodes(tagNode); for (const rightNode of rightNodes) { if ( (rightNode.type === 'id' && !ignoreId) || (rightNode.type === 'class' && !ignoreClass) || (rightNode.type === 'attribute' && !ignoreAttribute) ) { let index = 0; let endIndex = 0; const selector = [tagNode, ...rightNodes].join('').trim(); if (nested) { ({ index, endIndex } = (0,_utils_getStrippedSelectorSource_mjs__WEBPACK_IMPORTED_MODULE_2__["default"])(selectorNode)); } else { index = tagNode.sourceIndex ?? 0; endIndex = index + selector.length; } (0,_utils_report_mjs__WEBPACK_IMPORTED_MODULE_7__["default"])({ ruleName, result, node: ruleNode, message: messages.rejected, messageArgs: [selector], index, endIndex, }); break; } } }); } (0,_utils_flattenNestedSelectorsForRule_mjs__WEBPACK_IMPORTED_MODULE_1__["default"])(ruleNode, result).forEach( ({ selector, resolvedSelectors, nested }) => { checkSelector(resolvedSelectors, selector, nested); }, ); }); }; }; rule.ruleName = ruleName; rule.messages = messages; rule.meta = meta; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (rule); /***/ }) }; ; //# sourceMappingURL=135.extension.js.map