mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-08-26 22:29:24 +00:00

# Description of Changes <!-- Please provide a summary of the changes, including: - What was changed - Why the change was made - Any challenges encountered 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/devGuide/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/devGuide/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/devGuide/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/devGuide/DeveloperGuide.md#6-testing) for more details. --------- Co-authored-by: ConnorYoh <40631091+ConnorYoh@users.noreply.github.com>
77 lines
2.4 KiB
TypeScript
77 lines
2.4 KiB
TypeScript
import { useState, useEffect, useCallback } from 'react';
|
|
import { AutomationConfig } from '../../../services/automationStorage';
|
|
import { SuggestedAutomation } from '../../../types/automation';
|
|
|
|
export interface SavedAutomation extends AutomationConfig {}
|
|
|
|
export function useSavedAutomations() {
|
|
const [savedAutomations, setSavedAutomations] = useState<SavedAutomation[]>([]);
|
|
const [loading, setLoading] = useState(true);
|
|
const [error, setError] = useState<Error | null>(null);
|
|
|
|
const loadSavedAutomations = useCallback(async () => {
|
|
try {
|
|
setLoading(true);
|
|
setError(null);
|
|
const { automationStorage } = await import('../../../services/automationStorage');
|
|
const automations = await automationStorage.getAllAutomations();
|
|
setSavedAutomations(automations);
|
|
} catch (err) {
|
|
console.error('Error loading saved automations:', err);
|
|
setError(err as Error);
|
|
setSavedAutomations([]);
|
|
} finally {
|
|
setLoading(false);
|
|
}
|
|
}, []);
|
|
|
|
const refreshAutomations = useCallback(() => {
|
|
loadSavedAutomations();
|
|
}, [loadSavedAutomations]);
|
|
|
|
const deleteAutomation = useCallback(async (id: string) => {
|
|
try {
|
|
const { automationStorage } = await import('../../../services/automationStorage');
|
|
await automationStorage.deleteAutomation(id);
|
|
// Refresh the list after deletion
|
|
refreshAutomations();
|
|
} catch (err) {
|
|
console.error('Error deleting automation:', err);
|
|
throw err;
|
|
}
|
|
}, [refreshAutomations]);
|
|
|
|
const copyFromSuggested = useCallback(async (suggestedAutomation: SuggestedAutomation) => {
|
|
try {
|
|
const { automationStorage } = await import('../../../services/automationStorage');
|
|
|
|
// Convert suggested automation to saved automation format
|
|
const savedAutomation = {
|
|
name: suggestedAutomation.name,
|
|
description: suggestedAutomation.description,
|
|
operations: suggestedAutomation.operations
|
|
};
|
|
|
|
await automationStorage.saveAutomation(savedAutomation);
|
|
// Refresh the list after saving
|
|
refreshAutomations();
|
|
} catch (err) {
|
|
console.error('Error copying suggested automation:', err);
|
|
throw err;
|
|
}
|
|
}, [refreshAutomations]);
|
|
|
|
// Load automations on mount
|
|
useEffect(() => {
|
|
loadSavedAutomations();
|
|
}, [loadSavedAutomations]);
|
|
|
|
return {
|
|
savedAutomations,
|
|
loading,
|
|
error,
|
|
refreshAutomations,
|
|
deleteAutomation,
|
|
copyFromSuggested
|
|
};
|
|
} |