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',
13 { field=>'ratenum', type=>'hidden', },
14 { field=>'orig_regionnum', type=>'hidden', },
15 { field=>'dest_regionnum', type=>'hidden', },
16 { field=>'dest_regionname', type=>'fixed', },
17 { field=>'dest_prefixes_short', type=>'fixed', },
18 { field=>'min_included', type=>'text', size=>5 },
19 { field=>'min_charge', type=>'money', size=>4 },
20 { field =>'sec_granularity',
22 options => [ keys %granularity ],
23 labels => \%granularity,
32 tie my %granularity, 'Tie::IxHash', FS::rate_detail::granularities();
38 my $conf = new FS::Conf;
40 unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
42 #slightly inefficient, i suppose an edit+error callback would be better
44 my ($keywords) = $cgi->keywords;
45 if ( $keywords =~ /^(\d+)$/
46 || $cgi->param('ratedetailnum') =~ /^(\d+)$/ ) {
47 my $rate_detail = qsearchs('rate_detail', { 'ratedetailnum' => $1 } )
48 or die "unknown ratedetailnum $1";
50 $rate_detail->rate->ratename. ' rate for '. $rate_detail->dest_regionname;
53 #sec_granularity should default to 60! for new rates when this gets used for em