[freeside-commits] freeside/httemplate/misc/elements customer-table.html, NONE, 1.1
Jeff Finucane,420,,
jeff at wavetail.420.am
Thu Aug 16 06:40:46 PDT 2007
Update of /home/cvs/cvsroot/freeside/httemplate/misc/elements
In directory wavetail:/tmp/cvs-serv28263/httemplate/misc/elements
Added Files:
customer-table.html
Log Message:
support hours 'usage' tracking for our own internal use (#1733)
--- NEW FILE: customer-table.html ---
% # options example...
% #
% # #listrefs...
% # 'header' => [ '#', 'Item' ],
% # 'fields' => [
% # 'column',
% # sub { my ($row,$param) = @_; $param->{"column$row"}; },
% # ],
% # 'sizes' => [], # sizes ignored for immutable
% # 'types' => ['immutable', ''], # immutable or ''/text
% # 'param' => { column0 => 1 }, # preset column of row 0 to 1
% #
<SCRIPT TYPE="text/javascript">
function clearhint_custnum() {
if ( this.value == 'Not found' || this.value == 'Multiple' ) {
this.value = '';
this.style.color = '#000000';
}
}
function clearhint_customer() {
this.style.color = '#000000';
if ( this.value == '(last name or company)' || this.value == 'Not found' )
this.value = '';
}
function <% $opt{prefix} %>search_custnum() {
this.style.color = '#000000'
var custnum_obj = this;
var searchrow = this.getAttribute('rownum');
var custnum = this.value;
if ( custnum == 'searching...' || custnum == 'Not found' || custnum == '' )
return;
if ( this.getAttribute('magic') == 'nosearch' ) {
this.setAttribute('magic', '');
return;
}
if ( ( <% $opt{prefix} %>rownum - searchrow ) == 1 ) {
<% $opt{prefix} %>addRow();
}
var customer = document.getElementById('customer'+searchrow);
customer.value = 'searching...';
customer.disabled = true;
customer.style.color = '#000000';
customer.style.backgroundColor = '#dddddd';
var customer_select = document.getElementById('cust_select'+searchrow);
customer.style.display = '';
customer_select.style.display = 'none';
function search_custnum_update(name) {
var name = eval('(' + name + ')' );
customer.disabled = false;
customer.style.backgroundColor = '#ffffff';
if ( name.length > 0 ) {
customer.value = name;
customer.setAttribute('magic', 'nosearch');
} else {
customer.value = 'Not found';
customer.style.color = '#ff0000';
custnum_obj.style.color = '#ff0000';
}
}
custnum_search( custnum, search_custnum_update );
}
function <% $opt{prefix} %>search_customer() {
var customer_obj = this;
var searchrow = this.getAttribute('rownum');
var customer = this.value;
if ( customer == 'searching...' || customer == 'Not found' || customer == '' )
return;
if ( this.getAttribute('magic') == 'nosearch' ) {
this.setAttribute('magic', '');
return;
}
if ( ( <% $opt{prefix} %>rownum - searchrow ) == 1 ) {
<% $opt{prefix} %>addRow();
}
var custnum_obj = document.getElementById('custnum'+searchrow);
custnum_obj.value = 'searching...';
custnum_obj.disabled = true;
custnum_obj.style.color = '#000000';
custnum_obj.style.backgroundColor = '#dddddd';
var customer_select = document.getElementById('cust_select'+searchrow);
function search_customer_update(customers) {
var customerArray = eval('(' + customers + ')');
custnum_obj.disabled = false;
custnum_obj.style.backgroundColor = '#ffffff';
if ( customerArray.length == 0 ) {
custnum_obj.value = 'Not found';
custnum_obj.style.color = '#ff0000';
customer_obj.style.color = '#ff0000';
customer_obj.style.display = '';
customer_select.style.display = 'none';
} else if ( customerArray.length == 1 ) {
custnum_obj.value = customerArray[0][0];
customer_obj.value = customerArray[0][1];
customer_obj.style.display = '';
customer_select.style.display = 'none';
} else {
custnum_obj.value = 'Multiple'; // or something
custnum_obj.style.color = '#ff0000';
//blank the current list
for ( var i = customer_select.length; i >= 0; i-- )
customer_select.options[i] = null;
opt(customer_select, '', 'Multiple customers match "' + customer + '" - select one', '#ff0000');
//add the multiple customers
for ( var s = 0; s < customerArray.length; s++ )
opt(customer_select, customerArray[s][0], customerArray[s][1], '#000000');
opt(customer_select, 'cancel', '(Edit search string)', '#000000');
customer_obj.style.display = 'none';
customer_select.style.display = '';
}
}
smart_search( customer, search_customer_update );
}
function select_customer() {
var custnum = this.options[this.selectedIndex].value;
var customer = this.options[this.selectedIndex].text;
var searchrow = this.getAttribute('rownum');
var custnum_obj = document.getElementById('custnum'+searchrow);
var customer_obj = document.getElementById('customer'+searchrow);
if ( custnum == '' ) {
} else if ( custnum == 'cancel' ) {
custnum_obj.value = '';
custnum_obj.style.color = '#000000';
this.style.display = 'none';
customer_obj.style.display = '';
customer_obj.focus();
} else {
custnum_obj.value = custnum;
custnum_obj.style.color = '#000000';
customer_obj.value = customer;
customer_obj.style.color = '#000000';
this.style.display = 'none';
customer_obj.style.display = '';
}
}
function opt(what,value,text,color) {
var optionName = new Option(text, value, false, false);
optionName.style.color = color;
var length = what.length;
what.options[length] = optionName;
}
</SCRIPT>
<TABLE ID="<% $opt{prefix} %>OneTrueTable" BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0>
<TR>
<TH>Cust #</TH>
<TH>Customer</TH>
% foreach my $header ( @{$opt{header}} ) {
<TH><% $header %></TH>
% }
</TR>
% my $row = 0;
% for ( $row = 0; exists($param->{"custnum$row"}); $row++ ) {
<TR>
<TD>
<INPUT TYPE="text" NAME="custnum<% $row %>" ID="custnum<% $row %>" SIZE=8 MAXLENGTH=12 VALUE="<% $param->{"custnum$row"} %>" rownum="<% $row %>">
<SCRIPT TYPE="text/javascript">
var custnum_input<% $row %> = document.getElementById("custnum<% $row %>");
custnum_input<% $row %>.onfocus = clearhint_custnum;
custnum_input<% $row %>.onchange = <% $opt{prefix} %>search_custnum;
</SCRIPT>
</TD>
<TD>
<INPUT TYPE="text" NAME="customer<% $row %>" ID="customer<% $row %>" SIZE=64 VALUE="<% $param->{"customer$row"} %>" rownum="<% $row %>">
<SCRIPT TYPE="text/javascript">
var customer_input<% $row %> = document.getElementById("customer<% $row %>");
customer_input<% $row %>.onfocus = clearhint_customer;
customer_input<% $row %>.onclick = clearhint_customer;
customer_input<% $row %>.onchange = <% $opt{prefix} %>search_customer;
</SCRIPT>
<SELECT NAME="cust_select<% $row %>" ID="cust_select<% $row %>" rownum="<% $row %>" STYLE="color:#ff0000; display:none">
</SELECT>
<SCRIPT TYPE="text/javascript">
var customer_select<% $row %> = document.getElementById("cust_select<% $row %>");
customer_select<% $row %>.onchange = select_customer;
</SCRIPT>
</TD>
% my $col = 0;
% foreach my $field ( @{$opt{fields}} ) {
% my $value;
% if ( ref($field) eq 'CODE' ) {
% $value = &{$field}($row,$param);
% } else {
% $value = $param->{"$field$row"};
% }
% my $name = (ref($field) eq 'CODE') ? "column${col}_$row" : "$field$row";
% my $size = $sizes->[$col] || 10;
<TD>
% if (! $types->[$col] || $types->[$col] eq 'text') {
<INPUT TYPE="text" NAME="<% $name %>" SIZE="<% $size %>" VALUE="<% $value %>" >
% } elsif ($types->[$col] eq 'immutable') {
<% $value %>
<INPUT TYPE="hidden" NAME="<% $name %>" VALUE="<% $value %>" >
% } else {
Cannot represent unknown type: <% $types->[$col] %>
% }
</TD>
% $col++;
% }
</TR>
% }
</TABLE>
<% include('/elements/xmlhttp.html',
'url' => $p. 'misc/xmlhttp-cust_main-search.cgi',
'subs' => [qw( custnum_search smart_search )],
)
%>
<SCRIPT TYPE="text/javascript">
var <% $opt{prefix} %>rownum = <% $row %>;
function <% $opt{prefix} %>addRow() {
var table = document.getElementById('<% $opt{prefix} %>OneTrueTable');
var tablebody = table.getElementsByTagName('tbody').item(0);
var row = document.createElement('TR');
var custnum_cell = document.createElement('TD');
var custnum_input = document.createElement('INPUT');
custnum_input.setAttribute('name', 'custnum'+<% $opt{prefix} %>rownum);
custnum_input.setAttribute('id', 'custnum'+<% $opt{prefix} %>rownum);
custnum_input.setAttribute('size', 8);
custnum_input.setAttribute('maxlength', 12);
custnum_input.setAttribute('rownum', <% $opt{prefix} %>rownum);
custnum_input.onfocus = clearhint_custnum;
custnum_input.onchange = <% $opt{prefix} %>search_custnum;
custnum_cell.appendChild(custnum_input);
row.appendChild(custnum_cell);
var customer_cell = document.createElement('TD');
var customer_input = document.createElement('INPUT');
customer_input.setAttribute('name', 'customer'+<% $opt{prefix} %>rownum);
customer_input.setAttribute('id', 'customer'+<% $opt{prefix} %>rownum);
customer_input.setAttribute('size', 64);
customer_input.setAttribute('value', '(last name or company)' );
customer_input.setAttribute('rownum', <% $opt{prefix} %>rownum);
customer_input.onfocus = clearhint_customer;
customer_input.onclick = clearhint_customer;
customer_input.onchange = <% $opt{prefix} %>search_customer;
customer_cell.appendChild(customer_input);
var customer_select = document.createElement('SELECT');
customer_select.setAttribute('name', 'cust_select'+<% $opt{prefix} %>rownum);
customer_select.setAttribute('id', 'cust_select'+<% $opt{prefix} %>rownum);
customer_select.setAttribute('rownum', <% $opt{prefix} %>rownum);
customer_select.style.color = '#ff0000';
customer_select.style.display = 'none';
customer_select.onchange = select_customer;
customer_cell.appendChild(customer_select);
row.appendChild(customer_cell);
% my $col = 0;
% foreach my $field ( @{$opt{fields}} ) {
var my_cell = document.createElement('TD');
% if ($types->[$col] eq 'immutable') {
% my $value;
% if ( ref($field) eq 'CODE' ) {
% $value = &{$field}($row,$param);
% } else {
% $value = $param->{"$field$row"};
% }
var my_text = document.createTextNode('<% $value %>');
my_cell.appendChild(my_text);
% }
var my_input = document.createElement('INPUT');
my_input.setAttribute('name', '<% $field %>'+<% $opt{prefix} %>rownum);
my_input.setAttribute('size', <% $sizes->[$col] || 10 %>);
% if ($types->[$col] eq 'immutable') {
my_input.setAttribute('type', 'hidden');
% }
my_cell.appendChild(my_input);
row.appendChild(my_cell);
% $col++;
% }
tablebody.appendChild(row);
<% $opt{prefix} %>rownum++;
}
% unless ($cgi->param('error')) {
<% $opt{prefix} %>addRow();
% }
</SCRIPT>
<%init>
my(%opt) = @_;
$opt{prefix} = '' unless defined $opt{prefix};
$opt{prefix} .= '_' if $opt{prefix};
my $types = $opt{'types'} ? [ @{$opt{'types'}} ] : [];
my $sizes = $opt{'sizes'} ? [ @{$opt{'sizes'}} ] : [];
my $param = $opt{param};
$param = $cgi->Vars if $cgi->param('error');
</%init>
More information about the freeside-commits
mailing list