Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

carbon-components

Package Overview
Dependencies
Maintainers
6
Versions
1107
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

carbon-components

The Carbon Design System is IBM’s open-source design system for products and experiences.

  • 11.34.1
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
73K
decreased by-12.84%
Maintainers
6
Weekly downloads
 
Created
Source

carbon-components

Styles for the Carbon Design System

Getting started

To install carbon-components in your project, you will need to run the following command using npm:

npm install -S carbon-components

If you prefer Yarn, use the following command instead:

yarn add carbon-components

This package requires Dart Sass in order to compile. It uses Sass modules to organize the codebase and provide exports to use.

If you're new to Sass, or are wondering how to configure Sass for your project, we recommend checking out the following resources and links:

Once you get Sass up and running in your project, make sure to configure Sass to include node_modules in its includePaths option. For more information, checkout the configuration section in our Sass docs.

Usage

You can bring in all the styles for the Carbon Design System by including carbon-components in your Sass files. For example:

@use 'carbon-components';

If you only would like to bring in specific components from Carbon, you can import them in a similar way:

@use 'carbon-components/scss/reset';
@use 'carbon-components/scss/components/accordion';
@use 'carbon-components/scss/components/button';
@use 'carbon-components/scss/components/checkbox';

There are various helpers that you can include from Carbon, as well, such as a CSS reset, grid, breakpoint helpers, and more. You can include these similar to how you bring in components:

// Bring in the CSS Reset
@use 'carbon-components/scss/reset';

// Bring in the CSS Grid
@use 'carbon-components/scss/grid';

To learn more about the various helpers that carbon-components provides, checkout the overview of the files available to use in our Sass docs.

Theming

You can change the default theme of Carbon by doing the following:

@use 'carbon-components/scss/themes';
@use 'carbon-components/scss/theme' with (
  $theme: themes.$g100
);

This example uses a built-in theme from Carbon provided by the scss/themes entrypoint. You can also use a custom theme, or add your own custom tokens to extend the theme.

// Configure with a custom theme
@use 'carbon-components/scss/theme' with (
  $theme: (
    background: #e2e2e2,
    text-primary: #ffffff,
  )
);
// Extend the g100 theme with your own tokens
@use 'carbon-components/scss/themes';
@use 'carbon-components/scss/theme' with (
  $fallback: themes.$g100,
  $theme: (
    custom-token-01: #000000,
  )
);

Design tokens

You can access the design tokens defined by the Carbon Design System through the carbon-components/scss/theme entrypoint. This file will allow you to refer to tokens using Sass Variables as well as get the current value for any token in the current theme. For example:

@use 'carbon-components/scss/theme';

body {
  background: theme.$background;
}

For a full list of tokens available for you to use, check out our theming documentation.

📖 API Documentation

If you're looking for carbon-components API documentation, check out:

🙌 Contributing

We're always looking for contributors to help us fix bugs, build new features, or help us improve the project documentation. If you're interested, definitely check out our Contributing Guide! 👀

📝 License

Licensed under the Apache 2.0 License.

Keywords

FAQs

Package last updated on 27 Jul 2023

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc