Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@instructure/babel-plugin-themeable-styles
Advanced tools
A babel plugin to transform CSS imports for themeable components
Transforms CSS imports (via css-modules-require-hook) into a JavaScript object that provides a CSS Module, along with a template function that, given a theme variables object, will return the themed CSS as a string.
Given CSS file:
/* style.css */
.root {
background: var(--background);
color: var(--color);
&:hover {
background: var(--hoverBackground);
color: var(--hoverColor);
}
}
and a JavaScript module that imports the CSS file:
/* Button.js */
import styles from './styles.css'
In addition to running postcss on the CSS
source, a unique component id is generated by hashing the source. The component id is
made available as the componentId
property in the resulting JavaScript import
object. The component id is also used to generate scoped CSS class names. By default,
in production, CSS class names are prepended by the component id. In development, CSS
class names are prepended by the name of the CSS source's containing directory in
addition to the component id for easier debugging.
If you'd like to customize how the scoped class names are generated, you can add a config file to your project root:
/* themeable.config.js */
module.exports = {
generateScopedName: (context, componentId, name, filepath, css) {
// note that you can use interpolated strings here too:
return `${componentId}-[folder]__${name}`
}
}
Or just pass an interpolated string to the generateScopedName option:
/* themeable.config.js */
module.exports = {
generateScopedName: '[name]__[local]___[hash:base64:5]'
}
The transformed CSS import result in development would look similar to the following example:
/* Button.js */
const styles = {
componentId: 'dUxGkD',
template: function (theme) {
const tmpl = function () {
return `.dUxGkD__Button__root {
background: ${theme.background};
color: ${theme.color};
}
.dUxGkD__Button__root:hover {
background: ${theme.hoverBackground};
color: ${theme.hoverColor};
}`
}
return tmpl.call(theme, theme)
},
root: 'dUxGkD__Button__root'
}
yarn add --dev @instructure/babel-plugin-themeable-styles
Note: the easiest way to use this plugin is to use the babel preset provided by @instructure/ui-babel-preset.
However the plugin can be configured on its own as follows:
In your .babelrc file:
{
"plugins": [
[
"@instructure/babel-plugin-themeable-styles",
{
ignore: "node_modules/**/*"
}
],
]
}
FAQs
A babel plugin to transform CSS imports for themeable components
We found that @instructure/babel-plugin-themeable-styles demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 28 open source maintainers 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
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.