The UI5 Web Components are the new offering of UI5 to provide a set of reusable UI elements to you which can be used for your static web sites or for web application using any web framework of your choice with a minimalistic footprint. They allow you to create a consistent user experience aligned to the SAP Fiori Design Guidelines and incorporate the Fiori 3 design.
Web Components are a set of features which allow to enhance the HTML vocabulary with custom HTML elements when the standard HTML elements are not sufficient (for example, a Button with an icon or a DatePicker). The custom HTML elements allow to share those features and qualities in a standard way. The complexity of HTML, CSS and components behavior is encapsulated behind a custom HTML element. The interaction with the custom HTML elements is done using the standard DOM API.
OpenUI5 is a JS framework that lets you build enterprise-ready web applications, responsive to all devices, running on almost any browser of your choice. It's based on JavaScript, using jQuery as its foundation and follows web standards. It eases your development with a client-side HTML5 rendering library including a rich set of controls and supports data binding to different data models (JSON, XML and OData).
UI5 Web Components…
- …are not built on top of UI5, but rather lightweight and independent UI elements
- …are not a successor of UI5, but rather a complementary offering
- …bring the relevant UI5 qualities and SAP Fiori UX to the HTML level, usable with any web framework
UI5 Web Components are good for…
- …static web sites built without web frameworks, to just add a few interactive UI elements
- …web applications which already use a different web framework
UI5 remains what it is: the best choice for…
- …building complete enterprise-ready and responsive web applications
To consume UI5 Web Components, first you need to install the NPM module:
npm install @ui5/webcomponents
...and optionally:
npm install @ui5/webcomponents-fiori
for some more specific Fiori UX components such as ui5-shellbar
.
Import the desired component(s) in your app to define the UI5 Web Component.
For example, to use ui5-button
you need to import it:
import "@ui5/webcomponents/dist/Button.js"; // loads ui5-button
...similarly to use ui5-shellbar
:
import "@ui5/webcomponents-fiori/dist/ShellBar.js"; // loads ui5-shellbar
Then, you can use the custom element in an HTML page:
<ui5-button>Hello world!</ui5-button>
Note: For a full list of the UI5 Web Components (and the respective NPM modules that ship them), click here
Currently only Chrome, Safari and Firefox support Web Components natively.
If your application should run on browsers without native Web Components support (Edge and/or IE11), import one the following modules before your first Web Component import:
import "@ui5/webcomponents-base/dist/features/browsersupport/Edge.js";
import "@ui5/webcomponents-base/dist/features/browsersupport/IE11.js";
Note: Importing the module for IE11 support automatically enables Edge support as well, so there is no need to import them both explicitly.
Example:
import "@ui5/webcomponents-base/dist/features/browsersupport/IE11.js"; // This will enable Edge and IE11 support for all Web Components below
import "@ui5/webcomponents/dist/Button.js"; // loads ui5-button
import "@ui5/webcomponents/dist/Label.js"; // loads ui5-label
UI5 Web Components have built-in internationalization and globalization support. Language, compact/cozy switch, date/time settings and theme can be changed with parameters.
To provide configuration settings, create a script
tag having data-ui5-config
and type="application/json"
:
<script data-ui5-config type="application/json">
{
"theme": "sap_belize",
"language": "EN"
}
</script>
UI5 Web Components support right-to-left text direction (RTL). To enable RTL globally, provide the option rtl: true
in the configuration script
tag:
<script data-ui5-config type="application/json">
{
"language": "en",
"rtl": true
}
</script>
UI5 Web Components supports Compact
and Cozy
mode. It is set to Cozy
by default. To enable Compact
, provide the css class ui5-content-density-compact
to any of your HTML elements and it apply compact size to all of its children.
<body class="ui5-content-density-compact">
<ui5-button></ui5-button>
<ui5-checkbox></ui5-checkbox>
</body>
UI5 Web Components support different calendar types (Gregorian, Islamic, Japanese, Buddhist and Persian). To change them, provide the option calendarType: "Islamic"
in the configuration script
tag:
<script data-ui5-config type="application/json">
{
"calendarType": "Islamic"
}
</script>
You can clone the UI5 Web Components repository and start the Playground app with the following commands:
yarn # to install all dependencies
yarn start # to serve the project
This will open the Playground page in the browser!
To build the UI5 Web Components, just run the following commands:
yarn # to install all dependecies
yarn build # to build the project
Afterwards, you can find the static UI5 Web Components - Playground in the dist
folder of the playground.
In a couple of guides we refer to the Yarn node package manager. This is because it offers functionality that the otherwise preferred npm package manager is currently lacking. Namely, the workspace setting which is currently used in the OpenUI5 (mono-)repository. Note that npm might add this feature in the future.
Keep in mind that linking the same module with npm and Yarn may cause issues. Also, Yarn can't work with links created by npm and vice versa.
- UI5 Web Components
- UI5 Web Components Fiori
- UI5 Web Components Icons
- UI5 Web Components Base
- UI5 Web Components Theme Base
- UI5 Web Components Localization
None as of 1.0.0-rc.5
No major bugs known.
We welcome all comments, suggestions, questions, and bug reports. Please follow our Support Guidelines on how to report an issue, or chat with us in the #webcomponents
channel of the OpenUI5 Community Slack.
Please check our Contribution Guidelines.
Copyright (c) 2019 SAP SE or an SAP affiliate company. All rights reserved. This file is licensed under the Apache Software License, Version 2.0 except as noted otherwise in the LICENSE file.