This commit was manufactured by cvs2svn to create tag 'freeside_1_4_2'.
[freeside.git] / httemplate / edit / svc_forward.cgi
1 <!-- mason kludge -->
2 <%
3
4 my $conf = new FS::Conf;
5 my $mydomain = $conf->config('domain');
6
7 my($svcnum, $pkgnum, $svcpart, $part_svc, $svc_forward);
8 if ( $cgi->param('error') ) {
9   $svc_forward = new FS::svc_forward ( {
10     map { $_, scalar($cgi->param($_)) } fields('svc_forward')
11   } );
12   $svcnum = $svc_forward->svcnum;
13   $pkgnum = $cgi->param('pkgnum');
14   $svcpart = $cgi->param('svcpart');
15   $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
16   die "No part_svc entry!" unless $part_svc;
17 } else {
18
19   my($query) = $cgi->keywords;
20
21   if ( $query =~ /^(\d+)$/ ) { #editing
22     $svcnum=$1;
23     $svc_forward=qsearchs('svc_forward',{'svcnum'=>$svcnum})
24       or die "Unknown (svc_forward) svcnum!";
25
26     my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
27       or die "Unknown (cust_svc) svcnum!";
28
29     $pkgnum=$cust_svc->pkgnum;
30     $svcpart=$cust_svc->svcpart;
31   
32     $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
33     die "No part_svc entry!" unless $part_svc;
34
35   } else { #adding
36
37     $svc_forward = new FS::svc_forward({});
38
39     foreach $_ (split(/-/,$query)) { #get & untaint pkgnum & svcpart
40       $pkgnum=$1 if /^pkgnum(\d+)$/;
41       $svcpart=$1 if /^svcpart(\d+)$/;
42     }
43     $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
44     die "No part_svc entry!" unless $part_svc;
45
46     $svcnum='';
47
48     #set fixed and default fields from part_svc
49     foreach my $part_svc_column (
50       grep { $_->columnflag } $part_svc->all_part_svc_column
51     ) {
52       $svc_forward->setfield( $part_svc_column->columnname,
53                               $part_svc_column->columnvalue,
54                             );
55     }
56   }
57
58 }
59 my $action = $svc_forward->svcnum ? 'Edit' : 'Add';
60
61 my %email;
62
63 #starting with those currently attached
64 foreach my $method (qw( srcsvc_acct dstsvc_acct )) {
65   my $svc_acct = $svc_forward->$method();
66   $email{$svc_acct->svcnum} = $svc_acct->email if $svc_acct;
67 }
68
69 if ($pkgnum) {
70
71   #find all possible user svcnums (and emails)
72
73   #and including the rest for this customer
74   my($u_part_svc,@u_acct_svcparts);
75   foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
76     push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
77   }
78
79   my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
80   my($custnum)=$cust_pkg->getfield('custnum');
81   my($i_cust_pkg);
82   foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
83     my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
84     my($acct_svcpart);
85     foreach $acct_svcpart (@u_acct_svcparts) {   #now find the corresponding 
86                                               #record(s) in cust_svc ( for this
87                                               #pkgnum ! )
88       foreach my $i_cust_svc (
89         qsearch( 'cust_svc', { 'pkgnum'  => $cust_pkgnum,
90                                'svcpart' => $acct_svcpart } )
91       ) {
92         my $svc_acct =
93           qsearchs( 'svc_acct', { 'svcnum' => $i_cust_svc->svcnum } );
94         $email{$svc_acct->svcnum} = $svc_acct->email;
95       }  
96     }
97   }
98
99 } elsif ( $action eq 'Add' ) {
100   die "\$action eq Add, but \$pkgnum is null!\n";
101 }
102
103 my($srcsvc,$dstsvc,$dst)=(
104   $svc_forward->srcsvc,
105   $svc_forward->dstsvc,
106   $svc_forward->dst,
107 );
108 my $src = $svc_forward->dbdef_table->column('src') ? $svc_forward->src : '';
109
110 #display
111
112 %>
113
114 <%= header("Mail Forward $action") %>
115
116 <% if ( $cgi->param('error') ) { %>
117   <FONT SIZE="+1" COLOR="#ff0000">Error: <%= $cgi->param('error') %></FONT>
118   <BR><BR>
119 <% } %>
120
121 Service #<%= $svcnum ? "<B>$svcnum</B>" : " (NEW)" %><BR>
122 Service: <B><%= $part_svc->svc %></B><BR><BR>
123
124 <FORM ACTION="process/svc_forward.cgi" METHOD="POST">
125 <INPUT TYPE="hidden" NAME="svcnum" VALUE="<%= $svcnum %>">
126 <INPUT TYPE="hidden" NAME="pkgnum" VALUE="<%= $pkgnum %>">
127 <INPUT TYPE="hidden" NAME="svcpart" VALUE="<%= $svcpart %>">
128
129 <SCRIPT TYPE="text/javascript">
130 function srcchanged(what) {
131   if ( what.options[what.selectedIndex].value == 0 ) {
132     what.form.src.disabled = false;
133     what.form.src.style.backgroundColor = "white";
134   } else {
135     what.form.src.disabled = true;
136     what.form.src.style.backgroundColor = "lightgrey";
137   }
138 }
139 function dstchanged(what) {
140   if ( what.options[what.selectedIndex].value == 0 ) {
141     what.form.dst.disabled = false;
142     what.form.dst.style.backgroundColor = "white";
143   } else {
144     what.form.dst.disabled = true;
145     what.form.dst.style.backgroundColor = "lightgrey";
146   }
147 }
148 </SCRIPT>
149
150 <%= ntable("#cccccc",2) %>
151 <TR><TD ALIGN="right">Email to</TD>
152 <TD><SELECT NAME="srcsvc" SIZE=1 onChange="srcchanged(this)">
153 <% foreach $_ (keys %email) { %>
154   <OPTION<%= $_ eq $srcsvc ? " SELECTED" : "" %> VALUE="<%= $_ %>"><%= $email{$_} %></OPTION>
155 <% } %>
156 <% if ( $svc_forward->dbdef_table->column('src') ) { %>
157   <OPTION <%= $src ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
158 <% } %>
159 </SELECT>
160 <% if ( $svc_forward->dbdef_table->column('src') ) { %>
161 <INPUT TYPE="text" NAME="src" VALUE="<%= $src %>" <%= ( $src || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
162 <% } %>
163 </TD></TR>
164
165 <TR><TD ALIGN="right">Forwards to</TD>
166 <TD><SELECT NAME="dstsvc" SIZE=1 onChange="dstchanged(this)">
167 <% foreach $_ (keys %email) { %>
168   <OPTION<%= $_ eq $dstsvc ? " SELECTED" : "" %> VALUE="<%= $_ %>"><%= $email{$_} %></OPTION>
169 <% } %>
170 <OPTION <%= $dst ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
171 </SELECT>
172 <INPUT TYPE="text" NAME="dst" VALUE="<%= $dst %>" <%= ( $dst || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
173 </TD></TR>
174     </TABLE>
175 <BR><INPUT TYPE="submit" VALUE="Submit">
176 </FORM>
177   </BODY>
178 </HTML>