1 <% include('/elements/header.html', "Mail Forward $action") %>
3 <% include('/elements/error.html') %>
5 Service #<% $svcnum ? "<B>$svcnum</B>" : " (NEW)" %><BR>
6 Service: <B><% $part_svc->svc %></B><BR><BR>
8 <FORM ACTION="process/svc_forward.cgi" METHOD="POST">
9 <INPUT TYPE="hidden" NAME="svcnum" VALUE="<% $svcnum %>">
10 <INPUT TYPE="hidden" NAME="pkgnum" VALUE="<% $pkgnum %>">
11 <INPUT TYPE="hidden" NAME="svcpart" VALUE="<% $svcpart %>">
13 <SCRIPT TYPE="text/javascript">
14 function srcchanged(what) {
15 if ( what.options[what.selectedIndex].value == 0 ) {
16 what.form.src.disabled = false;
17 what.form.src.style.backgroundColor = "white";
19 what.form.src.disabled = true;
20 what.form.src.style.backgroundColor = "lightgrey";
23 function dstchanged(what) {
24 if ( what.options[what.selectedIndex].value == 0 ) {
25 what.form.dst.disabled = false;
26 what.form.dst.style.backgroundColor = "white";
28 what.form.dst.disabled = true;
29 what.form.dst.style.backgroundColor = "lightgrey";
34 <% ntable("#cccccc",2) %>
35 <TR><TD ALIGN="right">Email to</TD>
36 <TD><SELECT NAME="srcsvc" SIZE=1 onChange="srcchanged(this)">
37 % foreach $_ (keys %email) {
39 <OPTION<% $_ eq $srcsvc ? " SELECTED" : "" %> VALUE="<% $_ %>"><% $email{$_} %></OPTION>
41 % if ( $svc_forward->dbdef_table->column('src') ) {
43 <OPTION <% $src ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
47 % if ( $svc_forward->dbdef_table->column('src') ) {
49 <INPUT TYPE="text" NAME="src" VALUE="<% $src %>" <% ( $src || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
54 <TR><TD ALIGN="right">Forwards to</TD>
55 <TD><SELECT NAME="dstsvc" SIZE=1 onChange="dstchanged(this)">
56 % foreach $_ (keys %email) {
58 <OPTION<% $_ eq $dstsvc ? " SELECTED" : "" %> VALUE="<% $_ %>"><% $email{$_} %></OPTION>
61 <OPTION <% $dst ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
63 <INPUT TYPE="text" NAME="dst" VALUE="<% $dst %>" <% ( $dst || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
66 <BR><INPUT TYPE="submit" VALUE="Submit">
69 <% include('/elements/footer.html') %>
74 unless $FS::CurrentUser::CurrentUser->access_right('Provision customer service'); #something else more specific?
76 my $conf = new FS::Conf;
78 my($svcnum, $pkgnum, $svcpart, $part_svc, $svc_forward);
79 if ( $cgi->param('error') ) {
80 $svc_forward = new FS::svc_forward ( {
81 map { $_, scalar($cgi->param($_)) } fields('svc_forward')
83 $svcnum = $svc_forward->svcnum;
84 $pkgnum = $cgi->param('pkgnum');
85 $svcpart = $cgi->param('svcpart');
86 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
87 die "No part_svc entry!" unless $part_svc;
89 } elsif ( $cgi->param('pkgnum') && $cgi->param('svcpart') ) { #adding
91 $cgi->param('pkgnum') =~ /^(\d+)$/ or die 'unparsable pkgnum';
93 $cgi->param('svcpart') =~ /^(\d+)$/ or die 'unparsable svcpart';
96 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
97 die "No part_svc entry!" unless $part_svc;
99 $svc_forward = new FS::svc_forward({});
103 $svc_forward->set_default_and_fixed;
107 my($query) = $cgi->keywords;
109 $query =~ /^(\d+)$/ or die "unparsable svcnum";
111 $svc_forward=qsearchs('svc_forward',{'svcnum'=>$svcnum})
112 or die "Unknown (svc_forward) svcnum!";
114 my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
115 or die "Unknown (cust_svc) svcnum!";
117 $pkgnum=$cust_svc->pkgnum;
118 $svcpart=$cust_svc->svcpart;
120 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
121 die "No part_svc entry!" unless $part_svc;
124 my $action = $svc_forward->svcnum ? 'Edit' : 'Add';
128 #starting with those currently attached
129 foreach my $method (qw( srcsvc_acct dstsvc_acct )) {
130 my $svc_acct = $svc_forward->$method();
131 $email{$svc_acct->svcnum} = $svc_acct->email if $svc_acct;
136 #find all possible user svcnums (and emails)
138 #and including the rest for this customer
139 my($u_part_svc,@u_acct_svcparts);
140 foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
141 push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
144 my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
145 my($custnum)=$cust_pkg->getfield('custnum');
147 foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
148 my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
150 foreach $acct_svcpart (@u_acct_svcparts) { #now find the corresponding
151 #record(s) in cust_svc ( for this
153 foreach my $i_cust_svc (
154 qsearch( 'cust_svc', { 'pkgnum' => $cust_pkgnum,
155 'svcpart' => $acct_svcpart } )
158 qsearchs( 'svc_acct', { 'svcnum' => $i_cust_svc->svcnum } );
159 $email{$svc_acct->svcnum} = $svc_acct->email;
164 } elsif ( $action eq 'Add' ) {
165 die "\$action eq Add, but \$pkgnum is null!\n";
168 my($srcsvc,$dstsvc,$dst)=(
169 $svc_forward->srcsvc,
170 $svc_forward->dstsvc,
173 my $src = $svc_forward->dbdef_table->column('src') ? $svc_forward->src : '';