From a826a56a35cfce46e3c8166a54669918c0fb4eed Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=A1=B9=E9=B8=BF=E4=BC=9F?= <734824565@qq.com> Date: Wed, 6 Aug 2025 11:48:28 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=B7=BB=E5=8A=A0=E8=AE=A1=E6=97=B6?= =?UTF-8?q?=E5=99=A8=E5=8A=9F=E8=83=BD=E4=BB=A5=E8=B7=9F=E8=B8=AA=E9=98=85?= =?UTF-8?q?=E8=AF=BB=E6=97=B6=E9=97=B4=E5=B9=B6=E6=8F=90=E4=BE=9B=E6=98=BE?= =?UTF-8?q?=E7=A4=BA=E9=80=89=E9=A1=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/web/src/pages/common/timer.ts | 19 +++++++++++++++++++ .../web/src/pages/vscode/content/index.vue | 3 +++ .../web/src/pages/vscode/layout/index.vue | 16 +++++++++++++++- .../web/src/pages/vscode/settings/index.vue | 8 ++++++++ packages/web/src/stores/setting.pc.ts | 8 +++++++- 5 files changed, 52 insertions(+), 2 deletions(-) create mode 100644 packages/web/src/pages/common/timer.ts diff --git a/packages/web/src/pages/common/timer.ts b/packages/web/src/pages/common/timer.ts new file mode 100644 index 00000000..f9fa4c8f --- /dev/null +++ b/packages/web/src/pages/common/timer.ts @@ -0,0 +1,19 @@ +import { useSettingStore } from '@/stores/setting'; +/** 启动和销毁计时器 hooks */ +export const userTimer = () => { + const settingStore = useSettingStore(); + + const timerId = ref(); + + onMounted(() => { + timerId.value = setInterval(() => { + settingStore.readTime += 1; + }, 1000); + }); + + onBeforeUnmount(() => { + if (timerId.value) { + clearInterval(timerId.value); + } + }); +}; diff --git a/packages/web/src/pages/vscode/content/index.vue b/packages/web/src/pages/vscode/content/index.vue index ee3dcb45..bf90699f 100644 --- a/packages/web/src/pages/vscode/content/index.vue +++ b/packages/web/src/pages/vscode/content/index.vue @@ -53,6 +53,7 @@ import { ContentType } from '@any-reader/rule-utils'; import { useContent, useTheme } from '@/pages/common/content'; import { useReadStore } from '@/stores/read'; +import { userTimer } from '@/pages/common/timer'; const contentRef = ref(); @@ -62,6 +63,8 @@ const { content, contentType, settingStore, lastChapter, nextChapter, onPageUp, useContent(contentRef); useTheme(contentRef); + +userTimer();