mirror of
https://github.com/livebook-dev/livebook.git
synced 2025-10-25 04:46:04 +08:00
41 lines
765 B
JavaScript
41 lines
765 B
JavaScript
import { parseHookProps } from "../lib/attribute";
|
|
|
|
const UPDATE_INTERVAL_MS = 100;
|
|
|
|
/**
|
|
* A hook used to display a counting timer.
|
|
*
|
|
* ## Props
|
|
*
|
|
* * `start` - the timestamp to count from
|
|
*
|
|
*/
|
|
const Timer = {
|
|
mounted() {
|
|
this.props = this.getProps();
|
|
|
|
this.interval = setInterval(() => this.updateDOM(), UPDATE_INTERVAL_MS);
|
|
},
|
|
|
|
updated() {
|
|
this.props = this.getProps();
|
|
this.updateDOM();
|
|
},
|
|
|
|
destroyed() {
|
|
clearInterval(this.interval);
|
|
},
|
|
|
|
getProps() {
|
|
return parseHookProps(this.el, ["start"]);
|
|
},
|
|
|
|
updateDOM() {
|
|
const elapsedMs = Date.now() - new Date(this.props.start);
|
|
const elapsedSeconds = elapsedMs / 1_000;
|
|
|
|
this.el.innerHTML = `${elapsedSeconds.toFixed(1)}s`;
|
|
},
|
|
};
|
|
|
|
export default Timer;
|