Technology Blogs by SAP
Learn how to extend and personalize SAP applications. Follow the SAP technology blog for insights into SAP BTP, ABAP, SAP Analytics Cloud, SAP HANA, and more.
cancel
Showing results for 
Search instead for 
Did you mean: 
former_member246153
Active Contributor
2,531
Issue

In my scenario i have a SmartFilter bar bound with an EntitySet in my Fiori application. I have enabled the SmartVariant for the SmartFilterBar. With that i have also added two custom fields to my SmartFilter bar. The values of the custom fields are bound to a local JsonModel. So while saving the variant my custom fields are getting ignored and it only saves the standard selection fields which are exposed in the CDS.
<smartFilterBar:SmartFilterBar id="smartFilterBar" useToolbar="false" smartVariant="VariantId"
persistencyKey="SmartFilterPKey" entitySet="EntitySetName" enableBasicSearch="false">
<smartFilterBar:controlConfiguration>
<smartFilterBar:ControlConfiguration key="Key1" visibleInAdvancedArea="true">
<smartFilterBar:customControl>
<Custom Filed1...
value="{customFilterModel>/value1}">
<smartFilterBar:customControl>
</smartFilterBar:ControlConfiguration>
</smartFilterBar:ControlConfiguration>
<smartFilterBar:ControlConfiguration key="Key2" visibleInAdvancedArea="true">
<smartFilterBar:customControl>
<Custom Filed2..
value="{customFilterModel>/value2}">
<smartFilterBar:customControl>
</smartFilterBar:ControlConfiguration>
</smartFilterBar:controlConfiguration>
</smartFilterBar>

 

Solution

The SmartFilterBar has two events that can be used to save the custom fields to the selected smart variant

  • beforeVariantFetch

  • afterVariantLoad


<smartFilterBar:SmartFilterBar id="smartFilterBar" useToolbar="false" smartVariant="VariantId"
persistencyKey="SmartFilterPKey" entitySet="EntitySetName" enableBasicSearch="false"
beforeVariantFetch="onBeforeVariantFetch" afterVariantLoad="onAfterVariantLoad">
<smartFilterBar:controlConfiguration>
<smartFilterBar:ControlConfiguration key="Key1" visibleInAdvancedArea="true">
<smartFilterBar:customControl>
<Custom Filed1...
value="{customFilterModel>/value1}">
<smartFilterBar:customControl>
</smartFilterBar:ControlConfiguration>
</smartFilterBar:ControlConfiguration>
<smartFilterBar:ControlConfiguration key="Key2" visibleInAdvancedArea="true">
<smartFilterBar:customControl>
<Custom Filed2..
value="{customFilterModel>/value2}">
<smartFilterBar:customControl>
</smartFilterBar:ControlConfiguration>
</smartFilterBar:controlConfiguration>
</smartFilterBar>

beforeVarientSave

This event is fired before a variant is saved. The event can be used to adapt the data of the custom filters, which will be saved as variant later.
onBeforeVariantFetch: function () {
let customFiltersObject = this.getModel("customFilterModel").getData();
this.byId("smartFilterBar").setFilterData({
_CUSTOM: customFiltersObject
});
}

So here we are getting custom fields data form the customFilterModel and setting this data with the property _CUSTOM to FilterData property of the SmartFilterBar. So these Custom Fields data will be retained while saving the variant.

afterVariantLoad

This event is fired after a variant has been loaded and applied to the FilterBar. The event can be used to adapt custom filters with data from the variant.
onAfterVariantLoad: function () {
let filterData = this.byId("smartFilterBar").getFilterData();
this.getModel("customFilterModel").setData(filterData._CUSTOM);
}

Here while loading the variant we are using this event handler to get the SmartFilterBar FilterData and set the _CUSTOM property values to the customFilterModel which is bound to the custom Fields in the UI.

 

Conclusion

With the help of these event handlers we are able to save and retrieve the custom filed values of the SmartFilterBar along with the SmartVariant.

Please feel free to ask your questions or post your comments.

Thanks.
1 Comment
DanieleInc
Participant
THANK YOU!

 

You saved my life!


