## manifest.json - Add `id` and `scope` fields for proper PWA identification - Split icon purposes into separate entries (was "any maskable", now separate) - Add `prefer_related_applications: false` ## index.html - Add `viewport-fit=cover` for notched devices - Add `mobile-web-app-capable` meta tag - Add `application-name` and `msapplication` meta tags - Add both 192px and 512px apple-touch-icon sizes ## styles.css - Add safe-area-inset padding for notched devices (iPhone X+) - Use 100dvh for proper mobile viewport height - Add bottom safe area to toast container and macro grid ## service-worker.js - Bump cache version to v2 to force update 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
58 lines
2.0 KiB
HTML
58 lines
2.0 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no, viewport-fit=cover">
|
|
<meta name="theme-color" content="#007acc">
|
|
<meta name="description" content="Remote macro control for your desktop">
|
|
|
|
<!-- PWA / iOS specific -->
|
|
<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">
|
|
<meta name="apple-mobile-web-app-title" content="MacroPad">
|
|
<meta name="application-name" content="MacroPad">
|
|
<meta name="msapplication-TileColor" content="#007acc">
|
|
<meta name="msapplication-tap-highlight" content="no">
|
|
|
|
<title>MacroPad</title>
|
|
|
|
<link rel="manifest" href="/manifest.json">
|
|
<link rel="icon" type="image/png" sizes="192x192" href="/static/icons/icon-192.png">
|
|
<link rel="icon" type="image/png" sizes="512x512" href="/static/icons/icon-512.png">
|
|
<link rel="apple-touch-icon" href="/static/icons/icon-192.png">
|
|
<link rel="apple-touch-icon" sizes="512x512" href="/static/icons/icon-512.png">
|
|
<link rel="stylesheet" href="/static/css/styles.css">
|
|
</head>
|
|
<body>
|
|
<!-- Header -->
|
|
<header class="header">
|
|
<h1>MacroPad</h1>
|
|
<div class="header-actions">
|
|
<div class="connection-status">
|
|
<div class="status-dot"></div>
|
|
<span>Disconnected</span>
|
|
</div>
|
|
<button class="header-btn secondary" onclick="app.refresh()">Refresh</button>
|
|
</div>
|
|
</header>
|
|
|
|
<!-- Tabs -->
|
|
<nav class="tabs" id="tabs-container">
|
|
<!-- Tabs rendered dynamically -->
|
|
</nav>
|
|
|
|
<!-- Macro Grid -->
|
|
<main class="macro-grid" id="macro-grid">
|
|
<div class="loading">
|
|
<div class="spinner"></div>
|
|
</div>
|
|
</main>
|
|
|
|
<!-- Toast Container -->
|
|
<div class="toast-container" id="toast-container"></div>
|
|
|
|
<script src="/static/js/app.js"></script>
|
|
</body>
|
|
</html>
|