https://slides.com/fabiopagoti/sitjoi2016/

Slides

Vocabularies

&

    Smart Controls

 

Fábio Pagoti

Fábio Pagoti

Cursos de 

HANA, UI5, Fiori, Gateway

e tantos outros...

+ c/ - ?

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

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

<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

Serviço Importado

Vocabulary Importado

Anotando Serviço usando vocabulário

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

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

<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,859