EducationSoftwareStrategy.com
StrategyCommunity

Knowledge Base

Product

Community

Knowledge Base

TopicsBrowse ArticlesDeveloper Zone

Product

Download SoftwareProduct DocumentationSecurity Hub

Education

Tutorial VideosSolution GalleryEducation courses

Community

GuidelinesGrandmastersEvents
x_social-icon_white.svglinkedin_social-icon_white.svg
Strategy logoCommunity

© Strategy Inc. All Rights Reserved.

LegalTerms of UsePrivacy Policy
  1. Home
  2. Topics

KB42054: How to Modify the Excel Header Content when Exporting a Report from MicroStrategy Web using the MicroStrategy Web SDK 9.4.x


Community Admin

• Strategy


How to Modify the Excel Header Content when Exporting a Report from MicroStrategy Web using the MicroStrategy Web SDK 9.4.x

The example provided in this document is provided “as-is” to the user and assumes that the user:

  • Can program, compile (e.g. javac, jikes, etc.), and execute Java programs
  • Can configure environment variables (e.g. JAR files, property files, etc.)
  • Have all the necessary tools to create Java applications (JDK, IDE, etc.)
  • Has access to the Strategy SDK documentation.
  • Has read the customization warning at the bottom of this document

 
PREREQUISITES:
For the sample to work, the Strategy Web JAR files must be accessible by the Java Runtime
Environment. The Strategy Web JAR files can be found under:

  • Strategy Web Universal (JSP): {web_root}/WEB-INF/lib directory.
  • Strategy Web (.NET): Program Files\Common Files\Strategy directory.

 
Note:
More elaborate programs will require additional library files and are out of the scope of this document.
 
Using the Web Customization Editor to create a plug-in
Strategy SDK provides a Web Customization Editor that can be used to create a customization plug-in. The following steps show how to create the plug-in and deploy.

  • Launch the Web Customization Editor.
  • Create a new plug-in and give it a meaningful name. For example: ModifyExcelHeaderContent.
    (For step by step instructions on creating a new plug-in, please navigate to Home > Web SDK > Customizing Strategy Web > Web Customization Editor > Features and Customizable).
  • Click in Strategy Web Configuration inside the Application Settings view to expand the hierarchical tree. The expanded list comprises the different settings that can be modified to perform customizations. 
  • Navigate to Pages. Right-mouse click report(Report Execution) and select Create New Add-On to launch the New Add-On Class Wizard.
  • Click Browse... next to the Source folder’s text field to select the src folder and click OK.
  • Enter the following information for the rest of the text fields:
    Package: ##Any package the client wants to use##
    Name: ModifyExcelHeader_AddOn
    Add-on description: This add-on will modify the Excel header content when exporting a report.
    Check the box for “Add custom logic before fetching data from Intelligence Server (preCollectData)"
     
ka04W00000147uvQAA_0EM440000002GeR.png
  • Click Finish. The ModifyExcelHeader_AddOn.java file should open in Eclipse.
    For additional information on Add-On creation, reference the MSDZ (Home > Web SDK > Customizing Strategy Web > Part II: Advanced Customization Topics > Customizing Add-ons> Add-on Creation).
     
  • Modify the preCollectData method as follows:


    
    public void preCollectData(PageComponent page) {
    	String reportHeader = "Report Header";
    	ReportBean rb;
    	
    	//Get the report bean from the page component  
    	rb = (ReportBean) page.getRoot().searchChild(ReportBean.class);
    	try {
    		if (rb != null) {
    		
    			//Get the report instance  
    			WebReportInstance ri = rb.getReportInstance();
    			ri.getResultSettings().getDetailsFormatter().setReportDetailsFormat("");
    			WebReportExcelExportSettings settings;
    			
    			if (ri != null) {
    			
    				//Execute the report in excel mode and get the report details section  
    				rb.setExecutionMode(EnumWebReportExecutionModes.REPORT_MODE_EXCEL);
    				WebReportData reportData = rb.getReportData();
    				String reportDetails = reportData.getReportDetails();
    				
    				if (reportDetails.contains("Empty")) {} else {
    					settings = (WebReportExcelExportSettings) ri.getExportSettings();
    					
    					if (settings != null && settings.getCustomProperties() != null) {
    					
    						// Set the excel header 
    						WebProperty prop = settings.getCustomProperties().getItemByName(WebReportExportSettings.PROPERTY_CUSTOM_EXCEL_REPORT_HEADER);
    						reportHeader = getReportHeader(reportDetails);
    						if (prop != null) prop.setValue(reportHeader);
    					}
    				}
    			}
    		}
    	} catch (Exception e) {}
    }
    //Modify the header value to the desired format 
    public String getReportHeader(String details) {
    	String reportHeader = "Report Header";
    	String str[] = details.split(" ");
    	
    	for (int i = 0; i < str.length; i++) {
    		System.out.println("String Array Value At: " + i + "=" + str);
    	}
    	reportHeader = "Start Date:" + str + " " + "End Date:" + str;
    	
    	return reportHeader;
    }

     


  • Save the changes.
  • Double-click report(Report Execution) to open the editor.
  • Click on the Add-on Properties tab. On the Add-On Properties tab, the custom add-on class ModifyExcelHeader_AddOn, should be listed under Class Name:
      
ka04W00000147uvQAA_0EM440000002GeP.png
  • Restart the Web Server to see the changes applied in Web.

 
ADDITIONAL INFORMATION:
The Strategy SDK allows you to customize the standard Strategy Web interface, and extend and integrate the Strategy business intelligence functionality into other applications. However, before changing the way Strategy Web products look or behave, it is helpful to understand how the application is built. For more information regarding the Strategy Web architecture or the process of customizing Strategy Web, please refer to Strategy Developer Zone (https://community.strategy.com/topic/0TO44000000FliLGAS/sdk).
 
To access the Strategy Developer Zone, you must have access to the Strategy Knowledge Base, you must have purchased the Strategy SDK, and you must be current on your Strategy maintenance agreement. If you are a US-based business and believe that you satisfy all three of these conditions but you do not have access to the Strategy Developer Zone, please contact Strategy Technical Support at support@microstrategy.com or at (703) 848-8700. If you are an international business, please contact Strategy Technical Support at the appropriate email address or phone number found at https://www.microstrategy.com/en/support/contact-support.
 
CUSTOMIZATION WARNING:
This customization is provided as a convenience to Strategy users and is only directly applicable to the version stated. While this code may apply to other releases directly, Strategy Technical Support makes no guarantees that the code provided will apply to any future or previous builds. In the event of a code change in future builds, Strategy Technical Support makes no guarantee that an updated version of this particular customization will be provided. In the event of a code change in future builds, Strategy may not be able to provide additional code on this matter even though this customization is provided at this time for this specific build. For enhancements to this customization or to incorporate similar functionality into other versions, contact your Account Executive to inquire about Strategy Consulting assistance.
 
 
 


Comment

0 comments

Details

Knowledge Article

Published:

June 21, 2017

Last Updated:

June 21, 2017