A simple library to process the image to many sizes for the website.
- Optimize the image size and quality of the website.
- Resize images to different sizes to use for desktop and mobile. It works better for the lazy load.
- Store the output locally or in the cloud storage (ext: s3, minio, ...).
This project requires NodeJS (version 14 or later) and NPM. Node and NPM are really easy to install. To make sure you have them available on your machine, try running the following command.
$ npm -v && node -v
6.4.1
v14.15.0
npm install simple-web-image
import SimpleWebImage from 'simple-web-image'
const config = {
drives: {
local: { rootDir: './tmp/output/simple-web-image' },
s3: {
accessKeyId: "THE AWS ACCESS KEY ID",
secretAccessKey: "THE AWS SECRET ACCESS KEY",
bucket: "simple-web-image",
region: "us-east-1"
}
}
}
const simple = new SimpleWebImage(config)
try {
await simple.drive('local').put(req, './tmp/output/simple-web-image/image-name')
await simple.drive('s3').put(req, './tmp/output/simple-web-image/image-name')
} catch (error) {
// code here
}
import express from "express"
import SimpleWebImage from "simple-web-image"
const app = express()
const port = 3000
const config = {}
const simple = new SimpleWebImage(config)
// should upload with binary body
app.post("/upload", async (req, res) => {
try {
await simple.drive('local').put(req, './tmp/output/simple-web-image/image-name')
res.send("upload success")
} catch (err) {
res.send("upload fail")
}
});
app.listen(port, () => {
console.log(`Example app listening on port ${port}`)
})
Look at the example repo for more details.
Any contributions from the community are welcome.
Find a bug, a typo, or something that’s not documented well? We’d love for you to open an issue telling us what we can improve! Follow the CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
We love your pull requests! Check out our Good First Issue and Help Wanted tags for good issues to tackle. Check out our contributors guide for more information.
If you like what you see, star us on GitHub
See the ROADMAP.md file
MIT License © Vu Lai