JSON Configurations for SAP Business One Menu
This document provides a structure for configuring menu and context menu entries in SAP Business One. These entries can open web-based pages and applications, allowing integration with external resources. Through these configurations, you can add a main menu or context menu to existing forms, extract data from those forms, validate the data, generate URLs, and open web content within SAP Business One.
General Structure
Each UI entity (UiDescription
, UICondition
, UIParameter
) is represented as a JSON object. The fields within each object define properties of that entity, and the values must follow the specified rules. Below is a detailed explanation of the structure and purpose of each component.
UiDescription
Defines a UI element like a form, context menu, or analysis item. Here’s an example structure:
{
"Type": "Form",
"FormType": "frm_sales_order",
"MenuUid": "unique_sales_order",
"Url": "https://example.com",
"MenuCaption": "Sales Order",
"MenuCaptionTranslationId": "Menu_Translation_Id",
"TitleTranslationId": "Title_Translation_Id",
"Title": "Sales Order",
"Condition": { ... },
"Parameters": [ ... ]
}
- Type (required) - Specifies
"Form"
,"ContextMenu"
, or"Analytics"
to define the UI element type. - FormType - Unique identifier for forms; required for
Type
set to"ContextMenu"
. - MenuUid (required) - Unique identifier for the UI element.
- FatherMenuUid - Specifies the parent element; required if
Type
is"Form"
. - Url - (required): URL associated with the UI element.
- InternalUrl - Internal URL for a Plugin hosted in AppEngine.
- MenuCaption - Display text in the menu; required for
"ContextMenu"
and"Form"
. - Title - UI element title; required for all types.
- Condition - Specifies visibility conditions for
"ContextMenu"
. - Parameters - Array of
UIParameter
objects defining parameters. - MenuCaptionTranslationId - Translation ID for
MenuCaption
. - TitleTranslationId - Translation ID for
Title
.
UICondition
Specifies conditions for UI element visibility. Example structure:
{
"SuppFormMode": 1,
"ItemUid": "item_1",
"RequiredPlugin": "plugin_code",
"SQLCondition": "SELECT 1 WHERE EXISTS (SELECT * FROM table WHERE condition)"
}
- SuppFormMode (required) - Integer representing the form modes, from -1 to 15.
- ItemUid - Specifies the item UID for menu availability.
- SQLCondition - SQL query that returns
1
if the menu should be available; parameters must match those defined inParameters
. - RequiredPlugin - Plugin Code is required for the menu to be available.
UIParameter
Defines parameters for the UI element. Example structure:
{
"Name": "param1",
"Type": "string",
"Row": false,
"TableName": "Orders",
"ColumnName": "OrderID",
"SQLTransformQuery": "SELECT Column FROM Table WHERE Condition = @param2"
}
- Name (required) - Name of the Parameter.
- Type (required) - Parameter type (
string
,int
,float
,date
). - Row - Boolean indicating if the value comes from the current row (
true
) or first row (false
). - TableName - Required unless
SQLTransformQuery
is provided; specifies table source for parameter value. - ColumnName - Required unless
SQLTransformQuery
is provided; specifies column source for parameter value. - SQLTransformQuery - Optional SQL query to override
TableName
andColumnName
.
Validation Logic
-
Required Fields - All required fields must be provided.
-
Type-Specific Fields - Fields such as
FormType
,MenuCaption
, andMenuUid
are required depending on the UI element type. -
SuppFormMode - Value must be from -1 to 15:
- -1: Always visible
- 1: OK
- 2: Add
- 4: Find
- 8: View
-
SQLTransformQuery: Should use only parameters defined in the
Parameters
array of theUiDescription
. -
ContextMenu Requirements:
MenuCaption
,FormType
, andCondition
must be provided.
Ensure JSON configurations meet these specifications and validation rules for error-free, functional UI elements.
Examples
Example 1: Context Menu on Sales Order Form
This context menu is displayed for a selected row if the ItemCode
starts with "A" and opens a Google search for the item code.
{
"Type": "ContextMenu",
"Title": "StartWithATest",
"FormType": "139",
"MenuUid": "SOMatrixRow",
"InternalUrl": false,
"MenuCaption": "StartWithATest",
"Url": "https://www.google.com/search?q=@ItemCode",
"Condition": {
"SuppFormMode": -1,
"SQLCondition": "SELECT CASE WHEN LEFT(@ItemCode, 1) = 'A' THEN 1 ELSE 0 END FROM DUMMY",
"ItemUid": "38"
},
"Parameters": [
{
"Name": "ItemCode",
"Type": "string",
"TableName": "38",
"ColumnName": "1",
"Row": true
}
]
}
Example 2: Context Menu on Item Master Data
This context menu is displayed on the Item Master Data form if ItemCode
starts with "A".
{
"Type": "ContextMenu",
"Title": "StartWithATest",
"FormType": "150",
"MenuUid": "AEPlug12s3",
"InternalUrl": false,
"MenuCaption": "StartWithATest",
"Url": "https://www.onet.pl/",
"Condition": {
"SuppFormMode": -1,
"SQLCondition": "SELECT CASE WHEN LEFT(@ItemCode, 1) = 'A' THEN 1 ELSE 0 END FROM DUMMY"
},
"Parameters": [
{
"Name": "ItemCode",
"Type": "string",
"TableName": "OITM",
"ColumnName": "ItemCode"
}
]
}
Example 3: SAP Menu that Opens Plugin
This entry will be added to the SAP Business One menu and will appear under Stock Management with FatherMenuUid = "3072". The InternalUrl parameter is set to true, ensuring that the URL opens within the AppEngine Launchpad. The URL consists of two parts: "ct.vehone" represents the ui.apps.namespace of the plugin, and "home" is the route within the plugin. Additional parameters can be appended to the URL, as demonstrated in previous examples.
{
"Type": "Form",
"Title": "Vehicle One",
"MenuUid": "CT_VEHONE_MAIN",
"FatherMenuUid": "3072",
"MenuCaption": "Vehicle One",
"MenuCaptionTranslationId": "sapMenuTitle",
"Url": "ct.vehone,home",
"InternalUrl": true
}
This document ensures that each JSON configuration complies with SAP Business One requirements for seamless integration with external applications. Properly structured and validated configurations ensure seamless functionality, reducing errors and enhancing user experience.