You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I would like to discuss the best way to handle style sheets in Miso application or component library. I think styles abstractions (whatever it is) should be:
Composable with library/application Haskell code.
Composable with each other.
More or less typed (optional).
At the moment I see couple of options, but they all are kinda bad:
Using the standard external CSS file. The problems are:
I don't see the right way to export it as a part of the library (these are no css-sources in cabal, unlike js-sources)
CSS class names are just Text which should be the same across Haskell (class_) and CSS codebase. Hard to maintain and refactor. Prone to errors.
Using inline <style> tags next to every small component. I think kinda bad idea, and I'm not sure how to scope styles locally to component this way. Not sure it is possible or easy (not an expert in CSS).
Using style_ attribute functions and different variants of compositions of it. It's a bit better, but:
Can not define styles for pseudo-elements (::hover, ::before, ::after etc)
Can not define advanced CSS animations like @keyframes my-animation-name
Doing some smart CSS code generation from some Haskell style sheet source (.hs files), exporting class names (functions, utilities) used in Miso lib/app codebase, but having additional Setup step for the app/lib which doing corresponding CSS file code generation somehow.
Kinda sounds hard to do (maybe not, idk).
If I did miss some documentation or cool advanced CSS examples in Miso, please let me know. Best regards!
The text was updated successfully, but these errors were encountered:
This is an important topic. There's a lot of different schools of thought on how to create and manage CSS in applications (CSS-in-JS, using preprocessors (sass, etc.), SMACSS, BEM, utility classes / tailwind). In an attempt to please everybody we did not make any hard decisions.
With that said, for preprocessors there is a project called clay that could be integrated with miso, providing additional type safety. Also I believe there are attempts to wrap tailwind classes with miso's class attribute (otherwise wouldn't be difficult to do this on your own).
I would like to discuss the best way to handle style sheets in Miso application or component library. I think styles abstractions (whatever it is) should be:
At the moment I see couple of options, but they all are kinda bad:
css-sources
in cabal, unlikejs-sources
)class_
) and CSS codebase. Hard to maintain and refactor. Prone to errors.<style>
tags next to every small component. I think kinda bad idea, and I'm not sure how to scope styles locally to component this way. Not sure it is possible or easy (not an expert in CSS).style_
attribute functions and different variants of compositions of it. It's a bit better, but:@keyframes my-animation-name
If I did miss some documentation or cool advanced CSS examples in Miso, please let me know. Best regards!
The text was updated successfully, but these errors were encountered: