<% ## # required ## # 'target_table' => 'table_name', # 'link_table' => 'table_name', # # 'name_col' => 'name_column', # #or # 'name_callback' => sub { }, # ## # recommended (required?) ## # 'source_obj' => $obj, # #or? # #'source_table' => 'table_name', # #'sourcenum' => '4', #current value of primary key in source_table # # # (none is okay, just pass it if you have it) ## # optional ## # 'disable-able' => 1, my( %opt ) = @_; my $target_pkey = dbdef->table($opt{'target_table'})->primary_key; my( $source_pkey, $sourcenum, $source_obj ); if ( $opt{'source_obj'} ) { $source_obj = $opt{'source_obj'}; #$source_table = $source_obj->dbdef_table->table; $source_pkey = $source_obj->dbdef_table->primary_key; $sourcenum = $source_obj->$source_pkey(); } else { #$source_obj? $source_pkey = $opt{'source_table'} ? dbdef->table($opt{'source_table'})->primary_key : ''; $sourcenum = $opt{'sourcenum'}; } my $hashref = $opt{'hashref'} || {}; my $extra_sql = ''; if ( $opt{'disable-able'} ) { $hashref->{'disabled'} = ''; $extra_sql .= ( $sourcenum && $source_pkey ) ? "OR $source_pkey = $sourcenum" : ''; } %> <% foreach my $target_obj ( qsearch({ 'table' => $opt{'target_table'}, 'hashref' => $hashref, 'select' => $opt{'target_table'}. '.*', 'addl_from' => "LEFT JOIN $opt{'link_table'} USING ( $target_pkey )", 'extra_sql' => $extra_sql, }) ) { my $targetnum = $target_obj->$target_pkey(); my $checked; if ( $cgi->param('error') ) { $checked = $cgi->param($target_pkey.$targetnum) ? 'CHECKED' : ''; } else { $checked = qsearchs( $opt{'link_table'}, { $source_pkey => $sourcenum, $target_pkey => $targetnum, } ) ? 'CHECKED' : '' } %> VALUE="ON"> <% if ( $opt{'target_link'} ) { %> <% } %><%= $targetnum %>: <% if ( $opt{'name_callback'} ) { %> <%= &{ $opt{'name_callback'} }( $target_obj ) %><%= $opt{'target_link'} ? '' : '' %> <% } else { my $name_col = $opt{'name_col'}; %> <%= $target_obj->$name_col() %><%= $opt{'target_link'} ? '' : '' %> <% } %> <% if ( $opt{'disable-able'} ) { %> <%= $target_obj->disabled =~ /^Y/i ? ' (DISABLED)' : '' %> <% } %>
<% } %>