svg-clock v1.0.0
SVG Clock
This web component allows you to include an animated analog clock in any website, regardless of framework. Just pass it a prepared SVG and it will animate it. You can use one of the provided clocks or prepare your own SVG.
Usage
First, pick a prepared SVG clock or create your own.
Then set the URL in the src attribute, which will load it asynchronously (which is recommended since it allows the SVG file to be cached by the browser):
<svg-clock src="..."></svg-clock>Alternatively, you can inline the SVG:
<svg-clock>
<svg>...</svg>
</svg-clock>Performance
svg-clock uses the visibilitychange event and document.hidden as well as IntersectionObserver (if supported) to pause the clock while it is hidden and restart it once it's visible.
Browser support
This component is built with Stencil and inherits the same browser support (Chrome 60+, Safari 10.1+, Firefox 63+, Edge 16+, and IE11).
But because IE11 and Edge 16 (but not Edge 17+) don't allow CSS transforms on SVG elements we use a fallback using the SVG transform origin attribute which needs to be defined (in the data-transform-origin attribute of each clock hand).
Using this component
Preparing an SVG
There are a couple things you need to do to prepare an SVG clock:
- All hands need to be in the 12 o'clock position (pointing straight up).
- Ensure the hand elements have IDs of
hours(orhours-24),minutesand optionallyseconds.hourswill take 12 hours to rotate 360°,hours-24will take 24 hours.
- Ensure those elements have no
transformproperty since it would interfere with the animation. - Add the correct CSS
transform-origindefinition as inline style (e.g.<g id="minutes" style="transform-origin: 50% 50%">) - For IE11 and Edge 16 support, determine the correct SVG transform origin (for the
transformproperty) and set it as thedata-transform-originattribute.
If you don't know how to find the correct transform-origin (CSS or SVG) we recommend initializing the clock so all hands point straight down (6:30:30 with disabled precision). Then adjust the origin (using browser DevTools) until the hands are in the correct position.
Example to test all hands at once:
<svg-clock disable-precision time="6:30:30" src="..."></svg-clock>Contributing
To start contributing, clone this repo to a new directory:
git clone https://github.com/tricki/svg-clock.git svg-clock
cd svg-clockand run:
npm install
npm startTo build the component for production, run:
npm run buildTo run the tests, run:
npm test6 years ago