<!doctype html>
<html lang="zh-CN">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0, viewport-fit=cover" />
    <meta name="color-scheme" content="light dark" />
    <meta name="mobile-web-app-capable" content="yes" />
    <meta name="apple-mobile-web-app-capable" content="yes" />
    <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent" />
    <title>音乐播放器</title>
    <link rel="icon" href="/favicon.ico" />
    <link rel="manifest" href="/webmanifest" />
    <meta name="theme-color" content="#000000" />

    <noscript></noscript>
    <link rel="apple-touch-icon" href="/images/cd.webp" />
    <link rel="prefetch" href="/webmanifest" as="fetch" crossorigin />
    <link rel="prefetch" href="/music.json" as="fetch" crossorigin />
    <script type="module" crossorigin src="/assets/index-BO1lX9U_.js"></script>
    <link rel="modulepreload" crossorigin href="/assets/react-N--QU9DW.js">
    <link rel="stylesheet" crossorigin href="/assets/index-KEv_eoyC.css">
  </head>
  <body>
    <div id="root"></div>
    <script>
      (function () {
        if (!('serviceWorker' in navigator)) {
          console.warn('❌ 当前浏览器不支持 Service Worker');
          return;
        }
        function registerSw() {
          navigator.serviceWorker
            .register('/sw.js', { scope: '/' })
            .then((registration) => {
              console.log('✅ 离线缓存已启用，版本:', registration.scope);

              registration.addEventListener('updatefound', () => {
                const newWorker = registration.installing;
                newWorker.addEventListener('statechange', () => {
                  if (newWorker.state === 'installed' && navigator.serviceWorker.controller) {
                    console.log('🔄 发现新版本，正在更新...');
                    if (confirm('发现新版本，是否立即更新？')) {
                      newWorker.postMessage({ action: 'skipWaiting' });
                      window.location.reload();
                    }
                  }
                });
              });
            })
            .catch((registrationError) => {
              console.warn('❌ 离线缓存启用失败:', registrationError);
            });
        }
        if (document.readyState === 'loading') {
          document.addEventListener('DOMContentLoaded', registerSw, { once: true });
        } else {
          registerSw();
        }
      })();
    </script>
  </body>
</html>
