index.html 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
  6. <!-- L-4: Restrict Referer header to origin-only on cross-origin navigation so
  7. sensitive tokens in query parameters are not leaked to third-party servers. -->
  8. <meta name="referrer" content="strict-origin-when-cross-origin" />
  9. <title>Bambuddy</title>
  10. <!-- PWA Meta Tags -->
  11. <meta name="description" content="Monitor and manage your Bambu Lab 3D printers" />
  12. <meta name="theme-color" content="#00ae42" />
  13. <meta name="mobile-web-app-capable" content="yes" />
  14. <meta name="apple-mobile-web-app-capable" content="yes" />
  15. <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent" />
  16. <meta name="apple-mobile-web-app-title" content="Bambuddy" />
  17. <!-- Manifest -->
  18. <link rel="manifest" href="/manifest.json" />
  19. <!-- Favicons -->
  20. <link rel="icon" type="image/png" sizes="32x32" href="/img/favicon-32x32.png" />
  21. <link rel="icon" type="image/png" sizes="16x16" href="/img/favicon-16x16.png" />
  22. <link rel="apple-touch-icon" sizes="180x180" href="/img/apple-touch-icon.png" />
  23. <!-- Splash screens for iOS -->
  24. <link rel="apple-touch-startup-image" href="/img/android-chrome-512x512.png" />
  25. </head>
  26. <body>
  27. <div id="root"></div>
  28. <script type="module" src="/src/main.tsx"></script>
  29. <!-- Service Worker Registration (skip on SpoolBuddy kiosk) -->
  30. <script>
  31. if ('serviceWorker' in navigator) {
  32. if (location.pathname.startsWith('/spoolbuddy')) {
  33. // Kiosk mode — nuke SW and all caches, then reload once to get clean state
  34. navigator.serviceWorker.getRegistrations().then((regs) => {
  35. if (regs.length > 0) {
  36. Promise.all([
  37. ...regs.map((r) => r.unregister()),
  38. caches.keys().then((names) => Promise.all(names.map((n) => caches.delete(n)))),
  39. ]).then(() => location.reload());
  40. }
  41. });
  42. } else {
  43. window.addEventListener('load', () => {
  44. navigator.serviceWorker.register('/sw.js')
  45. .then((registration) => {
  46. console.log('SW registered:', registration.scope);
  47. })
  48. .catch((error) => {
  49. console.log('SW registration failed:', error);
  50. });
  51. });
  52. }
  53. }
  54. </script>
  55. </body>
  56. </html>