Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 13 additions & 1 deletion lib/resolve-decl.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ function eachMapItemDependencyOfDecl(variablesUsedList, map, decl, cb) {
variablesUsedList.forEach(function(variableUsedName) {

// Find anything in the map that corresponds to that variable
gatherVariableDependencies(variablesUsedList, map).deps.forEach(function(mapItem) {
gatherVariableDependencies([variableUsedName], map).deps.forEach(function(mapItem) {

var mimicDecl;
if(mapItem.isUnderAtRule) {
Expand Down Expand Up @@ -96,6 +96,18 @@ function resolveDecl(decl, map, /*optional*/shouldPreserve, /*optional*/preserve
//console.log('resolveDecl 2');
var previousAtRuleNode;
eachMapItemDependencyOfDecl(valueResults.variablesUsed, map, decl, function(mimicDecl, mapItem) {
// Check if the declaration is already inside the same at-rule as the variable
var declAtRule = decl.parent.parent.type === 'atrule' ? decl.parent.parent : null;
var varAtRule = mapItem.isUnderAtRule ? mapItem.parent.parent : null;
var isSameAtRule = declAtRule && varAtRule &&
declAtRule.name === varAtRule.name &&
declAtRule.params === varAtRule.params;

// Skip if the variable is in the same at-rule (already accessible)
if(isSameAtRule) {
return;
}

var ruleClone = shallowCloneNode(decl.parent);
var declClone = decl.clone();
// Add the declaration to our new rule
Expand Down
24 changes: 24 additions & 0 deletions test/fixtures/multiple-vars-in-media-query.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
:root {
--translate-x: 0;
--translate-y: 0;
--rotate: 0deg;
--skew-x: 0deg;
--skew-y: 0deg;
--scale-x: 1;
--scale-y: 1;
}

@media (max-width: 500px) {
.modal {
--translate-y: 100%;
transform: translate(var(--translate-x), var(--translate-y)) rotate(var(--rotate)) skewX(var(--skew-x)) skewY(var(--skew-y)) scaleX(var(--scale-x)) scaleY(var(--scale-y));
}

.drawer {
position: fixed;
--translate-y: -100%;
transform: translate(var(--translate-x), var(--translate-y)) rotate(var(--rotate)) skewX(var(--skew-x)) skewY(var(--skew-y)) scaleX(var(--scale-x)) scaleY(var(--scale-y));
transition: transform 0.3s ease;
}
}

12 changes: 12 additions & 0 deletions test/fixtures/multiple-vars-in-media-query.expected.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
@media (max-width: 500px) {
.modal {
transform: translate(0, 100%) rotate(0deg) skewX(0deg) skewY(0deg) scaleX(1) scaleY(1);
}

.drawer {
position: fixed;
transform: translate(0, -100%) rotate(0deg) skewX(0deg) skewY(0deg) scaleX(1) scaleY(1);
transition: transform 0.3s ease;
}
}

13 changes: 13 additions & 0 deletions test/fixtures/simple-multi-var-media-duplication.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
:root {
--shadow-x: 0px;
--shadow-y: 2px;
--shadow-blur: 4px;
}

@media (max-width: 500px) {
.card {
--shadow-y: 8px;
box-shadow: var(--shadow-x) var(--shadow-y) var(--shadow-blur) rgba(0, 0, 0, 0.1);
}
}

6 changes: 6 additions & 0 deletions test/fixtures/simple-multi-var-media-duplication.expected.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
@media (max-width: 500px) {
.card {
box-shadow: 0px 8px 4px rgba(0, 0, 0, 0.1);
}
}

11 changes: 11 additions & 0 deletions test/test.js
Original file line number Diff line number Diff line change
Expand Up @@ -383,4 +383,15 @@ describe("postcss-css-variables", function() {
"remove-nested-empty-rules-after-variable-collection"
);
});

describe("bug fixes", function() {
test(
"should not duplicate media query blocks when resolving multiple variables (simple case)",
"simple-multi-var-media-duplication"
);
test(
"should not duplicate media query blocks when resolving multiple variables in same property",
"multiple-vars-in-media-query"
);
});
});