it-tools/src/tools/chronometer/chronometer.vue

54 lines
1.1 KiB
Vue
Raw Normal View History

2022-07-24 00:58:18 +02:00
<template>
<div>
<n-card>
<div class="duration">{{ formatMs(counter) }}</div>
2022-07-24 00:58:18 +02:00
</n-card>
<br />
<n-space justify="center">
<n-button v-if="!isRunning" secondary type="primary" @click="resume">Start</n-button>
2022-07-24 00:58:18 +02:00
<n-button v-else secondary type="warning" @click="pause">Stop</n-button>
<n-button secondary @click="counter = 0">Reset</n-button>
</n-space>
</div>
</template>
<script setup lang="ts">
import { useRafFn } from '@vueuse/core';
import { ref } from 'vue';
import { formatMs } from './chronometer.service';
2022-07-24 00:58:18 +02:00
const isRunning = ref(false);
const counter = ref(0);
2022-07-24 00:58:18 +02:00
let previousRafDate = Date.now();
const { pause: pauseRaf, resume: resumeRaf } = useRafFn(
() => {
const deltaMs = Date.now() - previousRafDate;
previousRafDate = Date.now();
counter.value += deltaMs;
},
{ immediate: false },
);
function resume() {
previousRafDate = Date.now();
resumeRaf();
isRunning.value = true;
}
function pause() {
pauseRaf();
isRunning.value = false;
}
2022-07-24 00:58:18 +02:00
</script>
<style lang="less" scoped>
.duration {
text-align: center;
font-size: 40px;
font-family: monospace;
margin: 20px 0;
}
</style>