From 5e95a1f7af841f10646133ad0cc155a2c5cea9fd Mon Sep 17 00:00:00 2001 From: syuilo Date: Sun, 26 Jun 2022 03:12:58 +0900 Subject: refactor(client): extract interval logic to a composable function MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit あと`onUnmounted`を`onMounted`内で呼んでいたりしたのを修正したりとか --- packages/client/src/scripts/use-interval.ts | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 packages/client/src/scripts/use-interval.ts (limited to 'packages/client/src/scripts/use-interval.ts') diff --git a/packages/client/src/scripts/use-interval.ts b/packages/client/src/scripts/use-interval.ts new file mode 100644 index 0000000000..eb6e44338d --- /dev/null +++ b/packages/client/src/scripts/use-interval.ts @@ -0,0 +1,22 @@ +import { onMounted, onUnmounted } from 'vue'; + +export function useInterval(fn: () => void, interval: number, options: { + immediate: boolean; + afterMounted: boolean; +}): void { + let intervalId: number | null = null; + + if (options.afterMounted) { + onMounted(() => { + if (options.immediate) fn(); + intervalId = window.setInterval(fn, interval); + }); + } else { + if (options.immediate) fn(); + intervalId = window.setInterval(fn, interval); + } + + onUnmounted(() => { + if (intervalId) window.clearInterval(intervalId); + }); +} -- cgit v1.2.3-freya From 9c6a2208107d8046c2f9c7eb302363cc214a8861 Mon Sep 17 00:00:00 2001 From: syuilo Date: Sat, 2 Jul 2022 22:07:04 +0900 Subject: chore(client): tweak ui --- packages/client/src/components/form/range.vue | 3 +- packages/client/src/components/marquee.vue | 4 +- packages/client/src/scripts/use-interval.ts | 2 + packages/client/src/widgets/rss-marquee.vue | 63 ++++++++++++++++----------- 4 files changed, 45 insertions(+), 27 deletions(-) (limited to 'packages/client/src/scripts/use-interval.ts') diff --git a/packages/client/src/components/form/range.vue b/packages/client/src/components/form/range.vue index d46174acc1..387ad26f3d 100644 --- a/packages/client/src/components/form/range.vue +++ b/packages/client/src/components/form/range.vue @@ -6,7 +6,7 @@
-
+
@@ -27,6 +27,7 @@ const props = withDefaults(defineProps<{ max: number; step?: number; textConverter?: (value: number) => string, + showTicks?: boolean; }>(), { step: 1, textConverter: (v) => v.toString(), diff --git a/packages/client/src/components/marquee.vue b/packages/client/src/components/marquee.vue index 2fd76a54f0..4685033517 100644 --- a/packages/client/src/components/marquee.vue +++ b/packages/client/src/components/marquee.vue @@ -1,5 +1,5 @@