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.

477 lines (367 loc) 13.7 kB
"use strict"; exports.id = 76; exports.ids = [76]; 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; } /***/ }), /***/ 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; } } /***/ }), /***/ 1767: /***/ ((__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 _utils_getRuleSelector_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1521); /* harmony import */ var _utils_isStandardSyntaxRule_mjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1568); /* harmony import */ var _utils_isValidIdentifier_mjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1768); /* harmony import */ var _utils_parseSelector_mjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1698); /* harmony import */ var _utils_report_mjs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(945); /* harmony import */ var _utils_ruleMessages_mjs__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(950); /* harmony import */ var _utils_validateOptions_mjs__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(873); const ruleName = 'selector-attribute-quotes'; const messages = (0,_utils_ruleMessages_mjs__WEBPACK_IMPORTED_MODULE_5__["default"])(ruleName, { expected: (value) => `Expected quotes around "${value}"`, rejected: (value) => `Unexpected quotes around "${value}"`, }); const meta = { url: 'https://stylelint.io/user-guide/rules/selector-attribute-quotes', fixable: true, }; /** @type {import('stylelint').CoreRules[ruleName]} */ const rule = (primary) => { return (root, result) => { const validOptions = (0,_utils_validateOptions_mjs__WEBPACK_IMPORTED_MODULE_6__["default"])(result, ruleName, { actual: primary, possible: ['always', 'never'], }); if (!validOptions) { return; } root.walkRules((ruleNode) => { if (!(0,_utils_isStandardSyntaxRule_mjs__WEBPACK_IMPORTED_MODULE_1__["default"])(ruleNode)) { return; } const { selector } = ruleNode; if (!selector.includes('[') || !selector.includes('=')) { return; } const selectorTree = (0,_utils_parseSelector_mjs__WEBPACK_IMPORTED_MODULE_3__["default"])((0,_utils_getRuleSelector_mjs__WEBPACK_IMPORTED_MODULE_0__["default"])(ruleNode), result, ruleNode); if (!selectorTree) return; /** * @param {keyof messages} messageType * @param {import('postcss-selector-parser').Attribute} attrNode */ const complain = (messageType, attrNode) => { const index = attrNode.sourceIndex + attrNode.offsetOf('value'); const value = attrNode.value || ''; const endIndex = index + (attrNode.raws.value ?? value).length; const fix = () => { const quoteMark = messageType === 'expected' ? '"' : null; attrNode.quoteMark = quoteMark; ruleNode.selector = selectorTree.toString(); }; (0,_utils_report_mjs__WEBPACK_IMPORTED_MODULE_4__["default"])({ message: messages[messageType], messageArgs: [value], index, endIndex, result, ruleName, node: ruleNode, fix: { apply: fix, node: ruleNode, }, }); }; selectorTree.walkAttributes((attributeNode) => { const { operator, value, quoted } = attributeNode; if (!operator || !value) { return; } if (!quoted && primary === 'always') { complain('expected', attributeNode); } if (quoted && primary === 'never') { // some selectors require quotes to be valid; // we pass in the raw string value, which contains the escape characters // necessary to check if escaped characters are valid // see: https://github.com/stylelint/stylelint/issues/4300 if ( !attributeNode.raws.value || !(0,_utils_isValidIdentifier_mjs__WEBPACK_IMPORTED_MODULE_2__["default"])(attributeNode.raws.value.slice(1, -1)) ) { return; } complain('rejected', attributeNode); } }); }); }; }; rule.ruleName = ruleName; rule.messages = messages; rule.meta = meta; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (rule); /***/ }), /***/ 1768: /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ isValidIdentifier) /* harmony export */ }); const ISO_10646_CHARACTERS = /\\[0-9a-f]{1,6}(\\r\\n|[ \t\r\n\f])?/gi; const SINGLE_ESCAPED_CHARACTERS = /\\./g; const NON_WORD_OR_DASH = /[^\w-]/; const DIGIT = /\d/; /** * Returns whether a string is a valid CSS identifier * (i.e. only alphanumeric characters, `-`, and `_`; * does not have a leading digit, leading dash followed by digit, or two leading dashes) * furthermore, any escaped or ISO 10646 characters are allowed. * @see https://www.w3.org/TR/CSS2/syndata.html#value-def-identifier * @param {string} ident * @returns {boolean} */ function isValidIdentifier(ident) { if (!ident || ident.trim() === '') { return false; } // trims, removes ISO 10646 characters, and singly-escaped characters const trimmedIdent = ident .trim() .replace(ISO_10646_CHARACTERS, '') .replace(SINGLE_ESCAPED_CHARACTERS, ''); if (NON_WORD_OR_DASH.test(trimmedIdent)) { return false; } if (DIGIT.test(trimmedIdent.charAt(0))) { return false; } if (trimmedIdent.charAt(0) === '-' && DIGIT.test(trimmedIdent.charAt(1))) { return false; } return true; } /***/ }) }; ; //# sourceMappingURL=76.extension.js.map