Features
Next-yak is a featured packed static CSS-in-JS framework with a minimal runtime aspect.
Static CSS
At the heart of next-yak lies the extraction of static CSS. You can write your styles as you normally would with styled-components. During build time, these styles are extracted, and your component is assigned a class that encapsulates these styles.
See transformed output
Dynamic styles
The static functionality itself is already very useful, but the bread and butter is an easy way to create dynamic styles. Styled-components popularized the approach of using props to drive dynamic CSS parts. With next-yak, you can use the exact same familiar API.
The CSS templates create their own class which is referenced during runtime when the function returns them. The other function which returns strings directly without setting new CSS properties, will be changed to a CSS variable, which is set on the element itself directly based on the functions return value.
See transformed output
Compatible with utility-first CSS frameworks (e.g. Tailwind)
Next-yak is fully compatible with utility-first CSS frameworks like Tailwind. Just use the atoms
function to
reference classes from these frameworks.
See transformed output
Animations
In order to create CSS animations, you can use the keyframes
API and specify the keyframes for the animation
you want to create. This can be used in your animation declarations within the same file.
See transformed output
Mixins
Mixins are declarations of the css
utility function. You can declare a variable which holds the css declaration and
use it inside your styled
declarations.
You can also make it dynamic, where the props are passed to the mixin.
During build time the CSS literal is converted to a class name (or multiple class names) and can be referenced by other CSS styles.
See transformed output
Automatic CSS variables
You may noticed that we sometimes used css`` and sometimes just a literal string. If the property name is already present and you want to have dynamic values of that property, you can just use literal strings. These get transformed into CSS variables during build time.
The value of the CSS variable is set via the style property of the component, ensuring no interference with potential CSS variable names that share the same name.
See transformed output
Theming
As of next.js >15.0.0, this feature doesn't work with server components anymore.
As your application grows, theming becomes increasingly important as a shortcut to pass the same values to components.
Next-yak integrates it in a hassle free manner that works for both Server Components and Client Components without
a difference in usage for you. Wrap your root with the ThemeProvider and add a yak.context.ts
file to your root directory
and you're ready to go.
Once this context file is in place, you can access the theme props on every component.
CSS Prop
We support out of the box the css
prop which is a shorthand for adding styles to an element. Similiar to inline-styles
it allows you to write local styles for certain elements on your page. Differently than inline-styles, it allows you to use
selectors that target wrapped elements.
It's meant for simple styling requirements, where you don't have to think about a name for a specialized component.
TypeScript
To use it with the correct types just add the following line to the top of the file
Or just add this to your tsconfig.json
and all your css props will have the correct types.