"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = rule; exports.ruleName = exports.meta = exports.messages = void 0; var _stylelint = require("stylelint"); var _utils = require("../../utils"); var ruleName = (0, _utils.namespace)("dollar-variable-colon-newline-after"); exports.ruleName = ruleName; var messages = _stylelint.utils.ruleMessages(ruleName, { expectedAfter: function expectedAfter() { return 'Expected newline after ":"'; }, expectedAfterMultiLine: function expectedAfterMultiLine() { return 'Expected newline after ":" with a multi-line value'; } }); exports.messages = messages; var meta = { url: (0, _utils.ruleUrl)(ruleName) }; exports.meta = meta; function rule(expectation, options, context) { var checker = (0, _utils.whitespaceChecker)("newline", expectation, messages); return function (root, result) { var validOptions = _stylelint.utils.validateOptions(result, ruleName, { actual: expectation, possible: ["always", "always-multi-line"] }, { actual: options, possible: { disableFix: _utils.isBoolean }, optional: true }); if (!validOptions) { return; } var shouldFix = context.fix && (!options || options.disableFix !== true); root.walkDecls(function (decl) { if (!decl.prop || decl.prop[0] !== "$") { return; } var value = decl.value.trim(); var startsWithParen = value[0] === "("; var endsWithParen = value[value.length - 1] === ")"; var endsWithDefault = /\)\s*!default$/.test(value); var isMultilineVarWithParens = startsWithParen && (endsWithParen || endsWithDefault) && !(0, _utils.isSingleLineString)(value); if (isMultilineVarWithParens) { 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() { if (propPlusColon[i] !== ":") { return "continue"; } var indexToCheck = propPlusColon.substr(propPlusColon[i], 3) === "/*" ? propPlusColon.indexOf("*/", i) + 1 : i; checker.afterOneOnly({ source: propPlusColon, index: indexToCheck, lineCheckStr: decl.value, err: function err(m) { if (shouldFix) { var nextLinePrefix = expectation === "always" ? decl.raws.before.replace(context.newline, "") : decl.value.split(context.newline)[1].replace(/^(\s+).*$/, function (_, whitespace) { return whitespace; }); decl.raws.between = decl.raws.between.replace(/:(.*)$/, ":".concat(context.newline).concat(nextLinePrefix)); return; } _stylelint.utils.report({ message: m, node: decl, index: indexToCheck, result: result, ruleName: ruleName }); } }); return "break"; }; for (var i = 0, l = propPlusColon.length; i < l; i++) { var _ret = _loop(); if (_ret === "continue") continue; if (_ret === "break") break; } }); }; } rule.ruleName = ruleName; rule.messages = messages; rule.meta = meta;