mirror of
https://github.com/BetterSEQTA/BetterSEQTA-Plus.git
synced 2026-06-06 03:34:40 +00:00
feat: remove background migration
This commit is contained in:
@@ -38,7 +38,6 @@ import documentLoadCSS from '@/css/documentload.scss?inline'
|
|||||||
import renderSvelte from '@/interface/main'
|
import renderSvelte from '@/interface/main'
|
||||||
import Settings from '@/interface/pages/settings.svelte'
|
import Settings from '@/interface/pages/settings.svelte'
|
||||||
import { settingsPopup } from './interface/hooks/SettingsPopup'
|
import { settingsPopup } from './interface/hooks/SettingsPopup'
|
||||||
import { migrateBackgrounds } from './seqta/utils/migrateBackgrounds'
|
|
||||||
|
|
||||||
let SettingsClicked = false
|
let SettingsClicked = false
|
||||||
export let MenuOptionsOpen = false
|
export let MenuOptionsOpen = false
|
||||||
@@ -546,10 +545,7 @@ export async function finishLoad() {
|
|||||||
|
|
||||||
if (settingsState.justupdated && !document.getElementById('whatsnewbk')) {
|
if (settingsState.justupdated && !document.getElementById('whatsnewbk')) {
|
||||||
OpenWhatsNewPopup();
|
OpenWhatsNewPopup();
|
||||||
|
|
||||||
/* Background Migration script */
|
|
||||||
}
|
}
|
||||||
migrateBackgrounds();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async function DeleteWhatsNew() {
|
async function DeleteWhatsNew() {
|
||||||
|
|||||||
@@ -49,14 +49,14 @@ export const StoreDownloadTheme = async (theme: { themeContent: Theme }) => {
|
|||||||
|
|
||||||
export const InstallTheme = async (themeData: ThemeContent) => {
|
export const InstallTheme = async (themeData: ThemeContent) => {
|
||||||
const strippedCoverImage = stripBase64Prefix(themeData.coverImage);
|
const strippedCoverImage = stripBase64Prefix(themeData.coverImage);
|
||||||
console.log('1!')
|
|
||||||
const coverImageBlob = base64ToBlob(strippedCoverImage);
|
const coverImageBlob = base64ToBlob(strippedCoverImage);
|
||||||
console.log('2!')
|
|
||||||
const images = themeData.images.map((image) => ({
|
const images = themeData.images.map((image) => ({
|
||||||
...image,
|
...image,
|
||||||
blob: base64ToBlob(stripBase64Prefix(image.data))
|
blob: base64ToBlob(stripBase64Prefix(image.data))
|
||||||
}));
|
}));
|
||||||
console.log('3!')
|
|
||||||
let availableThemes = await localforage.getItem('customThemes') as string[];
|
let availableThemes = await localforage.getItem('customThemes') as string[];
|
||||||
if (availableThemes && !availableThemes.includes(themeData.id)) {
|
if (availableThemes && !availableThemes.includes(themeData.id)) {
|
||||||
availableThemes.push(themeData.id);
|
availableThemes.push(themeData.id);
|
||||||
|
|||||||
@@ -1,127 +0,0 @@
|
|||||||
import browser from 'webextension-polyfill';
|
|
||||||
import base64ToBlob from './base64ToBlob';
|
|
||||||
import { openDatabase, writeData } from '@/interface/hooks/BackgroundDataLoader';
|
|
||||||
import { backgroundUpdates } from '@/interface/hooks/BackgroundUpdates';
|
|
||||||
import { loadBackground } from '@/seqta/ui/ImageBackgrounds';
|
|
||||||
|
|
||||||
const MIGRATION_STATE_KEY = 'background_migration_state';
|
|
||||||
|
|
||||||
interface MigrationState {
|
|
||||||
lastProcessedId: string | null;
|
|
||||||
total: number;
|
|
||||||
processed: number;
|
|
||||||
completed: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
export const migrateBackgrounds = async (): Promise<void> => {
|
|
||||||
console.info('Migrating backgrounds...');
|
|
||||||
|
|
||||||
const savedState = localStorage.getItem(MIGRATION_STATE_KEY);
|
|
||||||
const migrationState: MigrationState = savedState
|
|
||||||
? JSON.parse(savedState)
|
|
||||||
: { lastProcessedId: null, total: 0, processed: 0, completed: false };
|
|
||||||
|
|
||||||
if (migrationState.completed) {
|
|
||||||
console.info('Migration already completed');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
const iframe = document.createElement('iframe');
|
|
||||||
iframe.style.display = 'none';
|
|
||||||
|
|
||||||
const handleMessage = async (event: MessageEvent) => {
|
|
||||||
if (event.source !== iframe.contentWindow) return;
|
|
||||||
|
|
||||||
switch (event.data.type) {
|
|
||||||
case 'GET_LAST_PROCESSED_ID':
|
|
||||||
iframe.contentWindow?.postMessage({
|
|
||||||
type: 'LAST_PROCESSED_ID',
|
|
||||||
id: migrationState.lastProcessedId
|
|
||||||
}, '*');
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'BACKGROUND_DATA':
|
|
||||||
try {
|
|
||||||
const { id, data, mediaType, total, processed, isSelected } = event.data.payload;
|
|
||||||
const mimeType = mediaType === 'image' ? 'image/png' : 'video/mp4';
|
|
||||||
const blob = base64ToBlob(data, mimeType);
|
|
||||||
|
|
||||||
await storeBackground({
|
|
||||||
id,
|
|
||||||
blob,
|
|
||||||
type: mediaType
|
|
||||||
});
|
|
||||||
|
|
||||||
if (isSelected) {
|
|
||||||
localStorage.setItem('selectedBackground', id);
|
|
||||||
await loadBackground();
|
|
||||||
}
|
|
||||||
|
|
||||||
migrationState.lastProcessedId = id;
|
|
||||||
migrationState.total = total;
|
|
||||||
migrationState.processed = processed;
|
|
||||||
localStorage.setItem(MIGRATION_STATE_KEY, JSON.stringify(migrationState));
|
|
||||||
|
|
||||||
console.log(`Migrated background: ${id} (${processed}/${total})`);
|
|
||||||
} catch (error) {
|
|
||||||
console.error('Error handling background data:', error);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'MIGRATION_COMPLETE':
|
|
||||||
console.info('Migration completed successfully');
|
|
||||||
migrationState.completed = true;
|
|
||||||
localStorage.setItem(MIGRATION_STATE_KEY, JSON.stringify(migrationState));
|
|
||||||
window.removeEventListener('message', handleMessage);
|
|
||||||
iframe.remove();
|
|
||||||
backgroundUpdates.triggerUpdate();
|
|
||||||
resolve();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'MIGRATION_ERROR':
|
|
||||||
console.error('Migration failed:', event.data.error);
|
|
||||||
window.removeEventListener('message', handleMessage);
|
|
||||||
iframe.remove();
|
|
||||||
reject(new Error(event.data.error));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
window.addEventListener('message', handleMessage);
|
|
||||||
|
|
||||||
const startPinging = () => {
|
|
||||||
const pingInterval = setInterval(() => {
|
|
||||||
iframe.contentWindow?.postMessage({ type: 'PING' }, '*');
|
|
||||||
}, 500);
|
|
||||||
|
|
||||||
const messageHandler = (event: MessageEvent) => {
|
|
||||||
if (event.source === iframe.contentWindow) {
|
|
||||||
clearInterval(pingInterval);
|
|
||||||
window.removeEventListener('message', messageHandler);
|
|
||||||
iframe.contentWindow?.postMessage({ type: 'START_MIGRATION' }, '*');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
window.addEventListener('message', messageHandler);
|
|
||||||
};
|
|
||||||
|
|
||||||
iframe.src = browser.runtime.getURL('seqta/utils/migration/migrate.html');
|
|
||||||
document.body.appendChild(iframe);
|
|
||||||
startPinging();
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const storeBackground = async (data: {
|
|
||||||
id: string;
|
|
||||||
blob: Blob;
|
|
||||||
type: 'image' | 'video';
|
|
||||||
}): Promise<void> => {
|
|
||||||
try {
|
|
||||||
await openDatabase();
|
|
||||||
await writeData(data.id, data.type, data.blob);
|
|
||||||
} catch (error) {
|
|
||||||
console.error('Error storing background:', error);
|
|
||||||
throw error;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
Reference in New Issue
Block a user