2 <SCRIPT TYPE="text/javascript">
3 function sh_add<% $name %>()
6 if (document.getElementById('<% $name %>').selectedIndex == 0){
7 <% $controlledbutton ? $controlledbutton.'.disabled = true;' : ';' %>
9 <% $controlledbutton ? $controlledbutton.'.disabled = false;' : ';' %>
12 %if ($curuser->access_right($access_right)){
14 if (document.getElementById('<% $name %>').selectedIndex ==
15 (document.getElementById('<% $name %>').length - 1)) {
16 document.getElementById('new<% $name %>').disabled = false;
17 document.getElementById('new<% $name %>').style.display = 'inline';
18 document.getElementById('new<% $name %>Label').style.display = 'inline';
19 document.getElementById('new<% $name %>T').disabled = false;
20 document.getElementById('new<% $name %>T').style.display = 'inline';
21 document.getElementById('new<% $name %>TLabel').style.display = 'inline';
23 document.getElementById('new<% $name %>').disabled = true;
24 document.getElementById('new<% $name %>').style.display = 'none';
25 document.getElementById('new<% $name %>Label').style.display = 'none';
26 document.getElementById('new<% $name %>T').disabled = true;
27 document.getElementById('new<% $name %>T').style.display = 'none';
28 document.getElementById('new<% $name %>TLabel').style.display = 'none';
37 <TD ALIGN="right">Reason</TD>
39 <SELECT id="<% $name %>" name="<% $name %>" onFocus="sh_add<% $name %>()" onChange="sh_add<% $name %>()">
40 % my @reasons = qsearch( { table =>'reason',
42 % extra_sql => $extra_sql,
43 % addl_from => 'LEFT JOIN reason_type ON reason_type.typenum = reason.reason_type',
45 <OPTION VALUE="" <% ($init_reason eq "") ? 'SELECTED' : '' %>>Select Reason...</OPTION>
46 % foreach my $reason (@reasons) {
47 <OPTION VALUE="<% $reason->reasonnum %>" <% ($init_reason == $reason->reasonnum) ? 'SELECTED' : '' %>><% $reason->reason %></OPTION>
49 % if ($curuser->access_right($access_right)) {
50 <OPTION VALUE="-1" <% ($init_reason == -1) ? 'SELECTED' : '' %>>Add new reason</OPTION>
59 <P id="new<% $name %>TLabel" style="display:<% $display %>">Reason Type</P>
62 <SELECT id="new<% $name %>T" name="new<% $name %>T" disabled="<% $disabled %>" style="display:<% $display %>">
63 % for my $type (qsearch( 'reason_type', { 'class' => $class } )){
64 <OPTION VALUE="<% $type->typenum %>" <% ($init_type == $type->typenum) ? 'SELECTED' : '' %>><% $type->type %></OPTION>
72 <P id="new<% $name %>Label" style="display:<% $display %>">New Reason</P>
74 <TD><INPUT id="new<% $name %>" name="new<% $name %>" type="text" value="<% $init_newreason %>" disabled="<% $disabled %>" style="display:<% $display %>"></TD>
78 my($name, $class, $init_reason, $init_type, $init_newreason, $controlledbutton) = @_;
79 my($extra_sql, $curuser, $access_right, $display, $disabled);
82 $access_right='Add on-the-fly cancel reason';
83 }elsif ($class eq 'S') {
84 $access_right='Add on-the-fly suspend reason';
86 print "illegal class: $class";
89 if ($init_reason == -1){
97 $extra_sql = "WHERE class = '$class' ORDER BY reason_type";
98 $curuser = $FS::CurrentUser::CurrentUser;