mirror of
https://github.com/soconnor0919/hristudio.git
synced 2026-05-08 05:48:56 -04:00
feat(wizard): enhance branching logic and add next step selection in PropertiesPanel
This commit is contained in:
+1
-1
Submodule robot-plugins updated: 8f5ee4891f...8334b809f2
@@ -835,6 +835,40 @@ export function PropertiesPanelBase({
|
|||||||
</SelectContent>
|
</SelectContent>
|
||||||
</Select>
|
</Select>
|
||||||
</div>
|
</div>
|
||||||
|
<div>
|
||||||
|
<Label className="text-xs">After this step, go to</Label>
|
||||||
|
<p className="text-muted-foreground mb-1 text-[10px]">
|
||||||
|
Override the next step (use to converge branch paths).
|
||||||
|
</p>
|
||||||
|
<Select
|
||||||
|
value={(selectedStep.trigger.conditions as any)?.nextStepId ?? "__linear__"}
|
||||||
|
onValueChange={(val) => {
|
||||||
|
onStepUpdate(selectedStep.id, {
|
||||||
|
trigger: {
|
||||||
|
...selectedStep.trigger,
|
||||||
|
conditions: {
|
||||||
|
...(selectedStep.trigger.conditions as any),
|
||||||
|
nextStepId: val === "__linear__" ? undefined : val,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<SelectTrigger className="mt-1 h-7 w-full text-xs">
|
||||||
|
<SelectValue placeholder="Next step (default)" />
|
||||||
|
</SelectTrigger>
|
||||||
|
<SelectContent>
|
||||||
|
<SelectItem value="__linear__">Next step (default)</SelectItem>
|
||||||
|
{design.steps
|
||||||
|
.filter((s) => s.id !== selectedStep.id)
|
||||||
|
.map((s) => (
|
||||||
|
<SelectItem key={s.id} value={s.id}>
|
||||||
|
{s.name}
|
||||||
|
</SelectItem>
|
||||||
|
))}
|
||||||
|
</SelectContent>
|
||||||
|
</Select>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -922,8 +922,8 @@ export const WizardInterface = React.memo(function WizardInterface({
|
|||||||
// Log action execution
|
// Log action execution
|
||||||
console.log("Executing action:", actionId, parameters);
|
console.log("Executing action:", actionId, parameters);
|
||||||
|
|
||||||
// Handle branching logic (wizard_wait_for_response)
|
// Handle branching logic (wizard_wait_for_response / branch)
|
||||||
if (parameters?.value && parameters?.label) {
|
if (parameters?.label || parameters?.nextStepId) {
|
||||||
setLastResponse(String(parameters.value));
|
setLastResponse(String(parameters.value));
|
||||||
|
|
||||||
// If nextStepId is provided, jump immediately
|
// If nextStepId is provided, jump immediately
|
||||||
|
|||||||
@@ -499,6 +499,7 @@ export function WizardActionItem({
|
|||||||
// Manual/Wizard Actions (Leaf nodes)
|
// Manual/Wizard Actions (Leaf nodes)
|
||||||
!isContainer &&
|
!isContainer &&
|
||||||
action.type !== "wizard_wait_for_response" &&
|
action.type !== "wizard_wait_for_response" &&
|
||||||
|
!isBranch &&
|
||||||
!isCompleted && (
|
!isCompleted && (
|
||||||
<Button
|
<Button
|
||||||
size="sm"
|
size="sm"
|
||||||
@@ -524,7 +525,7 @@ export function WizardActionItem({
|
|||||||
<div className="grid grid-cols-1 gap-2 pt-3 sm:grid-cols-2">
|
<div className="grid grid-cols-1 gap-2 pt-3 sm:grid-cols-2">
|
||||||
{(action.parameters.options as any[]).map((opt, optIdx) => {
|
{(action.parameters.options as any[]).map((opt, optIdx) => {
|
||||||
const label = typeof opt === "string" ? opt : opt.label;
|
const label = typeof opt === "string" ? opt : opt.label;
|
||||||
const value = typeof opt === "string" ? opt : opt.value;
|
const value = typeof opt === "string" ? opt : (opt.value ?? opt.label);
|
||||||
const nextStepId =
|
const nextStepId =
|
||||||
typeof opt === "object" ? opt.nextStepId : undefined;
|
typeof opt === "object" ? opt.nextStepId : undefined;
|
||||||
|
|
||||||
|
|||||||
+1
-1
@@ -30,7 +30,7 @@
|
|||||||
],
|
],
|
||||||
"incremental": true,
|
"incremental": true,
|
||||||
/* Path Aliases */
|
/* Path Aliases */
|
||||||
"baseUrl": ".",
|
// "baseUrl": ".",
|
||||||
"paths": {
|
"paths": {
|
||||||
"~/*": [
|
"~/*": [
|
||||||
"./src/*"
|
"./src/*"
|
||||||
|
|||||||
Reference in New Issue
Block a user