Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations strongm on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

How do I include dropdown options in some entry fields of this form?

Status
Not open for further replies.

Malbordio

Programmer
Oct 19, 2014
12
PT
I have this vbscript form that allows me opening incidents, but, I wish to have a dropdown menu in some fields which allow me to select the appropriate option. How to I include those selectable options in this form?

Many thanks in advance and here is the code:

Code:
Option Explicit 
 Dim oParams, bAccepted, wsInsertIncidentAlert, sPar 
 ' base64 coded background image, converted with [URL unfurl="true"]http://picbase64.com/[/URL] 
 Const sBG = "[URL unfurl="true"]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"[/URL] 
 ' base64 coded logo image, converted with [URL unfurl="true"]http://picbase64.com/[/URL] 
 Const sLogo = "" 
 ' Prepare ticket values dictionary 
 Set oParams = CreateObject("Scripting.Dictionary") 
 With oParams 
     .Add "username", Array("O seu username", "input", "type='text'") 
     .Add "password", Array("A sua password", "input", "type='password'") 
     .Add "source_incident", Array("Incidente de Origem", "input", "type='text'") 
     .Add "dv_u_massive_classification", Array("Classificação do Massivo (Insira uma classificação geral)", "input", "type='text'") 
     .Add "assignment_group", Array("Suporte/Fornecedor (Equipa a atribuir alerta)", "input", "type='text'") 
     .Add "short_description", Array("Assunto (Insira um tópico para este alerta)", "input", "type='text'") 
     .Add "description", Array("Descrição (Descreva detalhadamente a sua situação)", "textarea", "rows='5'") 
 End With 
 ' Show `Get Ticket Values` form 
 GetParams "Centro de Comando: Novo Alerta", "ServiceNow: Criar Novo Alerta", sBG, sLogo, oParams, bAccepted, 550, 620 
 If Not bAccepted Then WScript.Quit 
 ' Specify the ticket values 
 Set wsInsertIncidentAlert = New ServiceNowDirectWS 
 wsInsertIncidentAlert.sServiceNowURL = "[URL unfurl="true"]https://url.service-now.com/"[/URL] 
 wsInsertIncidentAlert.sServiceNowUser = oParams("username") 
 wsInsertIncidentAlert.sServiceNowPass = oParams("password") 
 wsInsertIncidentAlert.SetMethod "incident_alert", "insert" 
 For Each sPar In Array("source_incident", "dv_u_massive_classification", "assignment_group", "short_description", "description") 
     wsInsertIncidentAlert.SetValue sPar, oParams(sPar) 
 Next 
 ' Perform the insert and check the status 
 If Not wsInsertIncidentAlert.Post Then 
     WScript.Echo "Error=" & wsInsertIncidentAlert.Status 
     WScript.Echo wsInsertIncidentAlert.StatusText 
     WScript.Quit 
 End If 
 Class ServiceNowDirectWS 
     ' Use this class to call ServiceNow Direct Web Services functions 
     ' For documentation on the Direct WS API see: 
     ' [URL unfurl="true"]http://wiki.servicenow.co..._Service_API_Functions[/URL] 
      
     Public sServiceNowUser, sServiceNowPass, sServiceNowURL 
     Dim sEndpointURL, sTableName, sMethod, sResponsePath 
     Dim oWSRequest, oWSRequestDoc, oWSResponseDoc 
     Dim oWSRequestEnvelope, oWSRequestBody, oWSRequestOperation 
      
     Public Sub SetMethod (tableName, method) 
         ' This function must be called BEFORE Post to initialize the class 
         ' method must be "insert", "update", "getKeys", "get" or "getRecords" 
         sTableName = tableName 
         sMethod = method 
         sResponsePath = "/soap:Envelope/soap:Body/" & sMethod & "Response/" 
         sEndpointURL = sServiceNowURL & sTableName & ".do?SOAP" 
         If (sMethod = "get" Or sMethod = "getRecords") Then 
             sEndpointURL = sEndpointURL & "&displayvalue=all" 
         End If 
         Set oWSRequest = CreateObject("MSXML2.XMLHTTP") 
         Set oWSRequestDoc = CreateObject("MSXML2.DOMDocument") 
         Set oWSRequestEnvelope = oWSRequestDoc.createElement("soap:Envelope") 
         oWSRequestEnvelope.setAttribute "xmlns:soap", _ 
         "[URL unfurl="true"]http://schemas.xmlsoap.org/soap/envelope/"[/URL] 
         Set oWSRequestBody = oWSRequestDoc.createElement("soap:Body") 
         Set oWSRequestOperation = oWSRequestDoc.createElement("tns:" & sMethod) 
         oWSRequestOperation.setAttribute "xmlns:tns", _ 
         "[URL unfurl="true"]http://www.service-now.com/"[/URL] & sTableName 
         oWSRequestDoc.appendChild oWSRequestEnvelope 
         oWSRequestEnvelope.appendChild oWSRequestBody 
         oWSRequestBody.appendChild oWSRequestOperation 
     End Sub 
      
     Public Function Post 
         ' This function does the actual Web Services call 
         ' It returns True if the call is successful and False if there is an error 
         oWSRequest.open "POST", sEndpointURL, False, sServiceNowUser, sServiceNowPass 
         oWSRequest.setRequestHeader "Content-Type", "text/xml" 
         oWSRequest.send oWSRequestDoc.xml 
         If oWSRequest.status = 200 Then 
             Set oWSResponseDoc = CreateObject("MSXML2.DOMDocument") 
             oWSResponseDoc.loadXML oWSRequest.responseText 
             oWSResponseDoc.setProperty "SelectionLanguage", "XPath" 
             oWSResponseDoc.setProperty "SelectionNamespaces", _ 
             "xmlns:soap='[URL unfurl="true"]http://schemas.xmlsoap.org/soap/envelope/'"[/URL] 
             Post = True 
         Else 
             Set oWSResponseDoc = Nothing 
             Post = False 
         End if 
     End Function 
      
     Public Function Status 
         ' If Post returns False then call this function to obtain the HTTP status code 
         Status = oWSRequest.status 
     End Function 
      
     Public Function StatusText 
         ' If Post returns False then call this function for the error text 
         StatusText = oWSRequest.statusText 
     End Function 
      
     Public Sub SetValue(fieldname, fieldvalue) 
         ' This function must be called BEFORE Post 
         Dim oChild 
         Set oChild = oWSRequestDoc.createElement(fieldname) 
         oChild.appendChild(oWSRequestDoc.createTextNode(fieldvalue)) 
         oWSRequestOperation.appendChild(oChild) 
     End Sub 
      
     Public Function GetValue(fieldname) 
         ' This function must be called AFTER Post 
         ' If method is "insert" then it can be used to obtain the sys_id of the inserted record 
         ' If method is "get" then it can be used to obtain any field from the record 
         GetValue = oWSResponseDoc.selectSingleNode(sResponsePath & fieldname).text 
     End Function 
      
     Public Function GetRowCount 
         ' This function may be called after Post if the method is "getRecords" 
         ' It returns the number of records in the result set 
         Dim sResultsPath, oNodeset 
         sResultsPath = sResponsePath & "getRecordsResult" 
         Set oNodeSet = oWSResponseDoc.selectNodes(sResultsPath) 
         getRowCount = oNodeSet.length 
     End Function 
      
     Public Function GetRowValue(rownum, fieldname) 
         ' This function may be called after Post if the method is "getRecords" 
         ' It returns a single field from a single record 
         Dim sRowPath, sFieldPath 
         sRowPath = sResponsePath & "getRecordsResult[" & rownum & "]/" 
         sFieldPath = sRowPath & fieldname 
         GetRowValue = oWSResponseDoc.selectSingleNode(sFieldPath).text 
     End Function 
      
 End Class 
 Sub GetParams(sTitle, sPrompt, sImgBackGround, sImgLogo, oParams, bAccepted, iWidth, iHeight) 
     Dim oWnd, sContent, aKeys, i 
     sContent = "<img src='" & sImgLogo & "'/><p><center>" & HtmlSafe(sPrompt) & "</center></p>" 
     aKeys = oParams.Keys 
     For i = 0 To oParams.Count - 1 
         sContent = sContent & "<span>" & HtmlSafe(oParams(aKeys(i))(0)) & "</span><br>" 
         sContent = sContent & "<" & oParams(aKeys(i))(1) & " id=ctl" & i & " " & oParams(aKeys(i))(2) & " style='font: 8pt tahoma; width: 100%;'></" & oParams(aKeys(i))(1) & ">" 
     Next 
     sContent = sContent & "<input onclick='window.accepted=true;' type='button' value='Criar' style='font: 8pt tahoma; width: 75px; height: 21px; float: right; margin-right: 20px;'/>" 
     Set oWnd = CreateWindow() 
     With oWnd 
         With .Document 
             .Title = sTitle 
             .GetElementsByTagName("head")(0).appendchild .CreateElement("style") 
             .stylesheets(0).cssText = "* {font: 8pt tahoma; margin: 5px;}" 
             .Body.Style.Margin = "18px" 
             .Body.Style.Background = "buttonface" 
             .Body.Style.BackgroundRepeat = "no-repeat" 
             .Body.Style.BackgroundImage = "url(" & sImgBackGround & ")" 
             .Body.InnerHtml = sContent 
         End With 
         .ResizeTo .Screen.AvailWidth,.Screen.AvailHeight 
         .ResizeTo iWidth + .Screen.AvailWidth - .Document.Body.OffsetWidth, iHeight + .Screen.AvailHeight - .Document.Body.OffsetHeight 
         .MoveTo CInt((.Screen.AvailWidth - iWidth) / 2), CInt((.Screen.AvailHeight - iHeight) / 2) 
     End With 
     oWnd.ExecScript "var accepted=false;" 
     On Error Resume Next 
     Do 
         bAccepted = oWnd.Accepted 
         If bAccepted Then Exit Do 
         If Err.Number <> 0 Then 
             bAccepted = False 
             Exit Sub 
         End If 
         WScript.Sleep 10 
     Loop 
     For i = 0 To oParams.Count - 1 
         oParams(aKeys(i)) = oWnd.Document.GetElementById("ctl" & i).Value 
     Next 
     oWnd.Close 
 End Sub 
 Function HtmlSafe(sText) 
     HtmlSafe = Replace(Replace(Replace(Replace(sText, "&", "&amp;"), "<", "&lt;"), ">", "&gt;"), vbCrLf, "<br>") 
 End Function 
 Function CreateWindow() 
     ' source [URL unfurl="true"]http://forum.script-coding.com/viewtopic.php?pid=75356#p75356[/URL] 
     Dim sSignature, oShellWnd, oProc 
     sSignature = Left(CreateObject("Scriptlet.TypeLib").Guid, 38) 
     Set oProc = CreateObject("WScript.Shell").Exec("mshta ""about:<html><head><script>moveTo(-32000,-32000);document.title=' '</script><hta:application id=app border=thick minimizebutton=no maximizebutton=no scroll=no showintaskbar=yes contextmenu=no selection=no innerborder=no icon=""""/><object id='shell' classid='clsid:8856F961-340A-11D0-A96B-00C04FD705A2'><param name=RegisterAsBrowser value=1></object><script>shell.putproperty('" & sSignature & "',document.parentWindow);</script></head></html>""") 
     Do 
         If oProc.Status > 0 Then 
             Set CreateWindow = Nothing 
             Exit Function 
         End If 
         For Each oShellWnd In CreateObject("Shell.Application").Windows 
             On Error Resume Next 
             Set CreateWindow = oShellWnd.GetProperty(sSignature) 
             If Err.Number = 0 Then Exit Function 
             On Error Goto 0 
         Next 
     Loop 
 End Function
 
<select size="1" name="OptionChooser" onChange="TestSub">
<option value="0"></option>
<option value="1">Option 1</option>
<option value="2">Option 2</option>
<option value="3">Option 3</option>
</select>

I hope that helps.

Regards,

Mark

No trees were harmed in posting this message, however a significant number of electrons were terribly inconvenienced.

Check out my scripting solutions at
Work SMARTER not HARDER.
 
Where in my script should I include yours please?
 
It has to go in the body. I would recommend you download HTAOmatic from Microsoft. It will help you build this out.


I hope that helps.

Regards,

Mark

No trees were harmed in posting this message, however a significant number of electrons were terribly inconvenienced.

Check out my scripting solutions at
Work SMARTER not HARDER.
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top