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

KB43841: How to Set the Alias of a Metric Object in a Grid in a Document Using the MicroStrategy Java Web SDK 9.4.1


Community Admin

• Strategy


Java example demonstrating how to set the alias of an attribute or metric on a grid inside a Report Services Document on-the-fly.

Using the Strategy Web SDK, it is possible to set the alias of an attribute or metric on a grid inside a Report Services Document on-the-fly.
 
Before Customization:

ka04W000000OfULQA0_0EM440000002GbA.jpeg

 
After Customization:

ka04W000000OfULQA0_0EM440000002Gb2.jpeg

 


package customclasses.addons;

import com.Strategy.web.app.addons.AbstractAppAddOn;
import com.Strategy.web.app.beans.PageComponent;
import com.Strategy.web.beans.RWBean;
import com.Strategy.web.beans.WebBeanException;
import com.Strategy.web.objects.SimpleList;
import com.Strategy.web.objects.WebObjectsException;
import com.Strategy.web.objects.WebTemplate;
import com.Strategy.web.objects.WebTemplateMetric;
import com.Strategy.web.objects.WebTemplateMetrics;
import com.Strategy.web.objects.rw.EnumRWUnitTypes;
import com.Strategy.web.objects.rw.RWData;
import com.Strategy.web.objects.rw.RWDefinition;
import com.Strategy.web.objects.rw.RWGridGraphDef;
import com.Strategy.web.objects.rw.RWInstance;
import com.Strategy.web.objects.rw.RWUnitDef;

public class ChangeObjectAliasinGrid extends AbstractAppAddOn {

	public String getAddOnDescription() {
		return "Addon set Alias for objects on grid in document";
	}

	public void postCollectData(PageComponent page) {
		RWBean rwb = null;
		rwb = (RWBean) page.getChildByClass(RWBean.class);
		if (rwb == null) return;

		// Only want this to affect a specific document. Document ID specified here.
		String docID = "2E0AEBFE4988DED7954BD2A00E56F7BF";
		try {
			// check if currently open document matches above ID. End code execution if not.
			if (!rwb.getObjectID().equalsIgnoreCase(docID)) 
				return;
				
		} catch (WebBeanException e) {
			e.printStackTrace();
		}
		
		RWInstance inst;
		try {
			inst = rwb.getRWInstance();
			RWData data = inst.getData();
			
			// Retrieve document definition
			RWDefinition def = inst.getDefinition();
			String key = null;
			
			// Name of grid object to be accessed
			String gridName = "myGrid";
			
			RWGridGraphDef grid = null;
			
			// Find grid/graph units within document definition.
			RWUnitDef[] units = def.findUnitsByType(EnumRWUnitTypes.RWUNIT_GRIDGRAPH);
			
			// Obtain key for selector, where name of selector matches the string stored in gridName.
			for (int i = 0; i < units.length; i++) {
				System.out.println("units=" + units.getName());
				
				if (units.getName().equals(gridName)) {
					key = units.getKey();
					System.out.println("key=" + key);
					grid = (RWGridGraphDef) units;
				}
			}
			// Retrieve template from grid. Required to retrieve list of metrics.
			WebTemplate gridTemplate = grid.getViewInstance().getTemplate();
			
			// Retrieve attributes from grid (needed if customization is required for attributes on grid).
			// SimpleList list = gridTemplate.getTemplateAttributes();
			
			// Retrieve metrics from grid (needed if customization is required for metrics on grid).
			WebTemplateMetrics metrics = gridTemplate.getTemplateMetrics();
			WebTemplateMetric metric = null; 
			
			// Loop through metrics on grid.
			for (int i = 0; i < metrics.size(); i++) {
				metric = metrics.get(i);
				
				// If metric name matches metric we are looking for, set alias as desired
				if (metric.getName().equalsIgnoreCase("Revenue")) {
					metric.setAlias("ChangeAliasName");
				}
			}
			
			// Apply changes to report instance
			inst.getRWManipulator().applyChanges();
			rwb.collectMinimalData();
			
		} catch (WebBeanException e) {
			e.printStackTrace();
		} catch (WebObjectsException e) {
			e.printStackTrace();
		}
	}
}

The example provided in this document is provided “as-is” and user has read the following customization warning:
ADDITIONAL INFORMATION:
The Strategy SDK allows you to customize several Strategy products and extend and integrate the Strategy business intelligence functionality into other applications. However, before changing the way Strategy products look or behave, it is helpful to understand how the application is built. For more information regarding the Strategy products or the process of customizing Strategy products, please refer to Strategy Developer Zone (https://developer.Strategy.com).
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@Strategy.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.Strategy.com/us/services/support/contact.
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:

April 10, 2017

Last Updated:

April 10, 2017