import rt 2.0.14
[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 if ($pkgnum) {
63
64   #find all possible user svcnums (and emails)
65
66   #starting with those currently attached
67   if ( $svc_forward->srcsvc ) {
68     my $svc_acct = qsearchs( 'svc_acct', { 'svcnum' => $svc_forward->srcsvc } );
69     $email{$svc_forward->srcsvc} = $svc_acct->email;
70   }
71   if ( $svc_forward->dstsvc ) {
72     my $svc_acct = qsearchs( 'svc_acct', { 'svcnum' => $svc_forward->dstsvc } );
73     $email{$svc_forward->dstsvc} = $svc_acct->email;
74   }
75
76   #and including the rest for this customer
77   my($u_part_svc,@u_acct_svcparts);
78   foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
79     push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
80   }
81
82   my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
83   my($custnum)=$cust_pkg->getfield('custnum');
84   my($i_cust_pkg);
85   foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
86     my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
87     my($acct_svcpart);
88     foreach $acct_svcpart (@u_acct_svcparts) {   #now find the corresponding 
89                                               #record(s) in cust_svc ( for this
90                                               #pkgnum ! )
91       foreach my $i_cust_svc (
92         qsearch( 'cust_svc', { 'pkgnum'  => $cust_pkgnum,
93                                'svcpart' => $acct_svcpart } )
94       ) {
95         my $svc_acct =
96           qsearchs( 'svc_acct', { 'svcnum' => $i_cust_svc->svcnum } );
97         $email{$svc_acct->svcnum} = $svc_acct->email;
98       }  
99     }
100   }
101
102 } elsif ( $action eq 'Edit' ) {
103
104   my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$svc_forward->srcsvc});
105   $email{$svc_forward->srcsvc} = $svc_acct->email;
106
107   $svc_acct=qsearchs('svc_acct',{'svcnum'=>$svc_forward->dstsvc});
108   $email{$svc_forward->dstsvc} = $svc_acct->email;
109
110 } else {
111   die "\$action eq Add, but \$pkgnum is null!\n";
112 }
113
114 my($srcsvc,$dstsvc,$dst)=(
115   $svc_forward->srcsvc,
116   $svc_forward->dstsvc,
117   $svc_forward->dst,
118 );
119
120 #display
121
122 %>
123
124 <%= header("Mail Forward $action") %>
125
126 <% if ( $cgi->param('error') ) { %>
127   <FONT SIZE="+1" COLOR="#ff0000">Error: <%= $cgi->param('error') %></FONT>
128   <BR><BR>
129 <% } %>
130
131 Service #<%= $svcnum ? "<B>$svcnum</B>" : " (NEW)" %><BR>
132 Service: <B><%= $part_svc->svc %></B><BR><BR>
133
134 <FORM NAME="dummy">
135
136 <%= ntable("#cccccc",2) %>
137 <TR><TD ALIGN="right">Email to</TD><TD><SELECT NAME="srcsvc" SIZE=1>
138 <% foreach $_ (keys %email) { %>
139   <OPTION<%= $_ eq $srcsvc ? " SELECTED" : "" %> VALUE="<%= $_ %>"><%= $email{$_} %></OPTION>
140 <% } %>
141 </SELECT></TD></TR>
142
143 <%
144   tie my %tied_email, 'Tie::IxHash',
145     ''  => 'SELECT DESTINATION',
146     %email,
147     '0' => '(other email address)';
148   my $widget = new HTML::Widgets::SelectLayers(
149     'selected_layer' => $dstsvc,
150     'options'        => \%tied_email,
151     'form_name'      => 'dummy',
152     'form_action'    => 'process/svc_forward.cgi',
153     'form_select'    => ['srcsvc'],
154     'html_between'   => '</TD></TR></TABLE>',
155     'layer_callback' => sub {
156       my $layer = shift;
157       my $html = qq!<INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">!.
158                  qq!<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">!.
159                  qq!<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">!.
160                  qq!<INPUT TYPE="hidden" NAME="dstsvc" VALUE="$layer">!;
161       if ( $layer eq '0' ) {
162         $html .= ntable("#cccccc",2).
163                  '<TR><TD ALIGN="right">Destination email</TD>'.
164                  qq!<TD><INPUT TYPE="text" NAME="dst" VALUE="$dst"></TD>!.
165                  '</TR></TABLE>';
166       }
167       $html .= '<BR><INPUT TYPE="submit" VALUE="Submit">';
168       $html;
169     },
170   );
171 %>
172
173 <TR><TD ALIGN="right">Forwards to</TD>
174 <TD><%= $widget->html %>
175   </BODY>
176 </HTML>