Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shellophobia/transform-image-js
JS library to transform the image
https://github.com/shellophobia/transform-image-js
blob canvas2d client-compression commonjs commonjs-modules compression frontend-compression image-resize javascript jquery-plugin js-compression jsdelivr jsdelivr-cdn npm npm-module npmjs react transform unpkg yarn
Last synced: 3 months ago
JSON representation
JS library to transform the image
- Host: GitHub
- URL: https://github.com/shellophobia/transform-image-js
- Owner: shellophobia
- License: mit
- Created: 2016-05-09T15:17:37.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2021-10-01T00:40:47.000Z (over 3 years ago)
- Last Synced: 2024-10-02T02:57:57.289Z (4 months ago)
- Topics: blob, canvas2d, client-compression, commonjs, commonjs-modules, compression, frontend-compression, image-resize, javascript, jquery-plugin, js-compression, jsdelivr, jsdelivr-cdn, npm, npm-module, npmjs, react, transform, unpkg, yarn
- Language: JavaScript
- Homepage: https://shellophobia.github.io/uploadresizeimage.html
- Size: 117 KB
- Stars: 15
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# transform-image-js
[![Build Status](https://img.shields.io/travis/shellophobia/transform-image-js.svg)](https://travis-ci.org/github/shellophobia/transform-image-js)
[![Version](https://img.shields.io/npm/v/@shellophobia/transform-image-js.svg)](https://www.npmjs.com/package/@shellophobia/transform-image-js)
[![License](https://img.shields.io/npm/l/@shellophobia/transform-image-js.svg)](https://www.npmjs.com/package/@shellophobia/transform-image-js)
[![minified size](https://img.shields.io/bundlephobia/min/@shellophobia/transform-image-js.svg)](https://www.npmjs.com/package/@shellophobia/transform-image-js)> [transform-image-js](https://github.com/shellophobia/transform-image-js) is a library to perform transformations on an image file e.g. resize an image within defined constraints and also allows to adjust the quality of image. One of the use cases is when you want to perform a size optimization on the image before uploading.
## Getting started
### Installing
Using npm:
```bash
npm i @shellophobia/transform-image-js
```Using yarn:
```bash
yarn add @shellophobia/transform-image-js
```Using jsDelivr CDN:
```html
```
Using unpkg CDN:
```html
```
### Usage
#### Import
in CommonJS:
```js
const transformImage = require("@shellophobia/transform-image-js")
```in ES6:
```js
import transformImage from '@shellophobia/transform-image-js';
```#### Resize image to max 500x500 with quality as 0.9:
##### Vanilla JS and HTML
```html```
```js
function handleUpload(e){
const file = e.target.files[0];
// The library will add a property `transformImageJS` on window once you import it
const transformImage = new transformImageJS.TransformImage({});
transformImage.resizeImage(file, {maxHeight: 500, maxWidth:500, quality:0.9}).then(res=>{
//The response returns an object that has the output blob in output attribute and has metadata for image sizes before and after transformation
console.log(res);
}).catch(err => {
// handle error
});
}// using async function
async function handleUpload(e) {
const file = e.target.files[0];
const transformImage = new transformImageJS.TransformImage({});
try {
const res = await transformImage.resizeImage(file, {maxHeight: 500, maxWidth:500, quality:0.9});
console.log(res);
} catch(e) {
// handle error
}
}
```##### React JSX
```js
import React from "react";
import transformImage from "@shellophobia/transform-image-js";const handleUpload = async (e) => {
const file = e.target.files[0];
console.log(file);
const transformImage = new transformImage({});
try {
const res = await transformImage.resizeImage(file, {maxHeight: 500, maxWidth:500, quality:0.9});
console.log(res);
} catch (e) {
console.log(e);
}
}export default function App() {
return (
);
}
```## API
### Initialization options
#### Description
Following options can be passed during initialization of transformImage that returns an object on which methods can be called#### `transformImage(options)`
| Name | Type | Description | Default |
|------------------|----------|----------------------------------------------------------------------|------------------------|
| sizeLimit | int | the byte size limit for the input file/blob | 16777216 bytes = 16MB |
| outputType | enum | defines the output object format. Allowed values :- blob/base64/file | blob |
| allowedFileTypes | []string | allowed types for the input file/blob e.g. PNG, JPEG, JPG | ["jpg", "png", "jpeg"] |### Methods
#### `resizeImage(imageFile, options, fileName) => {Promise}`
#### Description:
Resize an image file#### Parameters:
| Name | Type | Description | Required | Default |
|----------|-----------|---------------------------------------------------------------------------------------------|----------|---------|
| image | File/Blob | File object / Blob to be resized | Yes | N/A |
| options | Object | Additional options described below. The values can also override the TransformImage options | No | {} |
| fileName | string | Name of the file if outputType is file (Optional) | No | "" |##### Options
| Name | Type | Description | Default |
|-----------|-------|-------------------------------------------------------------------|---------|
| maxWidth | int | the max width for the file in px | 500 |
| maxHeight | int | the max height for the file in px | 500 |
| quality | float | a value between 0 and 1 to denote the quality of the output image | 0.9 |#### Returns:
Promise that resolves to the output object| Name | Type | Description |
|----------|--------------------|--------------------------------------------------------------------|
| output | blob/base64 string | Blob or base64 string based on configuration |
| metadata | object | Metadata about initial image dimensions and final image dimensions |##### Metadata
| Name | Type | Description |
|----------------|------|-----------------------|
| originalHeight | int | Original image height |
| originalWidth | int | Original image width |
| resizedHeight | int | Resized image height |
| resizedWidth | int | Resized image width |## JQuery Plugin
[image_compress_plugin](https://cdn.jsdelivr.net/npm/@shellophobia/[email protected]/jquery_plugin/image_compress_plugin.js) is a jquery plugin that allows to add a file upload and compress functionality.### Usage
#### Importing
```html```
#### Example
```htmlThis is a demo for the resize image jquery plugin. Feel free to go through the source code
here
Click Here to Upload
Or Drag N Drop the file
$(document).ready(function() {
$("#fileinput").uploadFile({
enablePreview: true,
appendFileInput: false,
autoSubmit: false,
previewSelector: "#preview"
});
});```
[Configuration gist for jquery plugin](https://gist.github.com/shellophobia/547a13696996eebbcf20b19f1bfffca4)
## License
[MIT](http://opensource.org/licenses/MIT)