npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

img-switcher

v1.0.1

Published

Switch images after JS is loaded to target resolution by breakpoints. Available in VanillaJS or TypeScript.

Downloads

1

Readme

Image Switcher

Switch images to target resolution by breakpoints after JavaScript is loaded.

ImgSwitcher allows you load image by breakpoints and by DPI's (retina display). You can define how many breakpoints you want to detect, how much DPI you want to check (@2x, @3x, etc.) and also you can have a different file type for the original image than the image type that is loaded by ImgSwitcher.

Installation

You can use NPM package:

npm i img-switcher --save

or download this repository and add imgSwticher.ts or imgSwitcher.js from public folder to your project.

Usage

At first you must get instance of ImgSwitcher:

const imgSwitcher = ImgSwitcher.getInstance();

After that you can simply initialize Image Switcher:

imgSwitcher.initImgSwitcher();

About naming of files/images, see Naming described below.

Optional Usage

If you want configure options (see Available options described below), you can do it via setOptions() function:

imgSwitcher.setOptions(options);

If you need reload list of images (due to lazy load, etc.), you can call getImages() function on existing instance:

imgSwitcher.getImages();

and after that or often you will want to use listener for resize width of viewport, so, in these cases you can simply call on existing instance runImgSwitcher() function:

imgSwitcher.runImgSwitcher();

Example

const imgSwitcher = ImgSwitcher.getInstance();
imgSwitcher.initImgSwitcher();

let timer: Timer;
window.addEventListener('resize', () => {
    if (timer) {
        clearTimeout(timer);
    }
    timer = setTimeout( () => {
        imgSwitcher.runImgSwitcher();
    }, 333);
}, true);

Available options

Via JS/TS

Object of options can contains:

  • attributes = list of data attributes names, see described bellow
  • breakpoints = list of breakpoints, which you want to handle
  • cssClass = base class selector for ImgSwitcher
  • cssStyleClass = class which is removed from image when is loaded new image
  • debug = boolean for enable/disable debugging via console.log for some part of code
  • multiplier = list of resolution multipliers, which you want to handle, e.g. retina display (@2x, @3x, etc.)

Also, you can set name of data attributes on image for specify separately settings for each of images:

  • data-img-switcher-bp = list of breakpoints divided by comma (e.g.: "320,640,960")
  • data-img-switcher-lbp = last used breakpoint
  • data-img-switcher-mp = list of multipliers divided by comma (e.g.: "1,2,3")
  • data-img-switcher-te = target extension it is used for example for SVG elements, where you have to define which type of new image will be loaded (e.g.: "png", "jpg", etc.)

Example of default options:

{
    attributes: {
        breakpoints: 'data-img-switcher-bp',
        lastBreakpoint: 'data-img-switcher-lbp',
        multipliers: 'data-img-switcher-mp',
        targetExtension: 'data-img-switcher-te'
    },
    breakpoints: [320, 640, 768, 1024, 1280, 1920],
    cssClass: 'js-img-switcher',
    cssStyleClass: 'o-img-switcher',
    debug: false,
    multiplier: [1, 2]
}

Directly on HTML Tag

Available options, as I described higher, are:

  • breakpoints: data-img-switcher-bp=""
    • divided by comma, e.g.: data-img-switcher-bp="320,640,960"
  • multipliers: data-img-switcher-mp=""
    • divided by comma, e.g.: data-img-switcher-mp="1,2"
  • target extension: data-img-switcher-te=""
    • it is used when you want to have type of first image another like loaded by ImgSwitcher. Typically usage is for SVG as first loaded images. So, if you have SVG (inline or as img tag) and you want to load jpg's you must use it in this way:

      <img src="/images/nameOfFile.svg" alt="" title="" data-img-switcher-te="jpg">

      After ImgSwitcher is initialized, he will try to load by specified breakpoint for example nameOfFile-640.jpg

Naming of files/images

Name of file in situation of three breakpoints (320, 960, 1280) and for @1x, @2x multipliers is:

  • nameOfImage.jpg (base most downsized image for first load of page)
  • nameOfImage-320.jpg (image until 320px breakpoint)
  • [email protected] (image until 320px breakpoint but for retina displays, so with doubled resolution)
  • nameOfImage-960.jpg (image from 321px and until 960px breakpoint)
  • [email protected] (image from 321px and until 960px breakpoint but for retina displays, so with doubled resolution)
  • nameOfImage-1280.jpg (image from 961px breakpoint)
  • [email protected] (image from 961px breakpoint but for retina displays, so with doubled resolution)

Known issues

  • Image is not loaded if script can't find image
    • yes, if you forgot add for example nameOfimage-960.jpg on your FTP or somewhere, script doesn't try to find closest higher available image. It is because this could be potential overkill for many calls to server, trying to find available variant of image. If you need to have for example four global breakpoints on images but you want just two on one of the images, use data attributes to define breakpoints for this image.

If you find a bug, please, create a issue.

Contributing

Fork

  1. Fork this project.

  2. Clone your fork to your local machine

    git clone https://github.com/your-username/img-switcher.git

  3. Create a branch with short name described bug/feature

    git checkout -b branch-name

  4. Make your changes.

    • please, make a manual testing
    • update documentation (README.md, CHANGELOG.md)
    • update examples if it's necessary
  5. Commit, push and create a pull request

Development

Simply run npm install

npm i

After that you can change code and in the end, please, run gulp task runner:

gulp

or

./node_modules/.bin/gulp

Rules

Please, install and use TSLint for keeping code style!

Changelog

There are four base categories:

  • Highlights
    • short description
  • Bug Fixes
    • list of bugs (linked to issue if exists and to commit)
  • Features
    • list of features (linked to feature if exists and to commit)
  • Performance Improvements
    • list of features (linked to feature if exists and to commit)

Contact

Email: [email protected]

Web: https://www.striky.sk/

License

MIT