add per-customer "Invoice reports" link, RT#13802
[freeside.git] / httemplate / view / svc_dsl.cgi
index a4b2d43..9d9134a 100644 (file)
@@ -1,14 +1,14 @@
 <% include('elements/svc_Common.html',
-            'table'     => 'svc_dsl',
-            'labels'    => \%labels,
-            'fields' => \@fields,
-           'svc_callback' => $svc_cb,
-           'html_foot' => $html_foot,
+            'table'        => 'svc_dsl',
+            'labels'       => \%labels,
+            'fields'       => \@fields,
+            'svc_callback' => $svc_cb,
+            'html_foot'    => $html_foot,
           )
 %>
 <%init>
-my $conf = new FS::Conf;
-my $date_format = $conf->config('date_format') || '%m/%d/%Y';
+
+# XXX: AJAX auto-pull
 
 my $fields = FS::svc_dsl->table_info->{'fields'};
 my %labels = map { $_ =>  ( ref($fields->{$_})
@@ -25,38 +25,62 @@ my $html_foot = sub {
 };
 
 my $svc_cb = sub {
-    my( $cgi,$svc_x, $part_svc,$cust_pkg, $fields1,$opt) = @_;
+    my( $cgi,$svc_dsl, $part_svc,$cust_pkg, $fields1,$opt) = @_;
 
     my @exports = $part_svc->part_export_dsl_pull;
     die "more than one DSL-pulling export attached to svcpart ".$part_svc->svcpart
-       if ( scalar(@exports) > 1 );
+        if ( scalar(@exports) > 1 );
     
     # if no DSL-pulling exports, then just display everything, which is the
     # default behaviour implemented above
     return if ( scalar(@exports) == 0 );
 
-    $opt->{'disable_unprovision'} = 1;
-    my $exporttype = @exports[0]->exporttype;  
+    my $export = @exports[0];
 
-    # XXX: AJAX auto-pull
-       
-    @fields = qw( svctn first last company username password );
+    @fields = ( 'phonenum',
+            { field => 'loop_type', 
+              value => 'FS::part_export::'.$export->exporttype.'::loop_type_long'
+            },
+            { field => 'desired_due_date', type => 'date', },
+            { field => 'due_date', type => 'date', },
+            { field => 'pushed', type => 'datetime', },
+            { field => 'monitored', type => 'checkbox', },
+            { field => 'last_pull', type => 'datetime', },
+            'first',
+            'last',
+            'company'  );
 
-    if($exporttype eq 'ikano') {
-       push @fields, 'isp_chg';
-       push @fields, 'isp_prev';
-       push @fields, 'staticips';
-    }
-    else {
-       # XXX
+    my $status = '';
+    if($export->exporttype eq 'ikano') {
+        push @fields, qw ( username password isp_chg isp_prev staticips );
+        $status = "Ikano " . $svc_dsl->vendor_order_type . " order #"
+                . $svc_dsl->vendor_order_id . " &nbsp; Status: " 
+                . $svc_dsl->vendor_order_status;
     }
-    
-    # hack against "can't use string ... as a subroutine ref while 'strict refs' in use"
-    my $statusSub = \&{'FS::part_export::'.$exporttype.'::status_line'};
-    my $statusLine = &$statusSub($svc_x,$date_format,"<BR>");
-    
-    $footer = "<B>$statusLine</B>";
+    # else add any other export-specific stuff here
+   
+    $footer = "<B>$status</B>";
+
+    my @notes = $svc_dsl->notes;
+    if ( @notes ) {
 
-    # XXX: notes
+      my $conf = new FS::Conf;
+      my $date_format = $conf->config('date_format') || '%m/%d/%Y';
+
+      $footer .=
+        "<BR><BR>Order Notes<BR>". ntable('#cccccc', 2). #id="dsl_notes"
+        '<TR><TH>Date</TH><TH>By</TH><TH>Priority</TH><TH>Note</TH></TR>';
+
+      foreach my $note ( @notes ) {
+        $footer .= "<TR>
+            <TD>".time2str("$date_format %H:%M",$note->date)."</TD>
+            <TD>".$note->by."</TD>
+            <TD>". ($note->priority eq 'N' ? 'Normal' : 'High') ."</TD>
+            <TD>".$note->note."</TD></TR>";
+      }
+
+      $footer .= '</TABLE>';
+
+    }
 };
 </%init>