Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/digibib/deichman-ui
Style-guide and component library
https://github.com/digibib/deichman-ui
postcss react storybook
Last synced: 3 months ago
JSON representation
Style-guide and component library
- Host: GitHub
- URL: https://github.com/digibib/deichman-ui
- Owner: digibib
- Created: 2019-01-15T09:28:03.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-03-03T13:31:37.000Z (almost 2 years ago)
- Last Synced: 2024-04-14T18:14:04.702Z (9 months ago)
- Topics: postcss, react, storybook
- Language: JavaScript
- Homepage: https://digibib.github.io/deichman-ui
- Size: 5.15 MB
- Stars: 5
- Watchers: 8
- Forks: 1
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
## Deichman-ui
![NPM version](https://img.shields.io/npm/v/@digibib/deichman-ui.svg)
![Bundle size](https://badgen.net/bundlephobia/minzip/@digibib/deichman-ui)Style-guide and component library for the Oslo public libraries
- [Documentation](https://digibib.github.io/deichman-ui)
- [Changelog](CHANGELOG.md)### Built with
- [React](https://reactjs.org/)
- [PostCSS](https://preset-env.cssdb.org/) CSS processing
- [Backpack.css](https://github.com/chris-pearce/backpack.css) CSS foundation for applications
- [Rollup](https://rollupjs.org/guide/en) JavaScript module bundler
- [Storybook](https://storybook.js.org/) UI Development Environment### Developing
Local development is done via React-storybook. Clone the repo and run:
```
npm i
npm start
```### New components
Before adding a new Component, make sure this is a generic utility-component. If it's not, add it to the project where it will be used. I.E, an "Accordion" is generic, a "LibraryDetailsCard" is probably not.
##### New component checklist:
| | Requirement | Description |
| --- | --------------------------- | --------------------------------------------------------------------------------- |
| ✅ | The component is semantic | Use HTML5 markup, the correct font hierarchy etc. |
| ✅ | The component is documented | Ensure the component has a `Component.md` file, a story and proptype definitions. |
| ✅ | The component is accessible | Usable with a keyboard, correct `:focus`-styles, correct `aria-roles`. |
| ✅ | The component is tested | Cross-browser testing. |### Icons
All icons are stored in the `/src/assets/icons` folder.
##### Adding a new icon:
- Export the icons for web!
- It's important that they're as lean as possible since they'll be downloaded by all visitors. [Use this Optimizer if possible](https://petercollingridge.appspot.com/svg-optimiser).
- Make sure the new icon has the same size/style/line width as the old files.
- Add the icon to the folder and run `npm run icons`.
- After the output file has been created (`public/icons.svg`), You need to manually replace any hex color values (taken from the source files) with `currentColor`. This will allow the icons to easily be colored when used. NB: Check the commit well to ensure you didn't edit any old icons/colors).
- Add the new icon to the `stories/1-Base/3-icons.stories.js` file.
- Publish new version of Deichman-UI.### Publishing
Make sure to update the [changelog](CHANGELOG.md) if there's any breaking changes.
To publish a new version of the library to npm:
```
npm version {major/minor/patch}
git push --tags
git push origin master
npm publish
```To publish/update the docs:
```
npm run deploy-storybook
```### CDN Cache
jsDelivr will cache the `@latest` tag for 24 hours, if you're using the latest version and wish to purge the cache, visit https://purge.jsdelivr.net/npm/@digibib/deichman-ui@latest/dist/index.css