index.html 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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. <script type="module" crossorigin src="/assets/index-BQYDsJHk.js"></script>
  26. <link rel="stylesheet" crossorigin href="/assets/index-B7mnhxng.css">
  27. </head>
  28. <body>
  29. <div id="root"></div>
  30. <!-- Service Worker Registration (skip on SpoolBuddy kiosk) -->
  31. <script>
  32. if ('serviceWorker' in navigator) {
  33. if (location.pathname.startsWith('/spoolbuddy')) {
  34. // Kiosk mode — nuke SW and all caches, then reload once to get clean state
  35. navigator.serviceWorker.getRegistrations().then((regs) => {
  36. if (regs.length > 0) {
  37. Promise.all([
  38. ...regs.map((r) => r.unregister()),
  39. caches.keys().then((names) => Promise.all(names.map((n) => caches.delete(n)))),
  40. ]).then(() => location.reload());
  41. }
  42. });
  43. } else {
  44. window.addEventListener('load', () => {
  45. navigator.serviceWorker.register('/sw.js')
  46. .then((registration) => {
  47. console.log('SW registered:', registration.scope);
  48. })
  49. .catch((error) => {
  50. console.log('SW registration failed:', error);
  51. });
  52. });
  53. }
  54. }
  55. </script>
  56. </body>
  57. </html>