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 'rate_time_name' => 'Time period',
9 'min_included' => 'Included minutes/calls',
10 'conn_charge' => 'Connection charge',
12 'min_charge' => 'Charge per minute/call',
13 'sec_granularity' => 'Granularity',
14 'classnum' => 'Usage class',
17 { field=>'ratenum', type=>'hidden', },
18 { field=>'orig_regionnum', type=>'hidden', },
19 { field=>'dest_regionnum', type=>'hidden', },
20 { field=>'ratetimenum', type=>'hidden', },
21 { field=>'dest_regionname', type=>'fixed', },
22 { field=>'dest_prefixes_short', type=>'fixed', },
23 { field=>'rate_time_name', type=>'fixed', },
24 { field=>'min_included', type=>'text', size=>5 },
25 { field=>'conn_charge', type=>'money', size=>4 },
28 options => [ keys %conn_secs ],
29 labels => \%conn_secs,
32 { field=>'min_charge', type=>'money', size=>4 },
33 { field =>'sec_granularity',
35 options => [ keys %granularity ],
36 labels => \%granularity,
40 type =>'select-table',
41 table =>'usage_class',
42 name_col =>'classname',
43 empty_label =>'(default)',
44 hashref =>{ disabled => '' },
48 'new_hashref_callback' => sub {
49 { ratenum => $cgi->param('ratenum'),
50 dest_regionnum => $cgi->param('dest_regionnum'),
51 ratetimenum => $cgi->param('ratetimenum'),
58 tie my %granularity, 'Tie::IxHash', FS::rate_detail::granularities();
59 tie my %conn_secs, 'Tie::IxHash', FS::rate_detail::conn_secs();
64 my $conf = new FS::Conf;
66 unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
68 #slightly inefficient, i suppose an edit+error callback would be better
70 my ($keywords) = $cgi->keywords;
71 if ( $keywords =~ /^(\d+)$/
72 || $cgi->param('ratedetailnum') =~ /^(\d+)$/ ) {
73 my $rate_detail = qsearchs('rate_detail', { 'ratedetailnum' => $1 } )
74 or die "unknown ratedetailnum $1";
76 $rate_detail->rate->ratename. ' rate for '. $rate_detail->dest_regionname;
79 #sec_granularity should default to 60! for new rates when this gets used for em