In this PR: - Refactored components to clarify their behavior. For example, I renamed the `Workflow` component to `WorkflowVisualizer`. This moved forward the issue #7010. - Create two variants of several workflow-related components: one version for editing and another for viewing. For instance, there is `WorkflowDiagramCanvasEditable.tsx` and `WorkflowDiagramCanvasReadonly.tsx` - Implement the show page for workflow versions. On this page, we display a readonly workflow visualizer. Users can click on nodes and it will expand the right drawer. - I added buttons in the header of the RecordShowPage for workflow versions: users can activate, deactivate or use the currently viewed version as the next draft. **There are many cache desynchronisation and I'll fix them really soon.** ## Demo (Turn sound on) https://github.com/user-attachments/assets/97fafa48-8902-4dab-8b39-f40848bf041e
37 lines
1.2 KiB
TypeScript
37 lines
1.2 KiB
TypeScript
import { useWorkflowVersion } from '@/workflow/hooks/useWorkflowVersion';
|
|
import { workflowDiagramState } from '@/workflow/states/workflowDiagramState';
|
|
import { workflowVersionIdState } from '@/workflow/states/workflowVersionIdState';
|
|
import { getWorkflowVersionDiagram } from '@/workflow/utils/getWorkflowVersionDiagram';
|
|
import { useEffect } from 'react';
|
|
import { useSetRecoilState } from 'recoil';
|
|
import { isDefined } from 'twenty-ui';
|
|
|
|
export const WorkflowVersionVisualizerEffect = ({
|
|
workflowVersionId,
|
|
}: {
|
|
workflowVersionId: string;
|
|
}) => {
|
|
const workflowVersion = useWorkflowVersion(workflowVersionId);
|
|
|
|
const setWorkflowVersionId = useSetRecoilState(workflowVersionIdState);
|
|
const setWorkflowDiagram = useSetRecoilState(workflowDiagramState);
|
|
|
|
useEffect(() => {
|
|
setWorkflowVersionId(workflowVersionId);
|
|
}, [setWorkflowVersionId, workflowVersionId]);
|
|
|
|
useEffect(() => {
|
|
if (!isDefined(workflowVersion)) {
|
|
setWorkflowDiagram(undefined);
|
|
|
|
return;
|
|
}
|
|
|
|
const nextWorkflowDiagram = getWorkflowVersionDiagram(workflowVersion);
|
|
|
|
setWorkflowDiagram(nextWorkflowDiagram);
|
|
}, [setWorkflowDiagram, workflowVersion]);
|
|
|
|
return null;
|
|
};
|