Security News
New Python Packaging Proposal Aims to Solve Phantom Dependency Problem with SBOMs
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools oft miss.
@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
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools oft miss.
Security News
Socket CEO Feross Aboukhadijeh discusses open source security challenges, including zero-day attacks and supply chain risks, on the Cyber Security Council podcast.
Security News
Research
Socket researchers uncover how threat actors weaponize Out-of-Band Application Security Testing (OAST) techniques across the npm, PyPI, and RubyGems ecosystems to exfiltrate sensitive data.