1 <% include( 'edit.html',
5 'error_callback' => sub {
6 my( $cgi, $svc_x, $fields, $opt ) = @_;
7 #$svcnum = $svc_x->svcnum;
8 $pkgnum = $cgi->param('pkgnum');
9 $svcpart = $cgi->param('svcpart');
11 $part_svc = qsearchs( 'part_svc', { svcpart=>$svcpart });
12 die "No part_svc entry!" unless $part_svc;
14 label_fixup($part_svc, $opt);
16 $svc_x->setfield('svcpart', $svcpart);
18 if ( my $cb = $opt{'svc_error_callback'} ) {
19 my $cust_pkg = $pkgnum
20 ? qsearchs('cust_pkg', {pkgnum=>$pkgnum})
22 &{ $cb }( $cgi,$svc_x, $part_svc,$cust_pkg, $fields,$opt);
26 'edit_callback' => sub {
27 my( $cgi, $svc_x, $fields, $opt ) = @_;
28 #$svcnum = $svc_x->svcnum;
29 my $cust_svc = $svc_x->cust_svc
30 or die "Unknown (cust_svc) svcnum!";
32 $pkgnum = $cust_svc->pkgnum;
33 $svcpart = $cust_svc->svcpart;
35 $part_svc = qsearchs ('part_svc', { svcpart=>$svcpart });
36 die "No part_svc entry!" unless $part_svc;
38 label_fixup($part_svc, $opt);
40 if ( my $cb = $opt{'svc_edit_callback'} ) {
41 my $cust_pkg = $pkgnum
42 ? qsearchs('cust_pkg', {pkgnum=>$pkgnum})
44 &{ $cb }( $cgi,$svc_x, $part_svc,$cust_pkg, $fields,$opt);
48 'new_hashref_callback' => sub {
49 #my( $cgi, $svc_x ) = @_;
57 'new_callback' => sub {
58 my( $cgi, $svc_x, $fields, $opt ) = @_;
60 $part_svc = qsearchs( 'part_svc', { svcpart=>$svcpart });
61 die "No part_svc entry!" unless $part_svc;
63 label_fixup($part_svc, $opt);
67 if ( my $cb = $opt{'svc_new_callback'} ) {
68 my $cust_pkg = $pkgnum
69 ? qsearchs('cust_pkg', {pkgnum=>$pkgnum})
71 &{ $cb }( $cgi,$svc_x, $part_svc,$cust_pkg, $fields,$opt);
74 $svc_x->set_default_and_fixed;
78 'field_callback' => sub {
79 my ($cgi, $object, $f) = @_;
81 my $columndef = $part_svc->part_svc_column($f->{'field'});
82 my $flag = $columndef->columnflag;
84 $f->{'type'} = length($columndef->columnvalue)
87 $f->{'value'} = $columndef->columnvalue;
88 } elsif ( $flag eq 'A' ) {
89 $f->{'type'} = 'hidden';
90 } elsif ( $flag eq 'M' ) {
91 $f->{'empty_label'} = 'Select inventory item';
92 $f->{'type'} = 'select-table';
93 $f->{'table'} = 'inventory_item';
94 $f->{'name_col'} = 'item';
95 $f->{'value_col'} = 'item';
96 $f->{'agent_virt'} = 1;
97 $f->{'agent_null'} = 1;
99 'classnum'=>$columndef->columnvalue,
102 $f->{'extra_sql'} = 'AND ( svcnum IS NULL ';
103 $f->{'extra_sql'} .= ' OR svcnum = '. $object->svcnum
105 $f->{'extra_sql'} .= ' ) ';
106 $f->{'disable_empty'} = $object->svcnum ? 1 : 0;
107 if ( $f->{'field'} eq 'mac_addr' ) {
108 $f->{'compare_sub'} = sub {
115 } elsif ( $flag eq 'H' ) {
116 $f->{'type'} = 'select-hardware_type';
118 'classnum'=>$columndef->columnvalue
121 } elsif ( $flag eq 'S' #selectable choice
122 && $f->{type} !~ /^select-svc(-domain|_pbx)$/ ) {
123 $f->{type} = 'select';
124 $f->{options} = [ split( /\s*,\s*/,
125 $columndef->columnvalue)
129 if ( $f->{'type'} eq 'select-svc_pbx'
130 || $f->{'type'} eq 'select-svc-domain'
133 $f->{'include_opt_callback'} =
134 sub { ( 'pkgnum' => $pkgnum,
135 'svcpart' => $svcpart,
140 if ( $f->{'field'} eq 'custnum' && $pkgnum ) {
141 my $cust_pkg = qsearchs('cust_pkg', {'pkgnum' => $pkgnum});
142 $object->set('custnum', $cust_pkg->custnum);
145 if ( my $cb = $opt{'svc_field_callback'} ) {
146 &{ $cb }( $cgi, $object, $f);
154 my $cust_pkg = qsearchs('cust_pkg', {'pkgnum' => $pkgnum});
155 $cust_main = $cust_pkg->cust_main if $cust_pkg;
158 ? include( '/elements/small_custview.html',
162 popurl(2). "view/cust_main.cgi"
168 'html_table_bottom' => sub {
171 foreach my $field ($svc_x->virtual_fields) {
172 if ($part_svc->part_svc_column($field)->columnflag ne 'F'){
173 # If the flag is X, it won't even show up
174 # in $svc_acct->virtual_fields.
176 $svc_x->pvf($field)->widget( 'HTML',
178 $svc_x->getfield($field)
185 'html_bottom' => sub {
186 qq!<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">!.
187 qq!<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">!;
190 %opt #pass through/override params
196 my( $part_svc, $opt ) = @_;
198 $opt->{'name'} ||= $part_svc->svc;
200 my $svcdb = $part_svc->svcdb;
201 require "FS/$svcdb.pm";
203 if ( UNIVERSAL::can("FS::$svcdb", 'table_info') ) {
204 #$opt->{'name'} ||= "FS::$svcdb"->table_info->{'name'};
206 my $fields = "FS::$svcdb"->table_info->{'fields'};
207 $opt->{'fields'} ||= [ grep { $_ ne 'svcnum' } keys %$fields ];
210 map { $_ => ( ref($fields->{$_})
211 ? $fields->{$_}{'label'}
219 #false laziness w/view/svc_Common.html
220 #override default labels with service-definition labels if applicable
221 my $labels = $opt->{labels}; # with -> here
222 foreach my $field ( keys %{ $opt->{labels} } ) {
223 my $col = $part_svc->part_svc_column($field);
224 $labels->{$field} = $col->columnlabel if $col->columnlabel !~ /^\s*$/;
234 #my( $svcnum, $pkgnum, $svcpart, $part_svc );
235 my( $pkgnum, $svcpart, $part_svc );
237 #get & untaint pkgnum & svcpart
238 if ( ! $cgi->param('error')
239 && $cgi->param('pkgnum') && $cgi->param('svcpart')
242 $cgi->param('pkgnum') =~ /^(\d+)$/ or die 'unparsable pkgnum';
244 $cgi->param('svcpart') =~ /^(\d+)$/ or die 'unparsable svcpart';
246 #$cgi->delete_all(); #so edit.html treats this correctly as new??