compressorjs VS storage

Compare compressorjs vs storage and see what are their differences.

storage

S3 compatible object storage service that stores metadata in Postgres (by supabase)
SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
With SurveyJS form UI libraries, you can build and style forms in a fully-integrated drag & drop form builder, render them in your JS app, and store form submission data in any backend, inc. PHP, ASP.NET Core, and Node.js.
surveyjs.io
featured
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
compressorjs storage
8 19
4,976 654
- 10.2%
2.1 8.4
12 months ago 4 days ago
JavaScript TypeScript
MIT License Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

compressorjs

Posts with mentions or reviews of compressorjs. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-12-11.
  • Client-side image compression with Supabase Storage
    4 projects | dev.to | 11 Dec 2022
    After researching a couple of different options, what I landed on was a package called compressorjs written by Chen Fengyuan. This library performs compression and resizing of images in the browser. I was a bit skeptical at first, but it's a cool project and has good browser support. How Compressorjs works is that it uses the HTML5 canvas element to read the original image data and perform lossy transformations to compress and resize the image. There's a whole bunch of transformation options. For my project, what I have found is simply changing the maximum width of the image to 600px and slightly reducing the quality has greatly reduced the file sizes.
  • One Click to Optimize Images, Create Repo and Making Commit
    2 projects | dev.to | 10 Dec 2022
    You can change image quality or pass different options. I set customized mimeType and width by passing option parameter here. You can find more usages from compressor.js original documentation.
  • How to compress images on client-side
    2 projects | dev.to | 12 Apr 2022
    I will use compressorjs, a tiny librarie (3.8 kB minzipped). Compressor.js uses the Browser's native HTMLCanvasElement.toBlob() API to do the compression work, which means it is lossy compression.
  • Compressing images on client side before upload
    4 projects | /r/webdev | 9 Feb 2022
    (I checked out : imagemin, compress.js, compressorjs and some small others)
  • Django CK editor with client side image shrinker
    1 project | /r/djangolearning | 23 Nov 2021
    Django CK editor comes with default image shrinker based on Pillow, But Pillow sucks at image shrinking, A frontend library called compressorjs does 5 times the Image quality with 5 times smaller the size.
  • 12 JavaScript Image Manipulation Libraries For Your Next Web App
    11 projects | dev.to | 9 Jun 2021
    MORE INFO
  • Made a Web App to reduce Image Size by up to 90%, No file Size Limit & Works Offline | compressimage.io
    4 projects | /r/webdev | 29 May 2021
    You don't actually need any web services. Just import the compressorjs library and the UPNG.js library on client side(frontend) and then before uploading the data to server compress the image. These libraries were actually written for frontend compression by their respective owners. https://github.com/photopea/UPNG.js (25kb) https://github.com/fengyuanchen/compressorjs (8kb)

storage

