Visualizing Dynamics 365 Sales Data with ComponentOne DataConnectors
Microsoft Dynamics 365 is a popular enterprise business solution designed to manage business processes. Some of the core modules include sales, customer service, marketing, and finance operations.
In the ComponentOne 2020 v1 release, we have added an ADO.NET data connector for Dynamics 365 Sales. This enables connecting seamlessly to sales entities in Dynamics 365 with just a few lines of code.
The Dynamics 365 ADO.NET connector becomes very useful when used with an analytical UI control such as the ComponentOne OLAP/Pivot control. The UI control provides the analytical abilities for records from Dynamics.
Let’s take a look at an example of the sales module. It is one of the most common and most important modules used by businesses, as it helps businesses keep a record of accounts, contacts, invoice records, and the flow of information from lead generation to orders and sales.
Here’s a look at the invoice entity and its records from Dynamics 365:
If a sales manager would like to analyze these invoice records to get information regarding:
- Total sales for a year
- Tax collected by country
- Total invoices shipped by year
The easiest way would be to download all the records to an Excel sheet and then create a pivot table, based on the fields. However, this would be a considerable manual effort and the process would have to repeat for every record update.
If we could build an analytical sales dashboard to automate this process it would make the job of the sales manager easier.
The ComponentOne DataConnectors for Dynamics 365 and the OLAP/Pivot control is useful to create this dashboard quickly.
Sales Dashboard Features
Here is the breakdown of features for implementing and using these controls.
Data Connector for Dynamics 365
- Connecting to Microsoft Dynamics 365 API
- Querying the Invoice Entity for data
ComponentOne OLAP/Pivot Control
- Displaying the data on the OLAP control for analysis
- Saving and Loading views (Total Sales for a Year, Tax Collected by Country, etc.)
Now that we understand the architecture, let's create an MVC Core application to implement the sales dashboard, step by step.
Step 1: Adding NuGet Packages for ComponentOne DataConnectors & OLAP Control
You can download and install the ComponentOne DataConnectors (part of the Service Components module) and the ASP.NET MVC Edition locally, or add references to the following packages from the NuGet Gallery (nuget.org):
- C1.AdoNet.D365S
- C1.AspNetCore.Mvc
- C1.AspNetCore.Mvc.Olap
- C1.DataConnector
Step 2: Configuring the Connection to Microsoft Dynamics 365 Sales
In order to connect to the Dynamics 365 Sales instance, we need these parameters:
appsettings.json
Note: All connection string settings provided above are placeholder values. The values must be modified as per your actual Dynamics 365 environment in order to execute correctly.
Step 3: Connecting to Dynamics 365 using the ComponentOne DataConnectors
The command Text contains the query for getting the records from the Dynamics 365 Invoice entity:
IndexController.cs
Step 4: Parsing the Data Received from Dynamics 365 Inside GetData()
The data received from Dynamics 365 is parsed to a readable format, so that it can be converted to an IList to be later used as a DataSource for the pivot control:
IndexController.cs
Step 5: Return the Invoice as a Model for the View Page
IndexController.cs
Step 6: Binding Invoice Data to ComponentOne OLAP
The invoice data received from the Model is bound the C1 MVC OLAP Control i.e c1-pivot-engine using the source-collection property of the c1-items-source control:
Index.cshtml
Step 7: Creating Dynamics Views on the Dashboard
Our sales dashboard has taken shape. The sales manager can add pivot fields to row, columns, and values fields using simple drag-drop operations to create dynamic views based on his requirements.
Loading and Saving Existing Views
In order to save or load an existing views to local storage, the 'View' definition of the OLAP control can be used:
Exporting OLAP Views to Excel
The MVC Olap/Pivot control extends the FlexGrid control, so you can export it to any of the formats supported by the extension modules provided with the FlexGrid. The list of the supported formats includes .xlsx, .csv, and .pdf.
For example, code below creates an Excel file with two sheets: the current view and a transposed version of the current view.
Dynamics 365 Pivot Demo
You can see a live demo of the ComponentOne DataConnectors for Dynamics 365 and the MVC OLAP control below.