TIP: To see the navigation parameters in use, see the navigation configuration example or configure a test application in the Luigi Fiddle.
Use the parameters and functions in this reference to configure your Luigi navigation structure.
- Routing parameters
- Navigation parameters
- Node parameters
- Profile
- Context switcher
- Product switcher
- App switcher
- Global search
You can configure the way Luigi tackles routing in your application in the routing:
section of the configuration file. For example, you can choose the routing strategy to apply in your application as either hash or path location routing.
- type: boolean
- description: defines either hash-based (
example.com/#/yourpath
) or path-based (example.com/yourpath
) routing. - default: the default is
false
, which means path routing is used.
- type: string
- description: sets the prefix character when using the
LuigiClient.linkManager().withParam()
function, which provides a simple way to attach query parameters to a view URL for activities such as sorting and filtering. Only this prefix can pass query parameters to micro frontends. A different prefix has to be used to pass parameters to the Luigi app itself to avoid potential conflicts between the two. - default: the default prefix character is
~
, but you may also define a custom one.
- type: RegExp[]
- description: defines regex patterns the router will skip when listening for path changes. This parameter is used for excluding redirect_uri parameters.
- default: the default patterns are
[/access_token=/, '/id_token=/]
.
- type: any
- description: defines custom behavior when a
404
error occurs. Luigi handles it by default. Leave its body empty if you have an external404
handling. You can return an Object with redirectTo parameter if you want Luigi to redirect to a specific navigation path after execution. - attributes:
- wrongPath (string): the path that the user tried navigating to.
- wasAnyPathFitted (bool): it is true if Luigi managed to fit a valid path which means wrongPath was only partially wrong. Otherwise it is false.
- type: boolean
- description: overrides the default behaviour of categories whether multiple categories can be collapsed. When set to
true
, only one category is collapsed. The navigation is similar to an accordion; when the user clicks another category the previously collapsed category is closed and the new one is opened. - default:
false
The navigation parameters allow you to configure global navigation settings directly under the navigation:
section in the configuration file.
- type: boolean
- description: if set to
true
, proper href attributes are added to all navigation links. It is set tofalse
by default. - since: v0.7.4
- type: any
- description: receives all values defined in the node configuration. It allows you to define a permission checker function that gets executed on every node. If it returns
false
, Luigi removes the node and its children from the navigation structure. See angular navigation.js for an example.
- type: function
- description: allows you to invoke and execute a specific function on the global level when a request to navigate to the node occurs. The function receives two node objects as input parameters: the previous node and current node, as described in the configuration.
- type: boolean
- description: renders all views in new frames. This setting overrides the same-domain frame reuse.
- default: the parameter defaults.isolateView is
false
by default, and you can overwrite it using the isolateView value on a single node level.
NOTE: The pageErrorHandler only works if the loading indicator is not disabled.
- type: object
- description: gives you the possibility to handle a situation in which Luigi Client doesn't respond. By default, it will redirect to the home page if nothing else is specified. timeout is required.
- default: the parameter defaults.pageErrorHandler is not specified by default, and you can overwrite it using the pageErrorHandler value on a single node level.
- attributes:
- timeout amount of time after which redirection will take effect.
- viewUrl specifies the location to redirect to on the micro frontend level (the main URL is not changed).
- redirectPath specifies the location to redirect to on the Luigi level (the main URL is changed).
- errorFn used to handle different scenarios other than redirection.
- since: v1.0.1
- type: boolean
- description: allows deactivating the default preloading of view groups iframes.
- type: object
- description: contains key-object pairs, where the key is the view group name as specified in the node parameters, and the object contains key-value pairs. In each key-value pair, the key is the feature name and the value is the actual setting. The following options are supported:
- attributes:
- preloadUrl(string): needs to be an absolute URL of a micro frontend belonging to a view group. It cannot be an URL of a node. It is recommended that you use a dedicated small, visually empty view, which imports Luigi Client and is fine with getting an empty context, for example, without an access token. The preloadUrl parameter is also required for view group caching in case you need a view group iframe to refresh whenever you navigate back to it.
- type: array
- description: contains an array of abstract intent objects that can be used to navigate through micro frontends through the LuigiClient linkManager.navigate() method. The attributes contained in each intent object of the array are abstract notations which can be used to define the target mapping of your desired intent navigation in a semantic way. Check our Advanced Scenarios page for an example.
- attributes:
- semanticObject(string): may represent a business entity such as a sales order or a product. It enables navigating to such entities in an abstract implementation-independent way. It can only only contain alphanumerical characters.
- action(string): defines an operation, i.e.:
display
,approve
oredit
. The operation is intended to be performed on a semanticObject such as a sales order or a certain product. It can only contain alphanumerical characters but also the underscore character. - pathSegment(string): represents the target of the navigation. In order to use it as a target link, it has to be defined under navigation nodes in the Luigi configuration.
- type: array
- description: a list of allowed web component URLs. They must be added as regular expressions to the array.
- example:
settings: {
navigation: {
validWebcomponentUrls:[
'https\:\/\/YOURPROJECT\.gitlab\.io\/.?'
]
}
Node parameters are all the parameters that can be added to an individual navigation node in the nodes:
section of the Luigi configuration file.
- type: string
- description: specifies the partial URL of the current segment. pathSegment must not contain slashes.
- examples:
- A static pathSegment of value
settings
results inexample.com/settings
. - A dynamic pathSegment is prefixed with a colon and can load any value. Find out more about dynamic paths in Luigi here.
- A static pathSegment of value
- type: string
- description: refers to an absolute path in the navigation structure or a relative path to a grandchild of the current path. If this parameter is defined, pathSegment is ignored.
- type: object
- description: indicates that the node links to an external URL. If this parameter is defined, pathSegment and link parameters are ignored.
- attributes:
- sameWindow defines if the external URL is opened in a new or current tab. The default value for this parameter
is
false
. - url is the external URL that the node leads to.
- sameWindow defines if the external URL is opened in a new or current tab. The default value for this parameter
is
- type: string
- description: contains the display name of the navigation node.
- type: string
- description: allows you to define your own custom testId to be used in E2E tests. If you do not specify it, it is a combination of the node's pathSegment followed by an underscore and the label, written as one word in lower case. If the pathSegment does not exist, the testId includes the label only. This way, you can have
pathsegment_label
orlabel
.
- type: boolean
- description: shows or hides a navigation node. You can still navigate to the node but it does not show up in the top or left pane.
- type: string
- description: contains the URL or path to a view which renders when you click the navigation node. Use either a full URL or a relative path. If viewUrl is undefined, Luigi activates the child node specified in defaultChildNode. When both viewUrl and defaultChildNode are undefined, Luigi opens the first child of the current node. viewUrl can contain variables from:
- dynamic path segments
- node parameters
- type: string
- description: contains a named node that is mainly for use in combination with a dynamic pathSegment to start navigation from a dynamic node using
LuigiClient.linkManager().fromContext('contextname')
.
- type: object
- description: sends the specified object as a context to the micro frontend.
- type: array | function
- description: in this element, you can specify children nodes. All children nodes will have the same parent prefix url. For example, if you look at our Fiddle showcase, you will see that home node has different children: this hierarchy will be reflected in children urls.
navigation: {
nodes: [{
pathSegment: 'home',
label: 'h',
hideFromNav: true,
children: [{
pathSegment: 'overview',
label: 'Overview',
icon: 'home',
viewUrl: '/examples/microfrontends/multipurpose.html',
context: {
title: 'Welcome to Luigi Fiddle!',
content: 'Click on "Modify Config" at the bottom right and play around with your Luigi configuration'
}
},
...
{
pathSegment: 'ui5sc',
label: 'Shopping Cart',
category: 'UI5 Demo Pages',
hideSideNav: true,
loadingIndicator: {
enabled: false
},
viewUrl: 'https://sapui5.netweaver.ondemand.com/test-resources/sap/m/demokit/cart/webapp/index.html'
}]
...
- type: string
- description: sets the child node that Luigi activates automatically if the current node has no viewUrl defined. Provide pathSegment of the child node you want to activate as a string.
NOTE: To define a root-level defaultChildNode which is different than the first header navigation node, set an object with defaultChildNode and children set to
navigation.nodes
instead of an array of nodes.
- example:
settings: {
navigation: {
nodes: {
defaultChildNode: 'overview',
children: [
{
pathSegment: 'docs',
label: 'Documentation',
viewUrl: '...'
},
{
pathSegment: 'overview',
label: 'Overview',
viewUrl: '...'
}
]
}
}
- type: boolean
- description: renders the view in a new frame when you enter and leave the node. This setting overrides the same-domain frame re-usage.
- default:
false
- type: string
- description: allows you to associate nodes to be rendered in the same iframe, as long as they belong to the same origin.
The value of this parameter is considered as the view group ID. If you want to use this feature, you must set preloadViewGroups to
true
and provide a preload URL for your view group ID in viewGroupsSettings. For further explanations, see this section. - example:
settings: {
navigation: {
preloadViewGroups: true,
viewGroupSettings:{
view_group_components: {
preloadUrl: '.....'
}
},
nodes: {
defaultChildNode: 'overview',
children: [
{
pathSegment: 'docs',
label: 'Documentation',
viewGroup: 'view_group_components',
viewUrl: '...'
},
{
pathSegment: 'overview',
label: 'Overview',
viewGroup: 'view_group_components',
viewUrl: '...'
}
]
}
}
- type: boolean
- description: focuses the navigation on its current hierarchy, omitting the display of children.
- type: boolean
- description: shows a loading indicator when switching between micro frontends. If you have a fast micro frontend, you can disable this feature to prevent flickering of the loading indicator.
- default:
true
- example:
loadingIndicator: { enabled: false }
- type: boolean
- description: if set to
false
, it disables the automatic hiding of the loading indicator once the micro frontend is loaded. It is only considered if the loading indicator is enabled. It does not apply if the loading indicator is activated manually with theLuigiClient.uxManager().showLoadingIndicator()
function. If the loading indicator is enabled and automatic hiding is disabled, useLuigiClient.uxManager().hideLoadingIndicator()
to hide it manually in your micro frontend during the startup. - default:
true
- example:
loadingIndicator: { hideAutomatically: false }
- type: string
- description: the name of an icon, without the
sap-icon--
prefix. Its source may be OpenUI or a custom link (relative or absolute) to an image. It is recommended to use a square image. The icon is displayed next to the node label in the side navigation or instead of the label in the top navigation. To show the label next to the icon in the top navigation, add theshowLabel
attribute.
- type: boolean
- description: Forces the label to be visible in the top navigation even if an icon is set.
- type: string
- description: adds the HTML
alt
attribute to an icon. Note that this property only applies to icons with a defined absolute or relative path.
- type: boolean
- description: if set to
true
, the left navigation disappears when you click the affected node. - default:
false
- type: object
- description: adds a badge with a number and a label to a node. Nodes that are part of a category show a cumulated number of all badges in this category.
- attributes:
- label is the label of the badge.
- count is a function or asynchronous function that returns a number.
Gets updated when you click the navigation. Use
Luigi.navigation().updateTopNavigation()
in Luigi Core or trigger it in Luigi Client by using the custom message feature.
- type: string or object
- description: defines a group of views separated with a headline and an icon. You should define at least one node in a group as an Object with label and icon attributes. For all other nodes, you can set category as a string with the
label
value. - attributes:
- label is a string that represents the title of the category.
- icon is the name of an icon, without the
sap-icon--
prefix. Its source may be OpenUI or a custom link (relative or absolute) to an image. It is recommended to use a square image. The icon is displayed next to the node label in the side navigation or instead of the label in the top navigation. In case you accidentally define different icons in a category group, only the first one is used. - altText adds the HTML
alt
attribute to an icon. Note that this property only applies to icons with a defined absolute or relative path. - collapsible if set to
true
, category items are hidden at first. To expand them, click the main category node. - testId is a string where you can define your own custom
testId
for E2E tests. If nothing is specified, it is the node's label written as one word in lower case, for examplelabel
.
- type: boolean or object
- description: configures the settings of a view which opens in a modal. You can set the openNodeInModal parameter to
true
to use the default modal title and size, or you can specify them using these attributes: - attributes:
- title is the modal title. By default, it is the node label. If there is no label, it is left empty.
- size specifies the size of the modal. The default size is
l
, which means 80% of the main window size. You can also usem
(60%) ands
(40%) to set the modal size.
- type: function
- description: executed when a request to navigate to the node occurs. As an input parameter, the function receives the node object as described in the configuration. This function can return results synchronously or asynchronously. If the function returns boolean
false
, the navigation is not triggered, otherwise, navigation renders as usual.
- type: boolean
- description: current locale can be changed from client using the corresponding API if this is set to
true
- example:
clientPermissions: { changeCurrentLocale: true }
- type: boolean
- description: renders the children of the node as a horizontal navigation bar. Sub-children are not supported. When you categorize nodes you will get a drop-down menu in the horizontal navigation.
- since: v0.7.0
- type: boolean or "exclusive"
- description: when set to
true
, the node is always accessible. When set toexclusive
, the node is only visible in logged-out state. Requires auth.disableAutoLogin to be set totrue
. anonymousAccess needs to be defined both on parent and child nodes.
- type: boolean
- description: marks the node as the beginning of a virtual tree. Allows navigation to any of its children's paths without the need of specifying nested children. The path that comes after the node marked as virtualTree is appended to its viewUrl. keepSelectedForChildren is automatically applied. This feature is often used in combination with LinkManager().withoutSync().navigate to be able to keep a micro frontend's existing router links.
- example:
In this example, navigating to
core.tld/settings/some/nested/view
will result in opening/sampleapp.html#/settings/some/nested/view
.{ pathSegment: 'settings', label: 'Settings', viewUrl: '/sampleapp.html#/settings', navigationContext: 'settings', virtualTree: true }
- since: v0.7.6
NOTE: The pageErrorHandler only works if the loading indicator is not disabled.
- type: object
- description: gives you the possibility to handle a situation in which Luigi Client doesn't respond. By default, it will redirect to the home page if nothing else is specified. timeout is required.
- attributes:
- timeout amount of time after which redirection will take effect.
- viewUrl specifies the location to redirect to on the micro frontend level (the main URL is not changed).
- redirectPath specifies the location to redirect to on the Luigi level (the main URL is changed).
- errorFn used to handle different scenarios other than redirection.
- since: v1.0.1
- type: array
- description: defines a list of feature toggles this node is restricted to. If all feature toggles in this list are active, the node will be visible in the top or left navigation. It is also possible to negate the feature toggle by adding a
!
in front of the toggle name. Then, the node is always visible except for the feature toggle defined with an exclamation mark. - example:
{ pathSegment: 'settings', label: 'Settings', viewUrl: '/sampleapp.html#/settings', navigationContext: 'settings', visibleForFeatureToggles:['ft1', '!ft2'] }
- since: 1.4.0
- type: boolean
- description: overrides the default behaviour of categories whether multiple categories can be collapsed. When set to
true
, only one category is collapsed. The navigation is similar to an accordion; when the user clicks another category the previously collapsed category is closed and the new one is opened. Note that this will be applied to its direct children. - default:
false
- type: boolean OR object
- description: mark a node as web component either by setting this attribute to
true
or defining an object with the attributes described below. In the latter case, theviewUrl
attribute of the node must point to the web component.js
file. - attributes:
- id: unique id of the web component
- type: string, like
module
. - selfRegistered: if it is
true
, the web component bundle will be added via script tag. - tagName: tag name where web component is added to DOM.
- since: 1.7.0
- type: object
- description: It is possible to compound web components in one micro frontend. Within this object, the layout of the web components can be defined. In addition, you can configure nested web components. In that case the parent web component has to be defined by a slot with a name to plug in the child web component. For example
<header><slot name="header">header</slot></header>
. Web components can communicate over an event bus. - attributes:
- renderer:
- type: object
- description: meta information about the layout of the compound web components
- attributes:
- use:
- type: string OR object
- description: You can define a CSS layout, like the CSS
grid
, or implement an extended layout by defining an object using theextends
property. In that case you have the possibility to implement the following functions to manipulate the standard renderer. - attributes:
- extends
- type: string, e.g.
grid
- description:
- type: string, e.g.
- createCompoundContainer
- type: function
- description: This function gets the grid layout
config
object as parameter.
- createCompoundItemContainer
- type: function
- description This function gets a the grid layout
config
object and the layout config object for the item.
- attachCompoundItem
- type: function
- description This function allows you to attach custom HTML to the item. This function gets the whole HTML container of the compound items and the item container as parameter.
- extends
- config:
- type: object
- description: defines the configuration object of the grid layout
- attributes:
- columns: represents the css
grid-template-columns
, e.g1fr 2fr
. - rows: represents the css
grid-template-rows
, e.g.150px 150px
. - gap: represents the css
grid-gap
, e.g.auto
. - min-height min height
- layouts
- type: array
- description: defines the configuration objects of the grid layout for media queries.
- attributes:
- columns: represents the css
grid-template-columns
, e.g1fr 2fr
. - rows: represents the css
grid-template-rows
, e.g.150px 150px
. - gap: represents the css
grid-gap
, e.g.auto
. - min-width min width
- max-width max width
- columns: represents the css
- columns: represents the css
- use:
- children
- type: array
- description: Array of web component nodes.
- attributes:
- id: unique
id
of the web component. - viewUrl: URL which points to the web component
.js
file. - context: object, which you can pass to the web component.
- layoutConfig: config object to define the position of an item in a grid. The properties are
row
andcolumn
and get the same values as in the CSS grid standard. If you want to use the mechanism of nested web components, you can define aslot
property with the slot name instead of the config object. In that case this web component node will be plugged in the parent web component. - eventListeners
- type: array
- description: array of events.
- attributes:
- source:
id
of the web component, which you want to listen. Alternatively you can set an asterisk, e.g.*
- name: name of the event, which this web component is listening to.
- action: type of the event, such as
update
. - dataConverter
- type function
- description This function gets the data object as parameter. If the received data are in a different format, you can use this function to convert the data.
- source:
- id: unique
- renderer:
- example:
{
pathSegment: 'webcomponent',
label: 'Webcomponent',
icon: 'along-stacked-chart',
loadingIndicator: {
enabled: false
},
context: {
title: 'Hello WebComponent!'
},
viewUrl: '/helloWorldWC.js',
webcomponent: true,
openNodeInModal: true
},
Below is Luigi's web component example configuration which shows 3 web components in a grid layout. It also includes the configuration for the event bus. The input
web component sends the typed input. The header
web component listens to a sendInput
event from a web component with the id input1
. Received data will be converted. An update
event will be triggered, changing the header
web component where an update
event listener is registered.
{
pathSegment: 'wc_grid',
label: 'Grid',
category: {
label: 'Compound',
icon: 'attachment-html',
collapsible: true
},
compound: {
renderer:
{
use: 'grid',
config: {
columns: '1fr 1fr 1fr',
/*rows: '150px',*/
/*gap: '30px',*/
layouts: [{
minWidth: 0,
maxWidth: 600,
columns: '1fr',
gap: 0
}, {
minWidth: 600,
maxWidth: 1024,
columns: '1fr 1fr',
gap: '30px'
}]
}
},
children: [{
viewUrl: 'URL_TO_HEADER_WEBCOMPONENT/panelHeader.js',
context: {
title: 'My Awesome Grid',
description: 'Really awesome'
},
layoutConfig: {
row: "1",
column: "1 / -1"
},
eventListeners: [{
source: 'input1',
name: 'sendInput',
action: 'update',
dataConverter: (data) => {
return 'new text: ' + data;
}
}]
}, {
id: 'input1',
viewUrl: 'URL_TO_SOME_WEBCOMPONENT/input.js',
context: {
title: 'Some input test',
instant: true
}
},
{
viewUrl: 'URL_TO_FOOTER_WEBCOMPONENT/panelFooter.js',
context: {
footer: 'This is the end of awesomeness'
},
layoutConfig: {
column: "1 / -1"
}
}]
}
}
- since: 1.7.0
The context switcher is a drop-down list available in the top navigation bar. It allows you to switch between a curated list of navigation elements such as Environments. To do so, add the contextSwitcher parameter to the navigation object using the following optional parameters:
- type: string
- description: specifies the default label that is shown if no context is selected.
- type: string
- description: specifies the base path, that is prepended to options[].pathValue. It must be an absolute path.
- type: boolean
- description: defines when to fetch options. When set to
true
, loads options when you click the context switcher. It doesn't involve any caching. When set tofalse
, loads options once the page loads. - default:
true
- type: array
- description: defines the list of context element.
- attributes:
- label defines the context element label. If not defined, the pathValue is passed to fallbackLabelResolver to set its value. The default value is pathValue, if fallbackLabelResolver is not defined.
- pathValue defines the context element path that is appended to parentNodePath and reflects a pathSegment.
- customRendererCategory defines a custom category for the option, which can be used by customSelectedOptionRenderer function to customize the rendering of the option when selected
- type: function
- parameters: option
- description: enables you to customize the selected option of the dropdown button of the context switcher by rendering HTML code inside a
<button>
. The function takes an option object as a parameter. It is recommended to use this function carefully because it is possible to inject JavaScript code. - since: v1.0.0
- type: function
- parameters: option, isSelected
- description: enables you to add custom items to the context switcher by rendering code inside a
<li>
element. The function takes an option object and a boolean isSelected as a parameter. It is recommended to use this function carefully because it is possible to inject JavaScript code. - since: v0.7.3
- type: array
- description: defines a list of additional elements that are shown on above or below the context switcher options.
- attributes:
- label defines the action element label.
- testId is a string where you can define your own custom
testId
for E2E tests. If nothing is specified, it is the node's label written as one word and lower case (e.g.label
). - position defines the action element position. Can be
top
orbottom
. The default value istop
. This parameter is optional. - link defines an absolute Link to a node. This parameter is optional.
- clickHandler specifies a function and is executed on click and should return a boolean. If it returns
true
, link is opened afterwards.
- type: any
- description: specifies a function used to fetch the label for options with no label defined. Additionally, it fetches the drop-down label for non-existing options.
- type: boolean
- description: if set to
true
, the labels retrieved through fallbackLabelResolver are cached within Luigi. This is useful, if fallbackLabelResolver is an async function which does a remote server call to fetch its value. - since: 1.4.0
- type: boolean
- description: if set to
true
, the sub-path is preserved on context switch.
- type: boolean
- description: if set to
false
, the drop-down is not shown on click if there is only one option and no actions. - default:
true
- since: v0.7.3
- type: string
- description: is the name of an icon from the OpenUI. It's displayed on smaller screens next to the default label or the selected context in a dropdown for the top navigation nodes. There is a default icon if nothing is set.
The profile section is a configurable drop-down list available in the top navigation bar. Within the configuration, you can override the logout item content (if authorization is configured) and/or add links to Luigi navigation nodes. To do so, add the profile parameter to the navigation object using the following optional parameters:
- type: object
- description: defines a list of additional elements that are shown on above or below the context switcher options.
- attributes:
- label overrides the text for the logout item. The default value is
Sign Out
. - testId is a string where you can define your own custom
testId
for E2E tests. If nothing is specified, it is the node's label written as one word and lower case (e.g.label
). - icon overrides the icon for the logout item. The default value is the SAP UI5 log icon.
- altText adds the HTML
alt
attribute to an icon. Note that this property only applies to icons with a defined absolute or relative path. - customLogoutFn defines a function to implement your own logout functionality. Use this function only if no IDP is configured. If you define IDP with a corresponding logout function, the customLogoutFn set for a profile is ignored.
- label overrides the text for the logout item. The default value is
- type: array
- description: an array of objects, each one being a link to a Luigi navigation node or an external URL.
- attributes:
- label defines the text for the link.
- testId is a string where you can define your own custom
testId
for E2E tests. If nothing is specified, it is the node's label written as one word and lower case (e.g.label
). - icon is the name of an icon from the OpenUI or a custom link (relative or absolute) to an image displayed next to the label or instead of it.
- altText adds the HTML
alt
attribute to an icon. Note that this property only applies to icons with a defined absolute or relative path. - link defines an absolute link to a node.
- openNodeInModal configures the settings of a view which opens in a modal. Details can be found here: openNodeInModal.
- externalLink is an object which indicates that the node links to an external URL. If this parameter
is defined, the link parameter
is ignored. It has the following attributes:
- sameWindow defines if the external URL is opened in the current tab or in a new one. The default value for this attribute
is
false
. - url is the external URL that the link leads to.
- sameWindow defines if the external URL is opened in the current tab or in a new one. The default value for this attribute
is
- type: function
- description: used to retrieve a user's name and email to simulate logging in. It can be used when authorization is disabled and also gets called if the defined IDP provider does not have settings.userInfoFn defined or does not provide a
userInfo
function internally. It can be asynchronous and should return an object with name, email and picture parameters. - since: v0.6.5
NOTE: Neither authorization nor profile parameter is configured if the profile section in the top navigation bar is not visible.
The product switcher is a pop-up window available in the top navigation bar. It allows you to switch between the navigation elements displayed in the pop-up. To do so, add the productSwitcher parameter to the navigation object using the following optional parameters:
- type: string
- description: defines the label of the product switcher. It is displayed as a title attribute on hover in the top navigation and as a headline in the mobile pop-up.
- type: string
- description: enables you to define your own custom
testId
for E2E tests. If nothing is specified, it is the node's label written as one word and lower case (e.g.label
).
- type: string
- description: the name of an icon, without the
sap-icon--
prefix. Its source may be OpenUI or a custom link (relative or absolute) to an image. The icon is displayed without label in the top navigation.
- type: string
- description: adds the HTML
alt
attribute to an icon. Note that this property only applies to icons with a defined absolute or relative path.
- type: number
- description: gives the possibility to define a number of columns to display products. It may be 3 or 4 columns. If nothing is specified, it is 4 columns by default.
- type: array
- description: an array of objects, each one being a link to a Luigi navigation node or an external URL. An item can have several attributes.
- attributes:
- label defines the text for the link.
- subTitle defines an additional text line for the link.
- testId is a string where you can define your own custom
testId
for E2E tests. If nothing is specified, it is the node's label written as one word and lower case (e.g.label
). - icon is the name of an icon from the OpenUI or a custom link (relative or absolute) to an image displayed next to the label or instead of it.
- altText adds the HTML
alt
attribute to an icon. Note that this property only applies to icons with a defined absolute or relative path. - link defines an absolute link to a node.
- selected if set to true, the item is displayed in selected state, useful e.g. if the item refers to the current product.
- externalLink is an object which indicates that the node links to an external URL. If this parameter
is defined, the link parameter
is ignored. It has the following attributes:
- sameWindow defines if the external URL is opened in the current tab or in a new one. The default value for this attribute
is
false
. - url is the external URL that the link leads to.
- sameWindow defines if the external URL is opened in the current tab or in a new one. The default value for this attribute
is
The app switcher is a drop-down list available in the top navigation bar. It allows you to switch between application elements displayed in the drop-down. To do so, add the appSwitcher parameter to the navigation object using the following optional parameters:
- type: boolean
- description: includes the link to the root of the Luigi application in the drop-down using the title specified in the settings/header section of the configuration as a label.
- type: array
- description: defines the list of application elements.
- attributes:
- title defines the application title. This is shown in the appSwitcher drop-down as well as the title in the header of the Luigi application if a user is in the context of the app.
- subTitle defines the application sub-title. This is shown as the sub-title in the header of the Luigi application if a user is in the context of the app.
- link is a link within the Luigi application that defines the root of the app. It is used to switch to the application if the drop-down entry is selected. It is also used to determine if a user is within the app's scope, so that the corresponding title and sub-title can be rendered in the header.
The global search is an input field available in the top navigation bar. The search is available if the Luigi configuration file contains on its root level a section called globalSearch
. Within this section you can implement and configure a search provider object.
- type: boolean
- description: disables the on:keyUp and other internal handlers on the search input field. It is a plain input field then, which can be used to attach your own handlers. If set to
true
, a searchProvider must be defined in order to show the search field, which can contain your custom logic. It is recommended to initialize your custom logic in the lifeCycle.luigiAfterInit hook. - since: 1.5.0
- type: Object
- description: The search provider is an object which contains different events and the possibility to implement a custom result renderer or change only the search result item.
- attributes:
- onInput
- type: Function
- description: will be executed on every key-up event.
- onEnter
- type: Function
- description: will be executed when the user presses 'Enter'.
- onEscape
- type: Function
- description: will be executed when the user presses 'Escape'.
- customSearchResultRenderer
- type: Function
- description: This function allows you to append your custom search result to a slot which Luigi provides for you. If this function is implemented the default search result popover is disabled.
- attributes:
- searchResults
- type: Array
- description: array of search result items
- slot
- type: DIV element
- description:
div
element as slot. You can append a custom implementation of the search result to thisdiv
element.
- searchApiObj
- type: Object
- description: It is an object with a function
fireItemSelected
as property. This function gets a search result item as parameter and fires the search provider eventonSearchResultItemSelected
.
- searchResults
- customSearchResultItemRenderer
- type: Function
- description: This function allows you to customize the single list element rendered in the default search result popover.
- attributes:
- searchResultItem
- type: Object
- description: search result item
- slot
- type: LI element
- description:
li
element as slot. You can append a custom implementation of asearchResultItem
to thisli
element.
- searchApiObj
- type: Object
- description: It is an object with a function
fireItemSelected
as property. This function gets asearchResultItem
as parameter and fires the search provider eventonSearchResultItemSelected
.
- searchResultItem
- onSearchResultItemSelected
- type: Function
- description: will be executed when the user clicks on a
searchResultItem
. - attribute searchResultItem
- inputPlaceholder
- type: string
- description: This text will be used as placeholder in the search input field.
- inputPlaceholder
- type: Function
- description: Output of this function will be used as placeholder in the search input field.
- inputPlaceholder
- type: Object
- description: Key value JSON object, where
key
is the language andvalue
is the text used as placeholder in the search input field. This function doesn't have any input parameter.
- toggleSearch
- type: Function
- description: This function will be executed every time you click on the search icon. - attributes:
- element
- type: INPUT element
- description: the input element where the user enters the search text.
- visible
- type: boolean
- description: specifies if the input text is visible or not.