{"id":7471,"date":"2019-11-26T06:00:15","date_gmt":"2019-11-26T14:00:15","guid":{"rendered":"https:\/\/www.microsoft.com\/en-us\/power-platform\/blog\/power-apps\/priceline-australia\/"},"modified":"2024-09-25T15:14:16","modified_gmt":"2024-09-25T22:14:16","slug":"priceline-australia","status":"publish","type":"power-apps","link":"https:\/\/www.microsoft.com\/en-us\/power-platform\/blog\/power-apps\/priceline-australia\/","title":{"rendered":"Priceline optimizes retail store operations with Microsoft Power Platform"},"content":{"rendered":"
\n
\n“The speed at which I could build out these on-screen components helped me realize the appeal of low-code platforms. Power Apps has a lot to offer even to the most experienced developers among us.” <\/em><\/span>\u2013 James Matson, IT Retail Innovation Lead, Australian Pharmaceutical Industries<\/em><\/span><\/p>\n<\/blockquote>\nIn this blog post we learn about James Matson\u2019s perspective as a full stack professional developer embracing low-code development with Microsoft Power Platform. James is an IT Retail Innovation Lead at Australian Pharmaceutical Industries (API), a publicly listed company that is about to celebrate its 110th birthday as one of Australia\u2019s leading pharmaceutical distributors and fastest growing health and beauty retailers. With presence across Australia, the API network boasts more than 480 Priceline and Priceline Pharmacy stores, 970 Soul Pattinson stores, Pharmacist Advice Club and over 50 Clear Skincare clinics. API is best known for their network of Priceline and Priceline Pharmacy stores<\/a>.<\/p>\n
James built a solution for Business Leaders (Area Managers), to gain insights on the health of their retail stores, and in doing so was convinced that \u201cPower Apps had a lot to offer even to the most experienced developers.\u201d The Power Platform connector infrastructure made it possible for him to easily integrate with Azure functions, Azure Table Storage, Bing Maps and existing web APIs.<\/p>\n
BUSINESS SCENARIO<\/strong><\/h3>\n
Priceline Pharmacy is a much-loved health and beauty brand in the Australian market with the retail store teams providing an exceptional customer experience. Each team aims to deliver the right range of products at the right time, be well presented, and provide a warm and knowledgeable customer service experience.<\/p>\n
Each month, the Business Leaders visit each of the 480+ Priceline stores, and primarily use the solution that James developed to access and view several retail and customer service metrics during key promotional events. These include how the store is tracking in regard to sales and basket size, and key best sellers.<\/p>\n
BEFORE POWER PLATFORM<\/strong><\/h3>\n
Before investing in the Power Platform, the process of providing business leaders and other key retail employees with the kind of information required to make informed decisions varied across different stores. Useful data could be gathered in one of the following ways:<\/p>\n
\n
- By running reports physically within the store<\/li>\n
- By utilizing central reports provided by Business Intelligence platforms, with a time delay<\/li>\n
- By manually gathering data from various systems and bringing it together manually and distributed via email.<\/li>\n<\/ul>\n
Each Pharmacy Business Leader would run reports at the support office to gather key retail metrics, interpret and format that information for inclusion in their own analysis, and then visit the store to get locally generated reports. They would also perform a review of the store from a visual merchandise and staff engagement perspective and record those results in a separate system, from which they\u2019d export the results to include in a final email report.<\/p>\n
The result of this process was hours of gathering information, and hours of putting that data together into an email report for the business. Each report ended up having a different look and feel compared to reports from stores in other parts of the country. During periods of peak promotional activity, the only way to ascertain how particular stores were performing, was to wait at least one business day for BI reports to run overnight and produce data related to the promotional activity in each store. By the time this happened, the opportunity to make decisions that might positively affect the outcome of the promotion had already passed. The challenges with the existing process were numerous:<\/p>\n
\n
- Manually transposing data from one place to another increases the chance of mistakes<\/li>\n
- With multiple systems providing data, the process of bringing these together was manual and time consuming<\/li>\n
- The resulting assessments were often based on old data and lacked consistency<\/li>\n<\/ul>\n
Let’s hear directly from James Matson on his journey into low-code development with Microsoft Power Platform, after which we’ll look at some of the details of his solution.<\/p>\n
LOW-CODE FOR THE FULL STACK DEVELOPER \u2013 by James Matson <\/strong><\/h3>\n
“<\/i>A few months ago, Priceline Pharmacy held an \u2018Ideas Jam\u2019 day, where we brought together different vendors (including Microsoft) to demonstrate some of the new technology that were making a mark on the retail space and generate ideas as to how we might use that technology to solve real world problems.\u00a0During that Ideas Jam, I was introduced to Viren Joseph, an AI architect based at the Microsoft Technology Center in Sydney<\/a>. Viren helped me to develop some really cool prototypes using the Azure bot framework and other Microsoft \/ Azure technologies. During the course of working together, I mentioned to Viren that our business leaders were engaged in this lengthy and manual process of evaluating store performance both out in the field and at head office, and that I thought this was an area ripe for disruption.<\/p>\n
As a .NET developer with years of development experience under my belt, I tossed ideas back and forth with Viren as to how to build a solution that would provide a great interactive dashboard for our staff that they could use either at their desk, or out in the field. I had toyed with various full stack solutions, the kind that would see me building out a database, a presentation layer, business logic and so on. I could already see the end result forming and knew that there was a good two to three months of development work in standing up anything that could deliver on the requirements.<\/p>\n
I explained this to Viren and wanted to get his take on what components might be best to use to get the outcome I was after. That\u2019s when he mentioned Power Apps. Before then, I\u2019d only ever taken a cursory glance at Power Apps. I knew it was a \u2018low-code\u2019 platform for the rapid delivery of business applications, and it was that low-code moniker that stopped me from exploring any further.
\nTo a full stack developer such as myself, the term \u2018low-code\u2019 came with a lot of assumptions, namely any solution build on top of \u2018low code\u2019 would be:<\/p>\n\n
- Too simplistic to address the requirements<\/li>\n
- Difficult to extend beyond whatever is offered \u2018out of the box\u2019<\/li>\n
- Easy to learn must mean \u2013 \u2018limited in functionality\u2019<\/li>\n<\/ul>\n
Simply put, I had always veered away from anything low-code because of all of the above reasons, but most importantly the inability to answer one simple question. \u201cWhy?\u201d Why would I use a low-code solution when I have the experience and skills to develop something from the ground up?
\nViren gently pushed me towards at least looking at Power Apps before moving on, so I did, and from that day onwards I haven\u2019t looked back.<\/p>\nFrom only a week or two of prototyping it became apparent that any preconceived notions I had of low-code were about to be blown away. At first, I approached the utilization of Power Apps as simply a presentation layer, and even in that I wasn\u2019t disappointed. Power Apps allowed me to very quickly stand up a visually pleasing and compelling front end, complete with dashboard style metrics tiles and values that provided the user with the ability to see \u2018at a glance\u2019 how the store in question is tracking in terms of retail metrics and store visit information. The speed at which I could build out these on-screen components helped me realise the appeal of low-code platforms, but as I began to experiment further I started to understand that Power Apps still has so much to offer a full stack developer such as myself.<\/p>\n
If you\u2019re not a professional developer, you can without a doubt build compelling apps. If you happen to be a pro dev however, you can leverage your experience and knowledge around application architecture to extend Power Apps far beyond its basic use cases. If you\u2019ve build complex application integrations elsewhere, you can leverage those within Power Apps via hundreds of pre-built connectors and integrations, and \u2013 if you really need the freedom to integrate any kind of data \u2013 you can utilize generic connectors like the HTTP Custom Connector to bring into the platform information from just about any service or API you happen to have built, even if it\u2019s not within the Microsoft ecosystem.<\/p>\n
What\u2019s more, is that these integrations might take even a pro developer several days or even weeks to complete, but with the Power Platform, the same functionality can be achieved with a few mouse clicks and some simple code placed in your app. Because of the seamless integration with your Office 365 environment, concepts like security and authentication are built into the platform, freeing the pro developer up to concentrate on the things that make the app unique \u2013 the business logic itself. The same can be said about multi-platform use. While a pro developer can achieve compatibility across multiple platforms, Power Apps dispenses with even the question itself, ensuring that whatever is built can operate across Mobile, Desktop, iOS and Android.<\/p>\n
Through the journey of creating the \u2018Heart In Hand\u2019 app, it was clear to see that Power Apps had a lot to offer even the most experienced developers among us.\u201d<\/p>\n
POWER PLATFORM SOLUTION \u2013 HEART IN HAND APP<\/strong><\/h3>\n
The genesis of this app was a conversation between James and the General Manager of Retail Operations. James asked her \u2013 \u201cif you wanted to know three things, what would they be?\u201d Her response was: Sales, Average Basket Size and Transactions per hour.
\nThrough experimentation with Power Apps and Power Automate, the \u201cHeart in Hand\u201d app was born. From the outset, the requirements were simple but critical:<\/p>\n\n
- Deliver an app that allows Business Leaders to access store information both in the office and on the road.<\/li>\n
- Bring together information from multiple systems about the performance of a retail outlet into a single view.<\/li>\n
- Provide a platform that is pleasing to look at and easy to navigate.<\/li>\n
- Provide a solution which enables hourly reporting by store during key promotional events<\/li>\n<\/ul>\n
Below is a high-level diagram that describes how the \u201cHeart In Hand\u201d App operates.<\/p>\n
\nMicrosoft Power Apps<\/strong>
\nA Power Apps canvas app is used by Business Leaders during key promotional events to visualize how a store is performing in near real-time. The app can drive friendly competition between stores as business leaders check the performance of all the stores in their region.<\/p>\nEvery new Business Leader has access to the canvas app, which can be used as a key tool for reviewing data during key promotional events.
\nThe users can be on the road, at head office, or in the store and obtain an up-to-the minute view of how sales are tracking in their stores and their region.
\nThe app users can use a form within the app to provide feedback on the app or post a new idea. Others can vote on ideas. Functionality is added to the app based on the ideas with the most votes\/likes.<\/p>\nUsers can also create their own custom groups of store locations to report on a subset of stores without seeing other information. The custom groups are stored in Azure Table Storage, each one consisting of an array of store locations, which are broken up into individual stores.<\/p>\n
HTTP Custom Connector<\/strong>
\nThe Custom Connector forms the basis of the data retrieval and display for the \u201cHeart In Hand\u201d app. The connector is backed onto a Web API which retrieves up-to-date sales data and other retail metrics which in turn have been sourced from each individual store.<\/p>\nMicrosoft Power Automate<\/strong>
\nMicrosoft Power Automate provides the app with the ability to execute more complex activities than Power Apps provides out of the box. The activities include things like storing and retrieving data from Azure Table Storage, and verifying the user\u2019s access to different parts of the app. This data then populates a variety of fields within the app.<\/p>\n
\n<\/i><\/p>\nFlow used to retrieve stored data from Azure Table Storage<\/span><\/p>\n
Another flow is used to obtain data from an external auditing platform \u2013 iAuditor \u2013 to display information about store visits into the app. The same flow uses Azure Functions to manipulate the raw data into HTML which can be displayed on one or more screens.<\/p>\n
\n<\/i><\/p>\nFlow used to retrieve data from external auditing platform – iAuditor<\/span><\/p>\n
Azure Table Storage<\/b>
\nAzure Table Storage is used to store useful telemetry information about app usage such as when the user signed in, what screens they visited and more.<\/p>\n
\n<\/i><\/p>\nSample telemetry data on app events stored in Azure Table Storage<\/span><\/p>\n
A combination of Azure Table Storage, Microsoft Power Automate, and Power Apps is used for users to suggest new ideas for functionality in the app. They can submit their ideas via a Power Apps screen, and the data is stored in Azure Table Storage via Microsoft Power Automate. The Flow used can also track whether the user has \u2018liked\u2019 other peoples\u2019 suggestions and ensure they can only like an idea once.<\/p>\n
<\/p>\n
Ancillary services<\/strong>
\nThe Heart In Hand app also uses a number of different connections from the vast library of available connectors, including Bing Maps, which is used to show the geographical location of the retail store. The address obtained from the HTTP custom connector is passed into the Bing Maps connector to obtain the location of the store.<\/p>\n<\/p>\n
IMPACT AND BENEFITS<\/strong><\/h3>\n
The benefits from the Power Platform solution can be summarized as follows:<\/p>\n
\n
- Near real-time data is now available in the hands of key Retail Operations employees<\/li>\n
- An easy to use user interface for navigating through critical retail KPIs<\/li>\n
- Mobility across all common devices<\/li>\n
- Provides an easy to enhance platform where users can shape the development of the app<\/li>\n
- A marked increase in the ability of Business Leaders to understand the impact of promotional activities<\/li>\n<\/ul>\n
SOLUTION ARCHITECTURE<\/strong><\/h3>\n
A Power Apps canvas app connected to web APIs via a custom connector is used to view insights on desktop and mobile devices. Several flows are used to write data to Azure Table Storage, manage user \u2018likes\u2019 on app suggestions, convert raw data into HTML, get location information from Bing Maps, and more.<\/p>\n
<\/p>\n
RELATED LINKS<\/strong><\/h3>\n
\n
- Story on Microsoft news site – Priceline powers its people with Power Apps solution<\/a><\/li>\n
- More Microsoft Power Apps stories: https:\/\/aka.ms\/PowerAppsStories<\/a> | https:\/\/aka.ms\/PowerPlatformResources<\/a><\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"
In this blog post we learn about James Matson\u2019s Microsoft Power Platform journey and his perspective as a full stack professional developer embracing low-code development. James Matson is an IT Retail Innovation Lead at Australian Pharmaceutical Industries (API), who are best known for their network of 470+ Priceline and Priceline Pharmacy stores across Australia.<\/p>\n","protected":false},"author":90,"featured_media":7543,"comment_status":"open","ping_status":"open","template":"","power-apps-category":[1580,1664],"power-apps-tag":[1581],"coauthors":[2350],"class_list":["post-7471","power-apps","type-power-apps","status-publish","has-post-thumbnail","hentry","power-apps-category-case-studies","power-apps-category-uncategorized","power-apps-tag-customer-story"],"yoast_head":"\n
Priceline optimizes retail store operations with Microsoft Power Platform - Microsoft Power Platform Blog<\/title>\n\n\n\n\n\n\n\n\n\n\n\t\n\t\n\t\n\n\n\t\n\t\n\t\n