Flexmonster Software License Agreement (“Agreement”) has been revised and is effective as of January 8, 2025.
The following modifications were made:
The modified version of Agreement is available here.
Downloading, installing, and/or continuing to use Flexmonster Software after January 8, 2025, constitutes Licensee’s acceptance of the terms and conditions of the modified version of Agreement. If Licensee does not agree to any of these terms and conditions, they must cease using Flexmonster Software and must not download, install, use, access, or continue to access Flexmonster Software. By continuing to use Flexmonster Software or renewing the license or maintenance after the effective date of these modifications to Agreement, Licensee accepts and agrees to be bound by the terms and conditions of the modified Agreement.
Flexmonster Accelerator can be integrated into your website back end as a separate ASP.NET controller. The main benefits of referencing the Accelerator as a DLL directly from the ASP.NET project are:
If Flexmonster is not yet embedded, set up an empty component in your webpage:
Complete the Integrating Flexmonster guide. Your code should look similar to the following example:
let pivot = new Flexmonster({ container: "pivotContainer", componentFolder: "node_modules/flexmonster/", toolbar: true });
Complete the Integration with React guide. Your code should look similar to the following example:
<FlexmonsterReact.Pivot toolbar={true} />
Complete the Integration with Angular guide. Your code should look similar to the following example:
<fm-pivot [toolbar]="true"> </fm-pivot>
Complete the Integration with Vue guide. Your code should look similar to the following example:
<Pivot toolbar />
Choose one of the following options:
To integrate Flexmonster Accelerator into an existing project, follow these steps:
Step 1. Install the Accelerator with NuGet – Visual Studio's package manager:
Flexmonster.Accelerator
package and install it:Step 2. Create a FlexmonsterConfig
class with information about the connection:
Your code should look similar to the following:
public class FlexmonsterConfig { public static void Register() { // Replace with actual data source // Example: Data Source=localhost Flexmonster.Accelerator.Controllers.FlexmonsterProxyController .ConnectionString = "Data Source=localhost"; Flexmonster.Accelerator.Utils.CacheManager .MemoryLimit = 10 * 1024 * 1024; // MB to bytes Flexmonster.Accelerator.Utils.CacheManager.Enabled = true; } }
In our project, this file is located in the Flexmonster Accelerator MVC/App_Start/ folder.
Note: to connect to Azure Analysis Services, specify AuthHelper
in FlexmonsterConfig
. This property is an instance of the AzureAuthHelper
class that has the following parameters:
Parameter | Description |
---|---|
ResourceURL | The URL of your Azure Analysis Services instance. Must be specified as https://<domain name> , where <domain name> is the region from the data source specified in the connection string. Example: https://aspaas.asazure.windows.net . |
AzureAuthority | The Azure authority URL (e.g., https://login.microsoftonline.com/<your_domain> ). Learn more in the Microsoft guide. |
AzureClientId | The client ID of the service principal registered in Azure Active Directory. |
AzureClientSecret | The client secret of the service principal registered in Azure Active Directory. |
Here's a code example:
public class FlexmonsterConfig { public static void Register() { // Replace with actual data source // Example: Data Source=asazure://aspaas.asazure.windows.net/myserver Flexmonster.Accelerator.Controllers.FlexmonsterProxyController .ConnectionString = "Data Source=asazure://aspaas.asazure.windows.net/myserver"; // AuthHelper for Azure Analysis Services Flexmonster.Accelerator.Controllers.FlexmonsterProxyController .AuthHelper = new AzureAuthHelper( // ResourceURL /* Must match the region from the data source specified in the ConnectionString */ "https://aspaas.asazure.windows.net", // AzureAuthority "https://login.microsoftonline.com/<your_azure_domain>", // AzureClientId "00000000-0000-0000-0000-000000000000", // AzureClientSecret "XXXXXXXXXXXXX" ); } }
Step 3. Register FlexmonsterConfig
inside the Application_Start
method of the Global.asax.cs
file:
FlexmonsterConfig.Register();
Step 4. Create an AcceleratorController
class that extends FlexmonsterProxyController
. This class will handle the requests to the Accelerator:
public class AcceleratorController :
Flexmonster.Accelerator.Controllers.FlexmonsterProxyController {
public override void OnRequest(BaseArgs args) {
base.OnRequest(args);
}
}
In our project, this file is located in the Flexmonster Accelerator MVC/Controllers/ folder.
Now it’s time to configure the client - Flexmonster Pivot Table and Charts. Let’s create a minimal configuration using the JavaScript API (replace proxyUrl
, catalog
and cube
parameters with your specific values):
let pivot = new Flexmonster({ container: "pivotContainer", componentFolder: "node_modules/flexmonster/", toolbar: true, report: { dataSource: { type: "microsoft analysis services", /* URL to Flexmonster Accelerator */ proxyUrl: "http://localhost:50005", /* Catalog name */ catalog: "Adventure Works DW Standard Edition", /* Cube name */ cube: "Adventure Works", // Flag to use the Accelerator instead of XMLA protocol binary binary: true } } });
let pivot = new Flexmonster({ container: "pivotContainer", componentFolder: "node_modules/flexmonster/", toolbar: true, report: { dataSource: { type: "microsoft analysis services", /* URL to Flexmonster Accelerator */ proxyUrl: "http://localhost:50005", /* Database name */ catalog: "Adventure Works DW Standard Edition", /* Model name */ cube: "Adventure Works", // Flag to use the Accelerator instead of XMLA protocol binary binary: true } } });
Launch the webpage from a browser — there you go! A pivot table is embedded into your project.
By default, logging is disabled in the Accelerator as a DLL. To enable logging, you need to implement the Flexmonster.Accelerator.Utils.ILogger
interface:
Step 1. In your project, create a C# class (e.g., MyLogger.cs
).
Step 2. Open the created file (e.g., MyLogger.cs
) and import Flexmonster.Accelerator.Utils
:
using Flexmonster.Accelerator.Utils;
Step 3. Implement the Flexmonster.Accelerator.Utils.ILogger
interface by implementing the Error
, Info
, Trace
, and Warn
methods. Your code should look similar to the following:
using Flexmonster.Accelerator.Utils; namespace Project_Namespace { public class MyLogger : ILogger { public void Error(string message) { System.Diagnostics.Debug.WriteLine(message); } public void Error(string message, params object[] args) { System.Diagnostics.Debug.WriteLine(message); } /* Info, Trace, and Warn methods can be implemented similarly */ } }
Notice that the Error
method is overloaded, so it is implemented twice. The same applies to Info
, Trace
, and Warn
methods. Overall, you should have eight methods implemented in your class.
Step 4. Go to the FlexmonsterConfig
class and add your logger implementation to the Register
method:
namespace Project_Namespace { public class FlexmonsterConfig { public static void Register() { // Other code Flexmonster.Accelerator.Utils.LoggerLocator.SetLogger(new MyLogger()); // Other code } } }
Now logging is enabled for the Accelerator as a DLL.
You may be interested in the following articles: