fix FK upgrade for pkg_referral: remove records referencing non-existant customer...
[freeside.git] / httemplate / view / svc_acct.cgi
1 % if ( $custnum ) { 
2
3   <& /elements/header.html, mt("View [_1] account",$svc) &>
4   <& /elements/small_custview.html, $custnum, '', 1,
5      "${p}view/cust_main.cgi" &> 
6   <BR>
7
8 % } else { 
9 % my $delmsg = emt('Permanently delete this account?');
10
11   <SCRIPT>
12   function areyousure(href) {
13       if (confirm(<% $delmsg |js_string %>) == true)
14           window.location.href = href;
15   }
16   </SCRIPT>
17   
18   <& /elements/header.html, mt('View account'), menubar(
19     emt("Cancel this (unaudited) account") =>
20             "javascript:areyousure(\'${p}misc/cancel-unaudited.cgi?$svcnum\')",
21   ) &>
22
23 % } 
24
25
26 <& elements/svc_radius_usage.html,
27               'svc'      => $svc_acct,
28               'part_svc' => $part_svc,
29               'cust_pkg' => $cust_pkg,
30               %gopt,
31 &>
32
33
34 <& svc_acct/change_svc_form.html,
35               'part_svc' => \@part_svc,
36               'svcnum'   => $svcnum,
37               'pkgnum'   => $pkgnum,
38               %gopt,
39 &>
40
41 <% mt('Service #') |h %><B><% $svcnum %></B>
42 <& /view/elements/svc_edit_link.html, 'svc' => $svc_acct &>
43 <& svc_acct/change_svc.html,
44               'part_svc' => \@part_svc,
45               %gopt,
46 &>
47
48 </FORM>
49
50
51 <& svc_acct/basics.html,
52               'svc_acct' => $svc_acct,
53               'part_svc' => $part_svc,
54               'cust_svc' => $cust_svc,
55               %gopt,
56 &>
57
58 </FORM>
59 <BR>
60
61 <& svc_acct/cardfortress.html,
62               'svc_acct' => $svc_acct,
63               %gopt,
64 &>
65
66 <& svc_acct/hosting.html,
67               %gopt,
68 &>
69
70 %#remove this?  does anybody even use it?  it was a misunderstood customer
71 %#request IIRC?
72 % my $conf = new FS::Conf;
73 % if ( $conf->exists('svc_acct-notes') ) {
74 %   warn 'WARNING: svc_acct-notes deprecated\n';
75 <% join("<BR>", $conf->config('svc_acct-notes') ) %>
76 <BR><BR>
77 % }
78
79 <& elements/svc_export_status.html, $svc_acct &>
80
81 <& elements/svc_export_settings.html, $svc_acct &>
82
83 <& /elements/table-tickets.html, object => $cust_svc &>
84
85 <BR>
86 <% joblisting({'svcnum'=>$svcnum}, 1) %>
87
88 <& /elements/footer.html &>
89 <%init>
90
91 die "access denied"
92   unless $FS::CurrentUser::CurrentUser->access_right('View customer services');
93
94 my $addl_from = ' LEFT JOIN cust_svc  USING ( svcnum  ) '.
95                 ' LEFT JOIN cust_pkg  USING ( pkgnum  ) '.
96                 ' LEFT JOIN cust_main USING ( custnum ) ';
97 my $query;
98 if ( $cgi->keywords ) {
99   ($query) = $cgi->keywords;
100 } else {
101   $query = $cgi->param('svcnum');
102 }
103 $query =~ /^(\d+)$/;
104 my $svcnum = $1;
105 my $svc_acct = qsearchs({
106   'select'    => 'svc_acct.*',
107   'table'     => 'svc_acct',
108   'addl_from' => $addl_from,
109   'hashref'   => { 'svcnum' => $svcnum },
110   'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql(
111                             'null_right' => 'View/link unlinked services'
112                           ),
113 });
114 die "Unknown svcnum" unless $svc_acct;
115
116 #false laziness w/all svc_*.cgi
117 my $cust_svc = $svc_acct->cust_svc;
118 my $pkgnum = $cust_svc->getfield('pkgnum');
119 my($cust_pkg, $custnum);
120 if ($pkgnum) {
121   $cust_pkg = qsearchs( 'cust_pkg', { 'pkgnum' => $pkgnum } );
122   $custnum = $cust_pkg->custnum;
123 } else {
124   $cust_pkg = '';
125   $custnum = '';
126 }
127 #eofalse
128
129 my $part_svc = qsearchs('part_svc',{'svcpart'=> $cust_svc->svcpart } );
130 die "Unknown svcpart" unless $part_svc;
131 my $svc = $part_svc->svc;
132
133 my @part_svc = ();
134 if ($FS::CurrentUser::CurrentUser->access_right('Change customer service')) {
135
136   if ( $pkgnum ) { 
137     @part_svc = grep {    $_->svcdb   eq 'svc_acct'
138                        && $_->svcpart != $part_svc->svcpart }
139                 $cust_pkg->available_part_svc;
140   } else {
141     @part_svc = qsearch('part_svc', {
142       svcdb    => 'svc_acct',
143       disabled => '',
144       svcpart  => { op=>'!=', value=>$part_svc->svcpart },
145     } );
146   }
147
148 }
149
150 my $communigate = scalar($part_svc->part_export('communigate_pro'));
151                 # || scalar($part_svc->part_export('communigate_pro_singledomain'));
152
153 my %gopt = ( 'communigate' => $communigate,
154            );
155
156 </%init>