Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Maintain Nested Sass Variables #26

Open
zastrow opened this issue Apr 17, 2019 · 1 comment
Open

Maintain Nested Sass Variables #26

zastrow opened this issue Apr 17, 2019 · 1 comment

Comments

@zastrow
Copy link
Contributor

zastrow commented Apr 17, 2019

I have come across a Splinter bug that I have given an attempt of solving myself. In doing so, I definitely have a better understanding of how Splinter is working, which has led me to think that this is instead a feature request.

Here is the problem:

When a variable is declared within a selector block in Sass, it is scoped to be used within all nested selector blocks.

e.g.

.foo {
	$this: 3;
	prop: $this;

	&--bar {
		prop: $this * 2;
	}
}

With standard Sass that would output:

.foo {
	prop: 3;
}

.foo--bar {
	prop: 6;
}

When Splinter is added to the build process however it half-renders the Sass. The output to the split manifest from the example above looks like this:

.foo {
	$this: 3;
	prop: $this;
}

.foo--bar {
	prop: $this * 2;
}

That output from Splinter results in a Sass error as the variable $this is no longer defined in .foo--bar.

For now, the work around is that all Sass variables have to be global variables. Not a bad thing, but scoped variables are really handy.

To me the solution would need to be that either the Sass nesting be maintained like the original code or the variables are stored and injected into the nested selectors when they are half-rendered by Splinter.

@zastrow
Copy link
Contributor Author

zastrow commented Sep 18, 2020

This needs verified. I worked on this earlier this year, but I recall we still had issues and that the fix in #27 didn’t take.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants