Compare commits

..

No commits in common. "90463443758c8a084369e3a684c7a00d6c9c099e" and "cf76e37c222d9797c1ac88fd9a121750c279983f" have entirely different histories.

6 changed files with 26 additions and 34 deletions

4
package-lock.json generated
View File

@ -1,12 +1,12 @@
{ {
"name": "twitch-vod-manager", "name": "twitch-vod-manager",
"version": "4.6.102", "version": "4.6.101",
"lockfileVersion": 3, "lockfileVersion": 3,
"requires": true, "requires": true,
"packages": { "packages": {
"": { "": {
"name": "twitch-vod-manager", "name": "twitch-vod-manager",
"version": "4.6.102", "version": "4.6.101",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"axios": "^1.6.0", "axios": "^1.6.0",

View File

@ -1,6 +1,6 @@
{ {
"name": "twitch-vod-manager", "name": "twitch-vod-manager",
"version": "4.6.102", "version": "4.6.101",
"description": "Twitch VOD Manager - Download Twitch VODs easily", "description": "Twitch VOD Manager - Download Twitch VODs easily",
"main": "dist/main.js", "main": "dist/main.js",
"author": "xRangerDE", "author": "xRangerDE",

View File

@ -19,22 +19,6 @@ function escapeHtml(value: string): string {
.replace(/'/g, '''); .replace(/'/g, ''');
} }
/* localStorage helpers every renderer module that persists state was
wrapping its get/set calls in the same try/catch idiom to handle
environments where localStorage isn't writable (private-browsing
quirks, certain sandboxed contexts). Centralising the pattern. */
function safeLocalStorageGet(key: string, fallback = ''): string {
try { return localStorage.getItem(key) ?? fallback; } catch { return fallback; }
}
function safeLocalStorageSet(key: string, value: string): void {
try { localStorage.setItem(key, value); } catch { /* localStorage may be unavailable */ }
}
function safeLocalStorageRemove(key: string): void {
try { localStorage.removeItem(key); } catch { /* localStorage may be unavailable */ }
}
let config: AppConfig = {}; let config: AppConfig = {};
let currentStreamer: string | null = null; let currentStreamer: string | null = null;
let isConnected = false; let isConnected = false;

View File

@ -53,11 +53,11 @@ const VOD_HIDE_DOWNLOADED_STORAGE_KEY = 'twitch-vod-manager:vod-hide-downloaded'
let vodHideDownloaded = false; let vodHideDownloaded = false;
function loadPersistedHideDownloaded(): boolean { function loadPersistedHideDownloaded(): boolean {
return safeLocalStorageGet(VOD_HIDE_DOWNLOADED_STORAGE_KEY) === '1'; try { return localStorage.getItem(VOD_HIDE_DOWNLOADED_STORAGE_KEY) === '1'; } catch { return false; }
} }
function persistHideDownloaded(value: boolean): void { function persistHideDownloaded(value: boolean): void {
safeLocalStorageSet(VOD_HIDE_DOWNLOADED_STORAGE_KEY, value ? '1' : '0'); try { localStorage.setItem(VOD_HIDE_DOWNLOADED_STORAGE_KEY, value ? '1' : '0'); } catch { /* ignore */ }
} }
function onVodHideDownloadedChange(): void { function onVodHideDownloadedChange(): void {
@ -78,15 +78,17 @@ const VOD_SORT_STORAGE_KEY = 'twitch-vod-manager:vod-sort';
let vodSortKey: VodSortKey = 'date_desc'; let vodSortKey: VodSortKey = 'date_desc';
function loadPersistedVodSort(): VodSortKey { function loadPersistedVodSort(): VodSortKey {
const stored = safeLocalStorageGet(VOD_SORT_STORAGE_KEY); try {
if (stored && (VALID_VOD_SORTS as readonly string[]).includes(stored)) { const stored = localStorage.getItem(VOD_SORT_STORAGE_KEY);
return stored as VodSortKey; if (stored && (VALID_VOD_SORTS as readonly string[]).includes(stored)) {
} return stored as VodSortKey;
}
} catch { /* localStorage may be unavailable */ }
return 'date_desc'; return 'date_desc';
} }
function persistVodSort(key: VodSortKey): void { function persistVodSort(key: VodSortKey): void {
safeLocalStorageSet(VOD_SORT_STORAGE_KEY, key); try { localStorage.setItem(VOD_SORT_STORAGE_KEY, key); } catch { /* localStorage may be unavailable */ }
} }
function vodDurationToSeconds(durationStr: string): number { function vodDurationToSeconds(durationStr: string): number {
@ -160,11 +162,15 @@ function refreshVodSortSelectLabels(): void {
} }
function loadPersistedVodFilter(): string { function loadPersistedVodFilter(): string {
return safeLocalStorageGet(VOD_FILTER_STORAGE_KEY); try {
return localStorage.getItem(VOD_FILTER_STORAGE_KEY) ?? '';
} catch {
return '';
}
} }
function persistVodFilter(query: string): void { function persistVodFilter(query: string): void {
safeLocalStorageSet(VOD_FILTER_STORAGE_KEY, query); try { localStorage.setItem(VOD_FILTER_STORAGE_KEY, query); } catch { /* localStorage may be unavailable */ }
} }
function filterVodsByQuery(vods: VOD[], query: string): VOD[] { function filterVodsByQuery(vods: VOD[], query: string): VOD[] {

View File

@ -12,15 +12,15 @@ let shouldOpenUpdateModalOnAvailable = false;
const SKIPPED_UPDATE_VERSION_KEY = 'twitch-vod-manager:skipped-update-version'; const SKIPPED_UPDATE_VERSION_KEY = 'twitch-vod-manager:skipped-update-version';
function getSkippedUpdateVersion(): string { function getSkippedUpdateVersion(): string {
return safeLocalStorageGet(SKIPPED_UPDATE_VERSION_KEY); try { return localStorage.getItem(SKIPPED_UPDATE_VERSION_KEY) || ''; } catch { return ''; }
} }
function persistSkippedUpdateVersion(version: string): void { function persistSkippedUpdateVersion(version: string): void {
safeLocalStorageSet(SKIPPED_UPDATE_VERSION_KEY, version); try { localStorage.setItem(SKIPPED_UPDATE_VERSION_KEY, version); } catch { /* localStorage may be unavailable */ }
} }
function clearSkippedUpdateVersion(): void { function clearSkippedUpdateVersion(): void {
safeLocalStorageRemove(SKIPPED_UPDATE_VERSION_KEY); try { localStorage.removeItem(SKIPPED_UPDATE_VERSION_KEY); } catch { /* localStorage may be unavailable */ }
} }
function notifyUpdate(message: string, type: 'info' | 'warn' = 'info'): void { function notifyUpdate(message: string, type: 'info' | 'warn' = 'info'): void {

View File

@ -836,14 +836,16 @@ function isKnownTab(value: string): value is typeof TAB_IDS[number] {
} }
function loadPersistedActiveTab(): string { function loadPersistedActiveTab(): string {
const stored = safeLocalStorageGet(ACTIVE_TAB_STORAGE_KEY); try {
if (stored && isKnownTab(stored)) return stored; const stored = localStorage.getItem(ACTIVE_TAB_STORAGE_KEY);
if (stored && isKnownTab(stored)) return stored;
} catch { /* localStorage may be unavailable in privacy modes */ }
return 'vods'; return 'vods';
} }
function persistActiveTab(tab: string): void { function persistActiveTab(tab: string): void {
if (!isKnownTab(tab)) return; if (!isKnownTab(tab)) return;
safeLocalStorageSet(ACTIVE_TAB_STORAGE_KEY, tab); try { localStorage.setItem(ACTIVE_TAB_STORAGE_KEY, tab); } catch { }
} }
function showTab(tab: string): void { function showTab(tab: string): void {