Files
zn-ai/src/stores/cron.ts
duanshuwen e77c815a86 feat: add new stores for cron, locale, providers, script, shared data, skills, and user info
- Implemented `cron` store to manage scheduled tasks with CRUD operations.
- Created `locale` store for language settings with persistence and system language detection.
- Added `providers` store to handle provider accounts and configurations with API interactions.
- Developed `script` store for managing automation scripts, including recording and execution.
- Introduced `sharedStore` for managing shared data across components.
- Established `skills` store for fetching, installing, and managing skills from a marketplace.
- Created `userinfo` store for user authentication and session management.

chore: update path aliases from `@store` to `@stores` in TypeScript configuration and Vite config
2026-04-15 21:49:25 +08:00

146 lines
4.2 KiB
TypeScript

/**
* Cron State Store
* Manages scheduled task state
*/
import { defineStore } from 'pinia';
import { ref, computed } from 'vue';
import { hostApiFetch } from '@lib/host-api';
import type { CronJob, CronJobCreateInput, CronJobUpdateInput } from '@lib/cron-types';
export const MOCK_CRON_JOBS: CronJob[] = [];
export const useCronStore = defineStore('cron', () => {
const jobs = ref<CronJob[]>([]);
const loading = ref(false);
const error = ref<string | null>(null);
const safeJobs = computed(() => (Array.isArray(jobs.value) ? jobs.value : []));
const activeJobs = computed(() => safeJobs.value.filter((j) => j.enabled));
const pausedJobs = computed(() => safeJobs.value.filter((j) => !j.enabled));
const failedJobs = computed(() => safeJobs.value.filter((j) => j.lastRun && !j.lastRun.success));
const fetchJobs = async () => {
const currentJobs = safeJobs.value;
if (currentJobs.length === 0) {
loading.value = true;
}
error.value = null;
try {
const result = await hostApiFetch<CronJob[]>('/api/cron/jobs');
jobs.value = result;
} catch (err) {
error.value = err instanceof Error ? err.message : String(err);
// Fallback to mock data on error for demo/development
jobs.value = MOCK_CRON_JOBS;
} finally {
loading.value = false;
}
};
const createJob = async (input: CronJobCreateInput) => {
const job: CronJob = {
id: `local-${Date.now()}`,
...input,
enabled: input.enabled ?? true,
createdAt: new Date().toISOString(),
updatedAt: new Date().toISOString(),
};
try {
const result = await hostApiFetch<CronJob>('/api/cron/jobs', {
method: 'POST',
body: JSON.stringify(input),
});
jobs.value = [...safeJobs.value, result];
return result;
} catch (err) {
console.warn('Failed to create cron job via API, using local fallback:', err);
jobs.value = [...safeJobs.value, job];
return job;
}
};
const updateJob = async (id: string, input: CronJobUpdateInput) => {
try {
const updatedJob = await hostApiFetch<CronJob>(`/api/cron/jobs/${encodeURIComponent(id)}`, {
method: 'PUT',
body: JSON.stringify(input),
});
jobs.value = safeJobs.value.map((job) => (job.id === id ? updatedJob : job));
} catch (err) {
console.warn('Failed to update cron job via API, using local fallback:', err);
jobs.value = safeJobs.value.map((job) =>
job.id === id
? { ...job, ...input, updatedAt: new Date().toISOString() }
: job,
);
}
};
const deleteJob = async (id: string) => {
try {
await hostApiFetch(`/api/cron/jobs/${encodeURIComponent(id)}`, {
method: 'DELETE',
});
} catch (err) {
console.warn('Failed to delete cron job via API, using local fallback:', err);
}
jobs.value = safeJobs.value.filter((job) => job.id !== id);
};
const toggleJob = async (id: string, enabled: boolean) => {
try {
await hostApiFetch('/api/cron/toggle', {
method: 'POST',
body: JSON.stringify({ id, enabled }),
});
} catch (err) {
console.warn('Failed to toggle cron job via API, using local fallback:', err);
}
jobs.value = safeJobs.value.map((job) =>
job.id === id ? { ...job, enabled, updatedAt: new Date().toISOString() } : job,
);
};
const triggerJob = async (id: string) => {
try {
const result = await hostApiFetch('/api/cron/trigger', {
method: 'POST',
body: JSON.stringify({ id }),
});
console.log('Cron trigger result:', result);
} catch (err) {
console.warn('Failed to trigger cron job via API, using local fallback:', err);
}
// Update lastRun locally as fallback
jobs.value = safeJobs.value.map((job) =>
job.id === id
? {
...job,
lastRun: {
time: new Date().toISOString(),
success: true,
},
updatedAt: new Date().toISOString(),
}
: job,
);
};
return {
jobs,
loading,
error,
safeJobs,
activeJobs,
pausedJobs,
failedJobs,
fetchJobs,
createJob,
updateJob,
deleteJob,
toggleJob,
triggerJob,
};
});