
Product
Introducing GitHub Actions Scanning Support
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socketβs new workflow scanning support.
@danielhaim/imageemitter
Advanced tools
A utility for loading images with event emission, utilizing an extended EvEmitter.
ImageEmitter is a streamlined utility designed for image loading tasks through event-driven approach. The utility manages the loading of images and extends its functionality to categorize images based on their dimensions and format.
done
, progress
, always
, and fail
.You can install this module via npm:
$ npm i @danielhaim/image-emitter
import ImageEmitter from "@danielhaim/image-emitter";
// Initialize image loader for selected images
const imageEmitter = new ImageEmitter(document.querySelectorAll("img"));
// Event Listener: Image Loading Progress
imageEmitter.on("progress", (loadedCount, totalImages) => {
console.log(`Progress: ${loadedCount}/${totalImages} images loaded.`);
});
// Event Listener: All Images Successfully Loaded
imageEmitter.on("done", () => {
console.log("Success: All images have been loaded.");
});
// Event Listener: Image Loading Failure
imageEmitter.on("fail", () => {
console.error("Error: One or more images failed to load.");
});
// Event Listener: Image Loading Completion (Regardless of Success/Failure)
imageEmitter.on("always", () => {
console.log("Info: Image loading process completed.");
});
ImageEvents
A foundational class for event handling.
constructor()
: Initializes the event and once-event handlers.on(eventName, listener)
: Registers an event listener.once(eventName, listener)
: Registers a one-time event listener.off(eventName, listener)
: Removes an event listener.emitEvent(eventName, args)
: Emits an event to all registered listeners.allOff()
: Removes all event listeners.ImageEmitter
Extends ImageEvents
for image loading.
constructor(elements)
: Initializes with a set of DOM elements.initImages()
: Prepares images for loading.checkImages()
: Checks and starts the loading process for all images.loadImage(imgElement, callback)
: Loads a single image.loadBackgroundImage(url, callback)
: Loads a background image.progress(loadedCount, totalImages)
: Tracks the progress of image loading.hasBackgroundImage(element)
: Checks if an element has a background image.getBackgroundImageUrl(element)
: Retrieves the background image URL of an element.ImageHelper
A utility class for image analysis and classification.
constructor(options)
: Initializes the class with custom size definitions and an option to use CSS classes or data attributes.
options.sizeDefinitions
: Custom size definitions for classifying images (e.g., { sm: 600, md: 1200, lg: 1500, xl: Infinity }).options.useClasses
: Boolean to choose between using CSS classes or data attributes.static getNaturalDimensions(img)
: Returns the natural dimensions of an image.static getImageFormat(img)
: Determines the format of an image (landscape, portrait, square).getImageSize(img)
: Classifies the size of an image based on custom size definitions.classifyImage(img)
: Returns the format and size classification of an image.classifyImages(images)
: Applies format and size classification to a collection of images by either adding CSS classes or data-img-format
and data-img-size
attributes.progress
: Triggered during the image loading process, provides the count of loaded images and the total.done
: Triggered when all images are loaded successfully.fail
: Triggered if any image fails to load.always
: Triggered when the image loading process is completed, regardless of success or failure.βββ LICENSE
βββ README.md
βββ __test__
βΒ Β βββ ImageEmitter.test.js
βΒ Β βββ ImageHelper.test.js
βΒ Β βββ test-image1.jpeg
βΒ Β βββ test-image2.jpeg
βΒ Β βββ test-image3.jpeg
βββ babel.config.js
βββ dist
βΒ Β βββ imageEmitter.amd.js
βΒ Β βββ imageEmitter.js
βββ index.js
βββ jest.config.js
βββ package-lock.json
βββ package.json
βββ src
βΒ Β βββ ImageEvents.js
βΒ Β βββ ImageHelper.js
βΒ Β βββ index.js
βββ webpack.config.js
FAQs
A utility for loading images with event emission, utilizing an extended EvEmitter.
The npm package @danielhaim/imageemitter receives a total of 31 weekly downloads. As such, @danielhaim/imageemitter popularity was classified as not popular.
We found that @danielhaim/imageemitter demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago.Β It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socketβs new workflow scanning support.
Product
Add real-time Socket webhook events to your workflows to automatically receive pull request scan results and security alerts in real time.
Research
The Socket Threat Research Team uncovered malicious NuGet packages typosquatting the popular Nethereum project to steal wallet keys.