Core-UI is a component library containing all components, layouts, icons and themes used for all Scality UI projects.
- Add
@scality/core-ui
in thepackage.json
's dependencies of your project.
"@scality/core-ui": "0.115.0",
@scality/core-ui
requires the peerDependencies below. Make sure that you have them in thepackage.json
's dependencies.
"@fortawesome/fontawesome-free": "^5.10.2",
"@fortawesome/fontawesome-svg-core": "^1.2.35",
"@fortawesome/free-regular-svg-icons": "^5.15.3",
"@fortawesome/free-solid-svg-icons": "^5.15.3",
"@fortawesome/react-fontawesome": "^0.1.14",
"@js-temporal/polyfill": "^0.4.4",
"polished": "3.4.1",
"pretty-bytes": "^5.6.0",
"react": "^17.0.2",
"react-debounce-input": "3.2.2",
"react-dom": "^17.0.2",
"react-dropzone": "^14.2.3",
"react-query": "^3.34.0",
"react-router": "^5.2.0",
"react-router-dom": "^5.2.0",
"react-select": "4.3.1",
"react-table": "^7.7.0",
"react-virtualized": "9.22.3",
"react-virtualized-auto-sizer": "^1.0.5",
"react-window": "^1.8.6",
"styled-components": "^4.1.2",
"styled-system": "^5.1.5",
"vega": "^5.17.3",
"vega-embed": "^6.0.0",
"vega-lite": "^5.0.0",
"vega-tooltip": "^0.27.0"
- Install the dependencies :
npm install
-
Import a component from
@scality/core-ui/dist/next'
or@scality/core-ui
-
Use props to change its appearance and behaviour
import { Button } from '@scality/core-ui/dist/next';
import { Icon } from '@scality/core-ui';
<Button variant="primary" onClick={handleClick} label="Save" icon={<Icon name="Save" />} />
To learn more about the available components, you can read the documentation
Components are themable by using the styled-components theming concept.
Wrap your app in a ThemeProvider
and provide it a theme :
import { ThemeProvider } from 'styled-components';
import { Layout } from '@scality/core-ui';
import { coreUIAvailableThemes as themes } from '@scality/core-ui/dist/style/theme';
<ThemeProvider theme={themes.darkRebrand}>
<Layout sidebar={sidebar} navbar={navbar}>
...
</Layout>
</ThemeProvider>
There is 2 default theme available in Core-UI : you can find them here
You can also modify or create a new theme. In this case make sure to respect this type :
export type CoreUITheme = {
statusHealthy: string;
statusHealthyRGB: string;
statusWarning: string;
statusWarningRGB: string;
statusCritical: string;
statusCriticalRGB: string;
selectedActive: string;
highlight: string;
border: string;
buttonPrimary: string;
buttonSecondary: string;
buttonDelete: string;
infoPrimary: string;
infoSecondary: string;
backgroundLevel1: string;
backgroundLevel2: string;
backgroundLevel3: string;
backgroundLevel4: string;
textPrimary: string;
textSecondary: string;
textTertiary: string;
textReverse: string;
textLink: string;
};
This project is built with React and TypeScript, and styled with styled-components.
To start contributing to core-ui, clone the repository :
git clone [email protected]:scality/core-ui.git
then install the dependancies :
npm install
Give your branch an explicit name with the reference to the Jira ticket or issue if it exists, and prefix it with :
- feature/ for new component or major component update :
feature/TICKET-123-some-feature
- improvement/ for code improvement, component update :
improvement/TICKET-456-some-improvement
- bugfix/ for bug related issue :
bugfix/TICKET-789-some-bug
Use :
git checkout -b <branch-name>
Create a new folder in src/lib/components
for the component file and test file.
Depending on your component, it can be useful to create more files for the style, hooks, or utility functions that are necessary for your component. It will make the code more readable and easier to maintain.
Create a new folder in stories
for the documentation files.
You should end with something like below :
- src/
- lib/
- components/
- example/
- Example.component.tsx
- Example.test.tsx
- stories/
- example/
- example.stories.tsx
- example.guideline.mdx
Expose your component in src/lib/index.ts
.
When creating a new version of an existing component, expose it in src/lib/next.ts
instead to avoid conflict.
You can use storybook to help with the development. Storybook helps to test and vizualize component in isolation. If it doesn't exist, write a story for the component :
// in stories/example/example.stories.tsx
import type { Meta, StoryObj } from '@storybook/react';
import { Example } from '../src/lib/components/example/Example.component.tsx';
const meta: Meta<typeof Example> = {
component: Example,
};
export default meta;
type Story = StoryObj<typeof Example>;
export const Default: Story = {
render: () => <Example />,
};
then launch storybook :
npm run storybook
Storybook will be launched on http://localhost:3000
.
To make sure your code is correctly lint, run :
npm run lint
It will run ESLint by using eslint-config-react-app
which is a shareable ESLint configuration used by Create React App.
Build tests with jest
Make sure to write tests that cover all cases, then you can run all tests with :
npm run test
or run a specific test with :
npm run test Example.test.tsx
Core-UI uses storybook for its documentation.
Illustrate use cases and state variations with stories.
All stories should be type.
If possible create or update the component guideline. This guideline is an MDX file containing details about the component usage and is illustrated with the stories write in stories.tsx file.
// in example.guideline.mdx
import { Canvas, Meta } from '@storybook/blocks';
import * as ExampleStories from './Example.stories';
<Meta of={ExampleStories} />
# Example Component
An Example component is used for example.
<Canvas of={ExampleStories.Default} />
Push your code on the repository
git push origin <branch-name>
then create a Pull Request
.
Pull request needs to be approved by at least one reviewer.
After your PR is approved you can comment /approve
After merging one or more PR in Core-UI, it is possible to plublish a new release. In the Core-UI repo, follow these steps :
- Go on
Releases
thenDraft a new release
- In the select menu
Choose a tag
: Create a new tag (the current tag increment by 1). - You can now
Generate release notes
: it will add all the PR infos since the last release.
You can add details if necessary. Publish release
- It will create a PR that need to be approved.
npm run build
Build the app for production to the dist
folder.
In this folder, you will find all components, icons and themes.