I attach my use case with MultiComboBox, in extension project of app "PurchaseRequisition manage":




 
onAfterVariantLoad: function (oEvent) {
// debugger;
var filterData = this.byId("idSmartFilterPR").getFilterData();
// this.getModel("customFilterModel").setData(filterData._CUSTOM);
if (filterData._CUSTOM) {
this.byId("idMultiComboPlant").setSelectedKeys(filterData._CUSTOM.Plant !== undefined ? filterData._CUSTOM.Plant : []);
this.byId("idMultiComboPurGroup").setSelectedKeys(filterData._CUSTOM.PurchasingGroup !== undefined ? filterData._CUSTOM.PurchasingGroup : []);
this.byId("idMultiComboPurOrg").setSelectedKeys(filterData._CUSTOM.PurchasingOrganization !== undefined ? filterData._CUSTOM.PurchasingOrganization : []);
this.byId("idMultiComboLgort").setSelectedKeys(filterData._CUSTOM.lgort !== undefined ? filterData._CUSTOM.lgort : []);
}
},
onBeforeVariantFetch: function (oEvent) {
// debugger;
// var customFiltersObject = this.getModel("customFilterModel").getData();
var aPlantKeys = this.byId("idMultiComboPlant").getSelectedKeys();
var aPurGroupKeys = this.byId("idMultiComboPurGroup").getSelectedKeys();
var aPurOrgKeys = this.byId("idMultiComboPurOrg").getSelectedKeys();
var aLgortKeys = this.byId("idMultiComboLgort").getSelectedKeys();
this.byId("idSmartFilterPR").setFilterData({
_CUSTOM: {
Plant: aPlantKeys,
PurchasingGroup: aPurGroupKeys,
PurchasingOrganization: aPurOrgKeys,
lgort: aLgortKeys
}
});
},

 
<smartfilterbar:ControlConfiguration controlType="auto" groupId="_BASIC" hasValueHelpDialog="true" index="1" key="Plant"
label="{i18n>Plant}" preventInitialDataFetchInValueHelpDialog="false" visible="true">
<smartfilterbar:customControl>
<MultiComboBox id="idMultiComboPlant" showSecondaryValues="true" items="{zCustPurReq>/VH_DivisioneSet}" selectionChange="onChangePlant">
<!--selectedKeys="{local>/PlantKeys}"-->
<core:ListItem text="{zCustPurReq>Name1}" additionalText="{zCustPurReq>Werks}" key="{zCustPurReq>Werks}"/>
</MultiComboBox>
</smartfilterbar:customControl>
</smartfilterbar:ControlConfiguration>
<smartfilterbar:ControlConfiguration controlType="auto" groupId="_BASIC" hasValueHelpDialog="true" index="2" key="PurchasingGroup"
label="{i18n>PurgGrp}" preventInitialDataFetchInValueHelpDialog="false" visible="true">
<smartfilterbar:customControl>
<MultiComboBox id="idMultiComboPurGroup" showSecondaryValues="true" items="{zCustPurReq>/VH_PurGroupSet}">
<!--selectedKeys="{local>/PurchasingGroupKeys}"-->
<core:ListItem text="{zCustPurReq>Eknam}" additionalText="{zCustPurReq>Ekgrp}" key="{zCustPurReq>Ekgrp}"/>
</MultiComboBox>
</smartfilterbar:customControl>
</smartfilterbar:ControlConfiguration>
<smartfilterbar:ControlConfiguration controlType="auto" groupId="_BASIC" hasValueHelpDialog="true" index="3" key="PurchasingOrganization"
label="{i18n>PurgOrg}" preventInitialDataFetchInValueHelpDialog="false" visible="true">
<smartfilterbar:customControl>
<MultiComboBox id="idMultiComboPurOrg" showSecondaryValues="true" items="{zCustPurReq>/VH_PurOrganizSet}">
<!--selectedKeys="{local>/PurchasingOrganizationKeys}"-->
<core:ListItem text="{zCustPurReq>Ekotx}" additionalText="{zCustPurReq>Ekorg}" key="{zCustPurReq>Ekorg}"/>
</MultiComboBox>
</smartfilterbar:customControl>
</smartfilterbar:ControlConfiguration>
<smartfilterbar:ControlConfiguration controlType="auto" groupId="_BASIC" hasValueHelpDialog="true" index="5" key="lgort"
label="{i18n>lgort}" preventInitialDataFetchInValueHelpDialog="false" visible="true">
<smartfilterbar:customControl>
<MultiComboBox id="idMultiComboLgort" showSecondaryValues="true" items="{local>/LgortItems}">
<!--selectedKeys="{local>/LgortKeys}"-->
<core:ListItem text="{local>Lgobe} ({local>Lgort})" additionalText="{local>Name1} ({local>Werks})" key="{local>Lgort}"/>
</MultiComboBox>
</smartfilterbar:customControl>
</smartfilterbar:ControlConfiguration>

 

Daniele