@nasa-jpl/react-stellar
TypeScript icon, indicating that this package has built-in type declarations

1.1.7 • Public • Published

npm version

react-stellar

React implementation of the Stellar design system built on top of the (native CSS Stellar) implementation [https://github.com/nasa-jpl/react-stellar]. The React implementation of the Stellar design system provides a more complete implementation of the Stellar design system whereas the native CSS Stellar only provides styling for native HTML elements as well as CSS variables for color and typography. React Stellar is written in Typescript and bundled with Rollup.

What is Stellar?

Stellar is design system for operations tools that enables developers and designers to make use of battle-tested components and focus their efforts on the unique aspects of their applications. Included in this design system are code components, design files and assets, and guidelines for use.

Component Usage and Demos

Demos and documentation for the components can be found here: https://nasa-jpl.github.io/react-stellar/. Not all Stellar design system components are supported yet as this is an ongoing effort. Many components in this library are build on top of Radix Primitives. Radix Primitives provide unstyled, accessible components meant to be used as building blocks for design systems. React Stellar components that use Radix Primitives will contain links to the Radix documentation for more detailed information regarding component properties and usage.

Library Installation and Usage

Run the following command in the root of your React application repository to install the library. This assumes you already have NodeJS installed on your machine and that you are installing this library into a React project.

npm install --save-dev @nasa-jpl/react-stellar

Importing Stellar Components in React

Include react-stellar and stellar styles using the following import in your app:

import "@nasa-jpl/react-stellar/dist/esm/stellar.css";

You can import a Stellar component using the following syntax:

import { Button } from "@nasa-jpl/react-stellar";

Example usage:

<Button variant="secondary" onClick={() => console.log("Click")}>
  Text
</Button>

Developing Components

Prerequisite Software

Before you can develop components for react-stellar you must install and configure the following products on your development machine:

Code Editor

The recommended editor for developing aerie-ui is VS Code.

Extensions

  1. Prettier - Code formatter
  2. ESLint
  3. Stylelint
  4. EditorConfig for VS Code
  5. Path Intellisense

Getting the Source

Clone the react-stellar repository:

git clone https://github.com/nasa-jpl/react-stellar.git
cd react-stellar

Installing NPM Modules

Install the JavaScript modules needed to build react-stellar:

npm install

Start Development Server

Development of react-stellar components is accomplished with Storybook, a frontend workshop for building UI components and pages in isolation. Run npm run storybook to automatically launch the Storybook for react-stellar in your default browser. The app will automatically reload if you change any of the source files.

Building For Production

Run npm run build-lib to build a production version of the component library. The build artifacts will be stored in the dist/ directory. Note that the build normally occurs in a Github Action but local building will often be performed for troubleshooting purposes.

Updating Stellar Icons

The react-stellar library creates React components for every icon supplied by the base Stellar repository. Run npm run build-icons to build these icons after updating the base Stellar depencency. Icons will automatically be created and exported in src/components/Icons.

Publish Component Library

Publish the library to NPM using the corresponding Github Action.

Storybook Deployment

Storybook is built and deployed to Github Pages using Github Actions.

Theming

Both Stellar and React-Stellar are built to be easily themable using a combination of class and CSS variable overrides. For a complete list of CSS variables that can be overridden please refer to the Stellar variables.scss file as well as the React Stellar [variables.scss] file. For example, to change the background color of a primary button you can override the CSS variable that defines that primary button background color:

:root {
  --st-button-primary-background-color: green;
}

Also note that there is limited support for dark theming but this effort is ongoing.

Readme

Keywords

none

Package Sidebar

Install

npm i @nasa-jpl/react-stellar

Weekly Downloads

113

Version

1.1.7

License

Apache-2.0

Unpacked Size

4.66 MB

Total Files

467

Last publish

Collaborators

  • mattdailis
  • jdylanstewart
  • duranb
  • aplave
  • camargo
  • jaray
  • laespinoza
  • stephiescastle
  • scotchester
  • nasa-jpl.www.developers