stitches
stitches copied to clipboard
CSS order issue.
Bug report
Describe the bug
I'm working on monorepo project which shares components between 3 packages, and sometimes I have some css ordering issues. I made a simple demo in stack blitz which replicates a simplified version of my project:
2 packages that has their own themes:
- components/app
- components/ui
SSR made in pages/_document.js
To Reproduce
https://stackblitz.com/edit/nextjs-dzxyti?file=pages/index.js
// components/ui/Button.js
import { styled } from './stitches';
export const Button = styled('button', { textDecoration: 'underline' });
// components/ui/ButtonExtended.js
import { styled } from './stitches';
import { Button } from './Button';
export const ButtonExtended = styled(Button, { textDecoration: 'none' });
Expected behavior
ButtonExtended
should have text decoration = none.
In my project
I also tried to concatenate all the getText
into one style tag, but still got the issue. And its happens randomly, on the same component sometimes I got the issue, sometimes I don't.
const Label = styled('label', {
alignItems: 'center',
borderRadius: '$2xl',
color: '$accent',
display: 'flex',
height: '100%',
justifyContent: 'center',
width: '100%',
variants: {
checked: {
true: {
backgroundColor: '$accent',
color: '#fff',
},
},
},
});
Resulting markup of with the variant checked true:
<label class="olympos-c-hItJky olympos-c-hItJky-gwBWcw-checked-true" />
Resulting css order:
.olympos-c-hItJky {
align-items: center;
border-radius: var(--olympos-radii-2xl);
color: var(--olympos-colors-accent);
display: flex;
height: 100%;
justify-content: center;
width: 100%;
}
.olympos-c-hItJky-gwBWcw-checked-true {
background-color: var(--olympos-colors-accent);
color: #fff;
}
As you can see the variant got overriden by the base css.
data:image/s3,"s3://crabby-images/c7dbc/c7dbcb1d2062bfffc067af841f5200b6db43c773" alt="Screenshot 2022-01-02 at 21 09 09"
Note: order from SSR is working fine (when I disable the javascript everything is ok), the hydration messes up the orders.
Here's the css from SSR:
data:image/s3,"s3://crabby-images/c2ac6/c2ac60560e1e551da834f53ef2a149e25b4e38b0" alt="Screenshot 2022-01-02 at 21 08 24"
Video where I have the bug in multiple places: https://www.youtube.com/watch?v=nVgBbH8Kv_E
$ yarn list @stitches/react
โโ @stitches/[email protected]
Came here to report this exact problem. I would expect that styling a styled base component (creating a 'child' styled component) would override styling of that base component. However, since both components get just one css class assigned, it is completely random if the styling will get overwritten. It is dependent on the order at which the css rules are read by the browser, which is not consistent.
I would expect one of 2 things to happen:
- Stitches makes sure that the rules of the child component will always end up below the rules of the base component in the generated styles. This might be an issue with JS execution order and everything.
- Stitches makes sure that the child component gets both the classname of the base component as well as an additional classname, and the rules specific for the child component are applied for the combination of both classnames, increasing their specificity.
I'm not familiar with the inner workings of Stitches so I don't know which is the more pragmatic/logical solution here.
Same issue here ๐
Also observing this issue :(
@hadihallak, seems pretty similar to #671, any ideas?
@GeeWizWow There area a few things at work in here like different components extending the same one and two stitches instances at the same time (which is something not currently something we encourage or test against) Regardless, will be looking into this. thanks for the ping ๐
Thanks for the reply!
which is something not currently something we encourage or test against
This is interesting, and removing the second instance of stitches does indeed resolve the issue, as seen here: https://stackblitz.com/edit/nextjs-szzpjc?file=pages%2Findex.js
Would you be able to recommend an alternative? We have setup multiple stitches instances as a way to support multiple brands with distinct styling requirements.
For example, would the following be a better approach?
// packages/primitives/theme
export const { createTheme } = createStitches({ ...empty... });
// packages/brand-one/theme
import { createTheme } from '@primitives/theme';
export const { ... } = createTheme({ ... });
// packages/brand-two/theme
import { createTheme } from '@primitives/theme';
export const { ... } = createTheme({ ... });
Thanks for the reply!
which is something not currently something we encourage or test against
This is interesting, and removing the second instance of stitches does indeed resolve the issue, as seen here: https://stackblitz.com/edit/nextjs-szzpjc?file=pages%2Findex.js
Would you be able to recommend an alternative? We have setup multiple stitches instances as a way to support multiple brands with distinct styling requirements.
For example, would the following be a better approach?
// packages/primitives/theme export const { createTheme } = createStitches({ ...empty... }); // packages/brand-one/theme import { createTheme } from '@primitives/theme'; export const { ... } = createTheme({ ... }); // packages/brand-two/theme import { createTheme } from '@primitives/theme'; export const { ... } = createTheme({ ... });
Awesome. thanks for the quick followup Yes this is exactly how I would handle it
I'm curios now if @jahirfiquitiva and @WDeenik are using a similar setups with multiple Stitches instances
I shared some stuff regarding this on discord a while ago...
I created this to replicate https://codesandbox.io/s/stitches-and-next-themes-forked-04pbg?file=/components/theme-switch.js
But I'm using a mix of css({})
and styled()
https://discord.com/channels/752614004387610674/752614004387610678/927691473502228560
https://discord.com/channels/752614004387610674/752614004387610678/927697534103728148
We always had just the one Stitches instance, but I am not sure if we used css({})
at the time we encountered this bug. Will check if that was the case around that time.
We don't use css({})
anymore at the moment, so if that was the cause of this bug it might work like expected now, but it will take a while for me to be sure since the bug itself was not present 100% of the time even when we encountered it, and it will involve quite the refactor now.
@jahirfiquitiva Your codesandbox gives an Internal Server Error when I open it
I checked when we first encountered this problem, that was right before the release of 1.2.6 which had a fix for a very similar problem. When I ran into it again later and responded to this issue I wasn't aware of that new version yet, so there's a chance that the issue was fixed there. We only had one Stitches instance and did not use css({})
.
I cannot reproduce the original bug anymore, but then again it was hard to reproduce back then as well as it only happened occasionally and not very consistent. We'll start extending styled components again (completely avoided it after encountering the bug a couple of times), will report back if we ever run into it again.
I have a problem with CSS order when trying to overwrite styles of styled
component using css
function. Here is the reproduction with description. I had this problem before 1.2.6 as well (before fixing https://github.com/modulz/stitches/issues/671).
Would you be able to recommend an alternative? We have setup multiple stitches instances as a way to support multiple brands with distinct styling requirements. For example, would the following be a better approach?
// packages/primitives/theme export const { createTheme } = createStitches({ ...empty... }); // packages/brand-one/theme import { createTheme } from '@primitives/theme'; export const { ... } = createTheme({ ... }); // packages/brand-two/theme import { createTheme } from '@primitives/theme'; export const { ... } = createTheme({ ... });
Awesome. thanks for the quick followup Yes this is exactly how I would handle it
Hey @hadihallak, we had a play around with the above this morning, and I'm afraid it wasn't quite what we were looking for, mostly my fault for not having been clear in my examples.
Taking the above code again, what we were really hoping to achieve was something along the lines of:
// packages/primitives/theme
export const { createTheme } = createStitches({
prefix: '_primitives',
theme: {
// nothing here
},
});
// packages/brand-one/theme
import { createTheme } from '@primitives/theme';
export const { styled } = createTheme({
colors: {
red: 'red',
purple: 'purple',
},
media: {
// some BPs here
},
utils: {
// some utils here,
},
});
// packages/brand-two/theme
import { createTheme } from '@primitives/theme';
export const { styled } = createTheme({
colors: {
green: 'green',
},
media: {
// some **different** BPs here
},
});
Notice how both brands export an instance of the styled
function, looking at the documentation, it appears that the only real way to support this would be to have multiple top level instances of createStitches
, but as discussed, than can create issues
two stitches instances at the same time (which is something not currently something we encourage or test against) Regardless, will be looking into this. thanks for the ping ๐
Hey @hadihallak, this is actually something that I've brought up before in https://github.com/modulz/stitches/discussions/534, for which the fix was https://github.com/modulz/stitches/pull/546.
When the change to using CSSOM was put out, it's something that I explicitly checked with @jonathantneal about, where we had the following conversation
DYLAN: does this also remove the ability for consumers to specify the id of the style element that their styles are inserted into, and by default they would all be written to ?
JON: There is no longer a required ID, as there was before. However, we plan to add some of the other abilities for you to target the stylesheet or where it is inserted. The big reason for that particular change is to deal with the fact that Stitches no longer overrides the whole style sheet all at once. So thereโs no โcallbackโ for the big olโ update. For now, Stitches figures out which stylesheet it belongs to.
DYLAN: Interesting. Would I be correct in assuming then that multiple copies of stitches running on the same page then (each with their unique prefix) would now be compatible running on the same page without potentially overriding styles from another instance?
JON: Yes. That was actually one of the use-cases. Stitches Core running alongside Stitches React, or doubling one of those.
Hopefully the context is helpful! ๐
Hey everyone, the original description of the bug perfectly explains the bugs I'm having now on a new project with Hydrogen framework. Basically the overrides and variants have the same specificity in the final css but are before the original (base) class and therefore they don't get applied. It's stitches version 1.2.8
I could just use !important
everywhere but I think this should be fixed on the library level. I understand it is not a minor bug and it needs time but can somebody at least tell us are there any plans to fix this and when?
Aside from this the library is great and I love it, thanks! ๐๐ป
Also having this issue now:
Oddly enough, the static server-side rendered css seems correct, but if I navigate to the page I'm working on, then the inline css
is not correctly overriding the base styled
css.