https://slides.com/fabiopagoti/sitjoi2016/
Slides
data:image/s3,"s3://crabby-images/b995c/b995c1f8eea3f60bf25f3607a2426a20c5ecbba5" alt=""
Vocabularies
&
Smart Controls
Fábio Pagoti
data:image/s3,"s3://crabby-images/ef250/ef2501caa14692eb20e764ff61bda267964313a8" alt=""
data:image/s3,"s3://crabby-images/5742c/5742cd488897076f4baab6a582fb1c1b4032d73b" alt=""
data:image/s3,"s3://crabby-images/b745a/b745a73a07d6db75ab0ff67eec5fe3ff9aa516e3" alt=""
Fábio Pagoti
Cursos de
HANA, UI5, Fiori, Gateway
e tantos outros...
data:image/s3,"s3://crabby-images/93cde/93cdecae523f5e1c977e731a04ca966a9f68cfb8" alt=""
+ c/ - ?
data:image/s3,"s3://crabby-images/15e0b/15e0b7d3f47567ea2edfc417bb0041e3b97df171" alt=""
Evolução do SAPUI5
1.25
1.28
Smart Form
Smart Table
Evolução do SAPUI5
1.30
Semantic Page
Evolução do SAPUI5
1.34
Smart Chat e Smart Micro Chart
data:image/s3,"s3://crabby-images/5b986/5b986edf0d67cc6aa600a9955aa31b55d5e2f19f" alt=""
1.38
Smart Micro Chart
<SmartBulletMicroChart
entitySet="Products" />
As regras de exibição estão no backend, escritas em oData Annotations
oData
Vocabularies e Annotations
Bê-a-bá de oData
- Entity Type
- Entity Set
- Property
- Association
- Association Set
$metadata sem annotations
<EntityType Name="Subscription">
<Key>
<PropertyRef Name="ID" />
</Key>
<Property Name="ID" Type="Edm.String" Nullable="false" MaxLength="32" />
<Property Name="user" Type="Edm.String" MaxLength="12" />
<Property Name="title" Type="Edm.String" MaxLength="255" />
<Property Name="deliveryAddress" Type="Edm.String" />
</EntityType>
$metadata c/ annotations
<EntityType Name="Subscription"
sap:semantics="subscriptions"
sap:content-version="1">
<Key>
<PropertyRef Name="ID" />
</Key>
<Property Name="ID" Type="Edm.String" Nullable="false" MaxLength="32"
sap:label="Sub. ID"
sap:creatable="false"
sap:updatable="false"
sap:filterable="false" />
<Property Name="user" Type="Edm.String" MaxLength="12" sap:label="User Name" sap:creatable="false" sap:filterable="false" />
<Property Name="title" Type="Edm.String" MaxLength="255" sap:label="Title" sap:filterable="false" />
<Property Name="deliveryAddress" Type="Edm.String" sap:label="Delivery Address" sap:filterable="false" />
</EntityType>
SEGW
Os annotations básicos são definidos via interface gráfica
SEGW
Como ~99% dos projetos são criados
Service with SAP Annotations
Vocabulary Repository
XMLs que criam novos annotations
data:image/s3,"s3://crabby-images/485b2/485b2d980a281beedca6e7d271cf2cf7a10d122b" alt=""
data:image/s3,"s3://crabby-images/6ec2f/6ec2f90f4f07122d34d282cea5dd5401d16ff3e9" alt=""
<Term Name="Updatable"
AppliesTo="EntityType"
Type="Edm.Boolean"
DefaultValue="true" >
<Annotation Term="Core.Description">
<String>
Specifies whether the annotated entity can be updated
</String>
</Annotation>
</Term>
Vocabulário "com.sap.vocabularies.Common.v1"
SEGW
Desbravando o inexplorado
Annotations for Service
O que faz um projeto de annotation?
Serviço + Vocabulário
data:image/s3,"s3://crabby-images/16e1b/16e1bed71a7c1e9ae0d6f3dbec875170beb4c6b7" alt=""
Serviço Importado
Vocabulary Importado
Anotando Serviço usando vocabulário
data:image/s3,"s3://crabby-images/3dfc1/3dfc1d84effe48118f7145e28fb2d75bf4668a77" alt=""
data:image/s3,"s3://crabby-images/f2bd3/f2bd367c300d5cb9a8c5f78365ca67228d59c023" alt=""
Editor de annotation
Classes Geradas
- DPC (Data Provider Class)
- MPC (Model Provider Class)
- APC (Annotation Provider Class)
Código UI5
- Component.js + manifest.json
- Sem visões
- Sem controllers
- Suporte a MockData
- 2 modelos no manifest.json
manifest.json
"dataSources": {
"mainService": {
"uri": "/sap/opu/odata/sap/ZPROJETO_TIPO_1_SRV/",
"type": "OData",
"settings": {
"annotations": [
"ZPROJETO_TIPO_3"
],
"localUri": "localService/metadata.xml"
}
},
"ZPROJETO_TIPO_3": {
"uri": "/sap/opu/odata/IWFND/CATALOGSERVICE;v=2/Annotations(TechnicalName='ZPROJETO_TIPO_3',Version='0001')/$value/",
"type": "ODataAnnotation",
"settings": {
"localUri": "localService/ZPROJETO_TIPO_3.xml"
}
}
},
Resultado Final
data:image/s3,"s3://crabby-images/574c9/574c961d6cf389bb69039f756458651246de68c7" alt=""
Prós
- + c/ -
- Praticidade
- Protótipos no BUILD
- Web IDE no HCP
- Regra no Back-End
Contras
- Falta de documentação
- Dependência de versões recentes do UI5
- Falta de documentação
- Nada adaptável
- Falta de documentação
- Regra no Back-End
+ Info
SAPUI5 Explored (Pesquisar por "Smart")
https://sapui5.netweaver.ondemand.com/explored.html
Web IDE Annotation Modeler
https://help.hana.ondemand.com/webide/frameset.htm?fe8ba75588964d3bbfc5c1bf96b04d1e.html
<MessageStrip
text="Obrigado!!!"
type="Success"
showIcon="true">
</MessageStrip>
oData Vocabularies & SAPUI5 Smart Controls
By Fabio Luiz Esperati Pagoti
oData Vocabularies & SAPUI5 Smart Controls
Vocabulários oData e UI5 Smart Controls
- 1,889