1 <% include('elements/edit.html',
4 'table' => 'rate_detail',
5 'labels' => { 'ratedetailnum' => 'Rate', #should hide...
6 'dest_regionname' => 'Region',
7 'dest_prefixes_short' => 'Prefix(es)',
8 'min_included' => 'Included minutes',
9 'min_charge' => 'Charge per minute',
10 'sec_granularity' => 'Granularity',
11 'classnum' => 'Usage class',
14 { field=>'ratenum', type=>'hidden', },
15 { field=>'orig_regionnum', type=>'hidden', },
16 { field=>'dest_regionnum', type=>'hidden', },
17 { field=>'dest_regionname', type=>'fixed', },
18 { field=>'dest_prefixes_short', type=>'fixed', },
19 { field=>'min_included', type=>'text', size=>5 },
20 { field=>'min_charge', type=>'money', size=>4 },
21 { field =>'sec_granularity',
23 options => [ keys %granularity ],
24 labels => \%granularity,
28 type =>'select-table',
29 table =>'usage_class',
30 name_col =>'classname',
31 empty_label =>'(default)',
32 hashref =>{ disabled => '' },
40 tie my %granularity, 'Tie::IxHash', FS::rate_detail::granularities();
46 my $conf = new FS::Conf;
48 unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
50 #slightly inefficient, i suppose an edit+error callback would be better
52 my ($keywords) = $cgi->keywords;
53 if ( $keywords =~ /^(\d+)$/
54 || $cgi->param('ratedetailnum') =~ /^(\d+)$/ ) {
55 my $rate_detail = qsearchs('rate_detail', { 'ratedetailnum' => $1 } )
56 or die "unknown ratedetailnum $1";
58 $rate_detail->rate->ratename. ' rate for '. $rate_detail->dest_regionname;
61 #sec_granularity should default to 60! for new rates when this gets used for em