| |
this part :wink: |
|
part 3 |
|
Now we will add two new features to the app:
Because of the Facade plugin we can test this also in the WebPreview of the SAP Web IDE.
In your project, open the view folder and right click on the Master.view.xml - Open With - Layout Editor
At the left choose the Button …
...and drag and drop it onto the right of the Search Bar.
Now change the properties of the new Button
Click Save.
We must now add the functionality that is invoked when the button is pressed.
Right-click on the button and choose Go to Code
The XML Code Editor opens.
Here you can find the new button.
Now we have to add more properties to the button description:
tooltip="Bar Code Scanner" press="onBarCodeScan"
And do not forget to save!
Double click on the Master.controller.js to open it.
Add the following line at the top of the controller file.
jQuery.sap.require("sap.m.MessageBox");
Add also the new function onBarCodeScan to the Master.controller.js
onBarCodeScan:function(){
var that = this;
var code = "";
try {
cordova.plugins.barcodeScanner.scan( function (result) {
sap.m.MessageBox.show("Barcode scanning result:\n" + "Result: " + result.text + "\n" + "Format: " + result.format + "\n" + "Cancelled: " + result.cancelled+"\n","");
code = result.text;
that.getView().byId("searchField").setValue(code);
that.onSearch();
}, function (error) {
sap.m.MessageBox.show("Barcode scanning failed: ", error,"");
} );
}
catch (e) {
sap.m.MessageBox.show("Cordova plugin is not available.","");
}
},
And do not forget to save!
This will use the Cordova barcode scanner plugin to scan a QR-Code or a Bar-Code andstores the result.
It creates a MessageBox which will show the text of the QR- or barcode and what code-format was read.
The result-text is added to the Search-Field and the Search function is then started.
It will also catch the errors if the scanning failed or the Cordova plugin isn’t available.
Note: If you want to improve the layout of the source code, right-click in the editor window - Beautify. This will arrange the code.
Now we will extend the Detail View.
First close the Layout Editor for Master.view.xml tab
Right click on the Detail.view.xml - Open With - Layout Editor
On the left choose the Button Control…
..and drag and drop it to the toolbar at the bottom.
Now change the properties of the new Button
Click Save.
We must now add the functionality that is invoked when the button is pressed.
Right-click on the button and choose Go to Code
The Code Editor opens in which you can find the new button.
Now we have to add more properties to the button description:
xmlns="sap.m" press="addContact”
And do not forget to save!
Open the Detail.controller.js
At the top of the controller add the following line
jQuery.sap.require("sap.m.MessageBox");
Then add the function addContact
addContact: function(oEvent) {
if (!navigator.contacts) {
sap.m.MessageBox.show("Contacts API only supported on Devices/Simulators", sap.m.MessageBox.Icon.INFORMATION, "Add Contact");
return;
}
var oView = this.getView();
var sEntityPath = "/" + oEvent.getSource().getBindingContext().getPath().slice(1) + "/ToSupplier";
var bpData = oView.getModel().getData(sEntityPath);
//Get Contacts data
var name = bpData.CompanyName;
var phone = bpData.PhoneNumber;
var email = bpData.EmailAddress;
var contact = navigator.contacts.create();
contact.name = {
givenName: name
};
var phoneNumbers = [];
var emails = [];
phoneNumbers[0] = new ContactField("work", phone, true);
emails[0] = new ContactField("email", email, false);
contact.phoneNumbers = phoneNumbers;
contact.emails = emails;
contact.save();
sap.m.MessageBox.show("Successfully saved into Device Contacts ", sap.m.MessageBox.Icon.SUCCESS, "Add Contact");
},
And do not forget to save!
This function obtains the ToSupplier-contact data from the selected product and saves it as a new contact.
Note: To improve the layout of the source code, right-click - Beautify. This will arrange the code.
We can test this new functionality using the Cordova Façade.
Remember that by activating the Hybrid Application Toolkit plugin in SAP Web IDE, we are able to test some of the hardware features of a mobile device directly in the desktop browser.
Click on index.html and then the Run button
You will see now two new buttons.
Click the barcode button next to the search field.
A Chrome pop up will ask you to allow the camera of your laptop.
Click Allow and scan the QR-Code/Barcode with the camera of your laptop.
A Message Box will show you the result of your code scan.
A search will be performed for the Product having this particular code.
To test the Add Contact functionality in the browser press F12 to open the Developer Tools.
Choose one product and click the Add to Contact
Important: Please click on a product in the master list. When resizing the screen, it is important to make sure that you have really selected a product in the master list.
A Message Box shows a success Message. Your saved contact you can find in the Resources tab in the Developer Tools - Resources - Local Storage - contacts
If you get an error: be sure that you have marked one product to open the details. If you use the first-load-details you will get an error.
In the next part I will show, how you can test it on your Mobile Device with the companion App.
More Web IDE stuff published by Technology RIG :smile:
See you
Claudi
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
User | Count |
---|---|
26 | |
14 | |
13 | |
12 | |
12 | |
8 | |
8 | |
7 | |
7 | |
5 |