@cqa-lib/cqa-ui 1.1.422 → 1.1.424
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/execution-screen/basic-step/basic-step.component.mjs +3 -3
- package/esm2020/lib/execution-screen/condition-debug-step/condition-debug-step.component.mjs +3 -3
- package/esm2020/lib/execution-screen/condition-step/condition-step.component.mjs +3 -3
- package/esm2020/lib/execution-screen/execution-step.models.mjs +1 -1
- package/esm2020/lib/execution-screen/loop-step/loop-step.component.mjs +3 -3
- package/esm2020/lib/execution-screen/step-group/step-group.component.mjs +3 -3
- package/fesm2015/cqa-lib-cqa-ui.mjs +10 -10
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +10 -10
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/execution-screen/execution-step.models.d.ts +1 -0
- package/package.json +1 -1
|
@@ -14,4 +14,4 @@ export const DEFAULT_STEP_MORE_MENU_OPTIONS = [
|
|
|
14
14
|
{ id: 'add-breakpoint', label: 'Add breakpoint' },
|
|
15
15
|
{ id: 'run-to-here', label: 'Run to here' },
|
|
16
16
|
];
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execution-step.models.js","sourceRoot":"","sources":["../../../../../src/lib/execution-screen/execution-step.models.ts"],"names":[],"mappings":"AAAA;;GAEG;AAiTH,sEAAsE;AACtE,MAAM,CAAC,MAAM,6BAA6B,GAAwB;IAChE,EAAE,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE;IACzC,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE;CACxC,CAAC;AAQF,kFAAkF;AAClF,MAAM,CAAC,MAAM,8BAA8B,GAAyB;IAClE,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;IAC7B,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE;IACvC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE;IACjC,EAAE,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,gBAAgB,EAAE;IACjD,EAAE,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,aAAa,EAAE;CAC5C,CAAC","sourcesContent":["/**\n * Models and interfaces for execution screen step components\n */\n\nexport type StepStatus = 'success' | 'failed' | 'pending' | 'running' | 'skipped' | 'SUCCESS' | 'FAILED' | 'PENDING' | 'RUNNING' | 'SKIPPED';\n\nexport interface TimingBreakdown {\n  app: number; // in seconds\n  tool: number; // in seconds\n}\n\nexport interface SubStep {\n  id: string;\n  description: string;\n  status: StepStatus;\n  duration: number; // in seconds\n  remainingSeconds?: number | null; // Remaining timeout in seconds for WAIT_FOR_LOCATOR logs\n  timestamp?: string; // optional timestamp like \"00:12\"\n}\n\nexport interface LoopIteration {\n  id: string;\n  label: string; // e.g., \"Iter 2 (production)\"\n  status: StepStatus;\n  subSteps?: SubStep[];\n}\n\nexport interface ConditionBranch {\n  type: 'if' | 'else' | 'else if';\n  label: string; // e.g., \"Premium user\" or \"Free user\"\n  conditionText?: string; // The condition expression text (empty for ELSE branches)\n  conditionType?: string; // Normalized condition type (e.g., CONDITION_IF, CONDITION_ELSE)\n  executed: boolean;\n  subSteps?: SubStep[];\n  branchStepId?: string | number; // ID of the branch step to load children from\n  isIfBranch?: boolean; // Whether this is the main IF branch\n  branchStep: any;\n}\n\nexport interface ScreenshotData {\n  baseline?: string; // URL or base64\n  current?: string; // URL or base64\n  difference?: string; // URL or base64\n}\n\nexport interface LogEntry {\n  level: 'info' | 'warning' | 'error';\n  message: string;\n  timestamp?: string;\n}\n\nexport interface FailureDetails {\n  testStepId: string;\n  expected: string;\n  actual: string;\n  failedAction?: string; // The action that failed\n  aiFixApplied?: boolean;\n  aiFixMessage?: string;\n  screenshots?: ScreenshotData;\n  logs?: LogEntry[];\n}\n\nexport interface BaseStepConfig {\n  id: string;\n  testStepId: number | undefined; // test step id from the test case\n  testStepResultId: string;\n  stepNumber: string; // e.g., \"1\", \"2.1\", \"3.2.1\"\n  title: string;\n  status: StepStatus;\n  duration: number; // total duration in seconds\n  timingBreakdown?: TimingBreakdown;\n  expanded?: boolean; // whether the step is expanded by default\n  failureDetails?: FailureDetails;\n  reasoning?: string[];\n  confidence?: string;\n  stepDeleted?: boolean;\n  executedResult?: {\n    video_start_time: number;\n    video_end_time: number;\n  };\n  // Additional properties for live execution and runtime use\n  selectedIterationId?: string; // which iteration to display\n  /** Internal debug/portal-only flags used at runtime (not persisted). */\n  isStepGroupChildren?: boolean;\n  stepMoreMenuOptions?: boolean;\n  debugPointDisabled?: boolean; // flag set externally (e.g. on skip) to disable the breakpoint\n  isRunResult?: boolean;\n}\n\nexport interface SelfHealAnalysisData {\n  originalLocator: string;\n  healedLocator: string;\n  confidence: number; // 0-100\n  healMethod: string; // e.g., \"Semantic Attribute Matching\"\n}\n\nexport interface SelfHealActionEvent {\n  type: SelfHealAction;\n  id: string;\n  healedLocator: string;\n  testStepId?: string; // test step id from the test case\n}\n\nexport type SelfHealAction = 'accept' | 'reject' | 'modify-accept';\n\nexport interface BasicStepConfig extends BaseStepConfig {\n  displayType: 'basic';\n  subSteps: SubStep[];\n  selfHealAnalysis?: SelfHealAnalysisData;\n  selfHealed?: boolean; // Indicates if self-healing was applied\n  selfHealDuration?: number; // Duration of self-healing process\n  nestedSteps?: ExecutionStepConfig[]; // nested child steps for recursive rendering\n}\n\nexport interface StepGroupConfig extends BaseStepConfig {\n  displayType: 'step-group';\n  groupName: string; // e.g., \"Navigation\", \"Checkout flow\"\n  steps: ExecutionStepConfig[]; // nested steps\n}\n\nexport interface LoopStepConfig extends BaseStepConfig {\n  displayType: 'loop';\n  loopType?: 'for' | 'while';\n  iterations: LoopIteration[];\n  selectedIterationId?: string; // which iteration to display\n  defaultIteration?: 'first' | 'last'; // default iteration to show\n  nestedSteps?: ExecutionStepConfig[]; // steps nested within the loop\n  showViewAllIterations?: boolean;\n  subSteps?: SubStep[];\n  iterationData?: any; // data for each iteration in live execution\n}\n\nexport interface ConditionStepConfig extends BaseStepConfig {\n  displayType: 'condition';\n  conditionText: string; // e.g., \"if user type is 'Premium'\"\n  branches: ConditionBranch[];\n  nestedSteps?: ExecutionStepConfig[]; // nested child steps for recursive rendering\n}\n\nexport interface FailedStepConfig extends BaseStepConfig {\n  displayType: 'failed';\n  subSteps: SubStep[];\n  failureDetails: FailureDetails;\n  reasoning?: string[];\n  confidence?: string;\n}\n\nexport interface AIAgentAction {\n  id: string;\n  description: string;\n  type: 'extract' | 'validate' | 'AI_AGENT_ACTION' | 'TYPE' | 'CLICK';\n  status: StepStatus;\n  confidence?: number; // 0-100\n  duration: number;\n  reasoning?: string;\n}\n\nexport interface AIAgentStepConfig extends BaseStepConfig {\n  displayType: 'ai-agent';\n  prompt: string;\n  optimizedRun?: boolean;\n  actionCount?: number;\n  actions: AIAgentAction[];\n  selectedTab?: 'action-trace' | 'planner-timeline' | 'ai-reasoning';\n}\n\nexport interface AIActionStepConfig extends BaseStepConfig {\n  displayType: 'ai-action';\n  actionCount?: number;\n  actionName?: 'ai_text_verification' | 'ai_ask' | 'ai_document_ask' | 'ai_verify';\n  actions: AIAgentAction[];\n}\n\nexport interface ApiAssertion {\n  id: string;\n  description: string;\n  status: 'passed' | 'failed';\n  expected: string;\n  actual: string;\n}\n\nexport interface ApiStepConfig extends BaseStepConfig {\n  displayType: 'api';\n  method: string; // GET, POST, PUT, DELETE, etc.\n  endpoint: string;\n  statusCode: number;\n  responseTime: number; // in milliseconds\n  requestBody?: any;\n  responseBody?: any;\n  requestHeaders?: any;\n  responseHeaders?: any;\n  assertions?: ApiAssertion[];\n  initialActions?: SubStep[]; // Actions before the API call\n}\n\nexport interface FileDownloadStepConfig extends BaseStepConfig {\n  displayType: 'file-download';\n  fileName: string;\n  fileType: string; // PDF, CSV, etc.\n  fileSize?: string; // e.g., \"2.4 MB\"\n  filePath?: string;\n  downloaded: boolean;\n}\n\nexport interface ExtractedField {\n  label: string;\n  value: string;\n  confidence: number; // 0-100\n}\n\nexport interface VerificationCheck {\n  id: string;\n  description: string;\n  status: 'pass' | 'fail';\n  expected: string;\n  actual: string;\n}\n\nexport interface DocumentVerificationStepConfig extends BaseStepConfig {\n  displayType: 'document-verification';\n  documentScreenshot?: string; // URL or base64\n  extractedFields: ExtractedField[];\n  verificationChecks: VerificationCheck[];\n}\n\nexport interface LiveSubStep {\n  id: string;\n  text: string; // Text from socket\n  isRunning: boolean; // true = show loader, false = show icon\n  duration?: number; // in seconds\n  status: 'passed' | 'failed' | 'pending' | 'success' | 'failure' | 'skipped';\n  remainingSeconds?: number | null; // Countdown seconds for WAIT_FOR_LOCATOR grouping\n}\n\nexport interface LiveExecutionStepConfig extends BaseStepConfig {\n  displayType: 'live-execution';\n  subSteps: LiveSubStep[];\n}\n\nexport interface DbQueryResult {\n  data: any[];\n  query: string;\n  executedAt?: string;\n  duration?: number; // in seconds\n  [key: string]: any; // For dynamic keys like \"Demo_user\"\n}\n\nexport interface DbAssertionResult {\n  variableName: string;\n  jsonPath: string;\n  expectedValue: any;\n  actualValue: any;\n  verificationType: string;\n  expectedType: string;\n  passed: boolean;\n}\n\nexport interface DbTestResult {\n  success: boolean;\n  results: { [key: string]: DbQueryResult };\n  assertionResults: DbAssertionResult[];\n  allAssertionsPassed: boolean;\n}\n\nexport interface DbVerificationStepConfig extends BaseStepConfig {\n  displayType: 'db-verification';\n  dbTestResult: DbTestResult;\n  subSteps?: SubStep[];\n  dbConfig?: {\n    name: string; // Environment name\n    dbType: string; // Database type (MySQL, SQLServer, etc.)\n  };\n}\n\nexport interface PrerequisiteItem {\n  id: string;\n  title: string; // e.g., \"Prerequisite 1: Login flow\"\n  status: StepStatus;\n  duration: number; // in seconds\n  stepConfig?: ExecutionStepConfig; // Optional: full step config to view details\n  /** Optional URL for \"View steps\" redirect. When viewStepsAsRedirect is true, each item can have its own URL. */\n  viewStepsUrl?: string;\n}\n\nexport type ExecutionStepConfig =\n  | BasicStepConfig\n  | StepGroupConfig\n  | LoopStepConfig\n  | ConditionStepConfig\n  | FailedStepConfig\n  | AIAgentStepConfig\n  | AIActionStepConfig\n  | ApiStepConfig\n  | FileDownloadStepConfig\n  | DocumentVerificationStepConfig\n  | LiveExecutionStepConfig\n  | DbVerificationStepConfig;\n\n/** Option for the Add-step menu shown when the Plus icon is clicked (e.g. \"Add before\", \"Add after\"). */\nexport interface AddStepMenuOption {\n  id: string;\n  label: string;\n  position?: string; // 'before' | 'after' | 'inside'\n  branchType?: string; // 'if' | 'else' | 'else if' - for condition steps\n  branchStepId?: string | number; // ID of the branch step for condition steps\n}\n\n/** Default options for the Add-step dropdown when isDebug is true. */\nexport const DEFAULT_ADD_STEP_MENU_OPTIONS: AddStepMenuOption[] = [\n  { id: 'add-before', label: 'Add before' },\n  { id: 'add-after', label: 'Add after' },\n];\n\n/** Option for the step \"More options\" (three-dot) menu (e.g. Skip, Duplicate, Delete, Add breakpoint, Run to here). */\nexport interface StepMoreMenuOption {\n  id: string;\n  label: string;\n}\n\n/** Default options for the More options (three-dot) menu when isDebug is true. */\nexport const DEFAULT_STEP_MORE_MENU_OPTIONS: StepMoreMenuOption[] = [\n  { id: 'skip', label: 'Skip' },\n  { id: 'duplicate', label: 'Duplicate' },\n  { id: 'delete', label: 'Delete' },\n  { id: 'add-breakpoint', label: 'Add breakpoint' },\n  { id: 'run-to-here', label: 'Run to here' },\n];\n"]}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execution-step.models.js","sourceRoot":"","sources":["../../../../../src/lib/execution-screen/execution-step.models.ts"],"names":[],"mappings":"AAAA;;GAEG;AAkTH,sEAAsE;AACtE,MAAM,CAAC,MAAM,6BAA6B,GAAwB;IAChE,EAAE,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE;IACzC,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE;CACxC,CAAC;AAQF,kFAAkF;AAClF,MAAM,CAAC,MAAM,8BAA8B,GAAyB;IAClE,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;IAC7B,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE;IACvC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE;IACjC,EAAE,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,gBAAgB,EAAE;IACjD,EAAE,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,aAAa,EAAE;CAC5C,CAAC","sourcesContent":["/**\n * Models and interfaces for execution screen step components\n */\n\nexport type StepStatus = 'success' | 'failed' | 'pending' | 'running' | 'skipped' | 'SUCCESS' | 'FAILED' | 'PENDING' | 'RUNNING' | 'SKIPPED';\n\nexport interface TimingBreakdown {\n  app: number; // in seconds\n  tool: number; // in seconds\n}\n\nexport interface SubStep {\n  id: string;\n  description: string;\n  status: StepStatus;\n  duration: number; // in seconds\n  remainingSeconds?: number | null; // Remaining timeout in seconds for WAIT_FOR_LOCATOR logs\n  timestamp?: string; // optional timestamp like \"00:12\"\n}\n\nexport interface LoopIteration {\n  id: string;\n  label: string; // e.g., \"Iter 2 (production)\"\n  status: StepStatus;\n  subSteps?: SubStep[];\n}\n\nexport interface ConditionBranch {\n  type: 'if' | 'else' | 'else if';\n  label: string; // e.g., \"Premium user\" or \"Free user\"\n  conditionText?: string; // The condition expression text (empty for ELSE branches)\n  conditionType?: string; // Normalized condition type (e.g., CONDITION_IF, CONDITION_ELSE)\n  executed: boolean;\n  subSteps?: SubStep[];\n  branchStepId?: string | number; // ID of the branch step to load children from\n  isIfBranch?: boolean; // Whether this is the main IF branch\n  branchStep: any;\n}\n\nexport interface ScreenshotData {\n  baseline?: string; // URL or base64\n  current?: string; // URL or base64\n  difference?: string; // URL or base64\n}\n\nexport interface LogEntry {\n  level: 'info' | 'warning' | 'error';\n  message: string;\n  timestamp?: string;\n}\n\nexport interface FailureDetails {\n  testStepId: string;\n  expected: string;\n  actual: string;\n  failedAction?: string; // The action that failed\n  aiFixApplied?: boolean;\n  aiFixMessage?: string;\n  screenshots?: ScreenshotData;\n  logs?: LogEntry[];\n}\n\nexport interface BaseStepConfig {\n  id: string;\n  uniqueId?: string; // unique identifier for steps reused across multiple groups\n  testStepId: number | undefined; // test step id from the test case\n  testStepResultId: string;\n  stepNumber: string; // e.g., \"1\", \"2.1\", \"3.2.1\"\n  title: string;\n  status: StepStatus;\n  duration: number; // total duration in seconds\n  timingBreakdown?: TimingBreakdown;\n  expanded?: boolean; // whether the step is expanded by default\n  failureDetails?: FailureDetails;\n  reasoning?: string[];\n  confidence?: string;\n  stepDeleted?: boolean;\n  executedResult?: {\n    video_start_time: number;\n    video_end_time: number;\n  };\n  // Additional properties for live execution and runtime use\n  selectedIterationId?: string; // which iteration to display\n  /** Internal debug/portal-only flags used at runtime (not persisted). */\n  isStepGroupChildren?: boolean;\n  stepMoreMenuOptions?: boolean;\n  debugPointDisabled?: boolean; // flag set externally (e.g. on skip) to disable the breakpoint\n  isRunResult?: boolean;\n}\n\nexport interface SelfHealAnalysisData {\n  originalLocator: string;\n  healedLocator: string;\n  confidence: number; // 0-100\n  healMethod: string; // e.g., \"Semantic Attribute Matching\"\n}\n\nexport interface SelfHealActionEvent {\n  type: SelfHealAction;\n  id: string;\n  healedLocator: string;\n  testStepId?: string; // test step id from the test case\n}\n\nexport type SelfHealAction = 'accept' | 'reject' | 'modify-accept';\n\nexport interface BasicStepConfig extends BaseStepConfig {\n  displayType: 'basic';\n  subSteps: SubStep[];\n  selfHealAnalysis?: SelfHealAnalysisData;\n  selfHealed?: boolean; // Indicates if self-healing was applied\n  selfHealDuration?: number; // Duration of self-healing process\n  nestedSteps?: ExecutionStepConfig[]; // nested child steps for recursive rendering\n}\n\nexport interface StepGroupConfig extends BaseStepConfig {\n  displayType: 'step-group';\n  groupName: string; // e.g., \"Navigation\", \"Checkout flow\"\n  steps: ExecutionStepConfig[]; // nested steps\n}\n\nexport interface LoopStepConfig extends BaseStepConfig {\n  displayType: 'loop';\n  loopType?: 'for' | 'while';\n  iterations: LoopIteration[];\n  selectedIterationId?: string; // which iteration to display\n  defaultIteration?: 'first' | 'last'; // default iteration to show\n  nestedSteps?: ExecutionStepConfig[]; // steps nested within the loop\n  showViewAllIterations?: boolean;\n  subSteps?: SubStep[];\n  iterationData?: any; // data for each iteration in live execution\n}\n\nexport interface ConditionStepConfig extends BaseStepConfig {\n  displayType: 'condition';\n  conditionText: string; // e.g., \"if user type is 'Premium'\"\n  branches: ConditionBranch[];\n  nestedSteps?: ExecutionStepConfig[]; // nested child steps for recursive rendering\n}\n\nexport interface FailedStepConfig extends BaseStepConfig {\n  displayType: 'failed';\n  subSteps: SubStep[];\n  failureDetails: FailureDetails;\n  reasoning?: string[];\n  confidence?: string;\n}\n\nexport interface AIAgentAction {\n  id: string;\n  description: string;\n  type: 'extract' | 'validate' | 'AI_AGENT_ACTION' | 'TYPE' | 'CLICK';\n  status: StepStatus;\n  confidence?: number; // 0-100\n  duration: number;\n  reasoning?: string;\n}\n\nexport interface AIAgentStepConfig extends BaseStepConfig {\n  displayType: 'ai-agent';\n  prompt: string;\n  optimizedRun?: boolean;\n  actionCount?: number;\n  actions: AIAgentAction[];\n  selectedTab?: 'action-trace' | 'planner-timeline' | 'ai-reasoning';\n}\n\nexport interface AIActionStepConfig extends BaseStepConfig {\n  displayType: 'ai-action';\n  actionCount?: number;\n  actionName?: 'ai_text_verification' | 'ai_ask' | 'ai_document_ask' | 'ai_verify';\n  actions: AIAgentAction[];\n}\n\nexport interface ApiAssertion {\n  id: string;\n  description: string;\n  status: 'passed' | 'failed';\n  expected: string;\n  actual: string;\n}\n\nexport interface ApiStepConfig extends BaseStepConfig {\n  displayType: 'api';\n  method: string; // GET, POST, PUT, DELETE, etc.\n  endpoint: string;\n  statusCode: number;\n  responseTime: number; // in milliseconds\n  requestBody?: any;\n  responseBody?: any;\n  requestHeaders?: any;\n  responseHeaders?: any;\n  assertions?: ApiAssertion[];\n  initialActions?: SubStep[]; // Actions before the API call\n}\n\nexport interface FileDownloadStepConfig extends BaseStepConfig {\n  displayType: 'file-download';\n  fileName: string;\n  fileType: string; // PDF, CSV, etc.\n  fileSize?: string; // e.g., \"2.4 MB\"\n  filePath?: string;\n  downloaded: boolean;\n}\n\nexport interface ExtractedField {\n  label: string;\n  value: string;\n  confidence: number; // 0-100\n}\n\nexport interface VerificationCheck {\n  id: string;\n  description: string;\n  status: 'pass' | 'fail';\n  expected: string;\n  actual: string;\n}\n\nexport interface DocumentVerificationStepConfig extends BaseStepConfig {\n  displayType: 'document-verification';\n  documentScreenshot?: string; // URL or base64\n  extractedFields: ExtractedField[];\n  verificationChecks: VerificationCheck[];\n}\n\nexport interface LiveSubStep {\n  id: string;\n  text: string; // Text from socket\n  isRunning: boolean; // true = show loader, false = show icon\n  duration?: number; // in seconds\n  status: 'passed' | 'failed' | 'pending' | 'success' | 'failure' | 'skipped';\n  remainingSeconds?: number | null; // Countdown seconds for WAIT_FOR_LOCATOR grouping\n}\n\nexport interface LiveExecutionStepConfig extends BaseStepConfig {\n  displayType: 'live-execution';\n  subSteps: LiveSubStep[];\n}\n\nexport interface DbQueryResult {\n  data: any[];\n  query: string;\n  executedAt?: string;\n  duration?: number; // in seconds\n  [key: string]: any; // For dynamic keys like \"Demo_user\"\n}\n\nexport interface DbAssertionResult {\n  variableName: string;\n  jsonPath: string;\n  expectedValue: any;\n  actualValue: any;\n  verificationType: string;\n  expectedType: string;\n  passed: boolean;\n}\n\nexport interface DbTestResult {\n  success: boolean;\n  results: { [key: string]: DbQueryResult };\n  assertionResults: DbAssertionResult[];\n  allAssertionsPassed: boolean;\n}\n\nexport interface DbVerificationStepConfig extends BaseStepConfig {\n  displayType: 'db-verification';\n  dbTestResult: DbTestResult;\n  subSteps?: SubStep[];\n  dbConfig?: {\n    name: string; // Environment name\n    dbType: string; // Database type (MySQL, SQLServer, etc.)\n  };\n}\n\nexport interface PrerequisiteItem {\n  id: string;\n  title: string; // e.g., \"Prerequisite 1: Login flow\"\n  status: StepStatus;\n  duration: number; // in seconds\n  stepConfig?: ExecutionStepConfig; // Optional: full step config to view details\n  /** Optional URL for \"View steps\" redirect. When viewStepsAsRedirect is true, each item can have its own URL. */\n  viewStepsUrl?: string;\n}\n\nexport type ExecutionStepConfig =\n  | BasicStepConfig\n  | StepGroupConfig\n  | LoopStepConfig\n  | ConditionStepConfig\n  | FailedStepConfig\n  | AIAgentStepConfig\n  | AIActionStepConfig\n  | ApiStepConfig\n  | FileDownloadStepConfig\n  | DocumentVerificationStepConfig\n  | LiveExecutionStepConfig\n  | DbVerificationStepConfig;\n\n/** Option for the Add-step menu shown when the Plus icon is clicked (e.g. \"Add before\", \"Add after\"). */\nexport interface AddStepMenuOption {\n  id: string;\n  label: string;\n  position?: string; // 'before' | 'after' | 'inside'\n  branchType?: string; // 'if' | 'else' | 'else if' - for condition steps\n  branchStepId?: string | number; // ID of the branch step for condition steps\n}\n\n/** Default options for the Add-step dropdown when isDebug is true. */\nexport const DEFAULT_ADD_STEP_MENU_OPTIONS: AddStepMenuOption[] = [\n  { id: 'add-before', label: 'Add before' },\n  { id: 'add-after', label: 'Add after' },\n];\n\n/** Option for the step \"More options\" (three-dot) menu (e.g. Skip, Duplicate, Delete, Add breakpoint, Run to here). */\nexport interface StepMoreMenuOption {\n  id: string;\n  label: string;\n}\n\n/** Default options for the More options (three-dot) menu when isDebug is true. */\nexport const DEFAULT_STEP_MORE_MENU_OPTIONS: StepMoreMenuOption[] = [\n  { id: 'skip', label: 'Skip' },\n  { id: 'duplicate', label: 'Duplicate' },\n  { id: 'delete', label: 'Delete' },\n  { id: 'add-breakpoint', label: 'Add breakpoint' },\n  { id: 'run-to-here', label: 'Run to here' },\n];\n"]}
|