Gathering detailed insights and metrics for @spectrum-css/treeview
Gathering detailed insights and metrics for @spectrum-css/treeview
Gathering detailed insights and metrics for @spectrum-css/treeview
Gathering detailed insights and metrics for @spectrum-css/treeview
npm install @spectrum-css/treeview
76.9
Supply Chain
70.7
Quality
95.9
Maintenance
100
Vulnerability
100
License
@spectrum-css/combobox@3.3.0
Published on 19 Nov 2024
@spectrum-css/radio@9.4.1
Published on 13 Nov 2024
@spectrum-css/fieldgroup@5.3.0
Published on 12 Nov 2024
@spectrum-css/checkbox@9.2.1
Published on 12 Nov 2024
@spectrum-css/search@7.4.0
Published on 11 Nov 2024
@spectrum-css/well@5.3.0
Published on 05 Nov 2024
Module System
Min. Node Version
Typescript Support
Node Version
NPM Version
1,207 Stars
4,186 Commits
196 Forks
43 Watching
164 Branches
311 Contributors
Updated on 25 Nov 2024
CSS (51.32%)
JavaScript (43.88%)
MDX (3.14%)
Nunjucks (0.78%)
Handlebars (0.35%)
Shell (0.31%)
HTML (0.22%)
Cumulative downloads
Total Downloads
Last day
-39.2%
169
Compared to previous day
Last week
-20.1%
944
Compared to previous week
Last month
18.7%
3,936
Compared to previous month
Last year
-66%
37,941
Compared to previous year
3
3
The preferred method of using Spectrum CSS relies on custom properties to swap out variables for different themes and contexts. This results in the lowest bundle sizes and is one of the simpler approaches.
Want to get a component up and running as soon as possible? Check out the quick start guide.
Spectrum CSS is CSS-only, implementing only the interactivity that can be done with pure CSS. We do include some lightweight JS-based interaction for demonstration purposes only in our Storybook. Spectrum CSS should only be used by implementations of Spectrum, or very simple applications that only need things like typography, checkboxes, text fields, etc.
Adobe maintains separate libraries written with web components and React that work in partnership with Spectrum CSS to create fully interactive Spectrum components.
The Spectrum Web Components library directly imports Spectrum CSS and optimizes it for use with web components.
Each component is released on npm as a separate, individually versioned package inside of the @spectrum-css org.
To incorporate Spectrum CSS into your project, you install the components you need along with any peer dependencies you need for your implementation. Most peer dependencies are optional and can bring additional features when installed along with a component. For example a button can be rendered with or without an icon; so if your use-case leverages an icon with your button, you'll want to install icon as a peer dependency.
1yarn add -DW @spectrum-css/tokens @spectrum-css/typography @spectrum-css/page @spectrum-css/icon @spectrum-css/button
Installed components will be available in the node_modules/@spectrum-css/
folder of your project.
All components in this library have a peer dependency on @spectrum-css/tokens
, which is a local package that serves up the Spectrum design tokens as CSS custom properties (via Style dictionary). These custom properties are leveraged in all components to create a cohesive visual language and to allow for easy theming. If you choose not to use the provided @spectrum-css/tokens
package, you must define your own custom properties or your components will render with a significant number of missing styles. When overriding certain styles is necessary, modifying styles is supported through the use of component-specific --mod
prefixed properties. More on this below.
Spectrum CSS components have build output that is designed to be used in a variety of ways:
index.css
- Preferred and most commonly used to incorporate Spectrum CSS into a project. This file includes the component's styles and variable definitions. In this version, token-driven CSS properties1 are mapped to empty --mod
prefixed variables (for customization) with a fallback to variables prefixed with --spectrum
(sourced from the design tokens).
.spectrum
and .spectrum--express
contexts which are used to toggle components between two different visual styles. The .spectrum
context is the default.index-vars.css
- Deprecated. This file is identical to index.css
. It is provided as a fallback for older implementations that may have been using it and will be removed. It is recommended to use index.css
instead.
index-base.css
: This file mimics the index.css
output, but does not include the .spectrum
or .spectrum--express
contexts.
.spectrum
context, you can use index-base.css
plus themes/spectrum.css
from the themes
directory to render the default Spectrum visual language.
.spectrum--express
context, on the other hand, is dependent on/expands on the default .spectrum
context. This means if you only want to use the Express context, you still need to include themes/spectrum.css
. In this case, we recommend using index.css
instead since it includes both contexts by default.themes/*.css
assets.index-theme.css
: This file provides only the visual language for a component. It is used in conjunction with index-base.css
and when loaded together, provides the same result as using index.css
by itself.
1: Token-driven CSS properties are properties whose values are mapped to a value in the @spectrum-css/tokens
package. These values represent design-language and are meant to be used across platforms. In contrast, properties specific to web-based implementations will not have a token value assigned, so not all CSS properties will use custom properties.
Start by including the base set of variables:
1/* Include tokens */ 2@import "node_modules/@spectrum-css/tokens/dist/index.css"; 3 4/* 5 For components with no other contexts available, load the 6 index.css file from the component's package. These are components 7 that do not have a spectrum or express context available. 8*/ 9@import "node_modules/@spectrum-css/page/dist/index.css"; 10@import "node_modules/@spectrum-css/typography/dist/index.css"; 11@import "node_modules/@spectrum-css/icon/dist/index.css"; 12 13/* 14 Recommended: For components with multiple contexts available, if you 15 want access to all contexts, load the index.css file, which includes 16 all contexts and component variables. 17*/ 18@import "node_modules/@spectrum-css/button/dist/index.css"; 19 20/* 21 If you only need the spectrum visual context: For components with 22 multiple contexts available, load only the spectrum context by sourcing 23 index-base.css and the spectrum theme from the themes directory. 24*/ 25@import "node_modules/@spectrum-css/button/dist/index-base.css"; 26@import "node_modules/@spectrum-css/button/dist/themes/spectrum.css";
Tokens values are mapped to context-specific classes which can be applied to the <html>
element or any place in your DOM where you wish to encapsulate or alter the visual language of your Spectrum components.
All contexts you want to use must be defined in order to load all the appropriate custom properties for the components you are using.
.spectrum
- The default visual language for Spectrum CSS.spectrum--express
- A variant of the standard visual language. This visual language will be deprecated in Spectrum 2.Scales represent the browsing context of the user. They are used to adjust the size of components to improve readability and usability on different devices.
.spectrum--medium
- The default scale for Spectrum CSS, used for desktop and tablet devices.spectrum--large
- A larger scale for Spectrum CSS, used for mobile devices and other small screens to create a more touch-friendly experienceThemes represent the color scheme of the user's browsing context. They are used to adjust the color of components to improve readability and usability in different environments.
.spectrum--light
- The default theme for Spectrum CSS, used for light mode.spectrum--dark
- A darker theme for Spectrum CSS, used for dark modeOther themes are available but are in the process of being deprecated and should not be used in new projects.
Put together, we would define the context for our application in the following way:
1<html class="spectrum spectrum--medium spectrum--light"></html>
To switch to Express, add the .spectrum--express
class to the <html>
element:
1<html 2 class="spectrum spectrum--medium spectrum--light spectrum--express" 3></html>
Note the spectrum--express
class is added to the existing classes; spectrum
should always be present to ensure the correct visual language is loaded.
Because CSS custom properties honor the cascading nature of CSS, you can infinitely nest different contexts. For example, you could have a .spectrum--dark
context inside of a .spectrum--light
context, and components will honor the innermost context.
You can override variables and modify Spectrum CSS' look and feel by re-defining the custom properties in context. Look for the Custom Property API section in each component to determine which custom properties you can override. See Action Button for a complete example.
Some components require certain "UI icons" to render. These icons are released within the @spectrum-css/ui-icons
package and are used by components like @spectrum-css/icon
and @spectrum-css/actionbutton
.
Based on which scales you'll be using, you can choose to load different files:
spectrum-css-icons.svg
- Both medium and large icons for responsive UIs that support both .spectrum--medium
and .spectrum--large
spectrum-css-icons-medium.svg
- Medium icons only, supports .spectrum--medium
only
spectrum-css-icons-large.svg
- Large icons only, supports .spectrum--large
only
Note: If you're using spectrum-css-icons.svg
, be sure to add .spectrum--medium
or .spectrum--large
to the <html>
element, or you'll see both medium and large icons at once.
If your app has any level of complexity, you'll need "workflow" icons to indicate actions. These icons are not required to render the base components, and instead are used within buttons or menu items for actions like share, play, justify, save, etc.
These icons are released within the @adobe/spectrum-css-workflow-icons
package. Visit the Spectrum workflow icon list and click on any icon to get the SVG markup.
To take advantage of locale specific changes such as placeholders not italicizing Japanese, your application should specify a Content-Language
response header or set the lang
attribute.
In addition, you should set the dir
attribute for components to render correctly.
For English, a left-to-right language:
1<html lang="en" dir="ltr"></html>
For Arabic, a right-to-left language:
1<html lang="ar" dir="rtl"></html>
We maintain a modern codebase that supports the latest two versions of evergreen web browsers. The current list of browsers officially supported by Spectrum CSS can be found in the browserslist section of the project's package.json file. This setting is used by the build tools when the source files are built. If you require additional browser support for your project, the CSS can be processed further with your chosen tools.
Spectrum CSS is designed to be as modern and flexible as possible, and as such, leaves room for consumers to optimize in their own way. There are many tools and techniques you can use to optimize CSS for your project such as tree shaking, purging, and minification. If you are loading the entire set of @spectrum-css/tokens
for example, you can safely tree shake the tokens to only include the variables you are using, often leading to a significant reduction in file size.
A very special thank you to all of our contributors without whom this project would not be possible.
Want to join the team? Check out the contributing guidelines to get started.
The following tasks are available:
Command | Description | Examples |
---|---|---|
clean | Cleans all output files for the project and all components | yarn clean |
build | Performs a build of all components | yarn build |
start | Performs a local development build of Storybook | yarn start |
compare | This compares the current version of components with the previous versions published to NPM and output a list of all the changes that have been made. This is useful for reviewing changes before a release. The information is provided in the command-line output as well as in a simple web page that is opened in your default browser upon completion. The web page includes links to the visual diffs for each component when the file sizes have changed.
| yarn compare yarn compare accordion yarn compare accordion actionbutton |
lint | Provides helpful updates and warnings for a component's package.json file. This helps keep all components in alignment. Use format to automatically fix any issues that are found. To run on a single component, use yarn linter accordion (where accordion is the name of the component or components you want to lint). | yarn lint yarn linter accordion yarn linter accordion actionbutton |
format | Provides helpful updates and warnings for a component's package.json file. This helps keep all components in alignment. To run on a single component, use yarn formatter accordion (where accordion is the name of the component or components you want to lint). | yarn format yarn formatter accordion yarn formatter accordion actionbutton |
refresh:env | This copies values for the project's .env file (an asset never committed to the repo as it contains login secrets) by using the .env.example file as a template. This script is useful when you need to update the .env file with new values from the .env.example file or when you checkout or clean the repo and need to restore the .env file. | yarn refresh:env |
As of February of 2024, the Spectrum CSS project has moved to a new tokens system (@spectrum-css/tokens instead of @spectrum-css/vars). If you are using Spectrum CSS and see that your styles are off, or not applying at all, ensure that you are using the correct tokens package for the component.
No vulnerabilities found.
Reason
30 commit(s) and 2 issue activity found in the last 90 days -- score normalized to 10
Reason
license file detected
Details
Reason
no binaries found in the repo
Reason
security policy file detected
Details
Reason
Found 11/12 approved changesets -- score normalized to 9
Reason
dangerous workflow patterns detected
Details
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
detected GitHub workflow tokens with excessive permissions
Details
Reason
dependency not pinned by hash detected -- score normalized to 0
Details
Reason
project is not fuzzed
Details
Reason
SAST tool is not run on all commits -- score normalized to 0
Details
Reason
14 existing vulnerabilities detected
Details
Score
Last Scanned on 2024-11-25
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More