Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gravity-ui/uikit
https://github.com/gravity-ui/uikit
Last synced: 1 day ago
JSON representation
- Host: GitHub
- URL: https://github.com/gravity-ui/uikit
- Owner: gravity-ui
- License: mit
- Created: 2021-11-09T13:28:54.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T11:01:31.000Z (4 months ago)
- Last Synced: 2024-10-29T11:48:00.519Z (4 months ago)
- Language: TypeScript
- Homepage: https://gravity-ui.com
- Size: 90.1 MB
- Stars: 601
- Watchers: 13
- Forks: 90
- Open Issues: 187
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
# UIKit · [data:image/s3,"s3://crabby-images/eb99a/eb99af61deb839ce750ebeb67525cafc44f5f798" alt="npm package"](https://www.npmjs.com/package/@gravity-ui/uikit) [data:image/s3,"s3://crabby-images/bf71c/bf71c88a8cca29f3443374809316785c4e8dc801" alt="CI"](https://github.com/gravity-ui/uikit/actions/workflows/ci.yml?query=branch:main) [data:image/s3,"s3://crabby-images/4d01a/4d01abb55e90f24b3549ba9069965e6b214c990e" alt="storybook"](https://preview.gravity-ui.com/uikit/)
A set of flexible, highly practical, and efficient React components for creating rich web applications.
data:image/s3,"s3://crabby-images/8afcf/8afcf2c528e57c02fd0e18d1039b9e9ae9ac36c3" alt="Cover image"
## Resources
### data:image/s3,"s3://crabby-images/2342c/2342c7fa7fdc1768cd21841bb043975b93941d52" alt="Globe Logo Light" data:image/s3,"s3://crabby-images/73dda/73dda25013b47272e0d591c937f8a51ab9f8598c" alt="Globe Logo Dark" [Website](https://gravity-ui.com)
### data:image/s3,"s3://crabby-images/dad8d/dad8dbfca2c3b4acaf9536dd48a6a46a70f42e03" alt="Documentation Logo Light" data:image/s3,"s3://crabby-images/18a32/18a32ae4e90c7fcfad70f9e443b7599f94e85592" alt="Documentation Logo Dark" [Documentation](https://gravity-ui.com/components/uikit/alert)
### data:image/s3,"s3://crabby-images/52256/52256f6e041f265d678c0a38e5777e21ca7e88ca" alt="Figma Logo Light" data:image/s3,"s3://crabby-images/c5663/c56638d95b915657f9f1027671076428f768b6e1" alt="Figma Logo Dark" [Figma]()
### data:image/s3,"s3://crabby-images/c3c34/c3c34eab7dd1818eebecdfabe8e6dd8f3d0de4e1" alt="Themer Logo Light" data:image/s3,"s3://crabby-images/06281/06281583108f5bf0cc6a289ae041275f45825148" alt="Themer Logo Dark" [Themer](https://gravity-ui.com/themer)
### data:image/s3,"s3://crabby-images/55743/55743ccce36d5645fd512534eb9f497f18e95ec2" alt="Storybook Logo Light" data:image/s3,"s3://crabby-images/06a3e/06a3e2a67272dc242cee06a9d72f846aa4f181b2" alt="Storybook Logo Dark" [Storybook](https://preview.gravity-ui.com/uikit/)
### data:image/s3,"s3://crabby-images/41296/412964e2fe4190f0941f812a094018463831db19" alt="Community Logo Light" data:image/s3,"s3://crabby-images/7f166/7f166b18aee625e09a190ef01a19cc31acc812c7" alt="Community Logo Dark" [Community](https://t.me/gravity_ui)
## Install
```shell
npm install --save-dev @gravity-ui/uikit
```## Usage
```jsx
import {Button} from '@gravity-ui/uikit';const SubmitButton = ;
```### Styles
UIKit comes with base styling and theme. In order to everything look nice include this at the top of your entry file:
```js
// index.jsimport '@gravity-ui/uikit/styles/fonts.css';
import '@gravity-ui/uikit/styles/styles.css';// ...
```UIKit supports different themes: light, dark and their contrast variants. Your app must be rendered inside `ThemeProvider`:
```js
import {createRoot} from 'react-dom/client';
import {ThemeProvider} from '@gravity-ui/uikit';const root = createRoot(document.getElementById('root'));
root.render(
,
);
```It is possible to generate initial root CSS-classes during SSR to avoid theme flashing:
```js
import {getRootClassName} from '@gravity-ui/uikit/server';const theme = 'dark';
const rootClassName = getRootClassName({theme});const html = `
`;
```Also, there is a SCSS [mixins](styles/mixins.scss) file with useful helpers to use in your app.
### I18N
Some components contain text tokens (words and phrases). They come in two languages: `en` (default) and `ru`.
To set the language use `configure` function:```js
// index.jsimport {configure} from '@gravity-ui/uikit';
configure({
lang: 'ru',
});
```## Development
To start the development server with storybook run the following:
```shell
npm start
```