96a00a5aa51689307dc727dc53c83c83942024bd
[freeside.git] / httemplate / edit / svc_forward.cgi
1 <% include('/elements/header.html', "Mail Forward $action") %>
2
3 <% include('/elements/error.html') %>
4
5 Service #<% $svcnum ? "<B>$svcnum</B>" : " (NEW)" %><BR>
6 Service: <B><% $part_svc->svc %></B><BR><BR>
7
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 %>">
12
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";
18   } else {
19     what.form.src.disabled = true;
20     what.form.src.style.backgroundColor = "lightgrey";
21   }
22 }
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";
27   } else {
28     what.form.dst.disabled = true;
29     what.form.dst.style.backgroundColor = "lightgrey";
30   }
31 }
32 </SCRIPT>
33
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) { 
38
39   <OPTION<% $_ eq $srcsvc ? " SELECTED" : "" %> VALUE="<% $_ %>"><% $email{$_} %></OPTION>
40 % } 
41 % if ( $svc_forward->dbdef_table->column('src') ) { 
42
43   <OPTION <% $src ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
44 % } 
45
46 </SELECT>
47 % if ( $svc_forward->dbdef_table->column('src') ) { 
48
49 <INPUT TYPE="text" NAME="src" VALUE="<% $src %>" <% ( $src || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
50 % } 
51
52 </TD></TR>
53
54 <TR><TD ALIGN="right">Forwards to</TD>
55 <TD><SELECT NAME="dstsvc" SIZE=1 onChange="dstchanged(this)">
56 % foreach $_ (keys %email) { 
57
58   <OPTION<% $_ eq $dstsvc ? " SELECTED" : "" %> VALUE="<% $_ %>"><% $email{$_} %></OPTION>
59 % } 
60
61 <OPTION <% $dst ? 'SELECTED' : '' %> VALUE="0">(other email address)</OPTION>
62 </SELECT>
63 <INPUT TYPE="text" NAME="dst" VALUE="<% $dst %>" <% ( $dst || !scalar(%email) ) ? '' : 'DISABLED STYLE="background-color: lightgrey"' %>>
64 </TD></TR>
65     </TABLE>
66 <BR><INPUT TYPE="submit" VALUE="Submit">
67 </FORM>
68
69 <% include('/elements/footer.html') %>
70
71 <%init>
72
73 die "access denied"
74   unless $FS::CurrentUser::CurrentUser->access_right('Provision customer service'); #something else more specific?
75
76 my $conf = new FS::Conf;
77
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')
82   } );
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;
88
89 } elsif ( $cgi->param('pkgnum') && $cgi->param('svcpart') ) { #adding
90
91   $cgi->param('pkgnum') =~ /^(\d+)$/ or die 'unparsable pkgnum';
92   $pkgnum = $1;
93   $cgi->param('svcpart') =~ /^(\d+)$/ or die 'unparsable svcpart';
94   $svcpart = $1;
95
96   $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
97   die "No part_svc entry!" unless $part_svc;
98
99   $svc_forward = new FS::svc_forward({});
100
101   $svcnum='';
102
103   $svc_forward->set_default_and_fixed;
104
105 } else { #editing
106
107   my($query) = $cgi->keywords;
108
109   $query =~ /^(\d+)$/ or die "unparsable svcnum";
110   $svcnum=$1;
111   $svc_forward=qsearchs('svc_forward',{'svcnum'=>$svcnum})
112     or die "Unknown (svc_forward) svcnum!";
113
114   my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
115     or die "Unknown (cust_svc) svcnum!";
116
117   $pkgnum=$cust_svc->pkgnum;
118   $svcpart=$cust_svc->svcpart;
119   
120   $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
121   die "No part_svc entry!" unless $part_svc;
122
123 }
124 my $action = $svc_forward->svcnum ? 'Edit' : 'Add';
125
126 my %email;
127
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;
132 }
133
134 if ($pkgnum) {
135
136   #find all possible user svcnums (and emails)
137
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');
142   }
143
144   my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
145   my($custnum)=$cust_pkg->getfield('custnum');
146   my($i_cust_pkg);
147   foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
148     my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
149     my($acct_svcpart);
150     foreach $acct_svcpart (@u_acct_svcparts) {   #now find the corresponding 
151                                               #record(s) in cust_svc ( for this
152                                               #pkgnum ! )
153       foreach my $i_cust_svc (
154         qsearch( 'cust_svc', { 'pkgnum'  => $cust_pkgnum,
155                                'svcpart' => $acct_svcpart } )
156       ) {
157         my $svc_acct =
158           qsearchs( 'svc_acct', { 'svcnum' => $i_cust_svc->svcnum } );
159         $email{$svc_acct->svcnum} = $svc_acct->email;
160       }  
161     }
162   }
163
164 } elsif ( $action eq 'Add' ) {
165   die "\$action eq Add, but \$pkgnum is null!\n";
166 }
167
168 my($srcsvc,$dstsvc,$dst)=(
169   $svc_forward->srcsvc,
170   $svc_forward->dstsvc,
171   $svc_forward->dst,
172 );
173 my $src = $svc_forward->dbdef_table->column('src') ? $svc_forward->src : '';
174
175 </%init>