Playing around with iframes... in javascript

Display a related entity in context of the parent is old stuff and could be found little every where if you search around. But finding samples to change or modify attached child entities is not so clear. One thing that differs if you render your iframe with a related entity is that it gets loaded during the form onload. This could be used for your advantage to do validation etc (on child/related entities witout callout logic ~ offline enabled = fast GUI response) but has a price of potential slower form onload.

Well enough, heres the code samples and yes it's just samples. Copy and past to either onload or onsave of your form. Slight modifications are needed to fit your entity names or fields.

Hide "Delete" button from iframe entity depending state of picklist from main form

function myCustomLoaded()

{

if (this.readyState
== "complete")

{

hideCustomDeleteButton()

}

}

function hideCustomDeleteButton()

{

var tmp =
crmForm.all.new_dropdownvalue.SelectedText;

switch (tmp)

{

case "Stängt":

case "Förlorad
Opportunity":

case "Not Choosen
Partner":

//TODO: Change entity number 10001 to
the one in your implementation

btnDelete =
document.all.IFRAME_mycustom.contentWindow.document.all._MBdoActioncrmGrid10001delete;

if (btnDelete != null)

btnDelete.style.display = "none";

break;

}

}

//In onload of
form

document.all.IFRAME_mycustom.onreadystatechange
= myCustomLoaded;

//Just call hideCustomDeleteButton from onchange of your picklist

Hide "New" button depending state of main form

var navCustom =
document.all.nav_opportunity_new_custom;

if (navCustom != null)

{

navCustom.style.display = "none";

//tab2 is used to place this frame

if
(crmForm.all.tab2Tab.style.display == "")

{

if (crmForm.FormType ==
CRM_FORM_DISABLED || crmForm.FormType == CRM_READ_ONLY_TYPE )

//Read only no new button
even if security saying something else

var url =
"/userdefined/areas.aspx?oId=" + crmForm.ObjectId +
"&oType=3&security=1&tabSet=opportunity_new_custom";

else

//Read from security and
render depending role

var url =
"/userdefined/areas.aspx?oId=" + crmForm.ObjectId +
"&oType=3&security=852023&tabSet=opportunity_new_custom";

document.all.IFRAME_mycustom.src = url;

}

}

 

Validate rows in grid from onsave for child entity

//call checkRows
in onsave

function checkRows()

{

var r = true;

var rows =
document.all.IFRAME_mycustom.contentWindow.crmGrid.InnerGrid.rows

//Change to your
cell to verify from grid

if (typeof(rows[0].cells[2])
== "undefined" || IsNull(rows[0].cells[2]))

return AlertMessage(0);

var total = 0;

var l = rows.length;

for (var
i = 0; i < l; i++)

total = total +
parseInt(rows[i].cells[2].innerText);

if (total != 5)

r = AlertMessage(total);

return r;

}

function AlertMessage(rows)

{

alert("You need to have atleast 5 rows to complete.
Current sum of rows: " + rows + "!");

return false;

}

https://msdn2.microsoft.com/en-us/library/ms535258.aspx
https://msdn2.microsoft.com/en-us/library/ms534638.aspx

Comments

  • Anonymous
    November 12, 2007
    Great information on using jscript. Could you assist with the following? Displaying activity history in Iframe of Contacts is straightforward with the following code: var navActivityHistory; navActivityHistory = document.all.navActivityHistory; if (navActivityHistory != null) { navActivityHistory.style.display = "none"; document.all.IFRAME_HistoryFrame.src="/sfa/conts/areas.aspx?oId=" + crmForm.ObjectId + "&oType=2&security=852023&tabSet=areaActivityHistory"; } else { alert("navHistory Not Found"); } However, I would like display a related entity (Contacts) in the context of a custom entity. The custom entity is Household and would like to display the members (contacts) of the household in an iframe on the Household form. Any ides would be appreciated.

  • Anonymous
    November 13, 2007
    Thanks! Please have a look at stunnware http://www.stunnware.com/crm2/topic.aspx?id=JS17 var lookup = crmForm.all.your_lookup_field; if ((lookup != null) && (lookup.DataValue != null)) {    var objectTypeCode = lookup[0].type;    var objectId = lookup[0].id;    var url = '/userdefined/edit.aspx?id=" + objectId + '&etc=' + objectTypeCode;    window.open(url); }