仅当 FormType 为 Create 时才将所有者设置为当前用户

Posted

技术标签:

【中文标题】仅当 FormType 为 Create 时才将所有者设置为当前用户【英文标题】:Set Owner To Current User only when the FormType is Create 【发布时间】:2014-05-17 00:46:39 【问题描述】:

所以我被要求创建一种方法来自动将订单的所有者设置为当前用户,而不是映射的帐户的默认所有者。

另外,我必须让它只在用户创建订单的实例中运行。

所以我从这个开始:

try
var xml = "" + 
"<?xml version=\"1.0\" encoding=\"utf-8\"?>" + 
"<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">" +
GenerateAuthenticationHeader() +
" <soap:Body>" + 
" <RetrieveMultiple xmlns=\"http://schemas.microsoft.com/crm/2007/WebServices\">" + 
" <query xmlns:q1=\"http://schemas.microsoft.com/crm/2006/Query\" xsi:type=\"q1:QueryExpression\">" + 
" <q1:EntityName>systemuser</q1:EntityName>" + 
" <q1:ColumnSet xsi:type=\"q1:ColumnSet\">" + 
" <q1:Attributes>" + 
" <q1:Attribute>businessunitid</q1:Attribute>" + 
" <q1:Attribute>firstname</q1:Attribute>" + 
" <q1:Attribute>fullname</q1:Attribute>" + 
" <q1:Attribute>lastname</q1:Attribute>" + 
" <q1:Attribute>organizationid</q1:Attribute>" + 
" <q1:Attribute>systemuserid</q1:Attribute>" + 
" </q1:Attributes>" + 
" </q1:ColumnSet>" + 
" <q1:Distinct>false</q1:Distinct>" + 
" <q1:Criteria>" + 
" <q1:FilterOperator>And</q1:FilterOperator>" + 
" <q1:Conditions>" + 
" <q1:Condition>" + 
" <q1:AttributeName>systemuserid</q1:AttributeName>" + 
" <q1:Operator>EqualUserId</q1:Operator>" + 
" </q1:Condition>" + 
" </q1:Conditions>" + 
" </q1:Criteria>" + 
" </query>" + 
" </RetrieveMultiple>" + 
" </soap:Body>" + 
"</soap:Envelope>" + 
"";
var xmlHttpRequest2 = new ActiveXObject("Msxml2.XMLHTTP");
xmlHttpRequest2.Open("POST", "/mscrmservices/2007/CrmService.asmx", false);
xmlHttpRequest2 .setRequestHeader("SOAPAction", "http://schemas.microsoft.com/crm/2007/WebServices/RetrieveMultiple");
xmlHttpRequest2.setRequestHeader("Content-Type", "text/xml; charset=utf-8");
xmlHttpRequest2.setRequestHeader("Content-Length", xml.length);
xmlHttpRequest2.send(xml);
var resultXml = xmlHttpRequest2.responseXML;
var entityNode = resultXml.selectSingleNode("//RetrieveMultipleResult/BusinessEntities/BusinessEntity");
var firstNameNode = entityNode.selectSingleNode("q1:firstname");
var lastNameNode = entityNode.selectSingleNode("q1:lastname");
var fullNameNode = entityNode.selectSingleNode("q1:fullname");
var systemUserIdNode = entityNode.selectSingleNode("q1:systemuserid");
var businessUnitIdNode = entityNode.selectSingleNode("q1:businessunitid");
var organizationIdNode = entityNode.selectSingleNode("q1:organizationid");

//Create an array to set as the DataValue for the the lookup control. 
var lookupData = new Array(); 
//Create an Object add to the array. 
var lookupItem= new Object(); 
//Set the id, typename, and name properties to the object. 
lookupItem.id = systemUserIdNode.text; 
lookupItem.typename = 'systemuser'; 
lookupItem.name = fullNameNode.text; 
// Add the object to the array. 
lookupData[0] = lookupItem; 
// Set the value of the lookup field to the value of the array. 
crmForm.all.ownerid.DataValue = lookupData;
crmForm.all.ownerid.ForceSubmit = true;


catch(err)alert("Error on user set.")

但这在每个 FormType 中都运行...所以我有点不知所措。

【问题讨论】:

【参考方案1】:

然后,在我的努力中,我想出了许多实现这一目标的方法,我终于找到了一种行之有效并愿意分享的方法。

这是我发现的工作:

