blob: a9ecda2bcd348ee3e1af7a3fd71e6d15af6010fc (
plain)
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
|
#$Header: /home/cvs/cvsroot/freeside/rt/lib/RT/Attic/Keywords.pm,v 1.1 2002-08-12 06:17:07 ivan Exp $
=head1 NAME
RT::Keywords - a collection of RT::Keyword objects
=head1 SYNOPSIS
use RT::Keywords;
my $keywords = RT::Keywords->new($user);
$keywords->LimitToParent(0);
while my ($keyword = $keywords->Next()) {
print $keyword->Name ."\n";
}
=head1 DESCRIPTION
=head1 METHODS
=begin testing
ok (require RT::TestHarness);
ok (require RT::Keywords);
=end testing
=cut
package RT::Keywords;
use strict;
use vars qw( @ISA );
use RT::EasySearch;
use RT::Keyword;
@ISA = qw( RT::EasySearch );
# {{{ sub _Init
sub _Init {
my $self = shift;
$self->{'table'} = 'Keywords';
$self->{'primary_key'} = 'id';
# By default, order by name
$self->OrderBy( ALIAS => 'main',
FIELD => 'Name',
ORDER => 'ASC');
return ($self->SUPER::_Init(@_));
}
# }}}
# {{{ sub _DoSearch
=head2 _DoSearch
A subclass of DBIx::SearchBuilder::_DoSearch that makes sure that _Disabled rows never get seen unless
we're explicitly trying to see them.
=cut
sub _DoSearch {
my $self = shift;
#unless we really want to find disabled rows, make sure we\'re only finding enabled ones.
unless($self->{'find_disabled_rows'}) {
$self->LimitToEnabled();
}
return($self->SUPER::_DoSearch(@_));
}
# }}}
# {{{ sub NewItem
sub NewItem {
my $self = shift;
return (RT::Keyword->new($self->CurrentUser));
}
# }}}
# {{{ sub LimitToParent
=head2 LimitToParent
Takes a parent id and limits the returned keywords to children of that parent.
=cut
sub LimitToParent {
my $self = shift;
my $parent = shift;
$self->Limit( FIELD => 'Parent',
VALUE => $parent,
OPERATOR => '=',
ENTRYAGGREGATOR => 'OR' );
}
# }}}
1;
|