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 🙏

© 2025 – Pkg Stats / Ryan Hefner

vue-html-analog-clock

v1.0.4

Published

Analog Clock Component for VueJS

Downloads

295

Readme

Vue HTML Analog Clock

Pretty simple analog clock, for whatever purpose it might be needed.

Features:

  • Supports v-model and by default updates the time every second (this can be changed from props)
  • Should be themeable with CSS, with theme prop.
  • Can be pretty much any size, though it's forced 1:1 aspect ratio
  • Can be automatically adjusted to container width

Installation and usage

Install from npm:

npm install vue-html-analog-clock

Then you can use it in your vue component like this:

import Clock from "vue-html-analog-clock";

...

components: {
	Clock,
},

Template:

<clock v-model="myDate" />

Configure with props

Use the following props to configure the clock.

Quick reference, more detailed below:

props: {
	theme: {
		type: String,
		default: "default"
	},
	size: {
		type: Number,
		default: defaultSize // == 320px
	},
	autoSize: {
		type: Boolean,
		default: false
	},
	value: {
		type: Date as PropType<Date>,
		default: () => new Date()
	},
	enableTimeFlow: {
		type: Boolean,
		default: true
	},
	intValTime: {
		type: Number,
		default: 100
	},
	transitionSpeed: {
		type: Number,
		default: 80
	}
},

theme

  • type: string
  • default: "default"

This prop adds a class to the component container: .vue-analog-clock-{theme}

This should allow you to alter the styling of the clock in the following manner:

<!-- put the theme name to the 'theme' prop -->
<clock theme="purple" />
// Use eg. Sass, Less to use this syntax
div.vue-analog-clock.vue-analog-clock-purple {
	div.clock-outer-ring {
		background-color: purple;
	}

	div.clock-container {
		background-color: lighten(purple, 70%);
	}

	// if you're not following the hierarchy, you might need to use !important
	div.pointer {
		background-color: darken(purple, 10%) !important;
	}
}

size

  • type: Number
  • default: 320

Clock size in pixels. This is both the width and the height of the clock.

If auto-size is enabled, this prop is ignored.

auto-size

  • type: Boolean,
  • default: false

if true, clock will automatically adjust it's size to the container element. This size is checked everytime the clock "updates", so it should keep up even if the container width changes, though it will not be smooth if transitions are used.

value

  • type: Date
  • default: new Date()

The clock will show this object's time. Part of the v-model functionality. Obviously, the component only cares about the time part of the object.

enable-time-flow

  • type: Boolean
  • default: true

If true, the time will update on it's own (just like a clock). If used with v-model, that value will be changed every second.

You can also use this to enable a play/pause functionality, where changing this to false will pause the clock, and then changing it back to true will continue the clock where it left off.

int-val-time

  • type: Number,
  • default: 100

Update interval time. Defaults to 100. Basically this is how often the clock "updates" itself.

transition-speed

  • type: Number
  • default: 80

Transition speed, used for the pointers. Higher values are only recommended if enable-time-flow is false.

Events

Well there's not much really, only the update event used for the v-model. This event fires every update cycle (check int-val-time).

Caveats

Time might not be 100% accurate

Because the component allows any time to be set on the clock and then updated automatically, the component tries to calculate seconds. This may or may not lead to the clock not being 100% in sync. Since javascript intervals are definitely not fired accurately (it is approximate), the clock tries to calculate the time offset between intervals and this way keep the seconds going accurately.

If you just want to show the current time (user's time) and be sure it's correct 100%, you can make this basic interval yourself:

<clock theme="purple" 
	:value="myDate" 
	:enable-time-flow="false" 
/>
data() { return {
	myDate: new Date()
}},

beforeMount() {
	window.setInterval(() => {
		this.myDate = new Date();
	}, 100);
}

Transition not working when going from 59->0

This constraint is due to the rotation of the pointer. After full 360 it changes back to 0, and if transition is enabled when this occurs, the pointer will go counter-clockwise to the 0deg rotation. Current workaround is to disable the transition when it's going to happen.