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

@astrocaleb/content-slider

v1.0.0

Published

Visually navigate between layered content without leaving the page.

Downloads

57

Readme

content-slider

Size Dependencies

Visually navigate between layered content without leaving the page.

Getting started

dist/
├── content-slider.js
├── content-slider.min.js
├── content-slider.css
└── content-slider.min.css

Installation

# npm
npm i @astrocaleb/content-slider

In browser:

<!-- not required unless `options.injectCSS` is set to `false` -->
<link href="/path/to/content-slider.css" rel="stylesheet">

<!-- not required if importing the `ContentSlider` module -->
<script src="/path/to/content-slider.js"></script>

Usage

HTML

This is the minimum markup required for using the default configuration.

<div data-content-slider> <!-- Wrapper for this content slider instance -->
    <div data-cs-panes>   <!-- Content panes wrapper -->
        <div data-cs-pane data-breadcrumb-text="Pane 1">...</div>
        <div data-cs-pane data-breadcrumb-text="Pane 2">...</div>
    </div>
</div>

The following data attributes are required for each content slider instance:

  • data-content-slider (only one per instance)
  • data-cs-panes (only one per instance)
  • data-cs-pane (as many as you need)
  • Only if defining breadcrumb markup manually (see examples):
    • data-cs-breadcrumbs (only one per instance)
    • data-slider-breadcrumb (as many as you need)

JS

const slider = new ContentSlider(selector, options);
  • selector (optional, but highly recommended)

    • Type: String
    • Default: '[data-content-slider]'
    • This is the wrapper selector for this specific instance.
    • It's highly recommended this is defined because it's required if you were to have more than one ContentSlider instance on the same page or if you are defining options.
  • options (optional)

    • Type: Object
    • The options to control the individual content slider instance. Check out the available options.

CSS

By default, every instance of ContentSlider attempts to inject styles directly into the head of the document if they don't exist already. Because of this you just need to use options.css for updating styles. Custom CSS options are applied to all ContentSlider instances because the existing styles defined in the head are overwritten with the custom CSS options.

Note: As of this version, if you want more control over styling and want to define the CSS file yourself, an option of injectCSS will need to be set to false for every new ContentSlider instance.

CSS variables are used (take note for browser support), and they are defined using the html selector. You can override them by targeting :root and define custom variable values. Example:

:root {
    --cs-link: #da0000;
    --cs-link-hover: #ff0f0f;
    --cs-background: transparent;
}

Here are the default CSS variables used:

html {
    --cs-background: #FFF;
    --cs-separator: "\276F";
    --cs-link-hue: 204;
    --cs-link-saturation: 82%;
    --cs-link-lightness: 36%;
    --cs-link: hsl(var(--cs-link-hue), var(--cs-link-saturation), var(--cs-link-lightness));
    --cs-link-hover: hsl(var(--cs-link-hue), var(--cs-link-saturation), calc(var(--cs-link-lightness) + 10%));
    --cs-transition-speed: 0.35s;
}

Examples (interactive examples)

Automatic Breadcrumb Creation

If you don't want to worry yourself with defining the breadcrumb markup and would like it to be dynamically generated, this is the best configuration for you.

Note: A unique id is automatically generated for each pane (each data-cs-pane element) unless defined in the markup manually. The ids are used by the breadcrumbs by default.

HTML

<div data-content-slider class="my-content-slider">
    <div data-cs-panes>
        <div data-cs-pane data-breadcrumb-text="Pane 1">...</div>
        <div data-cs-pane data-breadcrumb-text="Pane 2">...</div>
    </div>
</div>

JS

import ContentSlider from '@astrocaleb/content-slider';

// All default options
const slider = new ContentSlider('.my-content-slider');

// OR

// Use options to change how the content slider instance operates
const slider = new ContentSlider('.my-content-slider', {
    progressiveBreadcrumbs: true,
    callback: function() {
        alert("Pane is now visible!");
    }
});

You can also manually trigger showing a content pane using the id for a given pane. This requires manually defining an id per pane (each data-cs-pane element). Example:

HTML

