fix(version): Tab-Titel + Impressum dynamisch aus version.js
Vorher waren "Calendarr v18" in index.html hardcoded und wurden bei Releases nie mit gebumpt — v19/v20 wurden zwar in version.js gepflegt, landeten aber nie im Tab-Titel. Jetzt liest calendar.js APP_VERSION direkt aus version.js und setzt sowohl document.title als auch das Impressum-Footer-Label, damit das nicht mehr auseinanderlaufen kann. v21 / sw cache v21
This commit is contained in:
@@ -3,8 +3,8 @@
|
|||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8" />
|
<meta charset="UTF-8" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no, viewport-fit=cover" />
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no, viewport-fit=cover" />
|
||||||
<!-- APP_VERSION: update here + version.js on every release -->
|
<!-- Title wird beim Laden aus version.js dynamisch gesetzt -->
|
||||||
<title>Calendarr v18</title>
|
<title>Calendarr</title>
|
||||||
<link rel="icon" type="image/svg+xml" href="/static/favicon.svg" />
|
<link rel="icon" type="image/svg+xml" href="/static/favicon.svg" />
|
||||||
<link rel="manifest" href="/manifest.json" />
|
<link rel="manifest" href="/manifest.json" />
|
||||||
<meta name="theme-color" content="#4285f4" />
|
<meta name="theme-color" content="#4285f4" />
|
||||||
@@ -895,7 +895,7 @@
|
|||||||
<a href="mailto:scarriffleservices@gmail.com">scarriffleservices@gmail.com</a></p>
|
<a href="mailto:scarriffleservices@gmail.com">scarriffleservices@gmail.com</a></p>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-footer" style="justify-content:space-between;align-items:center">
|
<div class="modal-footer" style="justify-content:space-between;align-items:center">
|
||||||
<span style="font-size:12px;color:var(--text-3)">Calendarr v18</span>
|
<span id="impressum-version" style="font-size:12px;color:var(--text-3)">Calendarr</span>
|
||||||
<button class="btn btn-ghost" onclick="closeImpressum()">Schliessen</button>
|
<button class="btn btn-ghost" onclick="closeImpressum()">Schliessen</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -7,6 +7,14 @@ import { renderQuarter } from './views/quarter.js';
|
|||||||
import { openColorPicker } from './color-picker.js';
|
import { openColorPicker } from './color-picker.js';
|
||||||
import { openDatePicker, formatDtDisplay } from './date-picker.js';
|
import { openDatePicker, formatDtDisplay } from './date-picker.js';
|
||||||
import { t, setLang, getLang } from './i18n.js';
|
import { t, setLang, getLang } from './i18n.js';
|
||||||
|
import { APP_VERSION } from './version.js';
|
||||||
|
|
||||||
|
// Version sofort beim Modul-Load ueberall sichtbar setzen.
|
||||||
|
document.title = `Calendarr ${APP_VERSION}`;
|
||||||
|
document.addEventListener('DOMContentLoaded', () => {
|
||||||
|
const imp = document.getElementById('impressum-version');
|
||||||
|
if (imp) imp.textContent = `Calendarr ${APP_VERSION}`;
|
||||||
|
});
|
||||||
|
|
||||||
// Fetch avatar image as blob URL (with auth header)
|
// Fetch avatar image as blob URL (with auth header)
|
||||||
function fetchAvatarBlob() {
|
function fetchAvatarBlob() {
|
||||||
@@ -439,7 +447,7 @@ function updateTitle() {
|
|||||||
titleEl.innerHTML =
|
titleEl.innerHTML =
|
||||||
`<span class="view-title-main">${main}</span>` +
|
`<span class="view-title-main">${main}</span>` +
|
||||||
(year ? `<span class="view-title-year">${year}</span>` : '');
|
(year ? `<span class="view-title-year">${year}</span>` : '');
|
||||||
document.title = `Calendarr - ${fullText}`;
|
document.title = `Calendarr ${APP_VERSION} - ${fullText}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateViewButtons() {
|
function updateViewButtons() {
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
// Increment APP_VERSION with every code change
|
// Increment APP_VERSION with every code change
|
||||||
export const APP_VERSION = 'v20';
|
export const APP_VERSION = 'v21';
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
// the entry HTML / version files). New releases take effect on the next
|
// the entry HTML / version files). New releases take effect on the next
|
||||||
// reload, no manual SW unregister required.
|
// reload, no manual SW unregister required.
|
||||||
|
|
||||||
const CACHE_VERSION = 'calendarr-v20';
|
const CACHE_VERSION = 'calendarr-v21';
|
||||||
const OFFLINE_SHELL = ['/', '/index.html'];
|
const OFFLINE_SHELL = ['/', '/index.html'];
|
||||||
|
|
||||||
self.addEventListener('install', event => {
|
self.addEventListener('install', event => {
|
||||||
|
|||||||
Reference in New Issue
Block a user