www/apps/resources/app/lint/rules/no-conditional-expressions-in-workflow/page.mdx
export const metadata = {
title: no-conditional-expressions-in-workflow - ESLint plugin rules,
}
This rule disallows conditional operators, such as &&, ||, ??, ternaries, !, optional chaining, and equality checks, directly inside a createWorkflow constructor or a when().then() callback.
error. This rule is enabled in the recommended preset.
This rule targets files in your project's src/workflows directory. It reports conditional operators placed directly in a workflow's constructor or in a when().then() callback.
The following code is reported by the rule:
import {
createWorkflow,
WorkflowResponse,
} from "@medusajs/framework/workflows-sdk"
createWorkflow("my-workflow", (input) => {
const v = input || "default"
return new WorkflowResponse(v)
})
Instead, wrap value manipulation in transform:
import {
createWorkflow,
transform,
WorkflowResponse,
} from "@medusajs/framework/workflows-sdk"
createWorkflow("my-workflow", (input) => {
const v = transform({ input }, (data) => {
return data.input || "default"
})
return new WorkflowResponse(v)
})
A workflow's constructor and when().then() callbacks run at definition time, not execution time. So, the operands are placeholders rather than real values, and conditional operators don't behave as you might expect. Use transform to manipulate values at execution time.
Learn more in the Workflows documentation.
This rule isn't auto-fixable.