fix(VersionUpdateToast): 优化通知样式

fix(useVersionChecker): 优化处理逻辑
This commit is contained in:
PKC278
2026-01-03 20:15:05 +08:00
parent 43d2406ee9
commit 0fcad02f3b
5 changed files with 55 additions and 14 deletions

View File

@@ -294,7 +294,7 @@
// 3. 重载页面
const url = new URL(window.location.href)
url.searchParams.set('_t', Date.now().toString())
window.location.replace(url.toString())
window.location.replace(url.pathname + url.search + url.hash)
}
};
@@ -328,7 +328,16 @@
msg = messages['zh-CN'];
}
timeoutEl.innerHTML = msg.text + ' <a href="javascript:void(0)" onclick="window.clearAndReload()" id="timeout-btn">' + msg.btn + '</a>';
const textNode = document.createTextNode(msg.text + ' ');
const btnLink = document.createElement('a');
btnLink.href = 'javascript:void(0)';
btnLink.id = 'timeout-btn';
btnLink.onclick = window.clearAndReload;
btnLink.textContent = msg.btn;
timeoutEl.innerHTML = '';
timeoutEl.appendChild(textNode);
timeoutEl.appendChild(btnLink);
timeoutEl.style.display = 'block';
}
}, 15000); // 15秒后显示超时提示

View File

@@ -241,7 +241,8 @@ onMounted(async () => {
const url = new URL(window.location.href)
if (url.searchParams.has('_t')) {
url.searchParams.delete('_t')
window.history.replaceState({}, '', url.toString())
const newUrl = url.pathname + url.search + url.hash
window.history.replaceState(null, '', newUrl)
}
// 配置 ApexCharts

View File

@@ -1,9 +1,10 @@
<template>
<div class="version-update-toast">
<span class="message">{{ message }}</span>
<button class="refresh-button" @click="handleRefresh">
<button v-if="refreshText" class="refresh-button" @click="handleRefresh">
{{ refreshText }}
</button>
<div v-else class="spinner"></div>
</div>
</template>
@@ -11,7 +12,7 @@
// 接收 props
interface Props {
message: string
refreshText: string
refreshText?: string
onRefresh?: () => void
}
@@ -30,12 +31,12 @@ const handleRefresh = () => {
.version-update-toast {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
}
.message {
flex: 1;
white-space: nowrap;
}
.refresh-button {
@@ -48,6 +49,7 @@ const handleRefresh = () => {
font-size: 14px;
font-weight: 500;
white-space: nowrap;
flex-shrink: 0;
transition: all 0.2s;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
@@ -60,4 +62,20 @@ const handleRefresh = () => {
.refresh-button:active {
transform: scale(0.98);
}
.spinner {
width: 16px;
height: 16px;
border: 2px solid rgba(255, 255, 255, 0.3);
border-top-color: #fff;
border-radius: 50%;
animation: spin 0.8s linear infinite;
flex-shrink: 0;
}
@keyframes spin {
to {
transform: rotate(360deg);
}
}
</style>

View File

@@ -19,7 +19,7 @@ const needsUpdate = computed(() => {
export const reloadWithTimestamp = (): void => {
const url = new URL(window.location.href)
url.searchParams.set('_t', Date.now().toString())
window.location.replace(url.toString());
window.location.replace(url.pathname + url.search + url.hash)
}
/**
@@ -72,6 +72,7 @@ export function useVersionChecker() {
closeButton: false,
closeOnClick: false,
draggable: false,
toastClassName: 'version-update-toast-container',
})
}
@@ -104,13 +105,13 @@ export function useVersionChecker() {
// 优先尝试通过 Service Worker 检查更新
if ('serviceWorker' in navigator && navigator.serviceWorker.controller) {
console.log('[VersionChecker] Requesting Service Worker update check...')
console.log('[VersionChecker] 正在请求 Service Worker 检查更新...')
const registration = await navigator.serviceWorker.getRegistration()
// 如果已经有等待中的更新,直接处理
if (registration?.waiting) {
console.log('[VersionChecker] New worker waiting, skipping manual check.')
console.log('[VersionChecker] Service Worker 发现新版本,跳过版本号对比')
handleVersionMismatch()
return
}
@@ -119,7 +120,7 @@ export function useVersionChecker() {
messageChannel.port1.onmessage = event => {
if (event.data && event.data.type === 'SW_NO_UPDATE_DETECTED') {
console.log('[VersionChecker] Service Worker reported no update, checking version manually...')
console.log('[VersionChecker] Service Worker 报告无更新, 进行版本号检查...')
handleVersionMismatch()
}
}
@@ -144,19 +145,25 @@ export function useVersionChecker() {
navigator.serviceWorker.addEventListener('message', event => {
// 1. 发现新版本 -> 弹出通知
if (event.data && event.data.type === 'SW_VERSION_DETECTED') {
console.log('[VersionChecker] Detected new version:', event.data.version)
console.log('[VersionChecker] 发现新版本:', event.data.version)
notificationShowTime = Date.now()
toast.info(i18n.global.t('common.newVersionFound'), {
const component = h(VersionUpdateToast, {
message: i18n.global.t('common.newVersionFound'),
})
toast.info(component, {
timeout: false,
hideProgressBar: true,
closeButton: false,
toastClassName: 'version-update-toast-container',
})
}
// 2. 安装完成 -> 刷新页面
else if (event.data && event.data.type === 'SW_RELOAD_PAGE') {
const elapsed = Date.now() - notificationShowTime
const delay = Math.max(0, 1000 - elapsed)
console.log(`[VersionChecker] Update installed, reloading in ${delay}ms...`)
const delay = Math.max(0, 1500 - elapsed)
console.log(`[VersionChecker] 更新已安装, 延迟 ${delay}ms 后刷新...`)
setTimeout(() => {
reloadWithTimestamp()
}, delay)

View File

@@ -11,3 +11,9 @@
@import 'vue-toastification/dist/index.css';
@import 'vue3-perfect-scrollbar/style.css';
@import '@vue-js-cron/vuetify/dist/vuetify.css';
/* 版本更新通知专用样式 */
.version-update-toast-container {
min-width: unset !important;
width: fit-content !important;
}