Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sap-samples/ui5-exercises-codejam
Material for SAP CodeJam events about UI5. Step-by-step guide explaining how to build a frontend web application using UI5.
https://github.com/sap-samples/ui5-exercises-codejam
cloud-foundry exercises openui5 owner-nicoschoenteich sample sample-code sap-cap sap-codejam sap-fiori sapui5 web-development
Last synced: 6 days ago
JSON representation
Material for SAP CodeJam events about UI5. Step-by-step guide explaining how to build a frontend web application using UI5.
- Host: GitHub
- URL: https://github.com/sap-samples/ui5-exercises-codejam
- Owner: SAP-samples
- License: apache-2.0
- Created: 2022-04-20T12:43:52.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-09-27T06:51:07.000Z (4 months ago)
- Last Synced: 2025-01-08T14:32:55.157Z (14 days ago)
- Topics: cloud-foundry, exercises, openui5, owner-nicoschoenteich, sample, sample-code, sap-cap, sap-codejam, sap-fiori, sapui5, web-development
- Language: JavaScript
- Homepage:
- Size: 27.9 MB
- Stars: 57
- Watchers: 14
- Forks: 26
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
[![REUSE status](https://api.reuse.software/badge/github.com/SAP-samples/ui5-exercises-codejam)](https://api.reuse.software/info/github.com/SAP-samples/ui5-exercises-codejam)
# SAP CodeJam - UI5
This repository contains the material for SAP CodeJam events on UI5.
Please check the [prerequisites](/chapters/1.00-prep-dev-environment/readme.md#1-prerequisites) before the event an make sure you meet them.
## Overview
The material in this repository introduces you to the core principles of UI5, an enterprise-ready web development framework used to build apps that follow the Fiori design guidelines. This repository is a step-by-step guide explaining how build a frontend web application using UI5. The finished app is a bookshop app, where users can browse and order books. The app sits on top of the well-known [bookshop](https://github.com/SAP-samples/cloud-cap-samples/tree/main/bookshop) backend application built with the Node.js flavour of the SAP Cloud Application Programming Model (CAP).
![The finished app](/finished-app.png)
The finished UI5 bookshop app already exists in the [bookshop/finished-webapp](/bookshop/finished-webapp/) directory, but we want to rebuild it from scratch step by step. You can compare the finished app with your version in case you have issues along the way.
After reading all chapters and following the instructions, you will be able to build your own UI5 applications leveraging the official [SAPUI5 API Reference](https://sapui5.hana.ondemand.com/#/api).
## Previous Knowledge
The material in this repository aims to be beginner friendly. If you have never built a (UI5) web app before, you will still be able to follow along. No prior knowledge is required, although it certainly helps to have experience in (web) development.
The material includes additional explanations in collapsable sections (see example below), whenever a concept is used that web developers are probably already familiar with, but beginners might not be. You can decide for yourself whether you want to read or skip them.
See this example:
What is SAPUI5? 💬
> SAPUI5 is an HTML5 framework for creating cross-platform, enterprise-grade web applications in an efficient way.
>
> See this [blog post](https://blogs.sap.com/2021/08/23/what-is-sapui5/) for more information.## Material Organization
The material consists of a series of chapters, each in their own directory. The chapters build on top of each other and are meant to be completed in the given order. Each of the [chapters](#chapters) has its own 'readme' file with explanations, instructions, code samples and screen shots. From a session flow perspective, we are taking a "coordinated" approach:
The instructor will set you off on the first chapter. Do not proceed to the next chapter until the instructor tells you to do so. If you finish a chapter before others, there are some questions at the end of each chapter for you to ponder.
> The exercises are written in a conversational way - this is so that they have enough context and information to be completed outside the hands-on session itself. To help you navigate and find what you have to actually do next, there are pointers like this ➡️ throughout that indicate the things you have to actually do (as opposed to just read for background information).
## Chapters
- [00 - Preparing the Development Environment](/chapters/00-prep-dev-environment/)
- [01 - Scaffolding the App](/chapters/01-scaffolding/)
- [02 - Creating the First View](/chapters/02-first-view/)
- [03 - Creating and Consuming the First Model](/chapters/03-first-model/)
- [04 - Creating and Extending the First Controller](/chapters/04-first-controller/)
- [05 - Adding an 'Order' Feature](/chapters/05-order-feature/)
- [06 - Adding a 'Search' Feature](/chapters/06-search-feature/)
- [07 - Adding Expression Binding and Custom Formatting](/chapters/07-formatting/)
- [08 - Adding i18n Features](/chapters/08-i18n/)
- [09 - Adding Custom CSS](/chapters/09-custom-css/)
- [10 - Deploying the App](/chapters/10-deployment/) (Optional)
- [11 - Further Improvements and Learning Material](/chapters/11-further-improvements/)## SAPUI5 vs. OpenUI5
You will often read about either SAPUI5 or OpenUI5 when working with the framework. The main difference between the two is the license. Whereas SAPUI5 requires a license and is integrated into a lot of SAP products, OpenUI5 is open source and generally available under an Apache 2.0 license. SAPUI5 includes more libraries than OpenUI5, but the latter still contains all central functionality and most commonly used control libraries are identical in both deliveries.
The material in this repository would work with both deliveries, but uses OpenUI5. For the sake of simplicity and to indicate that the material would work with SAPUI5, too, the material simply refers to the framework as 'UI5'.
You can find more information about this in the [SAPUI5 Documentation](https://sapui5.hana.ondemand.com/#/topic/5982a9734748474aa8d4af9c3d8f31c0).
## Feedback
If you can spare a couple of minutes at the end of the session, please help the [author](https://github.com/nicoschoenteich) improve for next time by providing some feedback.
Simply use this [template](https://github.com/SAP-samples/ui5-exercises-codejam/issues/new?assignees=&labels=feedback&template=session-feedback-template.md&title=Session%20Feedback) link to create a special "feedback" issue, and follow the instructions in there.
Thank you!
## Support
Support for the content in this repository is available during SAP CodeJam events, for which this content has been designed. Otherwise, this content is provided 'as-is' with no other support.
## Contributing
If you wish to contribute code, offer fixes or improvements, please send a pull request. Due to legal reasons, contributors will be asked to accept a DCO when they create the first pull request to this project. This happens in an automated fashion during the submission process. SAP uses [the standard DCO text of the Linux Foundation](https://developercertificate.org/).## License
Copyright (c) 2022 SAP SE or an SAP affiliate company. All rights reserved. This project is licensed under the Apache Software License, version 2.0 except as noted otherwise in the [LICENSE](/LICENSE) file.