get rid of JSRS iframe foo for progress bar, use XMLHTTPRequest instead. really...
[freeside.git] / httemplate / elements / progress-popup.html
1 <%
2   my $jobnum = $cgi->param('jobnum');
3   my $url = $cgi->param('url');
4   my $message = $cgi->param('message');
5   my $formname = scalar($cgi->param('formname'));
6 %>
7 <HTML>
8   <HEAD>
9     <TITLE></TITLE>
10   </HEAD>
11   <BODY BGCOLOR="#ccccff" onLoad="refreshStatus()">
12
13 <%= include('/elements/xmlhttp.html',
14               'url'  => $p.'elements/jsrsServer.html',
15               'subs' => [ 'job_status' ],
16            )
17 %>
18 <SCRIPT TYPE="text/javascript" src="../elements/qlib/control.js"></SCRIPT>
19 <SCRIPT TYPE="text/javascript" src="../elements/qlib/imagelist.js"></SCRIPT>
20 <SCRIPT TYPE="text/javascript" src="../elements/qlib/progress.js"></SCRIPT>
21 <SCRIPT TYPE="text/javascript">
22 function refreshStatus () {
23   //jsrsExecute( '<%=$p%>elements/jsrsServer.html', updateStatus, 'job_status', '<%= $jobnum %>' );
24
25   job_status( '<%= $jobnum %>', updateStatus );
26 }
27 function updateStatus( status_statustext ) {
28
29   //var Array = status_statustext.split("\n");
30   var statusArray = eval('(' + status_statustext + ')');
31   var status = statusArray[0];
32   var statustext = statusArray[1];
33
34   //if ( status == 'progress' ) {
35   //IE workaround, no i have no idea why
36   if ( status.indexOf('progress') > -1 ) {
37     document.getElementById("progress_percent").innerHTML = statustext + '%';
38     bar1.set(statustext);
39     bar1.update;
40     //jsrsExecute( '<%=$p%>elements/jsrsServer.html', updateStatus, 'job_status', '<%= $jobnum %>' );
41     job_status( '<%= $jobnum %>', updateStatus );
42   } else if ( status.indexOf('complete') > -1 ) {
43 <% if ( $message ) { %>
44     document.getElementById("progress_message").innerHTML = "<%= $message %>";
45     document.getElementById("progress_bar").innerHTML = '';
46     document.getElementById("progress_percent").innerHTML = '<INPUT TYPE="button" VALUE="OK" onClick="parent.nd(1);">';
47     document.getElementById("progress_jobnum").innerHTML = '';
48     parent.document.<%=$formname%>.submit.disabled=false;
49 <% } elsif ( $url ) { %>
50     window.top.location.href = '<%= $url %>';
51 <% } else { %>
52     alert('job done but no url or message specified');
53 <% } %>
54   } else if ( status.indexOf('error') > -1 ) {
55     document.getElementById("progress_message").innerHTML = '<FONT SIZE="+1" COLOR="#FF0000">Error: ' + statustext + '</FONT>';
56     document.getElementById("progress_bar").innerHTML = '';
57     document.getElementById("progress_percent").innerHTML = '<INPUT TYPE="button" VALUE="OK" onClick="parent.nd(1);">';
58     document.getElementById("progress_jobnum").innerHTML = '';
59     parent.document.<%=$formname%>.submit.disabled=false;
60   } else {
61     alert('XXX unknown status returned from server: ' + status);
62   }
63   
64 }
65 </SCRIPT>
66
67     <TABLE>
68       <TR>
69         <TD ALIGN="center" ID="progress_message">
70           Server processing job...
71         </TD>
72       </TR><TR>
73         <TD ALIGN="center" ID="progress_bar">
74           <SCRIPT TYPE="text/javascript">
75             // Create imagelist
76             SEGS = new QImageList(4, 23, "../images/progressbar-empty.png", "../images/progressbar-full.png");
77             // Create bars
78             bar1 = new QProgress(null, "bar1", SEGS, 100);
79             // bar1.set(0);
80             // bar1.update;
81           </SCRIPT>
82         </TD>
83       </TR><TR>
84         <TD ALIGN="center">
85           <DIV ID="progress_percent">%</DIV>
86         </TD>
87       </TR><TR>
88         <TD ALIGN="center" ID="progress_jobnum">
89           (progress of job #<%= $jobnum %>)
90         </TD>
91       </TR>
92     </TABLE>
93
94   </BODY>
95 </HTML>
96