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 'region_group' => 'Region Group',
11 'conn_charge' => 'Connection charge',
13 'min_charge' => 'Charge per minute/call',
14 'sec_granularity' => 'Granularity',
15 'classnum' => 'Usage class',
18 { field=>'ratenum', type=>'hidden', },
19 { field=>'orig_regionnum', type=>'hidden', },
20 { field=>'dest_regionnum', type=>'hidden', },
21 { field=>'ratetimenum', type=>'hidden', },
22 { field=>'cdrtypenum', type=>'hidden', },
23 { field=>'dest_regionname', type=>'fixed', },
24 { field=>'dest_prefixes_short', type=>'fixed', },
25 { field=>'rate_time_name', type=>'fixed', },
26 { field => 'region_group',
30 { field=>'min_included', type=>'text', size=>5 },
31 { field=>'conn_charge', type=>'money', size=>4 },
34 options => [ keys %conn_secs ],
35 labels => \%conn_secs,
38 { field=>'min_charge', type=>'money', size=>4 },
39 { field =>'sec_granularity',
41 options => [ keys %granularity ],
42 labels => \%granularity,
46 type =>'select-table',
47 table =>'usage_class',
48 name_col =>'classname',
49 empty_label =>'(default)',
50 hashref =>{ disabled => '' },
54 'new_hashref_callback' => sub {
55 { ratenum => scalar($cgi->param('ratenum')),
56 dest_regionnum => scalar($cgi->param('dest_regionnum')),
57 ratetimenum => scalar($cgi->param('ratetimenum')),
58 cdrtypenum => scalar($cgi->param('cdrtypenum')),
67 tie my %granularity, 'Tie::IxHash', FS::rate_detail::granularities();
68 tie my %conn_secs, 'Tie::IxHash', FS::rate_detail::conn_secs();
73 my $conf = new FS::Conf;
75 unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
77 #slightly inefficient, i suppose an edit+error callback would be better
79 my ($keywords) = $cgi->keywords;
80 if ( $keywords =~ /^(\d+)$/
81 || $cgi->param('ratedetailnum') =~ /^(\d+)$/ ) {
82 my $rate_detail = qsearchs('rate_detail', { 'ratedetailnum' => $1 } )
83 or die "unknown ratedetailnum $1";
85 $rate_detail->rate->ratename. ' rate for '. $rate_detail->dest_regionname;
88 #sec_granularity should default to 60! for new rates when this gets used for em