Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cbillowes/gatsby-remark-interactive-gifs
A Gatsby plugin to add interactive animated gifs to markdown files.
https://github.com/cbillowes/gatsby-remark-interactive-gifs
embedded gatsby gatsby-plugin gatsby-remark gatsbyjs gif plugin remark
Last synced: 2 months ago
JSON representation
A Gatsby plugin to add interactive animated gifs to markdown files.
- Host: GitHub
- URL: https://github.com/cbillowes/gatsby-remark-interactive-gifs
- Owner: cbillowes
- License: mit
- Created: 2020-04-23T18:49:25.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-12-25T14:46:39.000Z (about 1 year ago)
- Last Synced: 2024-11-06T13:57:55.991Z (3 months ago)
- Topics: embedded, gatsby, gatsby-plugin, gatsby-remark, gatsbyjs, gif, plugin, remark
- Language: JavaScript
- Homepage: https://gifs.curiousprogrammer.dev/
- Size: 1.37 MB
- Stars: 8
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# gatsby-remark-interactive-gifs
[![npm](https://img.shields.io/npm/v/gatsby-remark-interactive-gifs)](https://www.npmjs.com/package/gatsby-remark-interactive-gifs)
[![Build Status](https://travis-ci.org/cbillowes/gatsby-remark-interactive-gifs.svg?branch=master)](https://travis-ci.org/cbillowes/gatsby-remark-interactive-gifs)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)A Gatsby plugin to add interactive animated gifs to markdown files.
[Check it out!](https://gifs.curiousprogrammer.dev/)## Install
`npm install --save gatsby-remark-interactive-gifs`
## Overview
* Add a gif to your markdown with the gif protocol in inline code. `gif:.gif`.
There are options to customize it defined later on.
* A still image is extracted and saved in the `dest` as `still-.gif`.
* Click events will toggle between play and playing.> **Gotchas:** A fresh copy needs to be downloaded to play a gif from the beginning.
> * All caching strategies are bypassed.
> * This plugin is designed for images that fill a container. Custom styling is required to
> cater for gifs not of 100% width.> **Tips:**
> * Optimize your gifs!
> * For imagery, I use icons from [www.flaticon.com](https://www.flaticon.com/) and make sure I attribute them.
> * For spinners/loading indicators, I use [loading.io](https://loading.io/).## Requirements
This plugin requires node >=10.
## Configure
gatsby-config.json:
```javascript
{
resolve: `gatsby-transformer-remark`,
options: {
plugins: [
{
resolve: `gatsby-remark-interactive-gifs`,
options: {
root: `${__dirname}`,
src: `${__dirname}/src/gifs`,
dest: `${__dirname}/public/static/gifs`,
play: `${__dirname}/src/images/play.gif`,
placeholder: `${__dirname}/src/images/placeholder.gif`,
loading: `${__dirname}/src/images/loading.gif`,
relativePath: `/static/gifs`
},
},
]
},
}
```* `root` - The root of your project.
* `src` - Where all the gifs you want processed are stored. Absolute path.
* `dest` - A path in `public` where your gifs are stored. Absolute path.
* `play` - An image to indicate that the gif can be interacted with. Absolute path.
* `placeholder` - An image to show when the gif is missing in action. Absolute path.
* `loading` - An image which shows when the gif is downloading. Absolute path.
* `relativePath` - The relative path served from `public/`.## How to query
Your animated gifs are available in GraphQL and the nodes can be access via `allInteractiveGif`.
```
query MyQuery {
allInteractiveGif {
edges {
node {
height
absolutePath
base64
relativePath
sourcePath
stillRelativePath
width
}
}
}
}
```## How to use
Simply reference your gif file name (relative to the configured `src` directory) in the gif protocol in order to embed the interactive gif.
```
`gif:dolphin.gif`
```You can customize it by adding attributes. They are in no particular order and neither are mandatory.
```
`gif:dolphin.gif:id=hitchikers-guide-to-the-galaxy;class=dolphin;caption=So long and thanks for all the fish`
```* `id` adds element an ids on the gif container and a `still-` on the still container.
* `class` adds a class to the parent interactive gif container.
* `caption` adds text to the bottom of the image.## How to style
Below is sample styling in `CSS` to get you started.
```css
.interactive-gif {}/* Responsive flicker-less display */
.interactive-gif .embedded {
position: relative;
width: 100%;
height: auto;
}.interactive-gif .loading,
.interactive-gif .still-container,
.interactive-gif .gif-container {
position: absolute;
top: 0;
width: 100%;
height: 100%;
}.interactive-gif .still,
.interactive-gif .gif {
width: 100%;
height: 100%;
cursor: pointer;
}/* Loading indicator */
.interactive-gif .loading .indicator {
position: absolute;
bottom: 0;
left: 0;
width: 80px;
filter: contrast(0.5);
}/* Play button */
.interactive-gif .still-container .play {
cursor: pointer;
filter: grayscale(100%);
width: 20%;
position: absolute;
opacity: 0.9;
left: 50%;
top: 50%;
transform: translateX(-50%) translateY(-50%);
}/* Text underneath the gif */
.interactive-gif .caption {
font-size: 90%;
font-style: italic;
}/* Image displayed when the gif cannot be found */
.interactive-gif .placeholder {
filter: grayscale(100%);
text-align: center;
}.interactive-gif .placeholder img {
width: 200px;
}
```You can convert the above CSS to
[scss](https://jsonformatter.org/css-to-scss),
[sass](https://jsonformatter.org/css-to-sass) or
[less](https://jsonformatter.org/css-to-less).## Example
```markdown
`gif:nyancat.gif:caption=Nyanyanyanyanyanyanya`
``````html
```> **Note:** `padding-top` is calculated using the aspect ratio of the image. The embedded container
> is given enough room to responsively contain the children images and containers.## Troubleshooting
Run a `gatsby clean` when your source nodes are no longer generated.
## Notes
The order of this plugin only matters when you use it together with `gatsby-remark-prismjs`. Prism transforms code blocks and I kind
of slapped a gif protocol in one which will confuse the daylight out of prism. Just reference this plugin somewhere above Prism.## Contribute
Read the [guidelines](./CONTRIBUTE.md) to contribute to this plugin.
## License
MIT, by Clarice Bouwer