1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
<%
##
# 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();
%>
<INPUT TYPE="checkbox" NAME="<%= $target_pkey. $targetnum %>" <%=
qsearchs( $opt{'link_table'}, {
$source_pkey => $sourcenum,
$target_pkey => $targetnum,
})
? 'CHECKED '
: ''
%> VALUE="ON">
<% if ( $opt{'target_link'} ) { %>
<A HREF="<%= $opt{'target_link'} %><%= $targetnum %>"><%
}
%><%= $targetnum %>:
<% if ( $opt{'name_callback'} ) { %>
<%= &{ $opt{'name_callback'} }( $target_obj ) %><%= $opt{'target_link'} ? '</A>' : '' %>
<% } else {
my $name_col = $opt{'name_col'};
%>
<%= $target_obj->$name_col() %><%= $opt{'target_link'} ? '</A>' : '' %>
<% } %>
<% if ( $opt{'disable-able'} ) { %>
<%= $target_obj->disabled =~ /^Y/i ? ' (DISABLED)' : '' %>
<% } %>
<BR>
<% } %>
|