package blogs::Record; use base "Contenido::Document"; use Encode; use Contenido::Globals; sub extra_properties { return ( { 'attr' => 'name', 'type' => 'string', 'rusname' => 'Сабж / настроение' }, { 'attr' => 'status', 'type' => 'status', 'rusname' => 'Статус записи', 'cases' => [ [0, 'Запись неактивна'], [1, 'Запись активна'], [2, 'Запись вынесена в топ блога'], [3, 'Запись вынесена на главную страницу'], ], }, { 'attr' => 'abstr', 'type' => 'wysiwyg', 'rusname' => 'Начало записи', 'rows' => 10 }, { 'attr' => 'body', 'type' => 'wysiwyg', 'rusname' => 'Текст под катом', 'rows' => 30 }, { 'attr' => 'author', 'type' => 'string', 'rusname' => 'Имя автора сообщения', }, { 'attr' => 'video', 'type' => 'text', 'rusname' => 'Поле для вставки HTML-кода видео', 'rows' => 10 }, { 'attr' => 'pictures', 'type' => 'images', 'rusname' => 'Список картинок', preview => ['300x300','250x250','200x200','150x150','120x120','100x100'] }, ) } sub class_name { return 'Запись блога'; } sub class_description { return 'Запись блога'; } sub class_table { return 'blogs::SQL::RecordsTable'; } sub contenido_status_style { my $self = shift; if ( $self->status == 2 ) { return 'color:green;'; } elsif ( $self->status == 3 ) { return 'color:olive;'; } elsif ( $self->status == 4 ) { return 'color:green;'; } elsif ( $self->status == 5 ) { return 'color:red;'; } } sub search_fields { return ('tags', 'name'); } sub table_links { return [ { name => 'Комменты', class => 'blogs::Comment', filter => 'record_id', field => 'record_id' }, ]; } sub pre_store { my $self = shift; if ( !$self->id && !$self->uid ) { if ( ref $session && exists $session->{id} && $session->{id} ) { $self->uid( $session->{id} ); } elsif ( ref $user ) { $self->uid( $user->id ); } } my $default_section = $project->s_alias->{blog_records} if ref $project->s_alias eq 'HASH' && exists $project->s_alias->{blog_records}; if ( $default_section ) { my $sections = $self->{sections}; if ( ref $sections eq 'ARRAY' && scalar @$sections ) { my @new_sects = grep { $_ != $default_section } @$sections; push @new_sects, $default_section; $self->sections(@new_sects); } elsif ( $sections && !ref $sections && $sections != $default_section ) { my @new_sects = ($default_section, $sections); $self->sections(@new_sects); } else { $self->sections($default_section); } } return 1; } sub post_store { my $self = shift; my @links = $self->keeper->get_links( class => 'blogs::TagCloud', dest_id => $self->id, ); foreach my $link ( @links ) { $link->delete(); } if ( $self->tags ) { my @tags = map { encode('utf-8', lc($_)) } split /[\t\ ]*,[\t\ ]*/, decode("utf-8", $self->tags); foreach my $tag ( @tags ) { my ($tid) = $self->keeper->get_documents( name => $tag, ilike => 1, class => 'blogs::Tag', ids => 1, limit => 1, ); unless ( $tid ) { my $tobj = blogs::Tag->new( $self->keeper ); $tobj->name( $tag ); $tobj->status( 1 ); $tobj->store; $tid = $tobj->id; } my $link = blogs::TagCloud->new( $keeper ); $link->status( 1 ); $link->source_id( $tid ); $link->source_class( 'blogs::Tag' ); $link->dest_id( $self->id ); $link->dest_class( $self->class ); $link->store; } } 1; } sub pre_delete { my $self = shift; my $comments_db_table = blogs::SQL::CommentsTable->db_table; my $sthcom = $self->keeper->SQL->prepare( "delete from $comments_db_table where record_id = ?" ); $sthcom->execute( $self->id ); $sthcom->finish; my $tags_db_table = blogs::SQL::TagsTable->db_table; my $sthtag = $self->keeper->SQL->prepare( "delete from $comments_db_table where dest_id = ? and dest_class = ?" ); $sthtag->execute( $self->id, $self->class ); $sthtag->finish; 1; } 1;