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

clocklet

v0.3.0

Published

An opinionated clock-style vanilla-js timepicker

Downloads

265

Readme

Clocklet

npm jsDelivr

An opinionated clock-style vanilla-js timepicker.
Demo
clocklet capture image

Features

  • Keyboard and numpad friendly
    • Autocomplete - e.g. "1"->"01:00", "12"->"12:00", "1234"->"12:34"
    • Support up/down arrow key to increment/decrement
  • Mouse and touch friendly
    • 3 clicks are sufficient to pick a time - am/pm, hour, minute
    • Click targets often used are large enough
    • No need to scroll
  • Declarative usage
  • Vanilla JS - no need jQuery or any other frameworks
  • Lightweight (CSS + JS ~ 7kB gzipped)

Installation

via npm (with a module bundler)

$ npm install clocklet
import "clocklet/css/clocklet.min.css";
import clocklet from "clocklet";

via CDN

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/[email protected]/css/clocklet.min.css">
<script src="https://cdn.jsdelivr.net/npm/[email protected]"></script>
<script>/* `window.clocklet` object is available */</script>

Download directly

clocklet.min.css
clocklet.min.js

Usage

Place <input> elements having data-clocklet attribute (either before or after loading the clocklet script).
When these elements get focused, the timepicker popups.

<input data-clocklet>

CodePen

Options

Default options

Default options can be set as properties of clocklet.defaultOptions object.
Option names must be described in camelCase.

clocklet.defaultOptions.zIndex = 9999;
clocklet.defaultOptions.format = "hh:mm a";

Element-specific options

Element-specific options can be specified as semicolon-separated data-clocklet attribute value.
Option names must be described in kebab-case.

<input data-clocklet="class-name: my-clocklet-style; placement: top;">

Available options

| Name | Type | Default | Description | | ---------- | ------------------------------ | -------- | ----------------------------------------------------------------------------------------------- | | class-name | string | "" | Class name to set to the root element of the popup. | | format | string | "HH:mm" | Time format (template) of the input element.Some tokens are replaced with the selected time value.See the format tokens section below. | | placement | "top" | "bottom" | "bottom" | Popup placement. | | alignment | "left" | "center" | "right" | "left" | Popup alignment. | | append-to | "body" | "parent" | "body" | The parent element into which the popup element will be inserted. | | z-index | number | string | "" | Popup z-order.If this value is an empty string, (1 + z-index of the input element) is used. |

Format tokens

| Token | Range | Description | | ----- | ---------------- | ---------------------------------------------------------------- | | H | "0" .. "23" | Hour in 0-based 24-hour notation with no padding. | | HH | "00" .. "23" | Hour in 0-based 24-hour notation with zero padding. | | _H | " 0" .. "23" | Hour in 0-based 24-hour notation with space padding. | | h | "1" .. "12" | Hour in 1-based 12-hour notation with no padding. | | hh | "01" .. "12" | Hour in 1-based 12-hour notation with zero padding. | | _h | " 1" .. "12" | Hour in 1-based 12-hour notation with space padding. | | k | "1" .. "24" | Hour in 1-based 24-hour notation with no padding. | | kk | "01" .. "24" | Hour in 1-based 24-hour notation with zero padding. | | _k | " 1" .. "24" | Hour in 1-based 24-hour notation with space padding. | | m | "0" .. "59" | Minute with no padding. | | mm | "00" .. "59" | Minute with zero padding. | | _m | " 0" .. "59" | Minute with space padding. | | a | "am" | "pm" | Post or ante meridiem abbreviation in lowercase without periods. | | aa | "a.m." | "p.m." | Post or ante meridiem abbreviation in lowercase with periods. | | A | "AM" | "PM" | Post or ante meridiem abbreviation in uppercase without periods. | | AA | "A.M." | "P.M." | Post or ante meridiem abbreviation in uppercase with periods. |

Events

Following events are raised on the input element by this library.

| Type | Cancelable | event.details | Description | | ---------------- | ---------- | ------------------ | ----------------------------------------- | | clocklet.opening | true | { options: {...} } | Raised before showing the clocklet popup. | | clocklet.opened | false | { options: {...} } | Raised after showing the clocklet popup. | | clocklet.closing | true | {} | Raised before hiding the clocklet popup. | | clocklet.closed | false | {} | Raised after hiding the clocklet popup. | | input | false | undefined | Raised after changing the input value. |

For example:

<input id="my-clocklet" data-clocklet>
<script>
  document
    .getElementById("my-clocklet")
    .addEventListener("clocklet.opening", function (event) {
      console.log(event.details.options);
      if (DO_NOT_NEED_TIMEPICKER) {
        event.preventDefault();
      }
    });
</script>

API

clocklet.defaultOptions

See default options section.

clocklet.open(inputElement[, options])

Show the timepicker for the specified inputElement with the options (optional).

clocklet.close()

Hide the timepicker.

clocklet.inline(containerElement[, { input, format }])

Place the timepicker into the containerElement.
The optional parameter is the binding setting for the input element.

License

WTFPL