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-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);
+ });
+});
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 db7f6e6230e..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
@@ -15,9 +15,9 @@ 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.',
+ '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: {