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.
badoo-styleguide
Advanced tools
Badoo styleguide used to develop UI components for the Web and React Native
Work in progress: This is a styleguide used by the frontend team in Magiclab, at the moment we are in the process of open sourcing it. Just working out some issues, cleaning up the API and adding documentation.
yarn add badoo-styleguide --dev
Create a file called styleguide.config.js
in your project (The name doesn't really matter).
Add the following content to the file
module.exports = {
/**
* Set it to true if your project is a React native project
* @optional
*/
isReactNative: false,
/**
* Set it to true if you want to resize sandboxes with the resize handle
* @optional
*/
hasResizableSandbox: false,
/**
* This function will apply provided actions during render of component
* @optional
*/
actionOnRender() {
// eslint-disable-next-line no-undef
if (document & !document.querySelector('body').classList) {
// eslint-disable-next-line no-undef
document.querySelector('body').classList.add('test')
}
},
/**
* Set it to true if you want to handle reset css & and default minimal css
* for styleguide outside of project
* equals to both noDefaultStyleguideStyles & noDefaultStyleguideStyles
* set to true
* @optional
*/
noDefaultGlobalStyles: false,
/**
* Set it to true if you want to switch off default Styleguide
* minimal style reset.
* @optional
*/
noDefaultStyleguideStyles: false,
/**
* Set it to true if you want to switch off normalize used for reset
* of styles
* @optional
*/
noDefaultNormalize: false,
/**
* Min-width for the sandbox wrapper (number | string)
* default – 320
* @optional
*/
sandboxMinWidth: 320,
/**
* Max-width for the sandbox wrapper (number | string)
* default – 960
* @optional
*/
sandboxMaxWidth: '100%',
/**
* This function will supply babel config object directly to babel-loader
* for list of options, please refer to https://babeljs.io/docs/en/config-files
* @optional
* @returns Object
*/
getBabelConfig() {
return {...};
}
/**
* This function will supply options directly to babel/parser
* for list of options, please refer to https://babeljs.io/docs/en/babel-parser
* @optional
* @returns Array<String>
*/
getBabelParserOptions() {
return ['classProperties'];
},
/**
* This function will tell the styleguide if the component being included
* is a specification/example component
* @optional
*/
isSpecificationPath(componentMeta, path) {
return path.indexOf(`${componentMeta.fileNameWithoutPrefix}.spec`) !== -1;
},
/**
* This function allows to set up global objects
* in browser environment
* @optional
*/
browserSetup() {
window.parameters = true;
}
/**
* This function returns element, which will be used for wrapping
* of the sandboxes content. This element can be used for introducing
* different extra features: context providers, props, controls
* @optional
* @returns {Component}
*/
getComponentWrapper() {
return require('MyComponent');
},
/**
* This function returns array of all the elements in the styleguide
* @optional
* @returns Array<Object>
*/
getSectionComponents({ path }) {
return [
{
components: [path.resolve('src/components/component/component')],
},
{
components: [path.resolve('src/components/error-boundary/error-boundary')],
},
];
},
/**
* Returns an array of all the sections in the styleguide
* @returns Array<Object>
*/
getSections() {
return [
{
name: 'MyComponentSection',
components: [
require('MyComponent'),
],
},
];
},
// This method tells us the root folder of your component
// hierarchy
getComponentRoots({ path }) {
return [
path.resolve(cwd, 'src')
];
},
// This method provide list of exceptions for loaders
getExceptionForLoaders({ path }) {
return {
jsLoader: path.resolve(cwd, 'src'),
tsLoader: /src/,
};
},
/**
* Returns the webpack loaders list for usage before component props eevaluation
* @param {string} path - The "path" node module to help you resolve any paths
* @returns Array<Object, string>
*/
getLoadersForComponents({ path }) {
return ['babel-loader'];
},
/**
* Returns the webpack configuration for your module setup
* @param {string} path - The "path" node module to help you resolve any paths
* @returns Object
*/
getWebpackConfig({ path }) {
const cwd = path.resolve(__dirname, '.');
// Any custom webpack configuration you need, this will be merged
// using webpack-merge
return {
resolve: {
modules: [
path.resolve(cwd, 'src/'),
path.resolve(cwd, 'node_modules/'),
],
}
};
}
}
The styleguide can be run as a local dev server or be compiled if you want to serve it from another host.
yarn badoo-styleguide --config=PATH_TO_STYLEGUIDE_CONFIG.js
Note: Styleguide benefits from caching results of initial build. It makes all subsequents recompilations much faster.
yarn badoo-styleguide --config=PATH_TO_STYLEGUIDE_CONFIG.js --buildDir=dist/
Or add it to your package.json "scripts" section
{
"scripts": {
"styleguide": "badoo-styleguide --config=PATH_TO_STYLEGUIDE_CONFIG.js",
"styleguide:compile": "badoo-styleguide --config=PATH_TO_STYLEGUIDE_CONFIG.js --buildDir=dist/"
}
}
The buildDir parameter switches off webpack-server and caching.
Note: The buildDir is resolved relative to where you ran "yarn" from
For easier work with different devices / media-queries we introduced several components:
StyleguidePlaceholder
returns mockup of component with provided parametersStyleguideStatic
returns image src from placehold.it with provided parametersStyleguideCell
returns component and its legend
StyleguideDeviceFrame
returns one of predefined frames, based on mobile device aspect-ratioStyleguideDeviceGroup
returns set of predefined frames, based on mobile device aspect-ratio
import { getImageUrl } from 'badoo-styleguide';
Pass --debug flag to the command line to get additional debug information.
yarn badoo-styleguide --config=PATH_TO_STYLEGUIDE_CONFIG.js --debug
v0.0.50
HOC
components (classes, React.components, React.pureComponents)FAQs
Badoo styleguide is sandbox environment to develop & document React UI components
The npm package badoo-styleguide receives a total of 59 weekly downloads. As such, badoo-styleguide popularity was classified as not popular.
We found that badoo-styleguide demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 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.