Revision 296 (by ahitrov, 2013/03/26 17:59:01) Promosite (anthill) project source
package promosuite::SQL::NewsTable;

use strict;
use base 'SQL::DocumentTable';

sub db_table
{
	return 'news';
}

sub available_filters {
	my @available_filters = qw(	
					_class_filter
					_status_filter
					_in_id_filter
					_id_filter
					_name_filter
					_class_excludes_filter
					_sfilter_filter
					_datetime_filter
					_date_equal_filter
					_date_filter
				 	_previous_days_filter
					_s_filter

					_excludes_filter
					_link_filter
					_ext_id_filter
				);
	return \@available_filters; 
}

# ----------------------------------------------------------------------------
# Свойства храним в массивах, потому что порядок важен!
# Это общие свойства - одинаковые для всех документов.
#
#   attr - обязательный параметр, название атрибута;
#   type - тип аттрибута, требуется для отображдения;
#   rusname - русское название, опять же требуется для отображения;
#   hidden - равен 1, когда 
#   readonly - инициализации при записи только без изменения в дальнейшем
#   db_field - поле в таблице
#   default  - значение по умолчанию (поле всегда имеет это значение)
# ----------------------------------------------------------------------------
sub required_properties
{
        my $self = shift;

        my @parent_properties = $self->SUPER::required_properties;
	return (
		@parent_properties,
		{							# Внешний идентификатор
			'attr'		=> 'ext_id',
			'type'		=> 'integer',
			'rusname'	=> 'Внешний идентификатор',
			'db_field'	=> 'ext_id',
			'db_type'       => 'integer',
		},
	);
}

########### FILTERS DESCRIPTION ####################################################################################
sub _ext_id_filter {
	my ($self,%opts)=@_;
	return undef unless ( exists $opts{ext_id} );
	return &SQL::Common::_generic_int_filter('d.ext_id', $opts{ext_id});
}

1;