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.
456 lines (356 loc) • 12.8 kB
JavaScript
exports.id = 52;
exports.ids = [52];
exports.modules = {
/***/ 1519:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ atRuleAfterIndex: () => (/* binding */ atRuleAfterIndex),
/* harmony export */ atRuleAfterNameIndex: () => (/* binding */ atRuleAfterNameIndex),
/* harmony export */ atRuleBetweenIndex: () => (/* binding */ atRuleBetweenIndex),
/* harmony export */ atRuleParamIndex: () => (/* binding */ atRuleParamIndex),
/* harmony export */ declarationBetweenIndex: () => (/* binding */ declarationBetweenIndex),
/* harmony export */ declarationValueIndex: () => (/* binding */ declarationValueIndex),
/* harmony export */ ruleAfterIndex: () => (/* binding */ ruleAfterIndex),
/* harmony export */ ruleBetweenIndex: () => (/* binding */ ruleBetweenIndex)
/* harmony export */ });
/* harmony import */ var _getAtRuleParams_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1520);
/* harmony import */ var _getRuleSelector_mjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1521);
/* harmony import */ var _validateTypes_mjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(579);
/** @import {AtRule, Declaration, Rule} from 'postcss' */
/**
* @param {AtRule} atRule
* @returns {number}
*/
function atRuleParamIndex(atRule) {
const index = atRuleAfterNameIndex(atRule);
return index + (atRule.raws.afterName?.length ?? 0);
}
/**
* @param {AtRule} atRule
* @returns {number}
*/
function atRuleAfterIndex(atRule) {
// subtract 1 for `}`
const endOffset = atRule.source?.end?.offset;
if (!endOffset) return atRule.toString().length - 1;
const afterLength = atRule.raws?.after?.length;
if (!afterLength) return endOffset - 1;
return endOffset - (afterLength + 1);
}
/**
* @param {AtRule} atRule
* @returns {number}
*/
function atRuleAfterNameIndex(atRule) {
// Initial 1 is for the `@`
return 1 + atRule.name.length;
}
/**
* @param {AtRule} atRule
* @returns {number}
*/
function atRuleBetweenIndex(atRule) {
return atRuleParamIndex(atRule) + (0,_getAtRuleParams_mjs__WEBPACK_IMPORTED_MODULE_0__["default"])(atRule).length;
}
/**
* @param {Declaration} decl
* @returns {number}
*/
function declarationBetweenIndex(decl) {
const { prop } = decl.raws;
const propIsObject = (0,_validateTypes_mjs__WEBPACK_IMPORTED_MODULE_2__.isObject)(prop);
return countChars([
propIsObject && 'prefix' in prop && prop.prefix,
(propIsObject && 'raw' in prop && prop.raw) || decl.prop,
propIsObject && 'suffix' in prop && prop.suffix,
]);
}
/**
* Get the index of a declaration's value
*
* @param {Declaration} decl
* @returns {number}
*/
function declarationValueIndex(decl) {
const { between, value } = decl.raws;
return (
declarationBetweenIndex(decl) +
countChars([between || ':', value && 'prefix' in value && value.prefix])
);
}
/**
* @param {Rule} rule
* @returns {number}
*/
function ruleBetweenIndex(rule) {
return (0,_getRuleSelector_mjs__WEBPACK_IMPORTED_MODULE_1__["default"])(rule).length;
}
/**
* @param {Rule} rule
* @returns {number}
*/
function ruleAfterIndex(rule) {
// subtract 1 for `}`
const endOffset = rule.source?.end?.offset;
if (!endOffset) return rule.toString().length - 1;
const afterLength = rule.raws?.after?.length;
if (!afterLength) return endOffset - 1;
return endOffset - (afterLength + 1);
}
/**
* @param {unknown[]} values
* @returns {number}
*/
function countChars(values) {
return values.reduce((/** @type {number} */ count, value) => {
if ((0,_validateTypes_mjs__WEBPACK_IMPORTED_MODULE_2__.isString)(value)) return count + value.length;
return count;
}, 0);
}
/***/ }),
/***/ 1520:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ getAtRuleParams)
/* harmony export */ });
/**
* @param {import('postcss').AtRule} atRule
* @returns {string}
*/
function getAtRuleParams(atRule) {
return atRule.raws.params?.raw ?? atRule.params;
}
/***/ }),
/***/ 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;
}
/***/ }),
/***/ 1535:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ atRuleRegexes: () => (/* binding */ atRuleRegexes),
/* harmony export */ descriptorRegexes: () => (/* binding */ descriptorRegexes),
/* harmony export */ functionRegexes: () => (/* binding */ functionRegexes),
/* harmony export */ propertyRegexes: () => (/* binding */ propertyRegexes)
/* harmony export */ });
/* harmony import */ var _reference_atKeywords_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1536);
const atRuleRegexes = {
mediaName: /^media$/i,
keyframesName: /^(-(o|moz|ms|webkit)-)?keyframes$/i,
propertyName: /^property$/i,
importName: /^import$/i,
unsupportedNestingNames: new RegExp(
`^((?!${[..._reference_atKeywords_mjs__WEBPACK_IMPORTED_MODULE_0__.nestingSupportedAtKeywords.values()].join('|')}).)*$`,
'i',
),
layerName: /^layer$/i,
containerName: /^container$/i,
scopeName: /^scope$/i,
};
const descriptorRegexes = {
syntaxName: /^syntax$/i,
};
const functionRegexes = {
layer: /layer\((.*?)\)/i,
};
const propertyRegexes = {
containerNameAndShorthandName: /^container(-name)?$/i,
};
/***/ }),
/***/ 1536:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ atKeywords: () => (/* binding */ atKeywords),
/* harmony export */ deprecatedAtKeywords: () => (/* binding */ deprecatedAtKeywords),
/* harmony export */ nestingSupportedAtKeywords: () => (/* binding */ nestingSupportedAtKeywords),
/* harmony export */ pageMarginAtKeywords: () => (/* binding */ pageMarginAtKeywords)
/* harmony export */ });
/* harmony import */ var _utils_uniteSets_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1537);
/** @type {ReadonlySet<string>} */
const deprecatedAtKeywords = new Set(['document', 'nest', 'viewport']);
/**
* @see https://www.w3.org/TR/css-nesting-1/#conditionals
* @type {ReadonlySet<string>}
*/
const nestingSupportedAtKeywords = new Set([
'apply',
'container',
'layer',
'media',
'scope',
'starting-style',
'supports',
]);
/**
* @see https://www.w3.org/TR/css-page-3/#syntax-page-selector
* @type {ReadonlySet<string>}
*/
const pageMarginAtKeywords = new Set([
'top-left-corner',
'top-left',
'top-center',
'top-right',
'top-right-corner',
'bottom-left-corner',
'bottom-left',
'bottom-center',
'bottom-right',
'bottom-right-corner',
'left-top',
'left-middle',
'left-bottom',
'right-top',
'right-middle',
'right-bottom',
]);
/**
* @see https://www.w3.org/TR/css-fonts-4/#font-feature-values-font-feature-value-type
* @type {ReadonlySet<string>}
*/
const fontFeatureValueTypes = new Set([
'annotation',
'character-variant',
'historical-forms',
'ornaments',
'styleset',
'stylistic',
'swash',
]);
/**
* @see https://developer.mozilla.org/en/docs/Web/CSS/At-rule
* @type {ReadonlySet<string>}
*/
const atKeywords = (0,_utils_uniteSets_mjs__WEBPACK_IMPORTED_MODULE_0__["default"])(
deprecatedAtKeywords,
nestingSupportedAtKeywords,
pageMarginAtKeywords,
fontFeatureValueTypes,
[
'counter-style',
'custom-media',
'custom-selector',
'font-face',
'font-feature-values',
'font-palette-values',
'import',
'keyframes',
'namespace',
'page',
'position-try',
'property',
'scroll-timeline',
'view-transition',
],
);
/***/ }),
/***/ 1537:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
__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], []));
}
/***/ }),
/***/ 1574:
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ isVarFunction)
/* harmony export */ });
/* harmony import */ var _typeGuards_mjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(886);
/**
* @param {import('postcss-value-parser').Node} node
* @returns {node is import('postcss-value-parser').FunctionNode}
*/
function isVarFunction(node) {
return (0,_typeGuards_mjs__WEBPACK_IMPORTED_MODULE_0__.isValueFunction)(node) && node.value.toLowerCase() === 'var';
}
/***/ }),
/***/ 1750:
/***/ ((__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_value_parser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1514);
/* harmony import */ var _utils_regexes_mjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1535);
/* harmony import */ var _utils_nodeFieldIndices_mjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1519);
/* harmony import */ var _utils_isVarFunction_mjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1574);
/* 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 = 'no-unknown-custom-properties';
const messages = (0,_utils_ruleMessages_mjs__WEBPACK_IMPORTED_MODULE_5__["default"])(ruleName, {
rejected: (property) => `Unexpected unknown custom property "${property}"`,
});
const meta = {
url: 'https://stylelint.io/user-guide/rules/no-unknown-custom-properties',
};
/** @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 });
if (!validOptions) return;
/** @type {Set<string>} */
const declaredCustomProps = new Set();
root.walkAtRules(_utils_regexes_mjs__WEBPACK_IMPORTED_MODULE_1__.atRuleRegexes.propertyName, ({ params }) => {
declaredCustomProps.add(params);
});
root.walkDecls(/^--/, ({ prop }) => {
declaredCustomProps.add(prop);
});
root.walkDecls((decl) => {
const { value } = decl;
const parsedValue = postcss_value_parser__WEBPACK_IMPORTED_MODULE_0__(value);
parsedValue.walk((node) => {
if (!(0,_utils_isVarFunction_mjs__WEBPACK_IMPORTED_MODULE_3__["default"])(node)) return;
const [firstNode, secondNode] = node.nodes;
if (!firstNode || declaredCustomProps.has(firstNode.value)) return;
// Second node (div) indicates fallback exists in all cases
if (secondNode && secondNode.type === 'div') return;
const startIndex = (0,_utils_nodeFieldIndices_mjs__WEBPACK_IMPORTED_MODULE_2__.declarationValueIndex)(decl);
(0,_utils_report_mjs__WEBPACK_IMPORTED_MODULE_4__["default"])({
result,
ruleName,
message: messages.rejected,
messageArgs: [firstNode.value],
node: decl,
index: startIndex + firstNode.sourceIndex,
endIndex: startIndex + firstNode.sourceEndIndex,
});
});
});
};
};
rule.ruleName = ruleName;
rule.messages = messages;
rule.meta = meta;
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (rule);
/***/ })
};
;
//# sourceMappingURL=52.extension.js.map
;