projects
/
freeside.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
This commit was generated by cvs2svn to compensate for changes in r8690,
[freeside.git]
/
httemplate
/
elements
/
xmlhttp.html
diff --git
a/httemplate/elements/xmlhttp.html
b/httemplate/elements/xmlhttp.html
index
4f4c5f5
..
d0c7990
100644
(file)
--- a/
httemplate/elements/xmlhttp.html
+++ b/
httemplate/elements/xmlhttp.html
@@
-1,15
+1,19
@@
-<%
- my ( %opt ) = @_;
+<%doc>
- my $url = $opt{'url'};
- my $method = exists($opt{'method'}) ? $opt{'method'} : 'GET';
- #my @subs = @{ $opt{'subs'};
+Example:
- $url .= ( ($url =~ /\?/) ? '&' : '?' )
- if $method eq 'GET';
+ include( '/elements/xmlhttp.html',
+ # required
+ 'url' => $p.'misc/something.html',
+ 'subs' => [ 'subroutine' ],
-%>
+ # optional
+ 'method' => 'GET', #defaults to GET, could specify POST
+ 'key' => 'unique', #unique key
+ );
+
+</%doc>
<SCRIPT TYPE="text/javascript">
function rs_init_object() {
<SCRIPT TYPE="text/javascript">
function rs_init_object() {
@@
-30,22
+34,22
@@
return A;
}
return A;
}
+% foreach my $func ( @{$opt{'subs'}} ) {
+%
+% my $furl = $url;
+% $furl =~ s/\"/\\\\\"/; #javascript escape
+%
+%
- <% foreach my $func ( @{$opt{'subs'}} ) {
-
- my $furl = $url;
- $furl =~ s/\"/\\\\\"/; #javascript escape
-
- %>
- function <%
=
$func%>() {
+ function <%
$key%><%
$func%>() {
// count args; build URL
// count args; build URL
- var url = "<%
=
$furl%>";
- var a = <%
=
$func%>.arguments;
+ var url = "<%$furl%>";
+ var a = <%
$key%><%
$func%>.arguments;
var args;
var len;
var args;
var len;
- var content = 'sub=<%
=
uri_escape($func) %>';
+ var content = 'sub=<% uri_escape($func) %>';
if ( a && typeof a == 'object' && a[0].constructor == Array ) {
args = a[0];
len = args.length
if ( a && typeof a == 'object' && a[0].constructor == Array ) {
args = a[0];
len = args.length
@@
-57,14
+61,14
@@
content = content + "&arg=" + escape(args[i]);
content = content.replace( /[+]/g, '%2B'); // fix unescaped plus signs
content = content + "&arg=" + escape(args[i]);
content = content.replace( /[+]/g, '%2B'); // fix unescaped plus signs
- if ( '<%
=
$method%>' == 'GET' ) {
+ if ( '<%$method%>' == 'GET' ) {
url = url + content;
}
url = url + content;
}
- //alert('<%
=
$method%> ' + url);
+ //alert('<%$method%> ' + url);
var xmlhttp = rs_init_object();
var xmlhttp = rs_init_object();
- xmlhttp.open("<%
=
$method%>", url, true);
+ xmlhttp.open("<%$method%>", url, true);
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState != 4)
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState != 4)
@@
-78,7
+82,7
@@
a[a.length-1](data);
if ( data.indexOf("<b>System error</b>") > -1 ) {
var w;
a[a.length-1](data);
if ( data.indexOf("<b>System error</b>") > -1 ) {
var w;
- if ( w = window.open("about:blank")
_ }
+ if ( w = window.open("about:blank")
) {
w.document.write(data);
} else {
// popup blocking? should use an overlib popup instead
w.document.write(data);
} else {
// popup blocking? should use an overlib popup instead
@@
-88,7
+92,7
@@
}
}
}
}
- if ( '<%
=
$method%>' == 'POST' ) {
+ if ( '<%$method%>' == 'POST' ) {
xmlhttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xmlhttp.send(content);
xmlhttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xmlhttp.send(content);
@@
-103,7
+107,19
@@
//rs_debug("x_$func_name url = " + url);
//rs_debug("x_$func_name waiting..");
}
//rs_debug("x_$func_name url = " + url);
//rs_debug("x_$func_name waiting..");
}
+% }
- <% } %>
</SCRIPT>
</SCRIPT>
+<%init>
+my ( %opt ) = @_;
+
+my $url = $opt{'url'};
+my $method = exists($opt{'method'}) ? $opt{'method'} : 'GET';
+#my @subs = @{ $opt{'subs'};
+my $key = exists($opt{'key'}) ? $opt{'key'} : '';
+
+$url .= ( ($url =~ /\?/) ? '&' : '?' )
+ if $method eq 'GET';
+
+</%init>