Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/leastbad/stimulus-image-grid
https://github.com/leastbad/stimulus-image-grid
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/leastbad/stimulus-image-grid
- Owner: leastbad
- License: mit
- Created: 2020-05-02T20:39:08.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-02-03T06:47:28.000Z (almost 2 years ago)
- Last Synced: 2024-11-01T23:25:01.700Z (2 months ago)
- Language: JavaScript
- Size: 1.89 MB
- Stars: 26
- Watchers: 3
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-stimulusjs - stimulus-image-grid - A StimulusJS controller for beautiful image grids. (Packages)
README
Stimulus Image Grid
A Stimulus controller for beautiful image grids
Tiny at <100 LOC
- **Simple**: with only three optional parameters, this is a drop-in, code-free solution
- **Unstyled**: Completely free of CSS opinions
- **Responsive**: Scales to whatever bounding container you give it
- **Backend Agnostic**: 100% client-side
- **Performant AF**: uses the ResizeObserver so there's zero screen flicker
- **Turbolinks**: compatible with Turbolinks by design
- **MIT Licensed**: free for personal and commercial use[![Youtube](http://img.youtube.com/vi/e08sFfBYoiE/0.jpg)](http://www.youtube.com/watch?v=e08sFfBYoiE "Stimulus Image Grid")
## Built for StimulusJS
This [Stimulus](https://stimulusjs.org/) controller allows you to make any configurations for the image grid directly with data attributes in your HTML. Once registered in your Stimulus application, you can use it anywhere you like.
Here is a simple example:
```html
```
Yes, that's really it.### Credit where credit is due
I don't know who wrote the original image-grid.js library. It shipped with a bunch of premium Bootstrap themes, but it relied on jQuery. While stimulus-image-grid is an improvement on the original in several significant ways, the actual meat and potatoes of the algorithm is 100% adapted from the code of a stranger. If you know who wrote [image-grid.js](https://github.com/Pactum/pactum.io/blob/9f2d162bc21f26d62c5d4ba801309bdeb8b9fa9e/v4/js/custom/image-grid.js), please let me know!
## Setup
Note: **stimulus-image-grid requires StimulusJS v2.0+**
*If you are reading this in the past* (Stimulus 2 isn't out yet) you can change your `stimulus` package in `package.json` to point to [this commit](https://github.com/stimulusjs/dev-builds/archive/b8cc8c4/stimulus.tar.gz).
Add image-grid to your main JS entry point or Stimulus controllers root folder:
```js
import { Application } from 'stimulus'
import ImageGrid from 'stimulus-image-grid'import { definitionsFromContext } from 'stimulus/webpack-helpers'
const application = Application.start()
const context = require.context('../controllers', true, /\.js$/)
application.load(definitionsFromContext(context))// Manually register ImageGrid as a Stimulus controller
application.register('image-grid', ImageGrid)
```## HTML Markup
For the image grid to work properly, it needs the raw image dimensions. If you know the dimensions at render time, set the `data-width` and `data-height` attributes. Otherwise, the library will calculate the size when it loads. This is slower and could cause a flicker, but it will only happen once - even across Turbolinks visits.
```html
```The library tries really hard to not be opinionated about HTML structure. The basic idea is that every child of the container element that has the image-grid controller declared upon it will have [zero or one] image(s), somewhere in its DOM hierarchy. So for example, you could have a scenario where images are wrapped in DIV tags and it will find [zero or one] image(s) in the hierarchy:
```html
```This library is fully responsive in that it will automatically re-flow the images to the ideal layout in real-time as the container it lives in changes size. If you're using a CSS library such as Bootstrap, this is usually managed with the [responsive breakpoint classes](https://getbootstrap.com/docs/4.4/layout/grid/#grid-options).
## Optional Parameters
There are only three configurable properties, all of which are set on the DOM element using data attributes:
Property | Default Value
-------- | -------------
padding | 10
targetHeight | 150
display | inline-block```html
...
```Padding is applied to the bottom of each image as well as the right edge of each image *that isn't the right-most image of its row*. Target height is applied to the row and you can tweak this value to suit the look of your application.
### Obtaining a reference to the Stimulus controller instance
When you place an image-grid controller on a DOM element, it hangs a variable on the element called `imageGrid` which allows you to access the internal state of the controller.
The only method you should ever call directly is `processImages()`, which shouldn't be necessary but I'm not a fucking oracle so I've got your back. Here's an example of forcing a grid re-flow on an element with the id `grid`:
```javascript
document.getElementById('grid').imageGrid.processImages()
```## Contributing
Bug reports and pull requests are welcome.
## License
This package is available as open source under the terms of the MIT License.