Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/ericrisco/astro-cloudinary-image

This Astro component makes it easy to wrap the Cloudinary URL Generator library to dynamically generate and optimize images from the Cloudinary service.
https://github.com/ericrisco/astro-cloudinary-image

Last synced: 29 days ago
JSON representation

This Astro component makes it easy to wrap the Cloudinary URL Generator library to dynamically generate and optimize images from the Cloudinary service.

Awesome Lists containing this project

README

        

![astrocloudinary](https://user-images.githubusercontent.com/20164590/221385959-78078d28-79c3-40ec-b2c1-c4dfa01c03ad.png)

# πŸš€ Astro Cloudinary Image

This [Astro](https://astro.build/) component makes it easy to wrap the Cloudinary URL Generator library to dynamically generate and optimize images from the Cloudinary service.

Pull requests and/or feature requests are very welcome!

## πŸ”₯ Motivation

This project aims to participate in [@midudev](https://www.github.com/midudev) hackathon: [Cloudinary CloudCreate](https://cloudinary.com/blog/cloudinary-cloudcreate-tech-products-hackathon?utm_source=twitter&utm_medium=social-company&utm_campaign=1307&utm_term=194&utm_content=blog_cloudcreate_hackathon), in collaboration with [Cloudinary](https://cloudinary.com/).

## πŸ’» Features

Below is a short list of features that **Astro Cloudinary Image** offers.

- βœ… **Crops the image to fit the specified dimensions.**
- βœ… **Scales the image to fill the specified dimensions.**
- βœ… **Scales the image to the specified dimensions.**
- βœ… **Scales the image to fit within the specified dimensions.**
- βœ… **Generates a thumbnail of the image.**
- βœ… **Centers the image around detected faces.**
- βœ… **Automatically detects the subject of the image and centers it.**
- βœ… **Add corner radius from 1px to max (round image)**
- βœ… **Rotate the image**
- βœ… **Applies various effects to the image.**

## πŸ› οΈ Installation

To install Astro Cloudinary Image, run the following command in your terminal:

```bash
npm install astro-cloudinary-image
```

or if you use yarn:

```bash
yarn add astro-cloudinary-image
```

or if you use pnpm:

```bash
pnpm add astro-cloudinary-image
```

## πŸ’» How To Use

1. In any of your Astro projects, you need to create a `.env` file and add your cloud name on Cloudinary, like:

```bash
CLOUDINARY_CLOUD_NAME=XXXXXXX
```

Where `XXXXXXX` is your cloud name. Tip: You can find your Cloudinary Cloud Name right on the main Dashboard of your account.

2. In any of your Astro pages, import `Cloudinary` and then use the component like:

```astro
---
import { Cloudinary } from 'astro-cloudinary-image';
---






Astro



```
## πŸ—ΊοΈ Mandatory Props

1. `src: string` - The URL of the image to be displayed. This `src` can be a full image url or the Cloudinary identifier on your media library

2. `alt: string` - The alt text for the image.

3. `errorImage: string` - A URL for a fallback image to display if the src image fails to load.

## πŸ—ΊοΈ Optional Props

1. `width?: string;` - Sets the width of the image. It accepts a string value that can be a number in pixels (e.g. "100", "50").

2. `height?: string;` - Sets the height of the image. It accepts a string value that can be a number in pixels (e.g. "100", "50").

3. `resize?:` - Specifies the resizing behavior of the image. It can have one of the following values:

Resize | Option Description
------------ | -------------
"crop" | Crops the image to fit the specified dimensions.
"fill" | Scales the image to fill the specified dimensions.
"scale" | Scales the image to the specified dimensions.
"minimumPad" | Scales the image to fit within the specified dimensions, adding padding if necessary.
"fit" | Scales the image to fit within the specified dimensions.
"limitFit" | Scales the image down to fit within the specified dimensions, but doesn't scale it up.
"thumbnail" | Generates a thumbnail of the image.
"limitFill" | Scales the image up or down to fill the specified dimensions, but doesn't crop it.
"minimumFit" | Scales the image up or down to fit within the specified dimensions, but doesn't scale it beyond its original size.
"limitPad" | Scales the image down to fit within the specified dimensions, adding padding if necessary, but doesn't scale it up.
"fillPad" | Scales the image up or down to fill the specified dimensions, adding padding if necessary.

4. `Gravity?:` - Specifies the gravity or position of the image. It can have one of the following values:

Gravity | Option Description
------------ | -------------
"face" | centers the image around detected faces.
"auto" | automatically detects the subject of the image and centers it.

5. `cornerRadius?:` number | "max"; - Specifies the radius of the corners of the image. It accepts a number value that represents the radius in pixels or the string value "max" that sets the maximum possible radius.

6. `rotate?:` number; - Rotates the image by a specified angle in degrees.

7. `effects?:` - Applies various effects to the image. It can have one or more of the following values:

Effect | Option Description
------------ | -------------
"blur" | blurs the image.
"grayscale" | converts the image to grayscale.
"sepia" | adds a sepia tone to the image.
"shadow" | adds a drop shadow to the image.
"colorize" | applies a color overlay to the image.
"oilPaint" | applies an oil painting effect to the image.
"cartoonify" | applies a cartoon effect to the image.
"outline" | adds an outline to the image.
"blackwhite" | converts the image to black and white.
"makeTransparent" | makes the background of the image transparent.
"vectorize" | converts the image to a vector format.
"gradientFade" | applies a gradient fade effect to the image.
"assistColorBlind" | simulates the experience of color blindness.
"backgroundRemoval" | removes the background of the image.
"dropShadow" | adds a drop shadow to the image.

__**In order to use `backgroundRemoval` you must activate `Cloudinary AI Background Removal` on Addons of your Cloudinary account. The `backgroundRemoval` must be allways the first effect**__

# βœ… Live Example

If you want to view live examples of the component, clone this repo and `npm run dev` it.

##

If you want to report any issues or have found a missing feature, please report it on [GitHub](https://github.com/ericrisco/astro-cloudinary-image/issues)!

Good luck out there, Astronaut. πŸš€