4.x style
[freeside.git] / httemplate / elements / file-upload.html
1 <SCRIPT TYPE="text/javascript">
2
3   function doUpload(form, callback) {
4     var name = 'form' + Math.floor(Math.random() * 99999); // perlize?
5     var d = document.createElement('DIV');
6     d.innerHTML = '<iframe style="display:none" src="about:blank" ' +
7                            'id="'   + name + '" ' +
8                            'name="' + name + '" ' +
9                            'onload="uploadComplete(\'' + name + '\')">' +
10                   '</iframe>';
11     document.body.appendChild(d);
12
13     var i = document.getElementById(name);
14     if (callback && typeof(callback) == 'function') {
15       i.onComplete = callback;
16     }
17
18     form.setAttribute('target', name);
19     return true;
20   }
21
22   function uploadComplete(id) {
23     var i = document.getElementById(id);
24     if (i.contentDocument) {
25       var d = i.contentDocument;
26     } else if (i.contentWindow) {
27       var d = i.contentWindow.document;
28     } else {
29       var d = window.frames[id].document;
30     }
31     if (d.location.href == "about:blank") {
32       return;
33     }
34
35     document.getElementById('r').innerHTML = d.body.innerHTML;
36     if (typeof(i.onComplete) == 'function') {
37       var p;
38       if (p = d.body.innerHTML.indexOf("File Upload Successful ") >= 0) {
39         var v = d.body.innerHTML.substr(p+24);
40         var u = document.getElementById('uploaded_files');
41         v = v.substr(0, v.indexOf(';'));
42         u.value = v;
43         i.onComplete(true, '');
44       }else{
45         i.onComplete(false, d.body.innerHTML);
46       }
47     }
48   }
49
50 <&| onload.js &>
51 // force the form to submit as multipart
52 var thisform = document.getElementById('uploaded_files').form;
53 thisform.enctype = 'multipart/form-data';
54 </&>
55 </SCRIPT>
56
57 <INPUT TYPE="hidden" NAME="uploaded_files" ID="uploaded_files" VALUE="" />
58
59 <INPUT TYPE="hidden" NAME="upload_fields" VALUE="<% join(',', @field) %>" />
60
61 % foreach (@field) {
62 %   if($param{'no_table'}) {
63   <% shift @label %> <INPUT TYPE="file" NAME="<% $_ %>" />
64 %   }
65 %   else {
66     <TR>
67       <TH ALIGN="<% $param{'label_align'} || 'right' %>"><% shift @label %></TH>
68       <TD><INPUT TYPE="file" NAME="<% $_ %>" /></TD>
69     </TR>
70 %   }
71 % }
72
73 <DIV STYLE="display:<% $param{debug} ? 'visible' : 'none' %>">
74   Debugging: <PRE ID="r"></PRE>
75 </DIV>
76
77 <%init>
78
79 my %param = @_;
80
81 my @label = ref($param{'label'}) ? @{$param{'label'}} : ($param{'label'});
82 my @field = ref($param{'field'}) ? @{$param{'field'}} : ($param{'field'});
83
84 </%init>