0.0.44 • Published 11 months ago

@sitelintcode/optimize-image-on-the-client-side v0.0.44

Weekly downloads
-
License
MOZILLA PUBLIC LI...
Repository
github
Last release
11 months ago

Optimize image on the client side

Optimize image after selecting using <input type="file">. The optimization process takes place in the background and it's done automatically by listening for changes on all inputs type file.

Note that images that are larger in size after compression are not taken into account.

Features

  • Compressing by the browser, client-side. No image is sent outside of the browser anywhere.
  • When compression takes more than 1 second then the user will see a busy indicator.

Demo

Optimize image on the client side

Benefits

  • Faster uploading and downloading data.
  • Reducing memory consumption.
  • Saves the space on the server.

Getting started

NPM

npm install @sitelintcode/optimize-image-on-the-client-side --save

TypeScript

import { OptimizeImage } from '@sitelintcode/optimize-image-on-the-client-side';

const optimizeImage: OptimizeImage = new OptimizeImage();

optimizeImage.install();

Options

cssQuerySelector?: string | undefined - you can specify here custom CSS selector to find your own input type file. By default there is a global change event listener that handles all inputs type file.

onCompressionDoneCallback?: Function - pass callback after compression is done. const onCompressionDone = (filesBeforeCompression, filesAfterCompression) => {};

quality: number = 0.75 - you may change the default quality parameter. Read more about quality paremeter on MDN Docs.

This could be set through install method arguments:

const optimizeImage = new OptimizeImage();

optimizeImage.install(undefined, undefined, 0.85);

or at any time later

const optimizeImage = new OptimizeImage();

optimizeImage.quality = 0.85;

Browser environment

<script src="https://cdn.jsdelivr.net/npm/@sitelintcode/optimize-image-on-the-client-side@0.0.39/dist/optimize-image-on-the-client-side.js"></script>
<script>
(function() {
  const optimizeImage = new window.sitelint.OptimizeImage();
  optimizeImage.install();
}())
</script>

Notes

Note the version number in the jsdelivr URL: 0.0.39. Don't forget to set desired version. You may check releases: https://github.com/sitelint/optimize-image-on-the-client-side/releases

Worth to mention that jsdelivr suggests:

Omit the version completely or use latest to load the latest one (not recommended for production usage).

Technical

  1. import { terser } from "rollup-plugin-terser"; was replaced with import { terser } from "rollup-plugin-minification"; because rollup-plugin-terser is not compatible with Rollup 3.x version. See: https://github.com/TrySound/rollup-plugin-terser/issues/119

Contributing

Contributions are welcome, and greatly appreciated! Contributing doesn't just mean submitting pull requests. There are many different ways for you to get involved, including answering questions on the issues, reporting or triaging bugs, and participating in the features evolution process.

License

MOZILLA PUBLIC LICENSE, VERSION 2.0

0.0.40

11 months ago

0.0.41

11 months ago

0.0.42

11 months ago

0.0.43

11 months ago

0.0.44

11 months ago

0.0.38

1 year ago

0.0.39

1 year ago

0.0.37

2 years ago

0.0.34

2 years ago

0.0.35

2 years ago

0.0.36

2 years ago

0.0.33

2 years ago

0.0.32

2 years ago

0.0.31

2 years ago

0.0.30

2 years ago

0.0.29

2 years ago

0.0.27

2 years ago

0.0.28

2 years ago

0.0.23

2 years ago

0.0.24

2 years ago

0.0.25

2 years ago

0.0.26

2 years ago

0.0.22

2 years ago

0.0.21

2 years ago

0.0.20

3 years ago

0.0.19

3 years ago

0.0.18

3 years ago

0.0.17

3 years ago

0.0.16

3 years ago

0.0.15

3 years ago

0.0.14

3 years ago

0.0.13

3 years ago

0.0.12

3 years ago

0.0.11

3 years ago

0.0.10

3 years ago

0.0.9

3 years ago

0.0.8

3 years ago

0.0.7

3 years ago

0.0.6

3 years ago

0.0.5

3 years ago

0.0.4

3 years ago

0.0.3

3 years ago

0.0.2

3 years ago