123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports["default"] = rule;
- exports.ruleName = exports.meta = exports.messages = void 0;
- exports.variableColonSpaceChecker = variableColonSpaceChecker;
- var _utils = require("../../utils");
- var _stylelint = require("stylelint");
- var ruleName = (0, _utils.namespace)("dollar-variable-colon-space-after");
- exports.ruleName = ruleName;
- var messages = _stylelint.utils.ruleMessages(ruleName, {
- expectedAfter: function expectedAfter() {
- return 'Expected single space after ":"';
- },
- rejectedAfter: function rejectedAfter() {
- return 'Unexpected whitespace after ":"';
- },
- expectedAfterSingleLine: function expectedAfterSingleLine() {
- return 'Expected single space after ":" with a single-line value';
- },
- expectedAfterAtLeast: function expectedAfterAtLeast() {
- return 'Expected at least one space after ":"';
- }
- });
- exports.messages = messages;
- var meta = {
- url: (0, _utils.ruleUrl)(ruleName)
- };
- exports.meta = meta;
- function rule(expectation, _, context) {
- var checker = (0, _utils.whitespaceChecker)("space", expectation, messages);
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never", "always-single-line", "at-least-one-space"]
- });
- if (!validOptions) {
- return;
- }
- variableColonSpaceChecker({
- root: root,
- result: result,
- locationChecker: checker.after,
- checkedRuleName: ruleName,
- position: "after",
- expectation: expectation,
- context: context
- });
- };
- }
- rule.ruleName = ruleName;
- rule.messages = messages;
- rule.meta = meta;
- function variableColonSpaceChecker(_ref) {
- var locationChecker = _ref.locationChecker,
- root = _ref.root,
- result = _ref.result,
- checkedRuleName = _ref.checkedRuleName,
- position = _ref.position,
- expectation = _ref.expectation,
- context = _ref.context;
- root.walkDecls(function (decl) {
- if (decl.prop === undefined || decl.prop[0] !== "$") {
- return;
- }
- if (context && context.fix) {
- if (expectation === "always-single-line" && !(0, _utils.isSingleLineString)(decl.value)) {
- return;
- }
- if (position === "before") {
- var replacement = expectation === "never" ? ":" : " :";
- decl.raws.between = decl.raws.between.replace(/\s*:/, replacement);
- } else if (position === "after") {
- var match = expectation === "at-least-one-space" ? /:(?! )/ : /:\s*/;
- var _replacement = expectation === "never" ? ":" : ": ";
- decl.raws.between = decl.raws.between.replace(match, _replacement);
- }
- return;
- }
- // Get the raw $var, and only that
- var endOfPropIndex = (0, _utils.declarationValueIndex)(decl) + decl.raw("between").length - 1;
- // `$var:`, `$var :`
- var propPlusColon = decl.toString().slice(0, endOfPropIndex);
- var _loop = function _loop(i) {
- if (propPlusColon[i] !== ":") {
- return "continue";
- }
- locationChecker({
- source: propPlusColon,
- index: i,
- lineCheckStr: decl.value,
- err: function err(m) {
- _stylelint.utils.report({
- message: m,
- node: decl,
- index: i,
- result: result,
- ruleName: checkedRuleName
- });
- }
- });
- return "break";
- };
- for (var i = 0; i < propPlusColon.length; i++) {
- var _ret = _loop(i);
- if (_ret === "continue") continue;
- if (_ret === "break") break;
- }
- });
- }
|