Skip to content

Latest commit

 

History

History
251 lines (154 loc) · 9.52 KB

README.md

File metadata and controls

251 lines (154 loc) · 9.52 KB

@grams-dev/ui

npm version npm downloads License GitHub commit activity (branch)

The @grams-dev/ui package is a collection of UI components designed for use with the Grams ecosystem. It provides developers with a set of reusable and customizable UI elements to create user-friendly decentralized applications (dApps).

Features

  • UI Components: A library of pre-built UI components tailored for Grams dApps.
  • Theme Customization: Easily customize the appearance and styling of components to match your dApp's design.
  • Responsive Design: Components are optimized for various screen sizes and devices, ensuring a seamless user experience.
  • Accessibility: Prioritizes accessibility standards to ensure that all users can interact with your dApp.
  • Easy Integration: Simple integration with existing Grams projects or new dApps being built from scratch.

Installation

You can install the @grams-dev/ui package via your preferred package manager.

npm

npm install --save @grams-dev/ui

Yarn

yarn add @grams-dev/ui

Usage

Import the i18n Object

In your index.(js|ts), import the i18n object from @grams-dev/i18n to access the translation strings

import '@grams-dev/i18n';

Stylesheet

Then, you'll need to import the grams.css CSS file distributed by the package. This should be done at the root of your project (in index.js or App.tsx of your React app) and will look like:

import '@grams-dev/ui/dist/grams.css';

...

Components

Once installed, you can import and use the UI components in your Grams dApp. Here's an example of how to use a Button component:

import React from 'react';
import { Unlock } from '@grams-dev/ui';

const MyComponent = () => {
  return (
    <Unlock onUnlock={() => console.log('User unlocked!')} />
  );
};

You can customize the appearance and behavior of the UI components using the provided props and CSS styles.

For more detailed information and examples, refer to the Storybook.

Using Component Library CSS Variables

Above we imported grams.css into the root of our project. grams.css contains a number of CSS variables that can be used across the project that consumes our component library.

In your CSS, you can use the variables defined in variables.css like:

.example-container {
    color: var(--grams-color-primary);
    background: var(--grams-background);
}

See: https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties for more information about CSS Variables.

Documentation

Comprehensive documentation for @grams-dev/ui is available at https://storybook.grams.dev. It includes detailed usage instructions, component reference, and examples to help you get started with the package.

Contributing

Contributions to @grams-dev/ui are welcome! If you encounter any issues or have suggestions for improvements, please feel free to open an issue or submit a pull request on the GitHub repository.

gcx (Recommended)

gcx setup -r ui

License

The @grams-dev/ui package is open source and distributed under the Apache License 2.0. Your contributions to the project are appreciated and will be licensed accordingly.

Development

Testing

npm run test

Building

npm run build

Storybook

To run a live-reload Storybook server on your local machine:

npm run storybook

To export your Storybook as static files:

npm run build:storybook

This will also copy the CNAME from the root directory to the static files. You can change it to any CNAME you want.

Scripts

Grams UI provides several convenient scripts to help with development and maintenance of the library.

/create-component

The /create-component script is used to generate a new UI component in the Grams UI library. It automates the process of setting up the component's file structure, boilerplate code, and test files. To use this script, run the following command:

npm run create:component <ComponentName>

Replace <ComponentName> with the desired name of your component, using PascalCase. This script will create a new folder in the src/components directory with the specified component name, along with the necessary files and directory structure.

/create-page

The /create-page script is used to generate a new page component in the Grams UI library. Similar to the /create-component script, it sets up the file structure and boilerplate code for a new page component. To use this script, run the following command:

npm run create:page <PageName>

Replace <PageName> with the desired name of your page component, using PascalCase. This script will create a new folder in the src/pages directory with the specified page name, along with the necessary files and directory structure.

/release

The /release script automates the process of releasing a new version of the Grams UI library. It performs various tasks such as version bumping, creating release notes, generating changelogs, and publishing the package to the package registry. To use this script, run the following command:

npm run release

This script will guide you through the release process, prompting for version updates and generating necessary release files. It ensures that the release process is streamlined and follows best practices.

Make sure to review and update the relevant configuration files (such as package.json and CHANGELOG.md) before running the release script to ensure accurate versioning and documentation.

These scripts provide a convenient way to perform common tasks when developing and maintaining the Grams UI library. Feel free to explore and utilize them as needed for your development workflow.

Publishing

Hosting via NPM

First, make sure you have an NPM account and are logged into NPM using the npm login command.

Then update the name field in package.json to reflect your NPM package name in your private or public NPM registry. Then run:

npm publish

The "prepublishOnly": "npm run build" script in package.json will execute before publish occurs, ensuring the build/ directory and the compiled component library exist.

Hosting via GitHub

I recommend you host the component library using NPM. However, if you don't want to use NPM, you can use GitHub to host it instead.

You'll need to remove build/ from .gitignore, build the component library (npm run build), add, commit and push the contents of build. See this branch for an example.

You can then install your library into other projects by running:

npm i --save git+https://github.com/grams-dev/ui.git#branch-name

OR

npm i --save github:grams-dev/ui#branch-name

Additional Help

Dark Mode

The example component TestComponent respects the user's dark mode operating system preferences and renders the component in the appropriate theme.

This is achieved by using the media query: @media (prefers-color-scheme: dark) in combination with CSS variables. The colours that change depending on dark mode preference can be found in src/index.css. Example usage of these variables can be found within src/TestComponent/TestComponent.css.

Read https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-color-scheme for more details.

Using CSS Preprocessors

The Rollup plugin rollup-plugin-postcss supports Sass, Less and Stylus:

  • For Sass, install less: yarn add node-sass --dev
  • For Stylus, install stylus: yarn add stylus --dev
  • For Less, install less: yarn add less --dev

CSS Modules

If you want to use CSS Modules, update postcss in rollup-config.js to:

postcss({
  modules: true
})

Component Code Splitting

Code splitting of your components is not supported by default.

Read this section of my blog post to find out how and why you would enable code splitting of your components. In summary, code splitting enables users to import components in isolation like:

import TestComponent from '@grams-dev/ui/dist/TestComponent';

This can reduce the bundle size for projects using older (CJS) module formats.

You can check out this branch or this commit to see what changes are neccesary to implement it.

Please note, there's an issue with code splitting and using rollup-plugin-postcss. I recommend using rollup-plugin-sass instead alongside code splitting.

Checkout the official Rollup plugin list for additional helpful plugins.