Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/JoshK2/react-spinners-css

Amazing collection of React spinners components with pure css
https://github.com/JoshK2/react-spinners-css

animation animations css css-spinners loaders progress react react-spinners spinners

Last synced: 3 months ago
JSON representation

Amazing collection of React spinners components with pure css

Awesome Lists containing this project

README

        

# React Spinners CSS Loaders ([Vue](https://github.com/JoshK2/vue-spinners-css), [Angular](https://github.com/JoshK2/ng-spinners))

[![CircleCI](https://circleci.com/gh/JoshK2/react-spinners-css.svg?style=svg)](https://circleci.com/gh/JoshK2/react-spinners-css)
[![bit components](https://img.shields.io/badge/dynamic/json.svg?color=6e3991&label=bit%20components&query=payload.totalComponents&url=https%3A%2F%2Fapi.bit.dev%2Fscope%2Fjoshk%2Freact-spinners-css)](https://bit.dev/joshk/react-spinners-css)
[![npm version](https://badge.fury.io/js/react-spinners-css.svg)](https://www.npmjs.com/package/react-spinners-css)
[![GitHub stars](https://img.shields.io/github/stars/joshk2/react-spinners-css)](https://github.com/JoshK2/react-spinners-css/stargazers)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg)](https://github.com/prettier/prettier)
[![GitHub license](https://img.shields.io/badge/license-MIT-blue.svg)](https://raw.githubusercontent.com/JoshK2/react-spinners-css/master/LICENSE)
[![Twitter Follow](https://img.shields.io/twitter/follow/joshkuttler)](https://twitter.com/JoshKuttler)



Amazing collection of React spinners components with pure css.
The React spinners are based on loading.io and from all over the web.
If you want to add your own spinner, please follow the [contributing guidelines](CONTRIBUTING.md).

- πŸ’…No extra CSS imports
- βœ‚οΈZero dependencies
- πŸ“¦Spinners can be installing separately

## [Live Demo](https://bit.dev/joshk/react-spinners-css)

Browse components and explore their props with [Bit](https://bit.dev/joshk/react-spinners-css).
Install specific react spinner component with npm, yarn or bit without having to install the whole project.
[Install components and live demo](https://bit.dev/joshk/react-spinners-css)

## πŸš€ List of Spinners - PropTypes and Default Props

Each component accepts a `color` prop, and few accepts also `size` prop.
The default `color` prop is `#7f58af`.
Component that accepts `size` prop have a default size in pixel.

| Spinner | color: string | size: number | className: string | style: object |
| -------------- | ------------- | ------------ | ----------------- | ------------- |
| `` | `#7f58af` | `64` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | `32` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | `80` | `""` | `{}` |
| `` | `#7f58af` | - | `""` | `{}` |
| `` | `#7f58af` | - | `""` | `{}` |
| `` | `#7f58af` | - | `""` | `{}` |
| `` | `#7f58af` | - | `""` | `{}` |

## πŸ“¦ Installation

### Using [npm](https://www.npmjs.com/package/react-spinners-css) to install react-spinners-css:

```bash
$ npm i --save react-spinners-css
```

### Play and install react spinners with Bit

Install specific react spinner component with bit, npm or yarn without having to install the whole project.
Using [bit](https://bit.dev/joshk/react-spinners-css) to play with live demo, and try the spinners before install.

set npm regisetry config(one time action):

```bash
npm config set '@bit:registry' https://node.bit.dev
```

and use your favorite package manager:

```bash
npm i @bit/joshk.react-spinners-css.facebook
yarn add @bit/joshk.react-spinners-css.facebook
bit import joshk.react-spinners-css/facebook
```

## πŸ’» Usage Examples

you can use a random color from [jotils](https://bit.dev/joshk/jotils/get-random-color)

```javascript
//using npm or yarn
import { Circle, Heart } from 'react-spinners-css';
//using bit
import Facebook from '@bit/joshk.react-spinners-css.facebook';
import { getRandomColor } from '@bit/joshk.jotils.get-random-color'
...
render() {
return(


//default color is #7f58af

//size prop is number in pixel

//default color is #7f58af


)
}
```

## πŸ‘Ύ Development

You can see the components locally by cloning this repo and doing the following steps:

- Install dependencies from `package.json`, run: `npm install`.
- Run the app in the development mode, run: `npm run start`.

## πŸ™Œ Contributing

- Pull requests and ⭐ stars are always welcome.
- For bugs and feature requests, please create an issue.
- If you want to add your own spinner, please follow the [contributing guidelines](CONTRIBUTING.md).
- If you want to update or add features to some spinner, please follow the [contributing guidelines](CONTRIBUTING.md).

## πŸ‘πŸ» Support my open-source

If you like to support my open-source contributions please star and share this project. πŸ’«

## ❔How to use with SSR?

- How to use with Next.js?
Install [next-transpile-modules](https://www.npmjs.com/package/next-transpile-modules) and set library CSS to be transpiled.
Example configuration with the library package or with a Bit component:

```
// next.config.js
const withTM = require('next-transpile-modules')([
'react-spinners-css',
'@bit/*',
]) // pass the modules you would like to see transpiled

module.exports = withTM()
```

- How to use with Razzle?
Create `razzle.config.js` file and add the following:

```
const nodeExternals = require('webpack-node-externals')

module.exports = {
modify: (config, { target, dev }) => {
config.externals =
target === 'node'
? [
nodeExternals({
whitelist: [
dev ? 'webpack/hot/poll?300' : null,
/\.(eot|woff|woff2|ttf|otf)$/,
/\.(svg|png|jpg|jpeg|gif|ico)$/,
/\.(mp4|mp3|ogg|swf|webp)$/,
/\.(css|scss|sass|sss|less)$/,
/^react-spinners-css/,
/^@bit\/(.*)/,
].filter(Boolean),
}),
]
: []
return config
},
}

```

This is a simple example [based on the Razzle repo](https://github.com/jaredpalmer/razzle/issues/689).

## πŸ“„ License

[MIT](https://github.com/JoshK2/react-spinners-css/blob/master/LICENSE)