2014-09-03 2 views
0

자바 스크립트를 처음 사용하기 때문에 기본적으로 CRM에서 편집 할 양식이 있습니다. OnLoad 기능을 사용할 때 서로 독립적 인 두 가지 스크립트가 있습니다. 두 스크립트 세트를 동일한 스크립트 개발자 (CRM의 동일한 양식에 대한 것이기 때문에)에 넣었을 때 두 코드 모두 독립적으로 작동합니다. 그 중 하나는 작동하지 않습니다.CRM 자바 스크립트, 동일한 OnLoad 양식의 여러 독립 스크립트 세트

누구든지 도움을받을 수 있습니까? 동일한 양식에 여러 개의 스크립트가있는 특별한 구문이 있습니까? 자바 스크립트는 다음과 같습니다

감사 :

var _roles = 'Compliance'; //array of security roles name 

var _fields = 'new_pend'; // array of field schema names to enable 

UpdateFields(); 

/* Functions */ 

function UpdateFields() { 

    var oXml = GetCurrentUserRoles(); 

    if (oXml != null) { 

     var roles = oXml.selectNodes("//BusinessEntity/q1:name"); 

     if (roles != null) { 

      for (i = 0; i < roles.length; i++) { 

       for (j = 0; j < _roles.length; j++) { 

        if (roles[i].text == _roles[j]) { 

         for (k = 0; k < _fields.length; k++) { 

          try { 

           document.getElementById(_fields[k]).Disabled = false; 

          } catch (e) { 

          } 

         } 

         return; 

        } 

       } 

      } 

     } 

    } 

    return; 

} 

function GetCurrentUserRoles() { 

    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>role</q1:EntityName>" + 
" <q1:ColumnSet xsi:type=\"q1:ColumnSet\">" + 
" <q1:Attributes>" + 
" <q1:Attribute>name</q1:Attribute>" + 
" </q1:Attributes>" + 
" </q1:ColumnSet>" + 
" <q1:Distinct>false</q1:Distinct>" + 
" <q1:LinkEntities>" + 
" <q1:LinkEntity>" + 
" <q1:LinkFromAttributeName>roleid</q1:LinkFromAttributeName>" + 
" <q1:LinkFromEntityName>role</q1:LinkFromEntityName>" + 
" <q1:LinkToEntityName>systemuserroles</q1:LinkToEntityName>" + 
" <q1:LinkToAttributeName>roleid</q1:LinkToAttributeName>" + 
" <q1:JoinOperator>Inner</q1:JoinOperator>" + 
" <q1:LinkEntities>" + 
" <q1:LinkEntity>" + 
" <q1:LinkFromAttributeName>systemuserid</q1:LinkFromAttributeName>" + 
" <q1:LinkFromEntityName>systemuserroles</q1:LinkFromEntityName>" + 
" <q1:LinkToEntityName>systemuser</q1:LinkToEntityName>" + 
" <q1:LinkToAttributeName>systemuserid</q1:LinkToAttributeName>" + 
" <q1:JoinOperator>Inner</q1:JoinOperator>" + 
" <q1:LinkCriteria>" + 
" <q1:FilterOperator>And</q1:FilterOperator>" + 
" <q1:Conditions>" + 
" <q1:Condition>" + 
" <q1:AttributeName>systemuserid</q1:AttributeName>" + 
" <q1:Operator>EqualUserId</q1:Operator>" + 
" </q1:Condition>" + 
" </q1:Conditions>" + 
" </q1:LinkCriteria>" + 
" </q1:LinkEntity>" + 
" </q1:LinkEntities>" + 
" </q1:LinkEntity>" + 
" </q1:LinkEntities>" + 
" </query>" +  
" </RetrieveMultiple>" +  
" </soap:Body>" + 
"</soap:Envelope>" + 
""; 

    var xmlHttpRequest = new ActiveXObject("Msxml2.XMLHTTP"); 

    xmlHttpRequest.Open("POST", "/mscrmservices/2007/CrmService.asmx", false); 

    xmlHttpRequest.setRequestHeader("SOAPAction", " http://schemas.microsoft.com/crm/2007/WebServices/RetrieveMultiple"); 

    xmlHttpRequest.setRequestHeader("Content-Type", "text/xml; charset=utf-8"); 

    xmlHttpRequest.setRequestHeader("Content-Length", xml.length); 

    xmlHttpRequest.send(xml); 

    var resultXml = xmlHttpRequest.responseXML; 

    return (resultXml); 

} 
+0

실행중인 CRM 버전은 무엇입니까? 스크립트의 세부 사항을 게시하고 OnLoad 이벤트에 의해 호출되도록 스크립트를 구성한 방법을 게시 할 수 있습니까? – Zach

+0

안녕하세요. CRM 4.0을 실행 중입니다. 위의 스크립트를 업로드했습니다. 이 스크립트는 기본적으로 CRM의 양식에 대해 OnLoad 이벤트를 호출합니다. 특정 사용자 역할과 사용자가 지정된 기준을 충족하는 역할을 가질 때 사용해야하는 특정 필드를 정의했습니다. 이것이 합리적인지 확실하지 않습니다. –

답변

0

안녕하세요 모든 사람이 읽기, 그 문제에 대한 해결책을 발견했다.

If 문을 사용하여 출력이 함수에 대한 입력을 기반으로 정의되어야합니다. 이 코드는 GetCurrentUserRoles 함수와 함께 사용하십시오. 모든 도움에 감사드립니다.

if(UserHasRole("Collections") ==true) 
{ 
crmForm.all.new_pend.Disabled = false; 
return; 
} 
else if (UserHasRole("Collections") ==false) 
{ 
crmForm.all.new_pend.Disabled = true; 
return; 
} 

function UserHasRole(roleName) 
{ 
//get Current User Roles, oXml is an object 
var oXml = GetCurrentUserRoles(); 
if(oXml != null) 

{ 
//select the node text 
var roles = oXml.selectNodes("//BusinessEntity/q1:name"); 
if(roles != null) 
{ 
for(i = 0; i < roles.length; i++) 
{ 
if(roles[i].text == roleName) 
{ 
//return true if user has this role 
return true; 
} 
} 
} 
} 
//otherwise return false 
return false; 
} 
관련 문제