-<%
+<%doc>
- # options example...
- #
- # 'table' => 'svc_something'
- #
- # 'labels' => {
- # 'column' => 'Label',
- # },
- #
- # listref - each item is a literal column name (or method) or (notyet) coderef
- # if not specified all columns (except for the primary key) will be viewable
- # 'fields' => [
- # ]
+#Example:
- my(%opt) = @_;
+ include( 'elements/svc_Common.html,
- my $table = $opt{'table'};
+ 'table' => 'svc_something'
- my $fields = $opt{'fields'}
- #|| [ grep { $_ ne 'svcnum' } dbdef->table($table)->columns ];
- || [ grep { $_ ne 'svcnum' } fields($table) ];
+ 'labels' => {
+ 'column' => 'Label',
+ },
- my($query) = $cgi->keywords;
- $query =~ /^(\d+)$/;
- my $svcnum = $1;
- my $svc_x = qsearchs( $opt{'table'}, { 'svcnum' => $svcnum } )
- or die "Unknown svcnum $svcnum in ". $opt{'table'}. " table\n";
-
- my $cust_svc = $svc_x->cust_svc;
- my($label, $value, $svcdb) = $cust_svc->label;
-
- my $pkgnum = $cust_svc->pkgnum;
-
- my($cust_pkg, $custnum);
- if ($pkgnum) {
- $cust_pkg = $cust_svc->cust_pkg;
- $custnum = $cust_pkg->custnum;
- } else {
- $cust_pkg = '';
- $custnum = '';
- }
+ #listref - each item is a literal column name (or method) or
+ # (notyet) coderef. if not specified all columns (except for the
+ #primary key) will be viewable
+ 'fields' => [
+ ]
-%>
+ # defaults to "edit/$table.cgi?", will have svcnum appended
+ 'edit_url' =>
-<% if ( $custnum ) { %>
+ #at the very bottom (well, as low as you can go from here)
+ 'html_foot' => '',
- <%= include("/elements/header.html","View $label: $value", menubar(
- "View this customer (#$custnum)" => "${p}view/cust_main.cgi?$custnum",
- )) %>
+ )
- <%= include( '/elements/small_custview.html', $custnum, '', 1 ) %>
- <BR>
+</%doc>
+<SCRIPT>
+function areyousure(href) {
+ if (confirm("Permanently delete this <% $label %>?") == true)
+ window.location.href = href;
+}
+</SCRIPT>
-<% } else { %>
+% if ( $custnum ) {
- <SCRIPT>
- function areyousure(href) {
- if (confirm("Permanently delete this <%= $label %>?") == true)
- window.location.href = href;
- }
- </SCRIPT>
+ <% include("/elements/header.html","View $label: $value") %>
+
+ <% include( '/elements/small_custview.html', $custnum, '', 1,
+ "${p}view/cust_main.cgi") %>
+ <BR>
+
+% } else {
- <%= include("/elements/header.html","View $label: $value", menubar(
+ <% include("/elements/header.html","View $label: $value", menubar(
"Cancel this (unaudited) $label" =>
"javascript:areyousure(\'${p}misc/cancel-unaudited.cgi?$svcnum\')"
)) %>
-<% } %>
+% }
-Service #<B><%= $svcnum %></B>
-| <A HREF="<%=$p%>edit/<%= $opt{'table'} %>.cgi?<%=$svcnum%>">Edit this <%= $label %></A>
+Service #<B><% $svcnum %></B>
+% my $url = $opt{'edit_url'} || $p. 'edit/'. $opt{'table'}. '.cgi?';
+| <A HREF="<%$url%><%$svcnum%>">Edit this <% $label %></A>
+| <A HREF="javascript:areyousure('<%$p.'misc/unprovision.cgi?'.$svcnum%>')">
+Unprovision this Service</A>
<BR>
-<%= ntable("#cccccc") %><TR><TD><%= ntable("#cccccc",2) %>
+<% ntable("#cccccc") %><TR><TD><% ntable("#cccccc",2) %>
-<% foreach my $f ( @$fields ) {
+% foreach my $f ( @$fields ) {
+%
+% my($field, $type, $value);
+% if ( ref($f) ) {
+% $field = $f->{'field'},
+% $value = $f->{'value'} ? &{ $f->{'value'} }($svc_x) : $svc_x->$field;
+% $type = $f->{'type'} || 'text',
+% } else {
+% $field = $f;
+% $value = $svc_x->$field;
+% $type = 'text';
+% }
+%
+% my $columndef = $part_svc->part_svc_column($field);
+% unless ($columndef->columnflag eq 'F' && !length($columndef->columnvalue)) {
- my( $field, $type);
- if ( ref($f) ) {
- $field = $f->{'field'},
- $type = $f->{'type'} || 'text',
- } else {
- $field = $f;
- $type = 'text';
- }
-%>
+ <TR>
+ <TD ALIGN="right">
+ <% ( $opt{labels} && exists $opt{labels}->{$field} )
+ ? $opt{labels}->{$field}
+ : $field
+ %>
+ </TD>
- <TR>
- <TD ALIGN="right">
- <%= ( $opt{labels} && exists $opt{labels}->{$field} )
- ? $opt{labels}->{$field}
- : $field
- %>
- </TD>
+% #eventually more options for <SELECT>, etc. fields
- <%
- #eventually more options for <SELECT>, etc. fields
- %>
+ <TD BGCOLOR="#ffffff"><% $value %><TD>
- <TD BGCOLOR="#ffffff"><%= $svc_x->$field %><TD>
+ </TR>
- </TR>
+% }
+%
+% }
-<% } %>
+% foreach (sort { $a cmp $b } $svc_x->virtual_fields) {
+ <% $svc_x->pvf($_)->widget('HTML', 'view', $svc_x->getfield($_)) %>
+% }
-<% foreach (sort { $a cmp $b } $svc_x->virtual_fields) { %>
- <%= $svc_x->pvf($_)->widget('HTML', 'view', $svc_x->getfield($_)) %>
-<% } %>
</TABLE></TD></TR></TABLE>
<BR>
-<%= joblisting({'svcnum'=>$svcnum}, 1) %>
-<%= include('/elements/footer.html') %>
+% if ( defined($opt{'html_foot'}) ) {
+
+ <% ref($opt{'html_foot'})
+ ? &{ $opt{'html_foot'} }($svc_x)
+ : $opt{'html_foot'}
+ %>
+ <BR>
+
+% }
+
+<% joblisting({'svcnum'=>$svcnum}, 1) %>
+
+<% include('/elements/footer.html') %>
+<%init>
+
+die "access denied"
+ unless $FS::CurrentUser::CurrentUser->access_right('View customer services');
+
+my(%opt) = @_;
+
+my $table = $opt{'table'};
+
+my $fields = $opt{'fields'}
+ #|| [ grep { $_ ne 'svcnum' } dbdef->table($table)->columns ];
+ || [ grep { $_ ne 'svcnum' } fields($table) ];
+
+my $svcnum;
+if ( $cgi->param('svcnum') ) {
+ $cgi->param('svcnum') =~ /^(\d+)$/ or die "unparsable svcnum";
+ $svcnum = $1;
+} else {
+ my($query) = $cgi->keywords;
+ $query =~ /^(\d+)$/ or die "no svcnum";
+ $svcnum = $1;
+}
+my $svc_x = qsearchs({
+ 'select' => $opt{'table'}.'.*',
+ 'table' => $opt{'table'},
+ 'addl_from' => ' LEFT JOIN cust_svc USING ( svcnum ) '.
+ ' LEFT JOIN cust_pkg USING ( pkgnum ) '.
+ ' LEFT JOIN cust_main USING ( custnum ) ',
+ 'hashref' => { 'svcnum' => $svcnum },
+ 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql(
+ 'null_right' => 'View/link unlinked services'
+ ),
+}) or die "Unknown svcnum $svcnum in ". $opt{'table'}. " table\n";
+
+my $cust_svc = $svc_x->cust_svc;
+my($label, $value, $svcdb) = $cust_svc->label;
+
+my $part_svc = $cust_svc->part_svc;
+
+ #false laziness w/edit/svc_Common.html
+ #override default labels with service-definition labels if applicable
+ my $labels = $opt{labels}; #not -> here
+ foreach my $field ( keys %$labels ) {
+ my $col = $part_svc->part_svc_column($field);
+ $labels->{$field} = $col->columnlabel if $col->columnlabel !~ /^\S*$/;
+ }
+
+my $pkgnum = $cust_svc->pkgnum;
+
+my($cust_pkg, $custnum);
+if ($pkgnum) {
+ $cust_pkg = $cust_svc->cust_pkg;
+ $custnum = $cust_pkg->custnum;
+} else {
+ $cust_pkg = '';
+ $custnum = '';
+}
+
+</%init>