Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jonjaques/react-loaders
Lightweight wrapper around Loaders.css.
https://github.com/jonjaques/react-loaders
Last synced: 2 months ago
JSON representation
Lightweight wrapper around Loaders.css.
- Host: GitHub
- URL: https://github.com/jonjaques/react-loaders
- Owner: jonjaques
- License: mit
- Created: 2015-03-25T09:41:31.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2022-04-01T04:38:28.000Z (almost 3 years ago)
- Last Synced: 2024-04-14T04:00:03.672Z (9 months ago)
- Language: CSS
- Homepage: http://jonjaques.github.com/react-loaders
- Size: 1.03 MB
- Stars: 374
- Watchers: 9
- Forks: 44
- Open Issues: 4
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
- awesome - jonjaques/react-loaders - Lightweight wrapper around Loaders.css. (CSS)
- awesome-list - react-loaders - Lightweight wrapper around Loaders.css. (Demos / Loader)
- awesome-react-components - react-loaders - Lightweight wrapper around Loaders.css. (UI Components / Loader)
- awesome-react-components - react-loaders - Lightweight wrapper around Loaders.css. (UI Components / Loader)
README
# React Loaders
Lightweight wrapper around [Loaders.css](https://github.com/ConnorAtherton/loaders.css).
[Demo](http://jonjaques.github.io/react-loaders)
## Install
```
npm install --save react-loaders loaders.css
```## Usage
Require the component.
```js
var Loader = require('react-loaders').Loader;
// also available as `default`function renderLoader() {
return
}```
### Props
```js
static propTypes = {
type: PropTypes.string,
active: PropTypes.bool,
color: PropTypes.string,
innerClassName: PropTypes.string, // applied to the same div as .loader-inner.${type}
// useful for advanced styling
// className & style are implied
};
```#### Sizing
**Note**: in ~2.x we had a size prop declared, but it never did anything so for 3.0 it has been removed. Why you ask? Well due to the way these are built by loaders.css, they are hardcoded to use specific pixel widths so sizing these natively would require rewriting that whole project.*Pro tip*: you can resize these by simply passing `style={{transform: 'scale(0.5)'}}`.
### CSS
Import any of the animations you want to use.```scss
$primary-color: $my-brand-color;
// How you import this will depend heavily on your build setup
// If using webpack though, `~` refers to node_modules
// @import '~loaders.css/src/animations/line-scale.scss'
@import 'loaders.css/src/animations/line-scale.scss'.loader-hidden {
display: none;
}
.loader-active {
display: block;
}
```**If `@import`ing with Sass, make you use something like [autoprefixer](https://github.com/postcss/autoprefixer) to add backwards compatibility.**