Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/paol-imi/muuri-react
The layout engine for React
https://github.com/paol-imi/muuri-react
bin-packing drag-and-drop filter grid grids layout layout-engine muuri react sorting
Last synced: 4 months ago
JSON representation
The layout engine for React
- Host: GitHub
- URL: https://github.com/paol-imi/muuri-react
- Owner: paol-imi
- License: mit
- Created: 2019-12-30T18:42:22.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-06-22T18:15:21.000Z (over 1 year ago)
- Last Synced: 2024-10-27T22:33:13.922Z (4 months ago)
- Topics: bin-packing, drag-and-drop, filter, grid, grids, layout, layout-engine, muuri, react, sorting
- Language: TypeScript
- Homepage: https://paol-imi.github.io/muuri-react/
- Size: 34 MB
- Stars: 357
- Watchers: 4
- Forks: 52
- Open Issues: 33
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
![]()
![]()
**Responsive**, **sortable**, **filterable** and **draggable** grid layouts with [`React`](https://reactjs.org/)
[data:image/s3,"s3://crabby-images/25be0/25be0ca55993c3f17572d58ee6e92f6dca27a1e2" alt="npm"](http://npm.im/muuri-react)
[data:image/s3,"s3://crabby-images/a993c/a993c2ee5974c8633bcbdadd773bde4ce4f8b1e2" alt="React: Component"](http://npm.im/muuri-react)
[data:image/s3,"s3://crabby-images/9c2bf/9c2bfb4ac71128a88555dd694bf5bcfd6eb8119e" alt="Circle Ci"](https://app.circleci.com/pipelines/github/Paol-imi/muuri-react)
[data:image/s3,"s3://crabby-images/5b4a7/5b4a7595e05beaaba65ef49c159683d125f32bc3" alt="Code style: Prettier"](https://prettier.io/)
[data:image/s3,"s3://crabby-images/fe040/fe0403f559398bb311a592ab9d807d87bce7b1fb" alt="Typescript: Codebase"](https://www.typescriptlang.org/)
## Design Principles π¨π»βπ«
**Muuri-React** is the React implementation of the amazing [**Muuri**](https://github.com/haltu/muuri) layout engine. This library allows you to build all kinds of layouts with [**React**](https://reactjs.org/) and make them responsive, sortable, filterable, draggable and/or animated.
All Muuri features are implemented in a **React-friendly** way, with custom **components** and **hooks**, to guarantee the simplest **developer experience**.## Features π
- Fully customizable layout π
- Drag-and-drop (even between grids) β
- Simple, Powerful, and Intuitive API β‘οΈ
- Extremely performant π
- Custom hooks π
- Nested grids π
- Scrollable grids π±οΈ
- Filtering β
- Sorting π
- Support IE9+ _(with polyfills)_ π
- Touch support π±
- Typescript βοΈ
- Fully open source ββοΈ## Documentation π
You can find the full documentation [**here**](https://paol-imi.github.io/muuri-react).
## Examples π‘
All [**examples**](https://paol-imi.github.io/muuri-react/showcase) have been created to explain one or more **features** of Muuri-react in an **easy** and direct way.
## Motivation π¨π»βπ«
You can build pretty amazing **layouts** without a single line of JavaScript these days. However, sometimes CSS just isn't enough, and that's where Muuri comes along. At it's very core **Muuri** is a layout engine which is limited only by your **imagination**π. You can build any kind of layout, asynchronously in web workers if you wish.
Layouts aside, you might need to sprinkle some flare (**animations**β‘) and interactivity (**filtering**, **sorting**, **dragΒ andΒ drop**β) on your layout. Stuff gets complex pretty fast and most of us probably reach for existing libraries to handle the complexity at that point. This is why most of these extra **features** are built into Muuri's **core**, so you don't have to go hunting for additional libraries or re-inventing the wheel for the nth time.
The long-term goal of Muuri is to provide a simple (and as low-level as possible) API for building amazing layouts with unmatched **performance**π and most of the **complexity**π¦ abstracted away.
## Help us grow β€οΈ
**Muuri-react** was born recently but is already very stable and full of features as it is based on the amazing **Muuri** layout engine. If you **like** π this project you can help us grow by **starring** β the repository.
## Contributing ποΈ
Contributions are always welcome. Before contributing, please read our [**Guidlines**](https://raw.githubusercontent.com/Paol-imi/muuri-react/master/CONTRIBUTING.md).
## Credits π€
Thanks to [**Niklas RΓ€mΓΆ**](https://github.com/niklasramo) for the amazing work with [**Muuri**](https://github.com/haltu/muuri).
## License Β©
Copyright Β© 2020 [**Paolo Longo**](https://github.com/Paol-imi) β’ [**MIT license**](LICENSE).