var xml = "" +
        "<?xml version=\"1.0\" encoding=\"utf-8\"?>" +
        "<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">" +
        GenerateAuthenticationHeader() +
        " <soap:Body>" +
        " <RetrieveMultiple xmlns=\"http://schemas.microsoft.com/crm/2007/WebServices\">" +
        " <query xmlns:q1=\"http://schemas.microsoft.com/crm/2006/Query\" xsi:type=\"q1:QueryExpression\">" +
        " <q1:EntityName>systemuser</q1:EntityName>" +
        " <q1:ColumnSet xsi:type=\"q1:ColumnSet\">" +
        " <q1:Attributes>" +
        " <q1:Attribute>businessunitid</q1:Attribute>" +
        " <q1:Attribute>firstname</q1:Attribute>" +
        " <q1:Attribute>fullname</q1:Attribute>" +
        " <q1:Attribute>lastname</q1:Attribute>" +
        " <q1:Attribute>organizationid</q1:Attribute>" +
        " <q1:Attribute>systemuserid</q1:Attribute>" +
        " </q1:Attributes>" +
        " </q1:ColumnSet>" +
        " <q1:Distinct>false</q1:Distinct>" +
        " <q1:Criteria>" +
        " <q1:FilterOperator>And</q1:FilterOperator>" +
        " <q1:Conditions>" +
        " <q1:Condition>" +
        " <q1:AttributeName>systemuserid</q1:AttributeName>" +
        " <q1:Operator>EqualUserId</q1:Operator>" +
        " </q1:Condition>" +
        " </q1:Conditions>" +
        " </q1:Criteria>" +
        " </query>" +
        " </RetrieveMultiple>" +
        " </soap:Body>" +
        "</soap:Envelope>" +
        "";
var xmlHttpRequest2 = new ActiveXObject("Msxml2.XMLHTTP");
xmlHttpRequest2.Open("POST", "/mscrmservices/2007/CrmService.asmx", false);
xmlHttpRequest2.setRequestHeader("SOAPAction", "http://schemas.microsoft.com/crm/2007/WebServices/RetrieveMultiple");
xmlHttpRequest2.setRequestHeader("Content-Type", "text/xml; charset=utf-8");
xmlHttpRequest2.setRequestHeader("Content-Length", xml.length);
xmlHttpRequest2.send(xml);
var resultXml = xmlHttpRequest2.responseXML;
var entityNode = resultXml.selectSingleNode("//RetrieveMultipleResult/BusinessEntities/BusinessEntity");
var firstNameNode = entityNode.selectSingleNode("q1:firstname");
var lastNameNode = entityNode.selectSingleNode("q1:lastname");
var fullNameNode = entityNode.selectSingleNode("q1:fullname");
var systemUserIdNode = entityNode.selectSingleNode("q1:systemuserid");
var businessUnitIdNode = entityNode.selectSingleNode("q1:businessunitid");
var organizationIdNode = entityNode.selectSingleNode("q1:organizationid");

        //Create an array to set as the DataValue for the the lookup control. 
var lookupData = new Array();
        //Create an Object add to the array. 
var lookupItem = new Object();
        //Set the id, typename, and name properties to the object. 
lookupItem.id = systemUserIdNode.text;
lookupItem.typename = 'systemuser';
lookupItem.name = fullNameNode.text;
        // Add the object to the array.
lookupData[0] = lookupItem;
        // Set the value of the lookup field to the value of the array.
var CRM_FORM_TYPE_CREATE = 1;
var CRM_FORM_TYPE_UPDATE = 2;
        // To carry over firstname and fullname callouts into the switch statement
var fullname = fullNameNode.text;
var firstName = firstNameNode.text;
switch (crmForm.FormType) 
case CRM_FORM_TYPE_CREATE:
    if (fullname == "Jeromie Kirchoff") 
        // alert("Hi " + firstName + '\n' + '\n' +"Let me make this easy for you!");

        crmForm.all.ownerid.DataValue = lookupData;
        crmForm.all.ownerid.ForceSubmit = true;

        // run the default order setting I had previously added in my Onload script.
        crmForm.all.new_orderstatus.DataValue = 6;
        try crmForm.orderrstat();  catch (err) alert("Function Call Out - ERROR - 0001-1"); 
    
    break;
case CRM_FORM_TYPE_UPDATE:
    break;

我希望这会有所帮助。 =)

【讨论】:

以上是关于仅当 FormType 为 Create 时才将所有者设置为当前用户的主要内容,如果未能解决你的问题,请参考以下文章

WordPress - 仅当 LT IE 9 时才将脚本排入队列

PostgreSQL:仅当元素唯一时才将元素附加到 jsonb 数组

仅当它们由相机拍摄而不是从照片库中选择时才将图像保存到照片库

仅当表中不存在两个 id 的组合时才将值插入表中

仅当记录不存在时才将 SQL 插入表中[重复]

仅当文件尚不存在时才将行附加到文件中