
Security News
Open Source Maintainers Demand Ability to Block Copilot-Generated Issues and PRs
Open source maintainers are urging GitHub to let them block Copilot from submitting AI-generated issues and pull requests to their repositories.
@hadihallak/css
Advanced tools
A simple benchmark VS styled-components
npm install @stitches/css
import { css } from "@stitches/css";
const button = css({
color: "gray",
"&:hover": {
color: "black",
},
borderColor: "black",
padding: "1rem",
});
const alertButton = css(button, {
borderColor: "red",
});
const dynamicButton = (disabled = false) =>
css(
button,
disabled && {
opacity: 0.5,
}
);
import { createCss } from "@stitches/css";
export const css = createCss({
// Optinally add a prefix to all classnames to avoid crashes
prefix: "my-lib",
// Maps tokens to properties. Follows the system-ui theme specification: https://system-ui.com/theme
tokens: {
colors: {
RED: "tomato",
},
space: {
0: "1rem",
},
fontSizes: {},
fonts: {},
fontWeights: {},
lineHeights: {},
letterSpacings: {},
sizes: {},
borderWidths: {},
borderStyles: {},
radii: {},
shadows: {},
zIndices: {},
transitions: {},
},
// Create screens with media queries. Note that the media queriy with the
// highest specificity should go last
breakpoints: {
tablet: (rule) => `@media (min-width: 700px) { ${rule} }`,
},
// Create your own custom CSS properties. Here the functional syntax
// shines to handle pseudo selectors
utils: {
marginX: (config) => (value: number | string) => ({
marginLeft: value,
marginRight: value,
}),
},
});
css({
color: "RED", // Creates "tomato"
tablet: {
color: "blue", // Color is "blue" when media query is active
},
marginX: 0, // Creates "1rem", as it composes margin, using "space" from tokens
border: "1px solid RED", // creates a "tomato" border
border: ["1px", "solid", "RED"], // You can also use array syntax to get typing
boxShadow: ["1px", "1px", "1px", "RED"], // You can also use array syntax with shadow
});
Stitches also allows you to put your utils at the front. That means you can create your very own CSS abstraction, where the underlying CSS properties are secondary.
import { createCss } from "@stitches/css";
export const css = createCss({
utilityFirst: true,
utils: {
text: (config) => (value: { color?: string; size?: number }) => ({
...(color ? { color } : {}),
...(size ? { fontSize: size + "rem" } : {}),
}),
},
});
css({
text: {
color: "red",
size: 2,
},
":hover": {
text: {
color: "blue",
},
},
// Override is a property that allows you to override
// with specific low level CSS properties
override: {
padding: "2rem",
},
});
You can create theme instances which overrides tokens:
import { createCss } from "@stitches/css";
export const css = createCss({
tokens: {
colors: {
primary: "tomato",
},
},
});
export const funnyTheme = css.theme({
colors: {
primary: "pink",
},
});
This theme represents a classname which can be added at any point in your DOM tree. You can add multiple themes, which overrides each other by the nested level you apply them.
The createCss
factory automatically detects if you are in a browser or server environment. That means when you this factory on the server it will hash the classnames (for rehydration abilities) and allow you to collect the styling to include in the responded html:
import { createCss } from "@stitches/css";
const css = createCss({});
const { result, styles } = css.getStyles(() => renderSomething(css));
Note that server produced CSS does not contain vendor prefixes, as there is no browser environment to look at. If you have a server rendered application you can either manually add the vendor prefixes you need:
css({
WebkitFontSmoothing: "antialiased",
MozOsxFontSmoothing: "grayscale",
});
Or you can use a postcss to do the conversion:
import { createCss } from "@stitches/css";
import postcss from "postcss";
import autoprefixer from "autoprefixer";
const css = createCss({});
const { result, styles } = css.getStyles(() => renderSomething(css));
Promise.all(
styles.map((style) =>
postcss([autoprefixer({ browsers: ["> 1%", "last 2 versions"] })]).process(
style
)
)
).then((styles) => {
// styles with vendor prefixes
});
FAQs
The modern CSS-in-JS library
The npm package @hadihallak/css receives a total of 0 weekly downloads. As such, @hadihallak/css popularity was classified as not popular.
We found that @hadihallak/css demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Open source maintainers are urging GitHub to let them block Copilot from submitting AI-generated issues and pull requests to their repositories.
Research
Security News
Malicious Koishi plugin silently exfiltrates messages with hex strings to a hardcoded QQ account, exposing secrets in chatbots across platforms.
Research
Security News
Malicious PyPI checkers validate stolen emails against TikTok and Instagram APIs, enabling targeted account attacks and dark web credential sales.