Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pimp-my-book/umqombothi-component-library
PMB Plus - React Component Library ๐ถ
https://github.com/pimp-my-book/umqombothi-component-library
design-systems javascript react tailwindcss yarn
Last synced: 30 days ago
JSON representation
PMB Plus - React Component Library ๐ถ
- Host: GitHub
- URL: https://github.com/pimp-my-book/umqombothi-component-library
- Owner: pimp-my-book
- Created: 2019-07-15T13:09:39.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-11T03:28:58.000Z (about 2 years ago)
- Last Synced: 2024-11-29T13:11:38.663Z (about 1 month ago)
- Topics: design-systems, javascript, react, tailwindcss, yarn
- Language: CSS
- Homepage: https://umqombothi.netlify.com
- Size: 3.52 MB
- Stars: 2
- Watchers: 3
- Forks: 2
- Open Issues: 26
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Umqombothi ๐ถ[![Build Status](https://travis-ci.org/pimp-my-book/umqombothi-component-library.svg?branch=master)](https://travis-ci.org/pimp-my-book/umqombothi-component-library) ![npm](https://img.shields.io/npm/v/umqombothi-component-library?style=plastic)
This is the React component Library based off the Design System for [PMB Plus](https://dggixahbp77tr.cloudfront.net/).
The design system can be viewed on [Figma](https://www.figma.com/file/MH0ruI8pUrg7s2NXM4jra59W/PMB?node-id=0%3A1)
### ๐ Features
* Range of components from buttons, navs, inputs etc
* Uses TailwindCSS
* [Storybook](https://umqombothi.netlify.com) app to view all components.
* Ability to interact with components on [Bit](https://bit.dev/pimp-my-book/umqombothi).## ๐ฆ Installation
You can easily install the library via NPM or Yarn:
**npm**
```
$ npm install umqombothi-component-library
```**yarn**
```
$ yarn add umqombothi-component-library
```## ๐ช๏ธ Usage
You can import the components like so:
```
import React from 'react'
import {Input} from 'umqombothi-component-library'
import ReactDOM from 'react-dom';function App() {
return (
);
}ReactDOM.render(, document.querySelector('#app'));
```
## ๐ฐ๏ธSSR Usage
To render it with NextJS there are additional steps. Check out this Codesandbox for a working [example](https://codesandbox.io/s/hello-world-xmu4s?fontsize=14&hidenavigation=1&theme=dark).
### Steps to follow once you have your NextJS app setup:
This is just to make sure you have the correct setup in your `next.config.js` and modules installed. ๐
I. Install modules
```
$ yarn add umqombohti-component-library next-transpile-modules @zeit/next-css @svgr/webpack
```II. Get your `next.config.js` setup correctly.
The reason why you installed : `next-transpile-modules & @zeit/next-cs` was to tell Next that you need these files to be transpiled and included with your NextJS bundle for when you deploy your app.
```
//next.config.jsconst withTM = require("next-transpile-modules");
const withCSS = require("@zeit/next-css");module.exports = withCSS(
withTM({
transpileModules: [
"umqombothi-component-library"
],
webpack(config) {
config.module.rules.push({
test: /\.svg$/,
use: ["@svgr/webpack"]
});
return config;
}
})
);```
Because the lib includes svgs in it, we need to a loader so Next can read them. (Wow we do a lot for this Next thingy ๐คจ)
## Styling
So the lib uses TailwindCSS for writting scalable CSS. You can easliy customes colours, spacing etc of components, but what is also great is you can easily use the provided classes to apply custom margin,padding,height, width etc.
For example:
```
<>
>
```Hear we just created a flex column and added about 2.5rem of padding to the column. ๐