Posts with mentions or reviews of storage. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-18.
  • Supabase Storage: now supports the S3 protocol
    5 projects | news.ycombinator.com | 18 Apr 2024
    [3] https://github.com/supabase/storage/issues/439
    5 projects | dev.to | 18 Apr 2024
    The Supabase Storage Engine is fully open source and is one of the few storage solutions that offer 3 interoperable protocols to manage your files:
  • What's the simplest solution to sell digital downloads via SvelteKit?
    1 project | /r/sveltejs | 5 Dec 2023
    For instance, consider a supabase setup where you place your photos in storage and your orders in a table. Then, have a function run automatically whenever a new row is added to the orders table. That function would be responsible for identifying what the customer bought and delivering it to them.
  • Managify: Manage Your Teams Easily
    6 projects | dev.to | 20 Jul 2023
    In this page, I used Supabase Storage to store the files uploaded by the users
  • HELP -> ERROR: function st_point(double precision, double precision) does not exist (SQLSTATE 42883)
    1 project | /r/Supabase | 19 Jun 2023
    -- Create a table for public profiles CREATE TABLE profiles ( id UUID REFERENCES auth.users ON DELETE CASCADE PRIMARY KEY, updated_at TIMESTAMP WITH TIME ZONE, username TEXT NULL, full_name TEXT, profile_image_url TEXT, bio TEXT, sex SMALLINT DEFAULT 0, CONSTRAINT username_length CHECK (CHAR_LENGTH(username) >= 3) ); -- Create a table for channeles CREATE TABLE channeles ( id SERIAL PRIMARY KEY, userRefId UUID REFERENCES auth.users(id), channel TEXT, updated_at TIMESTAMP WITH TIME ZONE ); -- Create a table for geo location CREATE TABLE user_geo ( id SERIAL PRIMARY KEY, userRefId UUID REFERENCES auth.users(id), location GEOGRAPHY(point) NOT NULL, updated_at TIMESTAMP WITH TIME ZONE ); create index user_geo_index on public.user_geo using GIST (location); -- Set up Row Level Security (RLS) -- See https://supabase.com/docs/guides/auth/row-level-security for more details. ALTER TABLE profiles ENABLE ROW LEVEL SECURITY; CREATE POLICY "Public profiles are viewable by everyone." ON profiles FOR SELECT USING (TRUE); CREATE POLICY "Users can insert their own profile." ON profiles FOR INSERT WITH CHECK (auth.uid() = id); CREATE POLICY "Users can update own profile." ON profiles FOR UPDATE USING (auth.uid() = id); -- Set up Row Level Security (RLS) -- See https://supabase.com/docs/guides/auth/row-level-security for more details. ALTER TABLE channeles ENABLE ROW LEVEL SECURITY; CREATE POLICY "Public channeles are viewable by everyone." ON channeles FOR SELECT USING (TRUE); CREATE POLICY "Users can insert their own channeles." ON channeles FOR INSERT WITH CHECK (auth.uid() = userRefId); CREATE POLICY "Users can update own channeles." ON channeles FOR UPDATE USING (auth.uid() = userRefId); -- Set up Row Level Security (RLS) -- See https://supabase.com/docs/guides/auth/row-level-security for more details. ALTER TABLE user_geo ENABLE ROW LEVEL SECURITY; CREATE POLICY "Public geo_location are viewable by everyone." ON user_geo FOR SELECT USING (TRUE); CREATE POLICY "Users can insert their own geo_location." ON user_geo FOR INSERT WITH CHECK (auth.uid() = userRefId); CREATE POLICY "Users can update own geo_location." ON user_geo FOR UPDATE USING (auth.uid() = userRefId); -- See https://supabase.com/docs/guides/auth/managing-user-data#using-triggers for more details. CREATE OR REPLACE FUNCTION public.handle_new_user() RETURNS TRIGGER AS $$ BEGIN INSERT INTO public.profiles ( id, updated_at, username, full_name, profile_image_url, bio, sex, ) VALUES ( NEW.id, NOW(), NEW.raw_user_meta_data->>'username', NEW.raw_user_meta_data->>'full_name', NEW.raw_user_meta_data->>'profile_image_url', NEW.raw_user_meta_data->>'bio', COALESCE(CAST(NEW.raw_user_meta_data->>'sex' AS SMALLINT), 0), ); INSERT INTO public.channeles (userRefId, channel, updated_at) VALUES (NEW.id, NEW.raw_user_meta_data->>'expoToken', NOW()); INSERT INTO public.user_geo (userRefId, location, updated_at) VALUES ( NEW.id, ST_Point(CAST(NEW.raw_user_meta_data->>'lat' AS FLOAT), CAST(NEW.raw_user_meta_data->>'lng' AS FLOAT)), NOW() ); RETURN NEW; END; $$ LANGUAGE plpgsql SECURITY DEFINER; CREATE TRIGGER on_auth_user_created AFTER INSERT ON auth.users FOR EACH ROW EXECUTE FUNCTION public.handle_new_user(); -- Set up Storage! INSERT INTO storage.buckets (id, name) VALUES ('profile_images', 'profile_images'); -- Set up access controls for storage. -- See https://supabase.com/docs/guides/storage#policy-examples for more details. CREATE POLICY "profile_image images are publicly accessible." ON storage.objects FOR SELECT USING (bucket_id = 'profile_images'); CREATE POLICY "Anyone can upload a profile_image." ON storage.objects FOR INSERT WITH CHECK (bucket_id = 'profile_images');
  • Supabase alternatives
    4 projects | /r/Supabase | 31 May 2023
    For example the storage-api. I was on version supabase/storage-api:v0.29.1 for a long time, until I realized, that there is a new version of it (0.40.1). Fast forward, upgraded everything, checked my application and everything storage related stopped working. From now on it's always the same procedure. Debugging the errors, digging through the code on GitHub, checking commits, issues, etc. After a while I found a bug from 2019 which had exactly the same error as I, tested the workaround and it worked again (partially, workaround).
  • A Rounded Solution to Image Handling on the OpenSauced Dashboard
    5 projects | dev.to | 17 May 2023
    Alternatively, we could use imagemagick (cli tool for image transforms) + supabase storage to do the same for free.
  • AWS Amplify Is a Grift
    2 projects | news.ycombinator.com | 10 Apr 2023
    [5] https://supabase.com/docs/guides/storage
  • Building a Startup from Scratch: My Mistakes as CTO
    2 projects | dev.to | 1 Feb 2023
    Storage
  • Any idea how to limit file upload size ?
    1 project | /r/Supabase | 12 Jan 2023
    We'll probably need to upload other types of assets in the future, so having a way to set the limit per bucket would be nice... There's an issue for this - I may make a PR to implement it at some point.

What are some alternatives?

When comparing compressorjs and storage you can also consider the following projects:

cropperjs - JavaScript image cropper.

supabase - The open source Firebase alternative.

sharp - High performance Node.js image processing, the fastest module to resize JPEG, PNG, WebP, AVIF and TIFF images. Uses the libvips library.

supabase-js - An isomorphic Javascript client for Supabase. Query your Supabase database, subscribe to realtime events, upload and download files, browse typescript examples, invoke postgres functions via rpc, invoke supabase edge functions, query pgvector.

pica - Resize image in browser with high quality and high speed

auth - A JWT based API for managing users and issuing JWT tokens

UPNG.js - Fast and advanced PNG (APNG) decoder and encoder (lossy / lossless)

nextjs-auth0 - Next.js SDK for signing in with Auth0

squoosh - Make images smaller using best-in-class codecs, right in the browser.

postgrest - REST API for any Postgres database

jimp - An image processing library written entirely in JavaScript for Node, with zero external or native dependencies.

fastify-multipart - Multipart support for Fastify