Skip to content

Latest commit

 

History

History
104 lines (76 loc) · 4.63 KB

luigi-ux-features.md

File metadata and controls

104 lines (76 loc) · 4.63 KB

Luigi UX features

Rendering of Luigi application in the DOM

By default, Luigi content, including the top navigation, left navigation, and the content iframe area, are rendered in the body tag of your Luigi Core application. As a result, Luigi content takes the whole space of your browser window.

However, you can render Luigi content in any other HTML container. It can be useful if you want to add a header or a footer on top of the Luigi content. To use this feature, add the luigi-app-root custom HTML attribute to the HTML tag in which you want to render the Luigi content.

NOTE: If you render the Luigi content in a custom container, the container is positioned relatively when you apply your own CSS. Also, set the height of the Luigi custom container either in px or vh.

Responsive application setup

You can quickly adjust the Luigi application to improve user experience on mobile devices, such as smartphones or tablets. Here are some examples:

  • Add the following line to your index.html file for the Luigi application to render well on a mobile device:
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1">
  • Define and apply responsiveNavigation settings to make the left navigation responsive.

  • Define and apply profileType 'simple' or 'Fiori3' to change the Profile Menu layout and design.

  • Define a custom width for the left side navigation. To do so, simply add the code below to the top of your index.html. The default width is 15rem.

:root{
  --luigi__left-sidenav--width: yourCustomWidth;
}
  • Define a custom width for the App Title on desktop and mobile simultaneously. To do so, simply add the code below to the top of your index.html. The default width --luigi__app-title--width: 60vw; and --luigi__multi-app-dropdown--width: 50vw;
:root{
  --luigi__app-title--width: yourCustomSinglAppTtitleWidth;
  --luigi__multi-app-dropdown--width: yourCustomMultiAppDropdownWidth;
}

App loading indicator

To show a loading indicator before Luigi Core or your first micro frontend is ready, add a container with the luigi-app-loading-indicator attribute to your index.html body or inside your luigi-app-root container.

<div luigi-app-loading-indicator>
  <div class="fd-busy-indicator--m" aria-hidden="false" aria-label="Loading">
    <div class="fd-busy-indicator--circle-0"></div>
    <div class="fd-busy-indicator--circle-1"></div>
    <div class="fd-busy-indicator--circle-2"></div>
  </div>
</div>

To automatically remove the loadining indicator after Luigi initialization phase you can set settings.appLoadingIndicator.hideAutomatically to true.

To keep the loading indicator until the first micro frontend is usable, follow these steps:

  1. Set the app loading indicator parameter hideAutomatically to false
{
  ...
  settings: {
    appLoadingIndicator: {
      hideAutomatically: false
    }
  }
  ...
}
  1. To remove the loading indicator, call Luigi.ux().hideAppLoadingIndicator() in Luigi Core once your initial micro frontend has finished loading. You can, for example, use the custom messages feature to allow the Luigi Client micro frontend to communicate with the Core when this function should be executed.

Collapsed left side navigation

If you use responsiveNavigation = 'semiCollapsible' or 'Fiori3' mode in your settings, you can adjust collapsed state of the left side navigation by using the collapseLeftSideNav function.

  • To close the left side navigation, execute Luigi.ux().collapseLeftSideNav(true) in Luigi Core once your initial micro frontend has finished loading. It will set the collapsed state to true in Local Storage. Which closes the left side navgation, by showing only icons.

  • Set the value to false if you want to open left side navigation.