diff --git a/src/components/ApprovalWorkflows/WorkflowStep.tsx b/src/components/ApprovalWorkflows/WorkflowStep.tsx new file mode 100644 index 00000000..e451744d --- /dev/null +++ b/src/components/ApprovalWorkflows/WorkflowStep.tsx @@ -0,0 +1,98 @@ +import Option from "@/interfaces/option"; +import clsx from "clsx"; +import { useState } from "react"; +import { BsTrash } from "react-icons/bs"; +import WorkflowStepNumber from "./WorkflowStepNumber"; +import WorkflowStepSelects from "./WorkflowStepSelects"; + +export type StepType = "form-intake" | "approval-by"; + +const teacherOptions: Option[] = [ + // fetch from database? +] + +const directorOptions: Option[] = [ + // fetch from database? +] + +interface Props { + editView?: boolean, + finalStep?: boolean, + isSelected?: boolean, + stepNumber: number, + stepType: StepType, + requestedBy: string, + //requestedBy: TeacherUser | CorporateUser | MasterCorporateUser, + onDelete?: () => void; +} + +export default function WorkflowStep({ + editView = false, + finalStep = false, + isSelected = false, + stepNumber, + stepType, + requestedBy, + onDelete, +}: Props) { + // disable selectability of step if in editView + const effectiveIsSelected = editView ? false : isSelected; + + const [leftValue, setLeftValue] = useState