While Jim Wang, Matt Wittemann, and many others have posted the code to load an associated view in an iframe on a CRM form, I am trying to give a self-contained JavaScript function to handle this requirement, with one tiny enhancement.
The following is the script that I have evolved based on the scripts that I have just mentioned.
/**
* Load an associated view into an IFrame while hiding it from LHS navigation menu.
* @author Daniel Cai, http://danielcai.blogspot.com/
*
* Parameters:
* @param iframe: The IFrame's object, e.g. crmForm.all.IFrame_Employer_Address
* @param navItemId: LHS navigator's HTML element ID of the associated view.
It usually starts with "nav".
*/
function loadAssociatedViewInIFrame (iframe, navItemId)
{
var clickActionPattern = /loadArea\(['"]{1}([A-Za-z0-9_]+)['"]{1}(, ?['"]\\x26roleOrd\\x3d(\d)['"])*\).*/;
var getFrameSrc = function (areaId, roleOrd)
{
var url = "areas.aspx?oId=" + encodeURI(crmForm.ObjectId);
url += "&oType=" + crmForm.ObjectTypeCode;
url += "&security=" + crmFormSubmit.crmFormSubmitSecurity.value;
url += "&tabSet=" + areaId;
url += (!roleOrd) ? "" : "&roleOrd=" + roleOrd;
return url;
};
var onReadyStateChange = function() {
if (iframe.readyState === 'complete') {
var frameDoc = iframe.contentWindow.document;
// Remove the padding space around the iframe
frameDoc.body.scroll = "no";
frameDoc.body.childNodes[0].rows[0].cells[0].style.padding = "0px";
iframe.detachEvent('onreadystatechange', onReadyStateChange);
}
};
(function init() {
if (!crmForm.ObjectId) return;
var navItem = document.getElementById(navItemId);
if (!navItem) return;
var clickAction = navItem.getAttributeNode('onclick').nodeValue;
if (!clickAction || !clickActionPattern.test(clickAction))
return;
var areaId = clickAction.replace(clickActionPattern, '$1');
var roleOrd = clickAction.replace(clickActionPattern, '$3');
navItem.style.display = 'none';
iframe.src = getFrameSrc(areaId, roleOrd);
iframe.allowTransparency = true; // Get rid of the white area around the IFrame
iframe.attachEvent('onreadystatechange', onReadyStateChange);
})();
};
The tiny enhancement I mentioned was, the script tries to make the IFrame transparent so you won’t see a white-color area around the IFrame. To use the above function, you may make a call like the following snippet:
loadAssociatedViewInIFrame(crmForm.all.IFRAME_Accounts, "navnew_account_new_project");In the above snippet, IFRAME_Accounts is the iframe that I am using to load the associated view, while navnew_account_new_project is the ID of the left navigation item which you can click to navigate to the associated CRM view.
[Update - Mar 27, 2010] I updated the code with some little enhancements while I was writing another blog post about removing "Add Existing" button from the associated view.
[Update - Feb 08, 2010] I updated the code a little bit, while I was writing another blog post today, so it now requires only two parameters instead of the previous three. I know it's a little silly to update a blog post that is almost one and half years old. My intention is to have a script that either looks better or works better if I see that kind of opportunity. ;-)

No comments:
Post a Comment