Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
@clds/theme-helper
Advanced tools
This package was created to simplify the usage of themes when working with styled-components. It provides a default theme (that all applications themes should merge with),
a theme API so components will be able to access the theme values easily and some utility functions to work with themes
Install the package using Package Manager:
yarn add @clds/theme-helper
pnpm add @clds/theme-helper
npm install --save @clds/theme-helper
In case your component receive a prop and you want to get different theme variable based on the prop value you can use this function
When using the the ThemeProvider
from styled-components you should provide a theme object,
In order to support some extra features like base theme, references to other theme variables (from application or default theme) and more we created this function.
You should invoke it with your theme and send the result to the ThemeProvider
import { ThemeProvider } from 'styled-components';
import { generateTheme } from '@clds/theme-helper';
import { theme } from './myTheme';
const App = (props) => (
<ThemeProvider theme={generateTheme(theme)}>
<MyButton high={true}>Button</MyButton>
</ThemeProvider>
);
this package also contains a default theme,
this is the base theme and every application can override it by providing it's own theme with overrides,
When adding or updating a component that should be affected from the theme variables there are few steps that should be done
We should add variables for each component and not use existing global variables,
this will give the applications much more flexibility when creating their own themes.
We should use references to other theme variables so we won't need to duplicate values.
The default theme filename is default.theme.js
.
//default.theme.js
const myComponent = {
color: 'colors.primary',
};
module.exports = {
...myComponent,
};
This will take our component color from the primary color that's under the colors section in the theme.
In order to provide the themeApi
we have a mappings file,
when updating the default theme we should also update the mappings file so the themeApi will expose our variables and point to the correct locations in the theme
The mappings filename is mappings.js
.
//mappings.js
export default {
...,
myComponentColor: 'myComponent.color',
}
Now you will be able to use theme.myComponentColor
in your component and let the applications customize it when providing their theme
This library follows Semantic Versioning.
See LICENSE
FAQs
Helper for themes
We found that @clds/theme-helper demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.