X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Felements%2Ftr-select-agent.html;h=04600fa8d9461290eebe1daa567c9644e15f1276;hp=83c8d1758aff37d621f6ce7fa14aea9845323f82;hb=3f2a7b01b59902faed5767d81e2959e131bdbdfd;hpb=c0e8da2f1e89729efa1032241e4239765a296514 diff --git a/httemplate/elements/tr-select-agent.html b/httemplate/elements/tr-select-agent.html index 83c8d1758..04600fa8d 100644 --- a/httemplate/elements/tr-select-agent.html +++ b/httemplate/elements/tr-select-agent.html @@ -1,36 +1,76 @@ -<% - my( $agentnum, %opt ) = @_; +<%doc> - my @agents; - if ( $opt{'agents'} ) { - #@agents = @{ $opt{'agents'} }; - #here is the agent virtualization - my $agentnums_href = $FS::CurrentUser::CurrentUser->agentnums_href; - @agents = grep $agentnums_href->{$_->agentnum}, @{ $opt{'agents'} }; - } else { - @agents = qsearch( { - 'table' => 'agent', - 'hashref' => { disabled=>'' }, - 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql, - }); - } +Example: -%> + include( '/elements/tr-select-agent.html', -<% if ( scalar(@agents) == 1 ) { %> + #recommended to keep things "sticky" on errors + 'curr_value' => $curr_value, - + ## + # optional + ## -<% } else { %> + 'label' => 'Agent for this thing', + 'empty_label' => 'Select agent', #override default + 'disable_empty' => 1, + + #set to 'None' or something to override default of showing all agents + #for employees w/ 'View customers of all agents' right + viewall_right => 'None', + + ); + + +% if ( scalar(@agents) == 1 || $opt{'fixed'} ) { + + + +% if ( scalar(@agents) != 1 ) { + + <% $opt{'label'} || emt('Agent') %> + > +% my $agent = qsearchs('agent', { 'agentnum' => $agentnum }); + <% $agent ? $agent->agent : '(all)' |h %> + + + +% } else { # YUCK. empty row so we don't throw g_row in edit.html off :/ + + +% } +% +% } else { - <%= $opt{'label'} || 'Agent: ' %> - - <%= include( '/elements/select-agent.html', $agentnum, - 'agents' => \@agents, - ) - %> + <% $opt{'label'} || emt('Agent') %> + > + <& /elements/select-agent.html, + 'curr_value' => $agentnum, + 'agents' => \@agents, + %opt, + &> -<% } %> +% } + +<%init> + +my %opt = @_; +my $agentnum = $opt{'curr_value'} || $opt{'value'}; + +my @agents = + $opt{'agents'} + ? @{ $opt{'agents'} } + : $FS::CurrentUser::CurrentUser->agents( + 'viewall_right' => $opt{'viewall_right'}, + ); + +my $colspan = $opt{'colspan'} ? 'COLSPAN="'.$opt{'colspan'}.'"' : ''; + +