4 my $conf = new FS::Conf;
6 my($svcnum, $pkgnum, $svcpart, $part_svc, $svc_forward);
7 if ( $cgi->param('error') ) {
8 $svc_forward = new FS::svc_forward ( {
9 map { $_, scalar($cgi->param($_)) } fields('svc_forward')
11 $svcnum = $svc_forward->svcnum;
12 $pkgnum = $cgi->param('pkgnum');
13 $svcpart = $cgi->param('svcpart');
14 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
15 die "No part_svc entry!" unless $part_svc;
18 my($query) = $cgi->keywords;
20 if ( $query =~ /^(\d+)$/ ) { #editing
22 $svc_forward=qsearchs('svc_forward',{'svcnum'=>$svcnum})
23 or die "Unknown (svc_forward) svcnum!";
25 my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
26 or die "Unknown (cust_svc) svcnum!";
28 $pkgnum=$cust_svc->pkgnum;
29 $svcpart=$cust_svc->svcpart;
31 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
32 die "No part_svc entry!" unless $part_svc;
36 $svc_forward = new FS::svc_forward({});
38 foreach $_ (split(/-/,$query)) { #get & untaint pkgnum & svcpart
39 $pkgnum=$1 if /^pkgnum(\d+)$/;
40 $svcpart=$1 if /^svcpart(\d+)$/;
42 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
43 die "No part_svc entry!" unless $part_svc;
47 #set fixed and default fields from part_svc
48 foreach my $part_svc_column (
49 grep { $_->columnflag } $part_svc->all_part_svc_column
51 $svc_forward->setfield( $part_svc_column->columnname,
52 $part_svc_column->columnvalue,
58 my $action = $svc_forward->svcnum ? 'Edit' : 'Add';
62 #starting with those currently attached
63 foreach my $method (qw( srcsvc_acct dstsvc_acct )) {
64 my $svc_acct = $svc_forward->$method();
65 $email{$svc_acct->svcnum} = $svc_acct->email if $svc_acct;
70 #find all possible user svcnums (and emails)
72 #and including the rest for this customer
73 my($u_part_svc,@u_acct_svcparts);
74 foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
75 push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
78 my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
79 my($custnum)=$cust_pkg->getfield('custnum');
81 foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
82 my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
84 foreach $acct_svcpart (@u_acct_svcparts) { #now find the corresponding
85 #record(s) in cust_svc ( for this
87 foreach my $i_cust_svc (
88 qsearch( 'cust_svc', { 'pkgnum' => $cust_pkgnum,
89 'svcpart' => $acct_svcpart } )
92 qsearchs( 'svc_acct', { 'svcnum' => $i_cust_svc->svcnum } );
93 $email{$svc_acct->svcnum} = $svc_acct->email;
98 } elsif ( $action eq 'Add' ) {
99 die "\$action eq Add, but \$pkgnum is null!\n";
102 my($srcsvc,$dstsvc,$dst)=(
103 $svc_forward->srcsvc,
104 $svc_forward->dstsvc,
107 my $src = $svc_forward->dbdef_table->column('src') ? $svc_forward->src : '';
113 <%= header("Mail Forward $action") %>
115 <% if ( $cgi->param('error') ) { %>
116 <FONT SIZE="+1" COLOR="#ff0000">Error: <%= $cgi->param('error') %></FONT>
120 Service #<%= $svcnum ? "<B>$svcnum</B>" : " (NEW)" %><BR>
121 Service: <B><%= $part_svc->svc %></B><BR><BR>
123 <FORM ACTION="process/svc_forward.cgi" METHOD="POST">
124 <INPUT TYPE="hidden" NAME="svcnum" VALUE="<%= $svcnum %>">
125 <INPUT TYPE="hidden" NAME="pkgnum" VALUE="<%= $pkgnum %>">
126 <INPUT TYPE="hidden" NAME="svcpart" VALUE="<%= $svcpart %>">
128 <SCRIPT TYPE="text/javascript">
129 function srcchanged(what) {
130 if ( what.options[what.selectedIndex].value == 0 ) {
131 what.form.src.disabled = false;
132 what.form.src.style.backgroundColor = "white";
134 what.form.src.disabled = true;
135 what.form.src.style.backgroundColor = "lightgrey";
138 function dstchanged(what) {
139 if ( what.options[what.selectedIndex].value == 0 ) {
140 what.form.dst.disabled = false;
141 what.form.dst.style.backgroundColor = "white";
143 what.form.dst.disabled = true;
144 what.form.dst.style.backgroundColor = "lightgrey";
149 <%= ntable("#cccccc",2) %>
150 <TR><TD ALIGN="right">Email to</TD>
151 <TD><SELECT NAME="srcsvc" SIZE=1 onChange="srcchanged(this)">
152 <% foreach $_ (keys %email) { %>
153 <OPTION<%= $_ eq $srcsvc ? " SELECTED" : "" %> VALUE="<%= $_ %>"><%= $email{$_} %></OPTION>
155 <% if ( $svc_forward->dbdef_table->column('src') ) { %>
156 <OPTION <%= $src ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
159 <% if ( $svc_forward->dbdef_table->column('src') ) { %>
160 <INPUT TYPE="text" NAME="src" VALUE="<%= $src %>" <%= ( $src || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
164 <TR><TD ALIGN="right">Forwards to</TD>
165 <TD><SELECT NAME="dstsvc" SIZE=1 onChange="dstchanged(this)">
166 <% foreach $_ (keys %email) { %>
167 <OPTION<%= $_ eq $dstsvc ? " SELECTED" : "" %> VALUE="<%= $_ %>"><%= $email{$_} %></OPTION>
169 <OPTION <%= $dst ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
171 <INPUT TYPE="text" NAME="dst" VALUE="<%= $dst %>" <%= ( $dst || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
174 <BR><INPUT TYPE="submit" VALUE="Submit">