From e0e1aceb61ff2d916366544a36651ad7cba79054 Mon Sep 17 00:00:00 2001 From: Carlos Castro Date: Wed, 4 Feb 2026 14:06:26 -0500 Subject: [PATCH 1/3] Rename Agent Loop to Agent in operation summary --- .../src/designer-client-services/lib/base/operations/agent.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts b/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts index db7f6e6230e..2060414c257 100644 --- a/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts +++ b/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts @@ -15,7 +15,7 @@ export const agentOperation = { displayName: 'Agent', iconUri, }, - summary: 'Agent Loop', + summary: 'Agent', description: 'Loop in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', visibility: 'Important', From af5096c94912ff57a840ac94aa1654cea53b039d Mon Sep 17 00:00:00 2001 From: Carlos Castro Date: Wed, 4 Feb 2026 14:41:05 -0500 Subject: [PATCH 2/3] Remove 'loop' terminology from agent user-facing strings MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Change description from 'Loop in which...' to 'Action in which...' - Update UI strings: 'agentic loop' → 'agent', 'agentic loops' → 'agents' - Update delete modal titles and error messages - Affects: operation definitions, EdgeContextualMenu, DeleteNodeModal, KindChangeDialog --- Localize/lang/strings.json | 34 +++++++++---------- .../src/lib/modals/DeleteNodeModal.tsx | 14 ++++---- .../EdgeContextualMenu/EdgeContextualMenu.tsx | 22 ++++++------ .../KindChangeDialog/KindChangeDialog.tsx | 4 +-- .../EdgeContextualMenu/EdgeContextualMenu.tsx | 20 +++++------ .../lib/base/operations/agent.ts | 2 +- .../lib/consumption/manifests/agentloop.ts | 2 +- .../lib/consumption/operations/agent.ts | 2 +- .../lib/standard/manifest/agentloop.ts | 2 +- 9 files changed, 50 insertions(+), 52 deletions(-) diff --git a/Localize/lang/strings.json b/Localize/lang/strings.json index 6ac3329f511..f2be766c618 100644 --- a/Localize/lang/strings.json +++ b/Localize/lang/strings.json @@ -29,7 +29,6 @@ "+gBLFF": "Your template has been saved.", "+iPg27": "Delete", "+ijo/2": "Paste last used expression", - "+jvca5": "Using a chat message trigger means your workflow will be conversational, which doesn't support actions running after an agentic loop. Delete any actions running after an agent to use this trigger.", "+l5XmZ": "Enter a positive integer between {min} and {max}", "+mAJR3": "(UTC+08:00) Kuala Lumpur, Singapore", "+mNJQl": "Create a logic app", @@ -148,6 +147,7 @@ "1Orv4i": "Details", "1REu5/": "See less", "1Xke9D": "open functions drawer", + "1YUi9I": "Add a hand-off agent", "1ZrOYn": "AI Foundry Project", "1dlfUe": "Actions perform operations on data, communicate between systems, or run other tasks.", "1eKQwo": "(UTC+08:00) Perth", @@ -289,7 +289,6 @@ "4aaixN": "Tour", "4bT5AR": "Invalid connection. To load complete details, complete or update the connection.", "4c0uPQ": "Required. The name of the parameter whose values you want.", - "4gOrfY": "This will also delete the agent's tools and actions.", "4ggAK+": "Error occurred while parsing agent instructions.", "4hi3ks": "Your flow has been updated.", "4hlqgK": "No results found for {searchTermBeingSearchedFor_DO_NOT_TRANSLATE}", @@ -613,7 +612,6 @@ "BuYrD3": "A single format specifier that indicates how to format the value of this Guid.", "BwOKWK": "Remember my choice", "Bwqlxd": "Key not found ''{nodeKey}''", - "BwwhOM": "Delete agentic loop tool", "BwxTBw": "Loading logic apps ...", "BxITRH": "Required. The object to check if it is greater than comparing object.", "BynK4X": "Ask a question", @@ -709,6 +707,7 @@ "E7NzDN": "Settings", "E7jFWU": "Logic App", "E8iqLl": "(UTC+11:00) Sakhalin", + "EAAlZ9": "Delete agent", "ECZC6Y": "Converts the parameter to a decimal number", "EE1vyH": "Update workflow before using this trigger", "EFQ56R": "Source code", @@ -744,6 +743,7 @@ "F1AkvV": "Ideal for process business transitional data", "F2wR+r": "Insert expression", "F3IDl8": "Required. The number of a specified time unit to add.", + "F3q0Hk": "Cannot paste actions below agents in agent to agent workflows", "F83QRP": "On a schedule", "F9dR1Q": "Add", "F9yRDC": "Method", @@ -836,6 +836,7 @@ "HFt+tF": "Favorites", "HH970i": "Month", "HILmmE": "Required. The collection to sort.", + "HMJPEj": "Cannot add subsequent actions below agents in agent to agent workflows", "HMiE+4": "Exit full screen", "HOwcCC": "Primary key", "HQ/HhZ": "Error loading connections", @@ -946,7 +947,6 @@ "K7/DnZ": "Output", "K9ORYo": "Schema ID", "KBaGkS": "Change connection reference", - "KFFF+N": "Cannot add subsequent actions below agentic loops in agent to agent workflows", "KGvXUc": "Update", "KKBCUX": "Validation failed", "KO2eUv": "Connectors", @@ -1043,7 +1043,6 @@ "MXTnCr": "Favorite", "MYgKHu": "Actions", "Mb/Vp8": "Next failed", - "MbUEdr": "Add a hand-off agent", "MbrpMM": "Configure channels for your agent", "Mc6ITJ": "Search", "MdtNYy": "Learn more about authentication", @@ -1309,6 +1308,7 @@ "SvQyvs": "Done", "SwWaHa": "Enter a valid run identifier", "Sy4cFC": "Concurrency control", + "Sy5Gcz": "Using a chat message trigger means your workflow will be conversational, which doesn't support actions running after an agent. Delete any actions running after an agent to use this trigger.", "SyFXM3": "Read less", "Sz8KN3": "Test", "T/7b2y": "Duration", @@ -1428,14 +1428,12 @@ "VLc3FV": "Source schema", "VLn4Dz": "Add images of this workflow as it appears in the designer in the original logic app. Take a screenshot in both light-mode and dar-mode versions. Upload files to Azure Blob Storage, then create a shared access signature (SAS) URL for each.", "VOk0Eh": "Request", - "VPVCkv": "Cannot paste actions below agentic loops in agent to agent workflows", "VPh9Jo": "(UTC+06:00) Novosibirsk", "VQ1BxQ": "Optional parameters", "VTMWCv": "Chat message", "VUH9aj": "23", "VUN/Gj": "Error loading tools. Please try again.", "VVfYvq": "Required. The number to divide by the Divisor.", - "VVp8sL": "Delete agentic loop", "VWH06W": "Please start the project by pressing F5 or run it through the Run and Debug view.", "VWd29W": "Basic workflow controls and operations", "VXpA1B": "Tools ({toolsCount})", @@ -1493,7 +1491,6 @@ "Wmc3Ux": "Run draft", "WnHWrD": "Workflow display name (title) is required.", "WnU9v0": "A managed identity is not configured on the logic app.", - "Wq8rLF": "Add an agentic loop", "Wt1TZJ": "Connections", "WtHzoy": "Agent log", "WtO4Wv": "No connection has been selected", @@ -1679,7 +1676,6 @@ "_+gBLFF.comment": "Title for the toaster after saving template.", "_+iPg27.comment": "Confirmation text for delete button", "_+ijo/2.comment": "Token picker for 'Paste last used expression'", - "_+jvca5.comment": "Description for dialog that appears when changing the kind of a node", "_+l5XmZ.comment": "description of maximum waiting runs setting", "_+mAJR3.comment": "Time zone value ", "_+mNJQl.comment": "Create new logic app link", @@ -1798,6 +1794,7 @@ "_1Orv4i.comment": "Title for the details section", "_1REu5/.comment": "Select to view fewer token options.", "_1Xke9D.comment": "aria label to open functions drawer", + "_1YUi9I.comment": "Text for button to add an agent", "_1ZrOYn.comment": "AI Foundry Project", "_1dlfUe.comment": "Description of what Actions are, on a tooltip about Actions", "_1eKQwo.comment": "Time zone value ", @@ -1939,7 +1936,6 @@ "_4aaixN.comment": "Button text for tour and tutorial", "_4bT5AR.comment": "Error message to show for connection error during deserialization.", "_4c0uPQ.comment": "Required string parameter to create a new parameter", - "_4gOrfY.comment": "Text for delete agentic loop modal body", "_4ggAK+.comment": "Error message for the agent instructions parsing failure.", "_4hi3ks.comment": "Chatbot workflow has been updated message", "_4hlqgK.comment": "Text to show when there are no search results", @@ -2263,7 +2259,6 @@ "_BuYrD3.comment": "Required format parameter to determine how to obtain GUID", "_BwOKWK.comment": "Label for the remember choice checkbox", "_Bwqlxd.comment": "Error message for key not found", - "_BwwhOM.comment": "Title for agent tool", "_BwxTBw.comment": "Loading logic apps", "_BxITRH.comment": "Required object parameter to check if greater than using greater function", "_BynK4X.comment": "Chatbot prompt to ask a question", @@ -2359,6 +2354,7 @@ "_E7NzDN.comment": "Button text for opening the settings", "_E7jFWU.comment": "Label for choosing logic app instance", "_E8iqLl.comment": "Time zone value ", + "_EAAlZ9.comment": "Title for agent node", "_ECZC6Y.comment": "Label for description of custom decimal Function", "_EE1vyH.comment": "Title for dialog that appears when changing the kind of a node", "_EFQ56R.comment": "Link to the source code of the template", @@ -2394,6 +2390,7 @@ "_F1AkvV.comment": "Second bullet point of stateful type", "_F2wR+r.comment": "Label for button to open expression token picker", "_F3IDl8.comment": "Required integer parameter to add to time", + "_F3q0Hk.comment": "Message shown when paste is disabled below agents in A2A workflows", "_F83QRP.comment": "Schedule trigger category", "_F9dR1Q.comment": "Add", "_F9yRDC.comment": "Label for the authentication method", @@ -2486,6 +2483,7 @@ "_HFt+tF.comment": "Favorites category", "_HH970i.comment": "Frequency value ", "_HILmmE.comment": "Required collection parameter to apply sort function on", + "_HMJPEj.comment": "Message shown when action addition is disabled within agents in A2A workflows", "_HMiE+4.comment": "Token picker for 'Exit full screen'", "_HOwcCC.comment": "Text for primary access key", "_HQ/HhZ.comment": "Title for error message when loading connections", @@ -2596,7 +2594,6 @@ "_K7/DnZ.comment": "The title of the output field in the static result parseJson action", "_K9ORYo.comment": "The title of the schema id field in the static result parseJson action", "_KBaGkS.comment": "Button text to take the user to the 'change connection' component while in xrm connection reference mode", - "_KFFF+N.comment": "Message shown when action addition is disabled within agentic loops in A2A workflows", "_KGvXUc.comment": "Button text for updating the MCP Server", "_KKBCUX.comment": "Title shown when there is an error in the template", "_KO2eUv.comment": "Label text for connectors filter", @@ -2693,7 +2690,6 @@ "_MXTnCr.comment": "Favorite button text", "_MYgKHu.comment": "Heading for a tooltip explaining Actions", "_Mb/Vp8.comment": "Button indicating to go to the next page with failed options", - "_MbUEdr.comment": "Text for button to add an agentic loop", "_MbrpMM.comment": "Channels tab description", "_Mc6ITJ.comment": "Placeholder text to search token picker", "_MdtNYy.comment": "Link text for authentication documentation", @@ -2959,6 +2955,7 @@ "_SvQyvs.comment": "confirmation text", "_SwWaHa.comment": "Invalid run identifier error message", "_Sy4cFC.comment": "title for concurrency setting", + "_Sy5Gcz.comment": "Description for dialog that appears when changing the kind of a node", "_SyFXM3.comment": "Text for read less button", "_Sz8KN3.comment": "Test", "_T/7b2y.comment": "Duration column header", @@ -3078,14 +3075,12 @@ "_VLc3FV.comment": "Source schema", "_VLn4Dz.comment": "Description for the workflow images section", "_VOk0Eh.comment": "Trigger belongs to Request category", - "_VPVCkv.comment": "Message shown when paste is disabled below agentic loops in A2A workflows", "_VPh9Jo.comment": "Time zone value ", "_VQ1BxQ.comment": "Label for the section to configure optional parameters", "_VTMWCv.comment": "Chat message trigger category", "_VUH9aj.comment": "Hour of the day", "_VUN/Gj.comment": "Error message when tools fail to load", "_VVfYvq.comment": "Required number parameter to be divided from in div function", - "_VVp8sL.comment": "Title for agentic loop node", "_VWH06W.comment": "Debug project error message", "_VWd29W.comment": "Simple Operations category description", "_VXpA1B.comment": "Title for the main section with the count of tools", @@ -3143,7 +3138,6 @@ "_Wmc3Ux.comment": "Run draft button text", "_WnHWrD.comment": "Error message when the workflow display name field which is title is empty", "_WnU9v0.comment": "Error message when no identity is associated", - "_Wq8rLF.comment": "Button text for adding an agentic loop", "_Wt1TZJ.comment": "Accessibility label for the connections section", "_WtHzoy.comment": "Agent log header text", "_WtO4Wv.comment": "Text to show that no connection has been selected", @@ -3370,6 +3364,7 @@ "_bg00eY.comment": "Numbered List text", "_bkuRuS.comment": "Text to show when there are no operations with the given filters", "_blRFVt.comment": "Chatbot connections setup card description", + "_blpdoG.comment": "Title for agent tool", "_boD8mP.comment": "Azure Cognitive Service Open AI resource label", "_bou7hY.comment": "Actions accordion title", "_boxBWI.comment": "Label text for the card that lets users replace the current workflow with blank workflow", @@ -3627,6 +3622,7 @@ "_hflWi6.comment": "Description for trimByteOrderMark function", "_hh3i/V.comment": "Other trigger methods category description", "_hhW/w8.comment": "Recurrence additional message if no minutes or starttime is specified", + "_hj/ald.comment": "Button text for adding an agent", "_hlrKDC.comment": "Column name for connection display name", "_ho2D6F.comment": "Close panel", "_hq1mk6.comment": "Error while parsing expression for path value", @@ -4180,7 +4176,6 @@ "_ti2c1D.comment": "Button text for moving to the next tab with action count", "_ti5TEd.comment": "Text for cancel button", "_tjQdhq.comment": "Solution type of the template", - "_tjg2VO.comment": "Button text for adding an agentic loop", "_tkkN++.comment": "Description for template profile tab", "_toHITB.comment": "BizTalk Migration category", "_toWTrl.comment": "Search from file list", @@ -4313,6 +4308,7 @@ "_wFCkpM.comment": "Require parameters to find minimum using min function", "_wG8fwz.comment": "Bullet List text", "_wGYmui.comment": "Header for including dynamic content section", + "_wK023m.comment": "Text for delete agent modal body", "_wKJdDk.comment": "Exception for unsupported token types", "_wP0/uB.comment": "Label for the button on the progress card that stops AI response generation", "_wPi8wS.comment": "Accessibility label indicating that the value is not set", @@ -4540,6 +4536,7 @@ "bg00eY": "Numbered list", "bkuRuS": "No operations found", "blRFVt": "Set up these connections to use them in your flow.", + "blpdoG": "Delete agent tool", "boD8mP": "Azure OpenAI resource", "bou7hY": "Actions", "boxBWI": "Replace your existing workflow with an empty workflow to rebuild your integration solution.", @@ -4797,6 +4794,7 @@ "hflWi6": "Removes Byte Order Mark (BOM) characters from the beginning of strings or binary content.", "hh3i/V": "Browse all available triggers", "hhW/w8": "If a recurrence doesn't specify a specific start date and time, the first recurrence runs immediately when you save or deploy the logic app", + "hj/ald": "Add an agent", "hlrKDC": "Connection", "ho2D6F": "Close panel", "hq1mk6": "Operation path value does not match the template for segment. Path {pathValue}, Template {pathTemplate}", @@ -5350,7 +5348,6 @@ "ti2c1D": "Next ({count} selected)", "ti5TEd": "Cancel", "tjQdhq": "Type", - "tjg2VO": "Add an agent", "tkkN++": "Add details to help template users evaluate this template. The profile includes the information shown to users and settings that control how the template is filtered and displayed.", "toHITB": "BizTalk Migration", "toWTrl": "Search", @@ -5483,6 +5480,7 @@ "wFCkpM": "Required. Either an array of values to find the minimum value, or the first value of a set.", "wG8fwz": "Bullet list", "wGYmui": "Including dynamic content", + "wK023m": "This will also delete the agent's tools and actions.", "wKJdDk": "Unsupported token type: {var}", "wP0/uB": "Stop generating", "wPi8wS": "----", diff --git a/libs/designer-ui/src/lib/modals/DeleteNodeModal.tsx b/libs/designer-ui/src/lib/modals/DeleteNodeModal.tsx index c09f48f6cd9..e1afabedb04 100644 --- a/libs/designer-ui/src/lib/modals/DeleteNodeModal.tsx +++ b/libs/designer-ui/src/lib/modals/DeleteNodeModal.tsx @@ -62,9 +62,9 @@ export const DeleteNodeModal = (props: DeleteNodeModalProps) => { }); const agentNodeTitle = intl.formatMessage({ - defaultMessage: 'Delete agentic loop', - id: 'VVp8sL', - description: 'Title for agentic loop node', + defaultMessage: 'Delete agent', + id: 'EAAlZ9', + description: 'Title for agent node', }); const switchCaseTitle = intl.formatMessage({ @@ -74,8 +74,8 @@ export const DeleteNodeModal = (props: DeleteNodeModalProps) => { }); const agentToolTitle = intl.formatMessage({ - defaultMessage: 'Delete agentic loop tool', - id: 'BwwhOM', + defaultMessage: 'Delete agent tool', + id: 'blpdoG', description: 'Title for agent tool', }); @@ -133,8 +133,8 @@ export const DeleteNodeModal = (props: DeleteNodeModalProps) => { const agentBodyMessage = intl.formatMessage({ defaultMessage: "This will also delete the agent's tools and actions.", - id: '4gOrfY', - description: 'Text for delete agentic loop modal body', + id: 'wK023m', + description: 'Text for delete agent modal body', }); const bodyMessage = diff --git a/libs/designer-v2/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx b/libs/designer-v2/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx index 625feb835e8..926a37dc844 100644 --- a/libs/designer-v2/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx +++ b/libs/designer-v2/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx @@ -205,15 +205,15 @@ export const EdgeContextualMenu = () => { }); const newAgentText = intl.formatMessage({ - defaultMessage: 'Add an agentic loop', - id: 'Wq8rLF', - description: 'Button text for adding an agentic loop', + defaultMessage: 'Add an agent', + id: 'hj/ald', + description: 'Button text for adding an agent', }); const newHandOffAgentText = intl.formatMessage({ defaultMessage: 'Add a hand-off agent', - id: 'MbUEdr', - description: 'Text for button to add an agentic loop', + id: '1YUi9I', + description: 'Text for button to add an agent', }); const pasteFromClipboard = intl.formatMessage({ @@ -229,9 +229,9 @@ export const EdgeContextualMenu = () => { }); const a2aAgentLoopDisabledText = intl.formatMessage({ - defaultMessage: 'Cannot add subsequent actions below agentic loops in agent to agent workflows', - id: 'KFFF+N', - description: 'Message shown when action addition is disabled within agentic loops in A2A workflows', + defaultMessage: 'Cannot add subsequent actions below agents in agent to agent workflows', + id: 'HMJPEj', + description: 'Message shown when action addition is disabled within agents in A2A workflows', }); const a2aParallelBranchDisabledText = intl.formatMessage({ @@ -241,9 +241,9 @@ export const EdgeContextualMenu = () => { }); const a2aPasteDisabledText = intl.formatMessage({ - defaultMessage: 'Cannot paste actions below agentic loops in agent to agent workflows', - id: 'VPVCkv', - description: 'Message shown when paste is disabled below agentic loops in A2A workflows', + defaultMessage: 'Cannot paste actions below agents in agent to agent workflows', + id: 'F3q0Hk', + description: 'Message shown when paste is disabled below agents in A2A workflows', }); const editHandoffText = intl.formatMessage({ diff --git a/libs/designer-v2/src/lib/ui/common/KindChangeDialog/KindChangeDialog.tsx b/libs/designer-v2/src/lib/ui/common/KindChangeDialog/KindChangeDialog.tsx index e3ba36c6b11..9c1695d2ea1 100644 --- a/libs/designer-v2/src/lib/ui/common/KindChangeDialog/KindChangeDialog.tsx +++ b/libs/designer-v2/src/lib/ui/common/KindChangeDialog/KindChangeDialog.tsx @@ -17,8 +17,8 @@ export const KindChangeDialog = () => { const toA2ADescription = intl.formatMessage({ defaultMessage: - "Using a chat message trigger means your workflow will be conversational, which doesn't support actions running after an agentic loop. Delete any actions running after an agent to use this trigger.", - id: '+jvca5', + "Using a chat message trigger means your workflow will be conversational, which doesn't support actions running after an agent. Delete any actions running after an agent to use this trigger.", + id: 'Sy5Gcz', description: 'Description for dialog that appears when changing the kind of a node', }); diff --git a/libs/designer/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx b/libs/designer/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx index 45366c19442..8275b52b397 100644 --- a/libs/designer/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx +++ b/libs/designer/src/lib/ui/common/EdgeContextualMenu/EdgeContextualMenu.tsx @@ -191,14 +191,14 @@ export const EdgeContextualMenu = () => { const newAgentText = intl.formatMessage({ defaultMessage: 'Add an agent', - id: 'tjg2VO', - description: 'Button text for adding an agentic loop', + id: 'hj/ald', + description: 'Button text for adding an agent', }); const newHandOffAgentText = intl.formatMessage({ defaultMessage: 'Add a hand-off agent', - id: 'MbUEdr', - description: 'Text for button to add an agentic loop', + id: '1YUi9I', + description: 'Text for button to add an agent', }); const pasteFromClipboard = intl.formatMessage({ @@ -214,9 +214,9 @@ export const EdgeContextualMenu = () => { }); const a2aAgentLoopDisabledText = intl.formatMessage({ - defaultMessage: 'Cannot add subsequent actions below agentic loops in agent to agent workflows', - id: 'KFFF+N', - description: 'Message shown when action addition is disabled within agentic loops in A2A workflows', + defaultMessage: 'Cannot add subsequent actions below agents in agent to agent workflows', + id: 'HMJPEj', + description: 'Message shown when action addition is disabled within agents in A2A workflows', }); const a2aParallelBranchDisabledText = intl.formatMessage({ @@ -226,9 +226,9 @@ export const EdgeContextualMenu = () => { }); const a2aPasteDisabledText = intl.formatMessage({ - defaultMessage: 'Cannot paste actions below agentic loops in agent to agent workflows', - id: 'VPVCkv', - description: 'Message shown when paste is disabled below agentic loops in A2A workflows', + defaultMessage: 'Cannot paste actions below agents in agent to agent workflows', + id: 'F3q0Hk', + description: 'Message shown when paste is disabled below agents in A2A workflows', }); const editHandoffText = intl.formatMessage({ diff --git a/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts b/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts index 2060414c257..c7ef9c26439 100644 --- a/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts +++ b/libs/logic-apps-shared/src/designer-client-services/lib/base/operations/agent.ts @@ -17,7 +17,7 @@ export const agentOperation = { }, summary: 'Agent', description: - 'Loop in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', + 'Action in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', visibility: 'Important', operationType: 'Agent', brandColor, diff --git a/libs/logic-apps-shared/src/designer-client-services/lib/consumption/manifests/agentloop.ts b/libs/logic-apps-shared/src/designer-client-services/lib/consumption/manifests/agentloop.ts index 5e8fa800e82..e80a7334f9c 100644 --- a/libs/logic-apps-shared/src/designer-client-services/lib/consumption/manifests/agentloop.ts +++ b/libs/logic-apps-shared/src/designer-client-services/lib/consumption/manifests/agentloop.ts @@ -7,7 +7,7 @@ export default { '', brandColor: '#00208A', description: - 'Loop in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', + 'Action in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', allowChildOperations: true, subGraphDetails: { diff --git a/libs/logic-apps-shared/src/designer-client-services/lib/consumption/operations/agent.ts b/libs/logic-apps-shared/src/designer-client-services/lib/consumption/operations/agent.ts index 40f17b491f5..4135c7b7705 100644 --- a/libs/logic-apps-shared/src/designer-client-services/lib/consumption/operations/agent.ts +++ b/libs/logic-apps-shared/src/designer-client-services/lib/consumption/operations/agent.ts @@ -17,7 +17,7 @@ export const agentOperation = { }, summary: 'Agent', description: - 'Loop in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', + 'Action in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', visibility: 'Important', operationType: 'Agent', brandColor, diff --git a/libs/logic-apps-shared/src/designer-client-services/lib/standard/manifest/agentloop.ts b/libs/logic-apps-shared/src/designer-client-services/lib/standard/manifest/agentloop.ts index f42a519025d..de160f429fa 100644 --- a/libs/logic-apps-shared/src/designer-client-services/lib/standard/manifest/agentloop.ts +++ b/libs/logic-apps-shared/src/designer-client-services/lib/standard/manifest/agentloop.ts @@ -7,7 +7,7 @@ export default { '', brandColor: '#00208A', description: - 'Loop in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', + 'Action in which the AI agent decides at each step which tools to use and how, and which text to generate to respond to the user.', allowChildOperations: true, subGraphDetails: { From cbd9488d8e76edeac4a7d0e4f803e96a6a9c13e0 Mon Sep 17 00:00:00 2001 From: Carlos Castro Date: Wed, 4 Feb 2026 15:29:30 -0500 Subject: [PATCH 3/3] Add unit tests for KindChangeDialog component --- .../__test__/KindChangeDialog.spec.tsx | 87 +++++++++++++++++++ 1 file changed, 87 insertions(+) create mode 100644 libs/designer-v2/src/lib/ui/common/KindChangeDialog/__test__/KindChangeDialog.spec.tsx diff --git a/libs/designer-v2/src/lib/ui/common/KindChangeDialog/__test__/KindChangeDialog.spec.tsx b/libs/designer-v2/src/lib/ui/common/KindChangeDialog/__test__/KindChangeDialog.spec.tsx new file mode 100644 index 00000000000..114f946c8a9 --- /dev/null +++ b/libs/designer-v2/src/lib/ui/common/KindChangeDialog/__test__/KindChangeDialog.spec.tsx @@ -0,0 +1,87 @@ +import React from 'react'; +import { render, screen, fireEvent } from '@testing-library/react'; +import { describe, vi, beforeEach, it, expect } from 'vitest'; +import { KindChangeDialog } from '../KindChangeDialog'; + +// Mock react-redux +const mockDispatch = vi.fn(); +vi.mock('react-redux', () => ({ + useDispatch: () => mockDispatch, + useSelector: vi.fn(), +})); + +// Mock react-intl +vi.mock('react-intl', async () => { + const actualIntl = await vi.importActual('react-intl'); + return { + ...actualIntl, + useIntl: () => ({ + formatMessage: vi.fn(({ defaultMessage }) => defaultMessage), + }), + }; +}); + +// Mock the modal selectors +let mockKindChangeDialogType: string | null = null; +const mockCloseKindChangeDialogAction = { type: 'modal/closeKindChangeDialog' }; +vi.mock('../../../../core', () => ({ + useKindChangeDialogType: () => mockKindChangeDialogType, + closeKindChangeDialog: () => mockCloseKindChangeDialogAction, +})); + +describe('KindChangeDialog', () => { + beforeEach(() => { + vi.clearAllMocks(); + mockKindChangeDialogType = null; + }); + + it('should not render dialog content when kindChangeDialogType is null', () => { + mockKindChangeDialogType = null; + + render(); + + expect(screen.queryByRole('dialog')).toBeNull(); + }); + + it('should render dialog with toA2A description when kindChangeDialogType is toA2A', () => { + mockKindChangeDialogType = 'toA2A'; + + render(); + + expect(screen.getByRole('dialog')).toBeInTheDocument(); + expect(screen.getByText('Update workflow before using this trigger')).toBeInTheDocument(); + expect(screen.getByText(/Using a chat message trigger means your workflow will be conversational/)).toBeInTheDocument(); + expect(screen.getByRole('button', { name: 'Close' })).toBeInTheDocument(); + }); + + it('should render dialog with toStateful description when kindChangeDialogType is toStateful', () => { + mockKindChangeDialogType = 'toStateful'; + + render(); + + expect(screen.getByRole('dialog')).toBeInTheDocument(); + expect(screen.getByText('Update workflow before using this trigger')).toBeInTheDocument(); + expect(screen.getByText(/Using this trigger changes your workflow to a type that doesn.t support handoffs/)).toBeInTheDocument(); + }); + + it('should render dialog with fromStateless description when kindChangeDialogType is fromStateless', () => { + mockKindChangeDialogType = 'fromStateless'; + + render(); + + expect(screen.getByRole('dialog')).toBeInTheDocument(); + expect(screen.getByText('Invalid trigger for stateless workflow')).toBeInTheDocument(); + expect(screen.getByText(/This preview version of logic apps does not yet support stateless logic apps/)).toBeInTheDocument(); + }); + + it('should dispatch closeKindChangeDialog action when Close button is clicked', () => { + mockKindChangeDialogType = 'toA2A'; + + render(); + + const closeButton = screen.getByRole('button', { name: 'Close' }); + fireEvent.click(closeButton); + + expect(mockDispatch).toHaveBeenCalledWith(mockCloseKindChangeDialogAction); + }); +});