<div data-content-slider class="my-content-slider">
    <div data-cs-panes>
        <div data-cs-pane id="pane-1" data-breadcrumb-text="Pane 1">...</div>
        <div data-cs-pane id="pane-2" data-breadcrumb-text="Pane 2">...</div>
    </div>
</div>

JS

const slider = new ContentSlider('.my-content-slider');
slider.showContentSliderPane('#pane-2');

The showContentSliderPane method accepts a pane id (required) but also optionally accepts a callback function, which overrides the default callback option from the constructor.

const slider = new ContentSlider('.my-content-slider');
slider.showContentSliderPane('#pane-2', function() {
    alert("This pane was triggered manually!");
});

Manual Breadcrumb Creation

If you need more control over the breadcrumbs markup, this is the where you want to start. The data-cs-breadcrumbs (breadcrumb wrapper) and data-slider-breadcrumb (each breadcrumb element) data attributes are required regardless of custom markup.

HTML

<div data-content-slider class="my-content-slider">
    <div data-cs-breadcrumbs>
        <span data-cs-breadcrumb>Pane 1</span>
        <span data-cs-breadcrumb>Pane 2</span>
        <span data-cs-breadcrumb>Pane 3</span>
    </div>
    <div data-cs-panes>
        <div data-cs-pane>...</div>
        <div data-cs-pane>...</div>
        <div data-cs-pane>...</div>
    </div>
</div>

JS

const slider = new ContentSlider('.my-content-slider', {
    automaticBreadcrumbs: false
});

Options

callback

  • Type: Function
  • Default: no-op

Callback that fires immediately after a pane comes into view.

motion

  • Type: Boolean
  • Default: true

Disable this option to change the sliding animation to be a fade instead. This is helpful for accessibility concerns.

injectCSS

  • Type: Boolean
  • Default: true

If this option is changed, it needs to be changed for all instances of ContentSlider. Even one instance using the default setting will inject the CSS into the head of the document.

If this is disabled, options.css is no longer respected and you will need to leverage the CSS variables yourself. See the section above with the available CSS variables.

startingIndex

  • Type: Number
  • Default: 0

Change which pane is visible at time of render. This is a regular zero-based index.

breadcrumbsEnabled

  • Type: Boolean
  • Default: true

This option is respected only when automaticBreadcrumbs is true.

automaticBreadcrumbs

  • Type: Boolean
  • Default: true

When this is disabled the breadcrumbs are not rendered automatically. breadcrumbsEnabled is ignored if this is disabled.

progressiveBreadcrumbs

  • Type: Boolean
  • Default: false

By default all breadcrumbs will render automatically. If this is true then breadcrumbs only automatically render after the first pane. Currently the only breadcrumbs that will render for each pane after the first will be:

  • First pane breadcrumb (actionable back to first pane)
  • Current pane breadcrumb (static text)

This option is respected only when automaticBreadcrumbs is true.

css

  • Type: Object
  • Default: {} (inherits/merges with values from cssDefaults)

These are the values defined in cssDefaults:

linkHue: '204',
linkSaturation: '82%',
linkLightness: '36%',
link: 'hsl(var(--cs-link-hue), var(--cs-link-saturation), var(--cs-link-lightness))',
linkHover: 'hsl(var(--cs-link-hue), var(--cs-link-saturation), calc(var(--cs-link-lightness) + 10%))',
background: '#FFF',
separator: '\\276F', // Note the escaped backslash
transitionSpeed: 0.35 // seconds

Note: transitionSpeed is a number because of how it's used in the CSS string that's injected into the head of the document.

Example of the placeholder in the CSS template literal:

// ...
transition: ${this.css.transitionSpeed}s all ease;
// ...

link and linkHover are just colors and can be in any format.

Example of their placeholders in the CSS template literal:

html {
// ...
--cs-link: ${this.css.link};
--cs-link-hover: ${this.css.linkHover};
// ...
}

And those CSS variables are used like this:

// ...
[data-cs-breadcrumbs] [data-cs-breadcrumb] { color: var(--cs-link); }
[data-cs-breadcrumbs] [data-cs-breadcrumb]:hover { color: var(--cs-link-hover); }
// ...

License

MIT