2 <TD CLASS="background" COLSPAN=99>
5 var provision_hold_td = [];
6 var provision_hold_input = [];
9 <% itable('', 4, 1) %><TR><TD VALIGN="top">
12 %foreach my $part_svc ( @part_svc ) {
13 % my $svcpart = $part_svc->svcpart;
14 % my $pkg_svc = $pkg_svc{$svcpart}
15 % || new FS::pkg_svc ( {
16 % 'pkgpart' => $pkgpart,
17 % 'svcpart' => $svcpart,
19 % 'primary_svc' => '',
22 % if ( $cgi->param('error') ) {
23 % my $primary_svc = ( $pkg_svc->primary_svc =~ /^Y/i );
24 % my $pkg_svc_primary = scalar($cgi->param('pkg_svc_primary'));
25 % $pkg_svc->primary_svc('')
26 % if $primary_svc && $pkg_svc_primary != $svcpart;
27 % $pkg_svc->primary_svc('Y')
28 % if ! $primary_svc && $pkg_svc_primary == $svcpart;
31 % push @fixups, "pkg_svc$svcpart";
34 % if ( $cgi->param("pkg_svc$svcpart") =~ /^\s*(\d+)\s*$/ ) {
36 % } elsif ( $pkg_svc->quantity ) {
37 % $quan = $pkg_svc->quantity;
40 % my $provision_hold = '';
41 % if ( grep { $_ eq "provision_hold$svcpart" } $cgi->param ) {
42 % $provision_hold = $cgi->param("hidden_svc$svcpart");
44 % $provision_hold = $pkg_svc->provision_hold;
47 % my @exports = $pkg_svc->part_svc->part_export;
48 % foreach my $export ( @exports ) {
49 % push @possible_exports, $export if $export->can('external_pkg_map');
54 <INPUT TYPE="text" NAME="pkg_svc<% $svcpart %>" SIZE=7 MAXLENGTH=6 VALUE="<% $quan %>">
58 <INPUT TYPE="radio" NAME="pkg_svc_primary" VALUE="<% $svcpart %>" <% $pkg_svc->primary_svc =~ /^Y/i ? ' CHECKED' : '' %>>
62 <A HREF="part_svc.cgi?<% $part_svc->svcpart %>"><% $part_svc->svc %></A> <% $part_svc->disabled =~ /^Y/i ? ' (DISABLED)' : '' %>
66 <INPUT TYPE="checkbox" NAME="hidden<% $svcpart %>" VALUE="Y"<% $pkg_svc->hidden =~ /^Y/i ? ' CHECKED' : ''%>>
69 <TD ALIGN="center" ID="td_provision_hold<% $svcpart %>">
70 <INPUT TYPE="checkbox" ID="input_provision_hold<% $svcpart %>" NAME="provision_hold<% $svcpart %>" VALUE="Y"<% $provision_hold =~ /^Y/i ? ' CHECKED' : ''%>>
73 provision_hold_td.push(document.getElementById('td_provision_hold<% $svcpart %>'));
74 provision_hold_input.push(document.getElementById('input_provision_hold<% $svcpart %>'));
78 % foreach ( 1 .. $columns-1 ) {
79 % if ( $count == int( $_ * scalar(@part_svc) / $columns ) ) {
82 </TABLE></TD><TD VALIGN="top"><% pkg_svc_thead() %>
87 % } # foreach $part_svc
89 </TR></TABLE></TD></TR></TABLE>
92 // start_on_hold from edit/part_pkg.cgi
93 // toggles display of provision_hold checkboxes when that changes
94 function provision_hold_check () {
95 var start_on_hold = document.getElementById('start_on_hold');
97 for (i = 0; i < provision_hold_td.length; i++) {
98 provision_hold_td[i].style.display = start_on_hold.checked ? '' : 'none';
100 for (i = 0; i < provision_hold_input.length; i++) {
101 provision_hold_input[i].disabled = start_on_hold.checked ? false : true;
105 function provision_hold_init () {
106 var start_on_hold = document.getElementById('start_on_hold');
108 start_on_hold.onchange = provision_hold_check;
109 provision_hold_check();
112 provision_hold_init();
115 % if ( scalar(@possible_exports) > 0 || scalar(@mapped_exports) > 0 ) {
117 <TH BGCOLOR="#dcdcdc">Export</TH>
118 <TH BGCOLOR="#dcdcdc">Vendor Package Id <FONT SIZE="-2">(blank to delete)</FONT></TH>
120 % foreach my $export ( @mapped_exports ) {
122 <TD><% $export->exportname %></TD>
123 <TD><INPUT TYPE="text" NAME="export<% $export->exportnum %>"
124 SIZE="30" VALUE="<% $vendor_pkg_ids{$export->exportnum} %>">
128 % foreach my $export ( @possible_exports ) {
129 % unless ( defined $vendor_pkg_ids{$export->exportnum} ) {
131 <TD><% $export->exportname %></TD>
133 <INPUT TYPE="text" NAME="export<% $export->exportnum %>" SIZE="30">
147 my $cgi = $opt{'cgi'};
152 return "\n\n". ntable('#cccccc', 2).
154 '<TH BGCOLOR="#dcdcdc"><FONT SIZE=-1>Quan.</FONT></TH>'.
155 '<TH BGCOLOR="#dcdcdc"><FONT SIZE=-1>Primary</FONT></TH>'.
156 '<TH BGCOLOR="#dcdcdc">Service</TH>'.
157 '<TH BGCOLOR="#dcdcdc"><FONT SIZE=-1>Hide<BR>from<BR>Invoices</FONT></TH>'.
158 '<TH BGCOLOR="#dcdcdc" ID="th_provision_hold' . $thead_count . '"><FONT SIZE=-1>Remove Hold After Provisioning</FONT></TH>'.
160 qq!<SCRIPT>provision_hold_td.push(document.getElementById('th_provision_hold$thead_count'))</SCRIPT>!;
164 my $part_pkg = $opt{'object'};
165 my $pkgpart = $part_pkg->pkgpart;
167 my $where = "WHERE disabled IS NULL OR disabled = ''";
169 $where .= " OR 0 < ( SELECT quantity FROM pkg_svc
170 WHERE pkg_svc.svcpart = part_svc.svcpart
171 AND pkgpart = $pkgpart
174 my @part_svc = qsearch('part_svc', {}, '', $where);
176 #my $q_part_pkg = $clone_part_pkg || $part_pkg;
177 #my %pkg_svc = map { $_->svcpart => $_ } $q_part_pkg->pkg_svc;
178 my %pkg_svc = map { $_->svcpart => $_ } $part_pkg->pkg_svc('disable_linked'=>1);
184 my @possible_exports = ();
185 my @mapped_exports = ();
186 my @part_pkg_vendor = $part_pkg->part_pkg_vendor;
187 foreach my $part_pkg_vendor ( @part_pkg_vendor ) {
188 push @mapped_exports, $part_pkg_vendor->part_export;
190 my %vendor_pkg_ids = $part_pkg->vendor_pkg_ids;