X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Flib%2FRT%2FCustomFieldValues.pm;h=6b5c624cbba78ed497cb0259b6b0e30ad826e8db;hb=7322f2afedcc2f427e997d1535a503613a83f088;hp=4fa062e7ce9586c6e0400ff8f5dc1438c3098485;hpb=75162bb14b3e38d66617077843f4dfdcaf09d5c4;p=freeside.git diff --git a/rt/lib/RT/CustomFieldValues.pm b/rt/lib/RT/CustomFieldValues.pm index 4fa062e7c..6b5c624cb 100644 --- a/rt/lib/RT/CustomFieldValues.pm +++ b/rt/lib/RT/CustomFieldValues.pm @@ -2,7 +2,7 @@ # # COPYRIGHT: # -# This software is Copyright (c) 1996-2011 Best Practical Solutions, LLC +# This software is Copyright (c) 1996-2016 Best Practical Solutions, LLC # # # (Except where explicitly superseded by other copyright notices) @@ -46,46 +46,22 @@ # # END BPS TAGGED BLOCK }}} -# Autogenerated by DBIx::SearchBuilder factory (by ) -# WARNING: THIS FILE IS AUTOGENERATED. ALL CHANGES TO THIS FILE WILL BE LOST. -# -# !! DO NOT EDIT THIS FILE !! -# +package RT::CustomFieldValues; use strict; +use warnings; +use base 'RT::SearchBuilder'; -=head1 NAME - - RT::CustomFieldValues -- Class Description - -=head1 SYNOPSIS - - use RT::CustomFieldValues - -=head1 DESCRIPTION - - -=head1 METHODS - -=cut - -package RT::CustomFieldValues; - -use RT::SearchBuilder; use RT::CustomFieldValue; -use vars qw( @ISA ); -@ISA= qw(RT::SearchBuilder); - +sub Table { 'CustomFieldValues'} sub _Init { my $self = shift; - $self->{'table'} = 'CustomFieldValues'; - $self->{'primary_key'} = 'id'; - # By default, order by SortOrder - $self->OrderByCols( + # By default, order by SortOrder + $self->OrderByCols( { ALIAS => 'main', FIELD => 'SortOrder', ORDER => 'ASC' }, @@ -95,41 +71,72 @@ sub _Init { { ALIAS => 'main', FIELD => 'id', ORDER => 'ASC' }, - ); + ); return ( $self->SUPER::_Init(@_) ); } +# {{{ sub LimitToCustomField + +=head2 LimitToCustomField FIELD + +Limits the returned set to values for the custom field with Id FIELD +=cut + +sub LimitToCustomField { + my $self = shift; + my $cf = shift; + return $self->Limit( + FIELD => 'CustomField', + VALUE => $cf, + OPERATOR => '=', + ); +} -=head2 NewItem +=head2 SetCustomFieldObject -Returns an empty new RT::CustomFieldValue item +Store the CustomField object which loaded this CustomFieldValues collection. +Consumers of CustomFieldValues collection (such as External Custom Fields) +can now work out how they were loaded (off a Queue or Ticket or something else) +by inspecting the CustomField. =cut -sub NewItem { +sub SetCustomFieldObject { my $self = shift; - return(RT::CustomFieldValue->new($self->CurrentUser)); + return $self->{'custom_field'} = shift; } -RT::Base->_ImportOverlays(); - -=head1 SEE ALSO -This class allows "overlay" methods to be placed -into the following files _Overlay is for a System overlay by the original author, -_Vendor is for 3rd-party vendor add-ons, while _Local is for site-local customizations. +=head2 CustomFieldObject -These overlay files can contain new subs or subs to replace existing subs in this module. +Returns the CustomField object used to load this CustomFieldValues collection. +Relies on $CustomField->Values having been called, is not set on manual loads. -Each of these files should begin with the line +=cut - no warnings qw(redefine); +sub CustomFieldObject { + my $self = shift; + return $self->{'custom_field'}; +} -so that perl does not kick and scream when you redefine a subroutine or variable in your overlay. +=head2 AddRecord -RT::CustomFieldValues_Overlay, RT::CustomFieldValues_Vendor, RT::CustomFieldValues_Local +Propagates the CustomField object from the Collection +down to individual CustomFieldValue objects. =cut +sub AddRecord { + my $self = shift; + my $CFV = shift; + + $CFV->SetCustomFieldObj($self->CustomFieldObject); + + push @{$self->{'items'}}, $CFV; + $self->{'rows'}++; +} + + +RT::Base->_ImportOverlays(); 1;