Merge branch 'master' of git.freeside.biz:/home/git/freeside
[freeside.git] / httemplate / view / svc_forward.cgi
1 % if ( $custnum ) {
2
3   <% include("/elements/header.html","View mail forward") %>
4   <% include( '/elements/small_custview.html', $custnum, '', 1,
5      "${p}view/cust_main.cgi") %>
6   <BR>
7
8 % } else {
9
10   <% include("/elements/header.html",'View mail forward', menubar(
11        "Cancel this (unaudited) mail forward" =>
12          "javascript:areyousure('${p}misc/cancel-unaudited.cgi?$svcnum')",
13      ))
14   %>
15
16   <SCRIPT>
17   function areyousure(href) {
18       if (confirm("Permanently delete this mail forward?") == true)
19           window.location.href = href;
20   }
21   </SCRIPT>
22
23 % }
24
25 <A HREF="<% $p %>edit/svc_forward.cgi?<% $svcnum %>">Edit this information</A>
26
27 <% ntable("#cccccc",2) %>
28
29   <TR>
30     <TD ALIGN="right">Service number</TD>
31     <TD BGCOLOR="#ffffff"><% $svcnum %></TD>
32   </TR>
33   <TR>
34     <TD ALIGN="right">Service</TD>
35     <TD BGCOLOR="#ffffff"><% $svc %></TD>
36   </TR>
37   <TR>
38     <TD ALIGN="right">Email to</TD>
39     <TD BGCOLOR="#ffffff"><% $source %></TD>
40   </TR>
41   <TR>
42     <TD ALIGN="right">Forwards to </TD>
43     <TD BGCOLOR="#ffffff"><% $destination %></TD>
44   </TR>
45
46 % foreach (sort { $a cmp $b } $svc_forward->virtual_fields) {
47     <% $svc_forward->pvf($_)->widget('HTML', 'view', $svc_forward->getfield($_)) %>
48 % }
49
50 </TABLE>
51
52 <BR>
53
54 <% include('elements/svc_export_settings.html', $svc_forward) %>
55
56 % if ( $conf->config('ticket_system') ) {
57 <& /elements/table-tickets.html, object => $cust_svc &>
58 % }
59
60 <% joblisting({'svcnum'=>$svcnum}, 1) %>
61
62 <% include('/elements/footer.html') %>
63 <%init>
64
65 die "access denied"
66   unless $FS::CurrentUser::CurrentUser->access_right('View customer services');
67
68 my $conf = new FS::Conf;
69
70 my($query) = $cgi->keywords;
71 $query =~ /^(\d+)$/;
72 my $svcnum = $1;
73 my $svc_forward = qsearchs({
74   'select'    => 'svc_forward.*',
75   'table'     => 'svc_forward',
76   'addl_from' => ' LEFT JOIN cust_svc  USING ( svcnum  ) '.
77                  ' LEFT JOIN cust_pkg  USING ( pkgnum  ) '.
78                  ' LEFT JOIN cust_main USING ( custnum ) ',
79   'hashref'   => {'svcnum'=>$svcnum},
80   'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql(
81                             'null_right' => 'View/link unlinked services'
82                           ),
83 });
84 die "Unknown svcnum" unless $svc_forward;
85
86 my $cust_svc = qsearchs('cust_svc',{'svcnum'=>$svcnum});
87 my $pkgnum = $cust_svc->getfield('pkgnum');
88 my($cust_pkg, $custnum, $display_custnum);
89 if ($pkgnum) {
90   $cust_pkg=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
91   $custnum=$cust_pkg->getfield('custnum');
92   $display_custnum = $cust_pkg->cust_main->display_custnum;
93 } else {
94   $cust_pkg = '';
95   $custnum = '';
96 }
97
98 my $part_svc = qsearchs('part_svc',{'svcpart'=> $cust_svc->svcpart } )
99   or die "Unknown svcpart";
100
101 my($srcsvc,$dstsvc,$dst) = (
102   $svc_forward->srcsvc,
103   $svc_forward->dstsvc,
104   $svc_forward->dst,
105 );
106 my $src = $svc_forward->dbdef_table->column('src') ? $svc_forward->src : '';
107
108 my $svc = $part_svc->svc;
109
110 my $source;
111 if ($srcsvc) {
112   my $svc_acct = qsearchs('svc_acct',{'svcnum'=>$srcsvc})
113     or die "Corrupted database: no svc_acct.svcnum matching srcsvc $srcsvc";
114   $source = $svc_acct->email;
115 } else {
116   $source = $src;
117 }
118
119 my $destination;
120 if ($dstsvc) {
121   my $svc_acct = qsearchs('svc_acct',{'svcnum'=>$dstsvc})
122     or die "Corrupted database: no svc_acct.svcnum matching dstsvc $dstsvc";
123   $destination = $svc_acct->email;
124 } else {
125   $destination = $dst;
126 }
127
128 </%init>