X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fview%2Felements%2Fsvc_Common.html;h=02484341be349fe13e20451e50c7479b0eca871a;hb=94929dd9a9f81ea430f4e8f3a26642466bdd4642;hp=0f103e3e0c338c007ff612a677abba12f12d8ce3;hpb=1053db7f76169cbbc87840539959a4c362aff242;p=freeside.git diff --git a/httemplate/view/elements/svc_Common.html b/httemplate/view/elements/svc_Common.html index 0f103e3e0..02484341b 100644 --- a/httemplate/view/elements/svc_Common.html +++ b/httemplate/view/elements/svc_Common.html @@ -1,116 +1,219 @@ -<% +<%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 ) %> -
+ + -<% } else { %> +% if ( $custnum ) { - + <& /elements/header.html, mt("View [_1]: [_2]",$label,$value) &> + + <& /elements/small_custview.html, $custnum, '', 1, + "${p}view/cust_main.cgi" &> +
+ +% } else { - <%= include("/elements/header.html","View $label: $value", menubar( - "Cancel this (unaudited) $label" => + <& /elements/header.html, mt("View [_1]: [_2]",$label,$value), menubar( + emt("Cancel this (unaudited) [_1]",$label) => "javascript:areyousure(\'${p}misc/cancel-unaudited.cgi?$svcnum\')" - )) %> + ) &> -<% } %> +% } -Service #<%= $svcnum %> -| Edit this <%= $label %> +<% mt('Service #') |h %><% $svcnum %> +% if ( $custnum ) { +% my $url = $opt{'edit_url'} || $p. 'edit/'. $opt{'table'}. '.cgi?'; +<& /view/elements/svc_edit_link.html, 'svc' => $svc_x, 'edit_url' => $url &> +% }
-<%= ntable("#cccccc") %><%= ntable("#cccccc",2) %> +<% ntable("#cccccc") %><% ntable("#cccccc",2) %> + +% my @inventory_items = $svc_x->inventory_item; +% foreach my $f ( @$fields ) { +% +% my($field, $type, $value); +% if ( ref($f) ) { +% $field = $f->{'field'}; +% $type = $f->{'type'} || 'text'; +% if ( $f->{'value_callback'} ) { +% my $hack_strict_refs = \&{ $f->{'value_callback'} }; +% $value = &$hack_strict_refs($svc_x); +% } else { +% $value = exists($f->{'value'}) +% ? $f->{'value'} +% : encode_entities($svc_x->$field); +% } +% } else { +% $field = $f; +% $type = 'text'; +% $value = encode_entities($svc_x->$field); +% } +% +% my $columndef = $part_svc->part_svc_column($field); +% if ( $columndef->columnflag =~ /^[MA]$/ && $columndef->columnvalue =~ /,/ ) +% { +% # inventory-select field with multiple classes +% # show the class name to disambiguate +% my ($item) = grep { $_->svc_field eq $field } @inventory_items; +% my $class = qsearchs('inventory_class', { classnum => $item->classnum }); +% $value .= ' ('. $class->classname . ')' if $class; +% } +% unless ($columndef->columnflag eq 'F' && !length($columndef->columnvalue)) { + + + + <% ( $opt{labels} && exists $opt{labels}->{$field} ) + ? $opt{labels}->{$field} + : $field + %> + + +% $value = time2str($date_format,$value) if ( $type eq 'date' && $value ); +% $value = time2str("$date_format %H:%M",$value) if ( $type eq 'datetime' && $value ); +% $value = $value eq 'Y' ? emt('Yes') : emt('No') if ( $type eq 'checkbox' ); +% #eventually more options for , etc. fields - %> +<& svc_devices.html, + 'svc_x' => $svc_x, + 'table' => $svc_x->device_table, +&> - <%= $svc_x->$field %> +% if ( defined($opt{'html_foot'}) ) { - + <% ref($opt{'html_foot'}) + ? &{ $opt{'html_foot'} }($svc_x) + : $opt{'html_foot'} + %> +
-<% } %> +% } -<% foreach (sort { $a cmp $b } $svc_x->virtual_fields) { %> - <%= $svc_x->pvf($_)->widget('HTML', 'view', $svc_x->getfield($_)) %> -<% } %> +% if ( $cust_svc ) { +<& /elements/table-tickets.html, object => $cust_svc &> +% } - +<% joblisting({'svcnum'=>$svcnum}, 1) %> -
-<%= joblisting({'svcnum'=>$svcnum}, 1) %> +<% include('/elements/footer.html') %> +<%init> + +die "access denied" + unless $FS::CurrentUser::CurrentUser->access_right('View customer services'); + +my(%opt) = @_; + +my $conf = new FS::Conf; +my $date_format = $conf->config('date_format') || '%m/%d/%Y'; -<%= include('/elements/footer.html') %> +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 "unparseable 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, $part_svc ); +my $labels = $opt{labels}; #not -> here + +if ( $cust_svc ) { + ($label, $value, $svcdb) = $cust_svc->label; + + $part_svc = $cust_svc->part_svc; + + #false laziness w/edit/svc_Common.html + #override default labels with service-definition labels if applicable + foreach my $field ( keys %$labels ) { + my $col = $part_svc->part_svc_column($field); + $labels->{$field} = $col->columnlabel if $col->columnlabel !~ /^\s*$/; + } +} else { + $label = "Unlinked $table"; + $value = $svc_x->label; + $svcdb = $table; + # just to satisfy callbacks + $part_svc = FS::part_svc->new({ svcpart => 0, svcdb => $table }); +} + +my $pkgnum = $cust_svc->pkgnum if $cust_svc; + +my($cust_pkg, $custnum); +if ($pkgnum) { + $cust_pkg = $cust_svc->cust_pkg; + $custnum = $cust_pkg->custnum; +} else { + $cust_pkg = ''; + $custnum = ''; +} + +&{ $opt{'svc_callback'} }( $cgi, $svc_x, $part_svc, $cust_pkg, $fields, \%opt ) + if $opt{'svc_callback'}; +