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

sm-slider

v2.2.0

Published

A minimalistic, configurable, responsive slider library.

Downloads

161

Readme

smSlider

smSlider is a library for creating responsive and slick sliders that serve whatever content you want them to. The general philosophy is to provide a flexible library in which the user can handle the styling mostly by itself. This makes it easy, to customize the slider without having to override a lot of library styles. Basically the only styling provided is done for the sake of animation and responsiveness.

Table of Contents

Installation

Run npm install -S sm-slider to install the package from npm. Alternatively, you can download the latest release from this repository.

To include the library, refer to the module definition you are using.

UMD

Include the sm-slider.js and sm-slider.css from the lib directory in your project. This makes smSlider available in the global scope.

AMD

Adjust your require.config.js to include the following code:

packages: [{
    name: 'smSlider',
    location: 'node_modules/sm-slider/lib',
    main: 'sm-slider'
}]

Now you can use the slider in your project like this:

define('myModule', ['smSlider'], function(smSlider) {
    // Access smSlider object here
});

CommonJS

Require the slider via const smSlider = require('sm-slider'); and use the smSlider variable to access its methods.

ESM

Import the slider via import smSlider from 'sm-slider'; and access it via the smSlider variable.

Usage

To use the slider, you first want to create some basic HTML markup and then initialize the slider via the JavaScript API.

Markup

<div class="sm-slider" data-sm-slider="{}">
    <div class="slides-wrapper">
        <div class="slides">
            <div class="slide">
                Slide 1
            </div>
            <div class="slide">
                Slide 2
            </div>
            <div class="slide">
                Slide 3
            </div>
        </div>
    </div>
</div>

In this example, you can pass options via the data-sm-slider attribute. For a list of possible options, refer to Options.

Slider arrows

As you might want to add arrows to the slider for the user to navigate, you can include them by altering the above markup as follows:

<div class="sm-slider" data-sm-slider="{}">
    <div class="arrow-left"></div>
    <div class="slides-wrapper">
        <div class="slides">
            <div class="slide">
                Slide 1
            </div>
            <div class="slide">
                Slide 2
            </div>
            <div class="slide">
                Slide 3
            </div>
        </div>
    </div>
    <div class="arrow-right"></div>
</div>

The arrow-elements will provide a clickable container that can be used to move to the next/previous slides. By default, the arrows are next to the slides. If you want the arrows to be on the actual slide, you can add the inset class to the arrow.

<div class="arrow-left inset"></div>

Navigation dots

The slider supports a navigation that displays which slide you are currently on. To enable it, simply insert an element with the dot-nav class into your DOM.

<div class="sm-slider" data-sm-slider="{}">
    <div class="arrow-left"></div>
    <div class="slides-wrapper">
        <div class="slides">
            <div class="slide">
                Slide 1
            </div>
            <div class="slide">
                Slide 2
            </div>
            <div class="slide">
                Slide 3
            </div>
        </div>
    </div>
    <div class="arrow-right"></div>
    <div class="dot-nav"></div>
</div>

Text Navigation

The slider supports a text navigation that displays which slide you are currently on with a custom text. To enable it, simply insert an element with the text-nav-wrapper class into your DOM. As children of this element you should insert elements with the text-nav class and a data-sm-slider-ref Attribute. To create a reference to the slide you should insert a data-sm-slider-hash Attribute with the same value as the data-sm-slider-ref Attribute to the slides you want to reference on.

<div class="sm-slider" data-sm-slider='{}'>
    <div class="arrow-left"><</div>
    <div class="slides-wrapper">
        <div class="slides">
            <div class="slide" data-sm-slider-hash="zero"></div>
            <div class="slide" data-sm-slider-hash="one">
                <div>
                    <img src="//placehold.it/1180x500">
                </div>
            </div>
            <div class="slide" data-sm-slider-hash="two">
                <img src="//placehold.it/1180x400">
            </div>
        </div>
    </div>
    <div class="arrow-right"><</div>
    <!--<div class="dot-nav"></div>-->
    <div class="text-nav-wrapper">
        <a class="text-nav" data-sm-slider-ref="zero">Slide 0</a>
        <a class="text-nav" data-sm-slider-ref="one">Slide 1</a>
        <a class="text-nav" data-sm-slider-ref="two">Slide 2</a>
    </div>
</div>

Global initialization

You can initialize all sliders on a page, by using

smSlider.init();

