INTELLIGENT WORK FORUMS
FOR COMPUTER PROFESSIONALS

Come Join Us!

Are you a
Computer / IT professional?
Join Tek-Tips Forums!
  • Talk With Other Members
  • Be Notified Of Responses
    To Your Posts
  • Keyword Search
  • One-Click Access To Your
    Favorite Forums
  • Automated Signatures
    On Your Posts
  • Best Of All, It's Free!

*Tek-Tips's functionality depends on members receiving e-mail. By joining you are opting in to receive e-mail.

Posting Guidelines

Promoting, selling, recruiting, coursework and thesis posting is forbidden.

Jobs

Jobs from Indeed

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

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

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

(OP)
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 --> vbscript

Option Explicit 
 Dim oParams, bAccepted, wsInsertIncidentAlert, sPar 
 ' base64 coded background image, converted with http://picbase64.com/ 
 Const sBG = "" 
 ' base64 coded logo image, converted with http://picbase64.com/ 
 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 = "https://url.service-now.com/" 
 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: 
     ' http://wiki.servicenow.co..._Service_API_Functions 
      
     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", _ 
         "http://schemas.xmlsoap.org/soap/envelope/" 
         Set oWSRequestBody = oWSRequestDoc.createElement("soap:Body") 
         Set oWSRequestOperation = oWSRequestDoc.createElement("tns:" & sMethod) 
         oWSRequestOperation.setAttribute "xmlns:tns", _ 
         "http://www.service-now.com/" & 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='http://schemas.xmlsoap.org/soap/envelope/'" 
             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 http://forum.script-coding.com/viewtopic.php?pid=75356#p75356 
     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 

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

<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 http://www.thespidersparlor.com/vbscript

Work SMARTER not HARDER.

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

(OP)
Where in my script should I include yours please?

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

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 http://www.thespidersparlor.com/vbscript

Work SMARTER not HARDER.

Red Flag This Post

Please let us know here why this post is inappropriate. Reasons such as off-topic, duplicates, flames, illegal, vulgar, or students posting their homework.

Red Flag Submitted

Thank you for helping keep Tek-Tips Forums free from inappropriate posts.
The Tek-Tips staff will check this out and take appropriate action.

Reply To This Thread

Posting in the Tek-Tips forums is a member-only feature.

Click Here to join Tek-Tips and talk with other members!

Resources

Close Box

Join Tek-Tips® Today!

Join your peers on the Internet's largest technical computer professional community.
It's easy to join and it's free.

Here's Why Members Love Tek-Tips Forums:

Register now while it's still free!

Already a member? Close this window and log in.

Join Us             Close