sveltesheet v0.5.3
sveltesheet
A Svelte preprocessor making dynamic styles easier to use.
Important!
This preprocessor is still under development and currently doesn't support all css features, like @media. Please report any problems and missing css features.
Examples
Using variables inside css:
<!-- Flex.svelte -->
<script>
    import { css } from "sveltesheet";
    export let direction: "column" | "row" = "row";
</script>
<div>
    <slot />
</div>
{css`
    div {
        display: flex;
        flex-direction: ${direction};
    }
`}Referencing Svelte components in css:
<!-- Box.svelte -->
<script>
    import { css } from "sveltesheet";
    export let color = "red";
</script>
<Flex>
    <slot />
</Flex>
${css`
    ${Flex} {
        background-color: ${color};
    }
`}In order for sveltesheet to know which tag we actually want to target when we write ${Flex}, we need to add {...cssTarget} on the target tag inside Flex.svelte:
<!-- Flex.svelte -->
<script>
    import { css, cssTarget } from "sveltesheet";
    export let direction: "column" | "row" = "row";
</script>
<div {...cssTarget}>
    <slot />
</div>
{css`
    div {
        display: flex;
        flex-direction: ${direction};
    }
`}Using bigger css parts
Sometimes it's useful to reuse a part of css. With sveltesheet, you can use the @css at-rule or css property to achieve this.
css property
<script>
    import { css } from "sveltesheet";
    function getTextStyle(size: "big" | "small") {
        // Note that you can use the `css` function for convenient syntax highlighting with a variety of IDE-plugins
        return css`
            font-size: ${size === "big" ? 2 : 1}rem;
            font-weight: ${size === "big" ? 700 : 400};
        `;
    }
</script>
<h1>Big heading!</h1>
<h2>Small heading.</h2>
{css`
    h1 {
        css: ${getTextStyle("big")};
    }
    h2 {
        css: ${getTextStyle("small")};
    }
`}@css at-rule
With the @css at rule, you can create whole rules, including the selectors.
💥 Important! The resulting css will always have a global scope, as it is not processed at runtime.
<script>
    import { css } from "sveltesheet";
    // Note that you can use the `css` function for convenient syntax highlighting with a variety of IDE-plugins
    const redTextCss = css`
        p {
            color: red;
        }
    `;
</script>
<h1>Title!</h1>
<p>Some text</p>
{css`
    @css ${redTextCss};
`}How to use
- Install the package. Run:- npm install stylesheet
 
- Inside svelte.config.js, addsveltesheet()to the list of preprocessors:
import adapter from "@sveltejs/adapter-auto";
import { vitePreprocess } from "@sveltejs/kit/vite";
//Import this:
import { sveltesheet } from "sveltesheet";
const config = {
	//Add `sveltesheet()` here:
	preprocess: [sveltesheet(), vitePreprocess()],
	kit: {
		adapter: adapter(),
	},
};
export default config;That's it! Sveltesheet should now be ready to use. ✨
How does it work?
There is no magic. This is a simple preprocessor, turning your css code into a <style> or <svelte:element this="style"> tag, depending on if your css is "dynamic" or not.
This...
{css`
    ${Component} > div {
        width: ${200 + 300}px;
        height: 200px;
    }
    div {
        background-color: red;
    }
`}gets transformed into something similar to this:
<style>
    [data-sveltesheet-ids="componentid"] > div {
        height: 200px;
    }
    div {
        background-color: red;
    }
</style>
<svelte:element this="style">
{`
    [data-sveltesheet-ids="componentid"][data-sveltesheet-ids="runtimeId"] > div[data-sveltesheet-ids="runtimeId"] {
        width: ${200 + 300}px;
    }
`}
</svelte:element>The preprocessor knows when you're using dynamic or static properties and splits them into <style> or <svelte:element this="style"> accordingly. Static properties get put into the <style>-tag, while dynamic properties go to into the <svelte:element>-tag.
This way, the css inside <svelte:element> gets dynamically updated each time its dependencies change, while the style-tag stays static at all times.