mirror of
https://github.com/Frooodle/Stirling-PDF.git
synced 2026-02-01 20:10:35 +01:00
# Description of Changes Please provide a summary of the changes, including: Vite fixes Indexxdb Closes #(issue_number) --- ## Checklist ### General - [ ] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have read the [Stirling-PDF Developer Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md) (if applicable) - [ ] I have read the [How to add new languages to Stirling-PDF](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md) (if applicable) - [ ] I have performed a self-review of my own code - [ ] My changes generate no new warnings ### Documentation - [ ] I have updated relevant docs on [Stirling-PDF's doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) (if functionality has heavily changed) - [ ] I have read the section [Add New Translation Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md#add-new-translation-tags) (for new translation tags only) ### UI Changes (if applicable) - [ ] Screenshots or videos demonstrating the UI changes are attached (e.g., as comments or direct attachments in the PR) ### Testing (if applicable) - [ ] I have tested my changes locally. Refer to the [Testing Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md#6-testing) for more details.
71 lines
1.9 KiB
TypeScript
71 lines
1.9 KiB
TypeScript
import { StorageStats } from "../services/fileStorage";
|
|
import { FileWithUrl } from "../types/file";
|
|
|
|
/**
|
|
* Storage operation types for incremental updates
|
|
*/
|
|
export type StorageOperation = 'add' | 'remove' | 'clear';
|
|
|
|
/**
|
|
* Update storage stats incrementally based on operation
|
|
*/
|
|
export function updateStorageStatsIncremental(
|
|
currentStats: StorageStats,
|
|
operation: StorageOperation,
|
|
files: FileWithUrl[] = []
|
|
): StorageStats {
|
|
const filesSizeTotal = files.reduce((total, file) => total + file.size, 0);
|
|
|
|
switch (operation) {
|
|
case 'add':
|
|
return {
|
|
...currentStats,
|
|
used: currentStats.used + filesSizeTotal,
|
|
available: currentStats.available - filesSizeTotal,
|
|
fileCount: currentStats.fileCount + files.length
|
|
};
|
|
|
|
case 'remove':
|
|
return {
|
|
...currentStats,
|
|
used: Math.max(0, currentStats.used - filesSizeTotal),
|
|
available: currentStats.available + filesSizeTotal,
|
|
fileCount: Math.max(0, currentStats.fileCount - files.length)
|
|
};
|
|
|
|
case 'clear':
|
|
return {
|
|
...currentStats,
|
|
used: 0,
|
|
available: currentStats.quota || currentStats.available,
|
|
fileCount: 0
|
|
};
|
|
|
|
default:
|
|
return currentStats;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Check storage usage and return warning message if needed
|
|
*/
|
|
export function checkStorageWarnings(stats: StorageStats): string | null {
|
|
if (!stats.quota || stats.used === 0) return null;
|
|
|
|
const usagePercent = (stats.used / stats.quota) * 100;
|
|
|
|
if (usagePercent > 90) {
|
|
return 'Warning: Storage is nearly full (>90%). Browser may start clearing data.';
|
|
} else if (usagePercent > 80) {
|
|
return 'Storage is getting full (>80%). Consider removing old files.';
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* Calculate storage usage percentage
|
|
*/
|
|
export function getStorageUsagePercent(stats: StorageStats): number {
|
|
return stats.quota ? (stats.used / stats.quota) * 100 : 0;
|
|
} |