feat: PWA-Installation aktiv anbieten, besonders für iPad/iOS.

Zeigt nach dem Login ein Installations-Banner mit Safari-Anleitung oder nativer Install-Schaltfläche und ergänzt iOS-Meta-Tags sowie einen dauerhaften Hinweis in den Einstellungen.

Co-authored-by: Cursor <cursoragent@cursor.com>
This commit is contained in:
2026-05-29 15:04:32 +02:00
parent 5d11dbacea
commit 44652d4699
8 changed files with 400 additions and 0 deletions
+162
View File
@@ -1944,5 +1944,167 @@ body:has(.theme-cupertino) {
margin-bottom: 12px;
}
/* PWA install prompt */
.pwa-install-banner {
position: fixed;
left: 16px;
right: 16px;
bottom: calc(16px + env(safe-area-inset-bottom, 0px));
z-index: 1200;
display: grid;
grid-template-columns: auto 1fr auto;
gap: 14px;
align-items: start;
padding: 16px 44px 16px 16px;
border-radius: 16px;
border: 1px solid rgba(212, 175, 55, 0.25);
background: rgba(11, 12, 16, 0.92);
box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
animation: fadeIn 0.35s ease-out;
max-width: 560px;
margin: 0 auto;
}
.pwa-install-inline {
display: grid;
grid-template-columns: auto 1fr;
gap: 14px;
align-items: start;
padding: 16px;
border-radius: 14px;
border: 1px solid rgba(212, 175, 55, 0.2);
background: rgba(255, 255, 255, 0.03);
margin-bottom: 16px;
}
.pwa-install-icon {
color: #fbbf24;
display: flex;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
border-radius: 12px;
background: rgba(251, 191, 36, 0.1);
flex-shrink: 0;
}
.pwa-install-body {
min-width: 0;
}
.pwa-install-title {
margin: 0 0 6px 0;
font-size: 16px;
font-weight: 600;
color: #f8fafc;
}
.pwa-install-text {
margin: 0;
font-size: 13.5px;
line-height: 1.45;
color: #94a3b8;
}
.pwa-install-steps {
list-style: none;
margin: 12px 0 0 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 8px;
}
.pwa-install-steps li {
display: flex;
align-items: center;
gap: 10px;
font-size: 13.5px;
color: #e2e8f0;
}
.pwa-ios-add-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 16px;
height: 16px;
border-radius: 4px;
border: 1px solid rgba(148, 163, 184, 0.6);
font-size: 12px;
font-weight: 700;
line-height: 1;
}
.pwa-install-hint {
margin: 10px 0 0 0;
font-size: 12px;
color: #64748b;
}
.pwa-install-actions {
display: flex;
flex-direction: column;
gap: 8px;
align-items: stretch;
}
.pwa-install-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
white-space: nowrap;
padding: 10px 14px !important;
font-size: 14px !important;
}
.pwa-install-dismiss-row {
display: flex;
gap: 12px;
justify-content: flex-end;
}
.pwa-install-link {
background: transparent;
border: none;
color: #cbd5e1;
font-size: 12px;
cursor: pointer;
padding: 0;
text-decoration: underline;
}
.pwa-install-link.muted {
color: #64748b;
}
.pwa-install-close {
position: absolute;
top: 10px;
right: 10px;
background: transparent;
border: none;
color: #94a3b8;
cursor: pointer;
padding: 4px;
border-radius: 8px;
}
.pwa-install-banner .pwa-install-actions {
grid-column: 1 / -1;
}
@media (max-width: 640px) {
.pwa-install-banner {
grid-template-columns: auto 1fr;
padding-right: 40px;
}
.pwa-install-actions {
grid-column: 1 / -1;
}
}