Skip to content

A responsive wrapper for the vanilla-extract style API.

License

Notifications You must be signed in to change notification settings

dev-uly/vanilla-syrup

Repository files navigation

vanilla-syrup 😋

Add a responsive flavor to your vanilla-extract the easy way. This is a responsive wrapper for the style API.

🧪 Experimental 🚧 WIP


Prerequisite

Make sure that you have already setup vanilla-extract in your project.


Installation

npm i vanilla-syrup

Setup

Create a vanilla-syrup.config.ts in the root folder of your project.

vanilla-syrup.config.ts:

import { createSyrup } from "vanilla-syrup";

export const { style } = createSyrup({
  breakpoints: {
    xs: "30rem",
    sm: "48rem",
    md: "62rem",
    lg: "80rem",
    xl: "96rem",
  },
  mobileFirst: true,
  mediaType: "all",
});


Usage

src/components/Button/button.css.ts:

import { style } from "../../../vanilla-syrup.config";

export const button = style({
  base: {
    backgroundColor: "red",
  },
  "@xs": {
    backgroundColor: "orange",
  },
  "@sm": {
    backgroundColor: "yellow",
  },
  "@md": {
    backgroundColor: "green",
  },
  "@lg": {
    backgroundColor: "blue",
  },
  "@xl": {
    backgroundColor: "violet",
  },
});

Note: The base parameter is required.

src/components/Button/Button.tsx:

import { button } from "./button.css";

export const Button = ({
  children,
  ...props
}: React.ComponentProps<"button">) => {
  return (
    <button className={button} {...props}>
      {children}
    </button>
  );
};


S/O to these awesome libraries


License

MIT © Ulyses Edcel C. Adrales

About

A responsive wrapper for the vanilla-extract style API.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published