Archive for July 23, 2011

How to verify the log files for CRM installation issues

  • Open “Run” window (Ctrl+R)
  • Type “%APPDATA%\Microsoft\MSCRM\Logs\
  • You find the list of generated logs
  • Sort by “Last Modified Time” to get the latest .log file

Useful CRM 2011 JScript Syntaxes

XRM.Page Model diagram

Xrm.Page Model

Xrm.Page Model

The Xrm.Page object serves as a namespace object to consolidate three properties on the form:


Xrm.Page.context provides methods to retrieve information specific to an organization, a user, or parameters that were passed to the form in a query string. provides an entity object that provides collections and methods to manage data within the entity form.


Xrm.Page.ui provides collections and methods to manage the user interface of the form.


— “CRM Enity” Properties

  •   //Entity Name
  •                     //Record GUID
  •  Xrm.Page.ui.getFormType()                      //CRM Form Type (Integer)
    **Create (1), Update (2), Read Only (3), Disabled (4), Bulk Edit (6)

Get & Set Text Field


Get Lookup


Set Lookup

  •  var lookUpValue = new Array();
    lookUpValue[0] = new Object();
    lookUpValue[0].id = idValue;
    lookUpValue[0].name = textValue;
    lookUpValue[0].entityType = ‘{Entity_Name}’;
  • Xrm.Page.getAttribute(“primarycontactid”).setValue(lookUpValue);

— Clear the Lookup

  • To clear the lookup field value, set with ‘null’
  • Xrm.Page.getAttribute(lookupAttribute).setValue(null);

Option Set Properties

  •“new_country”).getOptions()   // All Options
  •“new_country”).getText()         // Option Label value
  •“new_country”).getValue()       // Selected option value

Hide/Show controls

  • Xrm.Page.ui.controls.get(“name”).setVisible(true/false)

Disable/Enable controls

  •  Xrm.Page.ui.controls.get(“name”).setDisabled(true/false)

Set Focus

  • Xrm.Page.ui.controls.get(“name”).setFocus();

Set field’s Requirement Level

  • Xrm.Page.getAttribute(“name”).setRequiredLevel(“none”);
  • Xrm.Page.getAttribute(“name”).setRequiredLevel(“required”);
  •  Xrm.Page.getAttribute(“name”).setRequiredLevel(“recommended”);

Set the label for the control

  •  Xrm.Page.ui.controls.get(“name”).setLabel(“Label Text”);

Set URL for IFrams/WebResource

  •  Xrm.Page.ui.controls.get(“IFrame/WebResource Name”).setSrc(“URL”);

Get Parent of current control

  •  Xrm.Page.ui.controls.get(“name”).getParent();

“Current User” & “Organization” details

  • Xrm.Page.context.getUserId()                     //Current User ID
  •  Xrm.Page.context.getOrgUniqueName() //Organization Name
  •  Xrm.Page.context.getServerUrl()              //Server URL
  •  Xrm.Page.context.getUserRoles()             //Role ID’s of current user

Check isDirty

  •  // Form is IsDirty
  •“new_name”).getIsDirty()  //Field is IsDirty

Save Form

  • function save(){;}

Save&close Form

  • function saveandclose(){“saveandclose”);}

Close Form

  • function close(){Xrm.Page.ui.close();}

Expand/Collapse Tabs

  • var myTab = Xrm.Page.ui.tabs.get(“{tab_name}”);
  • myTab.setDisplayState(“expanded”); // To expand tab
  • myTab.setDisplayState(“collapsed”); // To collapse tab

Hide/Show Tabs & Sections

  • var myTab = Xrm.Page.ui.tabs.get(“{tab_name}”);
  • myTab.setVisible(True/False);
  • var mySec = myTab.sections.get(“{sec_name}”);
  • mySec.setVisible(True/False);

— Get current form properties if you have multiple forms

  • var item = Xrm.Page.ui.formSelector.getCurrentItem();if (item != null) {var itemId = item.getId(); // Form GUID

    var itemLabel = item.getLabel(); // Form Name


  • Note – If your entity has only one form defined, “getCurrentItem()” will return null so the “item” become “null”

 —Look up window customizations (Unsupported) 

We can perform below customization actions on the lookup dialog window using JScript

 – Disable the “View Selection” dropdown

 – Hide the “New” button

 – Hide the “Search” textbox (i.e.,Quick search)

//To hide “New” button

crmForm.all.attr_name.AddParam(“ShowNewButton”, 0);

// To hide “New” button – Post UR 13

var lookupControl = Sys.Application.findComponent(“attr_name”);

if (lookupControl != null){

lookupControl._element._behaviors[0].AddParam(“ShowNewButton”, 0);


//To disable “View Selection” dropdown

document.getElementById(“{attr_name}”).setAttribute(“disableViewPicker”, “1”);

//To hide “Search” textbox

document.getElementById(“{attr_name}”).setAttribute(“disableQuickFind”, “1”);

After applying the script (i.e., After placing the above lines in form onload event), the lookup window looks as below

Customized lookup dialog

Customized lookup dialog

Quick Reference :-

Great post on the difference B/W CRM 4.0 syntaxes Vs CRM 2011 syntaxes

Issues while installing CRM 4.0 on Windows Server 2008 R2

Errors Screen

While installing CRM 4.0 on Windows Server 2008 R2 server we  will get errors mentioned in above screen

1)    To fix the issue  “Service cisvc was not found on computer XYZ”


  • This is because CRM 4.0 requires the old “Indexing  Service (CISVC)” , which was part of Windows Server 2003


To fix this,  we need to enable the Windows Server 2003 indexing service (cisvc) on current Windows  Server 2008 machine within File Server Role. (Follow below steps)

Enabling CISVC Indexing Service

  • Open “Server Manager”
  • Click on “Roles” link
  • Go to “File Server Role” tab and click on  “Add Roles” link
  • Check “Indexing Service” under “Windows Server 2003 File Services”

2)    To fix the “Service  msftesql was not found”

Reason: –

  • This error comes from conflict between installing Microsoft Dynamics CRM 4.0 with SQL Server 2008.
  • The “msftesql” is the “Microsoft SQL Server Full  Text Indexing Service” which has a different name under SQL Server 2008


  • Open “Registry” (Go to Run -> Regedit)
  • Navigate to “HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services” on the tree
  • Rename ‘MSSQLFDLauncher’ Folder to ‘msftesql’
  • Restart the server
  • Go to “Services” (Run ->  Services.msc)
  • Start the “SQL Full-text Filter Daemon  Launcher (MSSQLSERVER)” service
  • Complete the CRM installation
  • Rename back msftesql Folder to  MSSQLFDLauncher (Follow step 1 – 3) 

3)    To fix the “Index was  outside the bounds of the array”

  • Configure “User  Account” which you have given while installing CRM  as service account for Report Server and  Analysis server
  • Instead of  above step, You can even give “Network Service Account” as service account  while installation