This method will initialize all target all element that have a the data-sm-slider attribute and try to initialize them as a slider.

Single initialization

If you want to target a specific slider, you can use the class constructor to initialize it. This is the preferred approach if you want more control over the slider and call functions on it (e.g. to switch slides from your script).

var $sliderRef = document.querySelector('.sm-slider');
var slider = new smSlider($sliderRef, options);

Note: the DOM element you target is not required to have the data-sm-slider attribute, since options are passed in via the constructor.

Options

The options object that you either pass in via the data-sm-slider attribute or the contructor can consist of the following options:

| Option | Description | Type | Default Value | Responsive | | ------------- | ------------------------------------------------------------- | -------- | -------------:| ----------:| | visibleSlides | Number of simultaneosly visible slides | number | 1 | yes | | step | Number of slides, the slider progresses with one slide action | number | 1 | yes | | infinite | True, if the slides should repeat upon reaching the end | boolean | false | | | autoplay | Time in milliseconds for the slides to switch automatically | number | 0 | | | breakpoints | See Responsiveness | Object | undefined | | | offsetLet | Value between 0 and 1 that controls, how much of the last slide is visible on the left. | number | 0 | yes | | showEmptySlides | False, if empty slides should be hidden | boolean | true | disabledSwipe | True, if touch swiping should be disabled | boolean | false | activeClass | Adds an active class to the first displayed element in the viewport | boolean | false

Responsiveness

smSlilder is built to fit different device sizes using the breakpoints option. The breakspoints option consists of a key/value pair that can override all default options that have a yes in the field for responsiveness in the options table above.

Example

var options = {
    "visibleSlides": 1,
    "breakpoints": {
        "768": {
            "visibleSlides": 2
        }
    }
};

The above configuration will make the slider display 1 slide by default and 2 slides when exceeding the 768px device-width breakpoint (i.e. tablet devices).

Vertical slides

smSlilder also supports vertical alignment of slides, instead of the usual horizonal one. In order to transform the slider into a vertical one, the element with the sm-slider class needs to be assigned the sm-slider--vertical class as well.

Please note that for best results, the following cases should apply:

  • The parent of sm-slider has either display flex, inline or inline-block
  • The content of the slide class has a fixed height
    • The dynamic height calculation is going to be addressed in the upcoming releases!

Events

smSlilder uses custom events to both notify the listener of specific actions, as well as listening to specific events itself. The following list shows the events that are implemented at the moment.

Attachable means, that a listener can be attached to handle the event, whereas Dispatchable means that the event can be triggered on the slider. Value describes the contents of event.detail either to process in the handler or when the event is dispatched.

| Event | Description | Attachable | Dispatchable | Value | | --------- | ---------------------------------------| ----------:| ------------:| ------------------------------------------------- | | next | Switches to the next slide | no | yes | undefined | | previous | Switches to the previous slide | no | yes | undefined | | slide | Switches to a specific slide | yes | yes | to: number (index of slide that is switched to) |

Attaching a listener

Eventlisteners can be attached in two ways: either using the reference to the class instance of the slider or attaching it to the root DOM element that contains the data-sm-slider.

Class instance reference

var slider = new smSlider($element, options);
slider.addEventListener(event, handler, options);

DOM element reference

var $sliderElement = document.querySelector('.sm-slider');
$sliderElement.addEventListener(event, handler, options);

Dispatching an event

Using the same references as described above, it is possible to dispatch events that the slider listens to.

var slider = new smSlider($element, options);
slider.dispatchEvent(new CustomEvent('slide', {
    detail: {
        to: 2 // index to slide to
    }
}));

Todo

  • [x] Configure number of visible slides
  • [x] Configure step size when sliding
  • [x] Configure infinite sliding
  • [x] Configure responsive breakpoints
  • [x] Handle resizes and orientation changes
  • [x] Touch support
  • [x] Custom events
  • [x] Autoplay
  • [x] Implement vertical slides support
  • [ ] Fix automatic height calculation on vertical slides
  • [ ] Lazy loading of images
  • [ ] Configure animation speed
  • [ ] Provide different timing functions

Contributing

To contribute to this project, fork the repository and create your feature/hotfix branch with whatever you want to add.

Install the project dependencies using npm i and start the development server via npm start. A webpack-dev-server will now listen on port 8080.

When you are finished developing, make sure to add a documented pull request.

Please note: Pull requests for new features that are not typed via flowtype as well as not following the general code style used in this project will be rejected.

License

MIT