0.19.0 • Published 2 days ago

@carbon/feature-flags v0.19.0

Weekly downloads
46
License
Apache-2.0
Repository
github
Last release
2 days ago

@carbon/feature-flags

Build with feature flags in Carbon

Getting started

To install @carbon/feature-flags in your project, you will need to run the following command using npm:

npm install -S @carbon/feature-flags

If you prefer Yarn, use the following command instead:

yarn add @carbon/feature-flags

Usage

The @carbon/feature-flags provides a runtime-based feature flag system that you can use to enable or disable experimental features from Carbon or in your own code.

To check if a feature flag is enabled, you can use the enabled function in JavaScript:

import { enabled } from '@carbon/feature-flags';

enabled('feature-flag-name');

In Sass, you would use the enabled function or mixin:

@use '@carbon/feature-flags';

// Return true if the flag is enabled
@if feature-flags.enabled('feature-flag-name') {
  //
}

@include enabled('feature-flag-name') {
  // only include contents if the flag is enabled
}

Managing feature flags

You can change whether a feature flag is enabled. In JavaScript, you can use the enable, disable, and merge functions to accomplish this.

import { enable, disable, merge } from '@carbon/feature-flags';

// Enable `feature-flag-a`
enable('feature-flag-a');

// Disable `feature-flag-a`
disable('feature-flag-a');

// Set a variety of feature flags to a specific value
merge({
  'feature-flag-a': true,
  'feature-flag-b': false,
  'feature-flag-c': true,
});

In Sass, you can configure whether a feature flag is enabled when you include the module or by using enable, disable, and merge.

@use '@carbon/feature-flags' with (
  $feature-flags: (
    'feature-flag-a': false,
    'feature-flag-b': true,
  ),
);

// Enable `feature-flag-a`
@include feature-flags.enable('feature-flag-a');

// Disable `feature-flag-b`
@include feature-flags.disable('feature-flag-b');

// Set a variety of feature flags to a specific value
@include feature-flags.merge(
  (
    'feature-flag-a': true,
    'feature-flag-b': true,
  )
);

🙌 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.

0.7.2

2 days ago

0.20.0-rc.0

4 days ago

0.19.0

1 month ago

0.19.0-rc.0

2 months ago

0.18.0-rc.0

2 months ago

0.18.0

2 months ago

0.7.1

2 months ago

0.17.0

2 months ago

0.17.0-rc.0

2 months ago

0.16.0-rc.0

9 months ago

0.16.0

9 months ago

0.15.0-rc.0

11 months ago

0.15.0

11 months ago

0.14.0-rc.0

12 months ago

0.14.0

12 months ago

0.13.0

1 year ago

0.13.0-rc.0

1 year ago

0.12.0

1 year ago

0.11.0-rc.0

1 year ago

0.10.0-rc.0

1 year ago

0.10.0

1 year ago

0.11.0

1 year ago

0.9.0-rc.0

2 years ago

0.9.0

2 years ago

0.8.0-rc.0

2 years ago

0.8.0

2 years ago

0.7.0-rc.0

2 years ago

0.7.0

2 years ago

0.6.0

3 years ago

0.6.0-rc.0

3 years ago

0.5.0

3 years ago

0.4.0-rc.0

3 years ago

0.4.0

3 years ago

0.5.0-rc.0

3 years ago

0.3.0

3 years ago

0.3.0-rc.0

3 years ago

0.2.0

3 years ago

0.2.0-rc.0

3 years ago

0.1.0

3 years ago

0.1.0-rc.0

3 years ago