summaryrefslogtreecommitdiff
path: root/httemplate/view/svc_dsl.cgi
blob: e6a3c5381e69f276e52601265a5349c845909e52 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<% include('elements/svc_Common.html',
            'table'        => 'svc_dsl',
            'labels'       => \%labels,
            'fields'       => \@fields,
            'svc_callback' => $svc_cb,
            'html_foot'    => $html_foot,
          )
%>
<%init>

# XXX: AJAX auto-pull

my $fields = FS::svc_dsl->table_info->{'fields'};
my %labels = map { $_ =>  ( ref($fields->{$_})
                             ? $fields->{$_}{'label'}
                             : $fields->{$_}
                         );
                 } keys %$fields;
my @fields = keys %$fields;

my $footer;

my $html_foot = sub {
    return $footer;
};

my $svc_cb = sub {
    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 no DSL-pulling exports, then just display everything, which is the
    # default behaviour implemented above
    if ( scalar(@exports) ) {

      my $export = @exports[0];

      @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',
      );

      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;
      }
      # else add any other export-specific stuff here
   
      $footer = "<B>$status</B>";

    }

    if ( grep $_->can('export_getstatus'), $part_svc->part_export ) {

      $footer .= '<BR><BR>'.
                 include('/elements/popup_link.html', {
                   'action'      => $p.'view/svc_Status.html'.
                                      '?svcnum='. $svc_dsl->svcnum,
                   'label'       => 'View line status', #link
                   'actionlabel' => 'View line status', #popup border
                   'width'       => 763,
                   'height'      => 300,
                 });

    }

    $footer .= '<BR><BR>'.
               include( '/view/elements/svc_devices.html',
                          'svc_x'   => $svc_dsl,
                          'table'   => 'dsl_device',
                          'no_edit' => 1,
                      );

    my @notes = $svc_dsl->notes;
    if ( @notes ) {

      my $conf = new FS::Conf;
      my $date_format = $conf->config('date_format') || '%m/%d/%Y';

      $footer .=
        "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>