UI5 intro
Dôvod vzniku
... ideme s dobou
R/2 od 1979
R/3 Dynpro
v4 od 1998
data:image/s3,"s3://crabby-images/92448/924485e30e7e7ff0c9fe383fe373dd987c132fee" alt=""
Webdynpro
od 2003
data:image/s3,"s3://crabby-images/c8f15/c8f157095af555b7c12eafde93d7ec50b484e0b7" alt=""
NWBC
od 2005
data:image/s3,"s3://crabby-images/93bfe/93bfe61b5873bf451ef2829dbf2ada23eba4fd23" alt=""
SAPUI5
od 2012
data:image/s3,"s3://crabby-images/50283/502835f8179158959e5d72fd5a272a15d6d108bc" alt=""
nezávislý od zariadenia => responsive
prepojenie
SAP UI5
OpenUI5 - open source
Fiori
aplikácie
UI frameworks
data:image/s3,"s3://crabby-images/9b191/9b191a5b5a5d970716608493f2968ac8df14a8d9" alt=""
FPM - Floorplan Manager
Technológie
data:image/s3,"s3://crabby-images/0bd10/0bd1085384adbec3123c2a34b99fd2e5ffdc3352" alt=""
+ preprocessor
data:image/s3,"s3://crabby-images/16940/169400735b0992303c7f72c06244a707f6e1d057" alt=""
data:image/s3,"s3://crabby-images/4c625/4c625a189322a395c81334467b76f784166966b7" alt=""
Ale hlavne...
data:image/s3,"s3://crabby-images/d97c4/d97c464af57c46149bf21c733fb2cf6e773423f1" alt=""
oplatí sa vedieť
XML
data:image/s3,"s3://crabby-images/e9d19/e9d194029055a191933441be1fe3edfe4a9d0244" alt=""
JSON
{ "Responsibility": [ { "id": 0,
"type": "none"
}, {
"id": 1,
"type": "responsible"
},
{
"id": 2,
"type": "backup"
}
] }
Gateway
OData
MVC
Model-View-Controller
data:image/s3,"s3://crabby-images/877cb/877cb1eff0ed8c7fc88932c1ebf669fda9196670" alt=""
MVC
control:UIComponent (Component.js) | +-- view:App (view/App.view.xml) | +-- control:SplitApp | +-- aggregation:masterPages | | | +-- view:Master (view/Master.view.xml) | | | +-- controller: Master (view/Master.controller.js) | +-- aggregation:detailPages | +-- view:Detail (view/Detail.view.xml) | | | +-- controller:Detail (view/Detail.controller.js) | +-- view:NotFound (view/NotFound.view.xml) | +-- view:AddProduct (view/AddProduct.view.xml) | +-- controller:AddProduct (view/AddProduct.controller.js)
Model
Client side
JSON model
XML model
Resource model - hlavne pre preklad
Server side
OData modeljeden hlavny model na aplikaciu
dalsie modely vo vlastnej "oblasti"
Model
OData
var url = "/proxy/http/<server>:<port>/sap/opu/odata/sap/ZGWSAMPLE_SRV/";
var oModel = new sap.ui.model.odata.ODataModel(url, true, "<user>", "<password>");
var oModel = new sap.ui.model.json.JSONModel("http://172.27.10.43/app/files/data.php");
var deviceModel = new sap.ui.model.json.JSONModel({
isPhone: sap.ui.Device.system.phone,
isNoPhone: ! sap.ui.Device.system.phone,
listMode: (sap.ui.Device.system.phone) ? "None" : "SingleSelectMaster",
listItemType: (sap.ui.Device.system.phone) ? "Active" : "Inactive"
});
oView.setModel(oModel);
oView.setModel(deviceModel, "device");
oView instanceof sap.ui.core.mvc.JSViewMODEL
Resource model
var i18nModel = new sap.ui.model.resource.ResourceModel({
bundleUrl: "i18n/i18n.properties"
});
oView.setModel(i18nModel, "i18n");
DomainsTitle=Domains
UsersTitle=Users
Persons=Persons
AddDomain=Add Domain
EditDomain=Edit Domain
DomainsTitle=Domény
UsersTitle=Užívatelia
Persons=Osoby
AddDomain=Pridať doménu
EditDomain=Upraviť doménu
i18n.propertiesi18n_sk_SK.propertiesDATA Binding
<List
id="list"
mode="{device>listMode}">
<items>
<StandardListItem
title="{i18n>DomainsTitle}"
type="Navigation"
press="handleDomains"
/>
<StandardListItem
title="{i18n>UsersTitle}"
type="Active"
press="handleUsers"
/>
</items>
</List>
Data binding
<List
id="list"
mode="{ui>/listMode}"
delete="handleDelete"
select="handleListSelect"
items="{/Data}">
<StandardListItem
title="{name}"
type="Active"
press="handleListItemPress">
</StandardListItem>
</List>
VIEW
koncovka .view.*
XML (moze byt mix spolu s HTML)
JSON
JS
HTML (data-* atributy)
VIEW
SAP.M.APP / SAP.M.SPLITAPP
data:image/s3,"s3://crabby-images/9c112/9c112fbd6b9f7027235c38c567bb7a63d7504d48" alt=""
Controller
eventy
onInit();
onExit();
onAfterRendering();
onBeforeRendering()
+ vlastne metódy
jQuery.sap.require("sap.m.MessageToast");
sap.ui.controller("tst.view.master.Master", {
handleDelete: function(e) {
var oItem = e.getParameter("listItem");
e.getSource().removeItem(oItem);
sap.m.MessageToast.show("Domain was deleted.");
}
});
Adresárová štruktúra
+---app | +---adminer | \---files +---assets | +---css | +---img | \---js +---i18n +---libs | +---dibi | \---tracy +---model +---resources +---util |---view | +---detail | +---fragments | \---master | +---Component.js \---index.html
Theming
data:image/s3,"s3://crabby-images/9f6f1/9f6f1b5fea23193eb12d1b69628a50eb7cbe3a99" alt=""
data:image/s3,"s3://crabby-images/9b7f7/9b7f7d0d4bbbf4f5d8598edaf49699ae832c6cec" alt=""
Vývoj
Notepad
...
Eclipse + Developer Tools
iný editor - Sublime Text
Zdroje
Debugging
data:image/s3,"s3://crabby-images/299f1/299f10b86069c2b3a43a11c97ff4c6a950b573e4" alt=""
Substitution
Miles plus
...
autorizácia
Zdroje
UI5 intro
By Roman Veselý
UI5 intro
in slovak
- 1,246