Files
lcbp3/frontend/lib/services/workflow-engine.service.ts
admin efd5183906
All checks were successful
Build and Deploy / deploy (push) Successful in 2m37s
260228:1427 20260228:14:00 workflow update
2026-02-28 14:27:33 +07:00

97 lines
3.6 KiB
TypeScript

// File: lib/services/workflow-engine.service.ts
import apiClient from '@/lib/api/client';
import {
CreateWorkflowDefinitionDto,
UpdateWorkflowDefinitionDto,
EvaluateWorkflowDto,
GetAvailableActionsDto,
} from '@/types/dto/workflow-engine/workflow-engine.dto';
import { Workflow } from '@/types/workflow';
const mapWorkflow = (backendObj: any): Workflow => {
if (!backendObj) throw new Error('Workflow not found');
return {
workflowId: backendObj.id,
workflowName: backendObj.dsl?.workflowName || backendObj.workflow_code,
description: backendObj.description || backendObj.dsl?.description || '',
workflowType: backendObj.workflow_code,
version: backendObj.version || 1,
isActive: backendObj.is_active,
dslDefinition: typeof backendObj.dsl === 'string' ? backendObj.dsl : backendObj.dsl?.dslDefinition || JSON.stringify(backendObj.dsl, null, 2),
stepCount: backendObj.compiled?.states ? Object.keys(backendObj.compiled.states).length : 0,
updatedAt: backendObj.updated_at || new Date().toISOString(),
};
};
export const workflowEngineService = {
// --- Engine Execution (Low-Level) ---
/**
* ตรวจสอบ Action ที่ทำได้ ณ สถานะหนึ่งๆ (ถาม Engine)
* POST /workflow-engine/available-actions
*/
getAvailableActions: async (data: GetAvailableActionsDto) => {
const response = await apiClient.post('/workflow-engine/available-actions', data);
return response.data?.data || response.data; // string[] e.g. ['APPROVE', 'REJECT']
},
/**
* ประมวลผล Transition (ถาม Engine ว่าถ้าทำ Action นี้แล้วจะไป State ไหน)
* POST /workflow-engine/evaluate
*/
evaluate: async (data: EvaluateWorkflowDto) => {
const response = await apiClient.post('/workflow-engine/evaluate', data);
return response.data?.data || response.data; // { nextState: '...', events: [...] }
},
// --- Definition Management (Admin / Workflow Editor) ---
/**
* ดึง Workflow Definition ทั้งหมด
* GET /workflow-engine/definitions
*/
getDefinitions: async (): Promise<Workflow[]> => {
const response = await apiClient.get('/workflow-engine/definitions');
const data = response.data?.data || response.data;
return Array.isArray(data) ? data.map(mapWorkflow) : data;
},
/**
* ดึง Workflow Definition ตาม ID
* GET /workflow-engine/definitions/:id
*/
getDefinitionById: async (id: string | number): Promise<Workflow> => {
const response = await apiClient.get(`/workflow-engine/definitions/${id}`);
const data = response.data?.data || response.data;
return mapWorkflow(data);
},
/**
* สร้าง Workflow Definition ใหม่
* POST /workflow-engine/definitions
*/
createDefinition: async (data: CreateWorkflowDefinitionDto) => {
const response = await apiClient.post('/workflow-engine/definitions', data);
return response.data?.data || response.data;
},
/**
* อัปเดต Workflow Definition
* PATCH /workflow-engine/definitions/:id
*/
updateDefinition: async (id: string | number, data: UpdateWorkflowDefinitionDto) => {
const response = await apiClient.patch(`/workflow-engine/definitions/${id}`, data);
return response.data?.data || response.data;
},
/**
* ลบ Workflow Definition
* DELETE /workflow-engine/definitions/:id
*/
deleteDefinition: async (id: string | number) => {
const response = await apiClient.delete(`/workflow-engine/definitions/${id}`);
return response.data?.data || response.data;
},
};