use vars qw($VERSION @ISA @EXPORT);
BEGIN {
- $VERSION = 3.00; # set the version for version checking
+ $VERSION = 3.01; # set the version for version checking
+ @ISA = qw(Exporter);
+ @EXPORT = qw(
+ &GetNewsToDisplay
+ &news_channels &get_new_channel &del_channels &add_channel &update_channel
+ &news_channels_categories &get_new_channel_category &del_channels_categories
+ &add_channel_category &update_channel_category &news_channels_by_category
+ &add_opac_new &upd_opac_new &del_opac_new &get_opac_new &get_opac_news
+ &add_opac_electronic &upd_opac_electronic &del_opac_electronic &get_opac_electronic &get_opac_electronics
+ );
}
=head1 NAME
=head1 FUNCTIONS
-=over 2
-
-=cut
-
-
-@ISA = qw(Exporter);
-@EXPORT = qw(
- &GetNewsToDisplay
- &news_channels &get_new_channel &del_channels &add_channel &update_channel
- &news_channels_categories &get_new_channel_category &del_channels_categories
- &add_channel_category &update_channel_category &news_channels_by_category
- &add_opac_new &upd_opac_new &del_opac_new &get_opac_new &get_opac_news
- &add_opac_electronic &upd_opac_electronic &del_opac_electronic &get_opac_electronic &get_opac_electronics
-);
-
-
-=item news_channels
+=head2 news_channels
($count, @channels) = &news_channels($channel_name, $id_category, $unclassified);
return (scalar(@channels), @channels);
}
-=item news_channels_by_category
+=head2 news_channels_by_category
($count, @results) = &news_channels_by_category();
Additionally the last index of results has a reference to all the news channels which don't have a category
+=back
+
=cut
sub news_channels_by_category {
}
sub add_opac_new {
- my ($title, $new, $lang, $expirationdate, $number) = @_;
+ my ($title, $new, $lang, $expirationdate, $timestamp, $number) = @_;
my $dbh = C4::Context->dbh;
- my $sth = $dbh->prepare("INSERT INTO opac_news (title, new, lang, expirationdate, number) VALUES (?,?,?,?,?)");
- $sth->execute($title, $new, $lang, $expirationdate, $number);
+ my $sth = $dbh->prepare("INSERT INTO opac_news (title, new, lang, expirationdate, timestamp, number) VALUES (?,?,?,?,?,?)");
+ $sth->execute($title, $new, $lang, $expirationdate, $timestamp, $number);
$sth->finish;
return 1;
}
sub upd_opac_new {
- my ($idnew, $title, $new, $lang, $expirationdate, $number) = @_;
+ my ($idnew, $title, $new, $lang, $expirationdate, $timestamp,$number) = @_;
my $dbh = C4::Context->dbh;
my $sth = $dbh->prepare("
UPDATE opac_news SET
new = ?,
lang = ?,
expirationdate = ?,
+ timestamp = ?,
number = ?
WHERE idnew = ?
");
- $sth->execute($title, $new, $lang, $expirationdate,$number,$idnew);
+ $sth->execute($title, $new, $lang, $expirationdate, $timestamp,$number,$idnew);
$sth->finish;
return 1;
}
my $data = $sth->fetchrow_hashref;
$data->{$data->{'lang'}} = 1;
$data->{expirationdate} = format_date($data->{expirationdate});
+ $data->{timestamp} = format_date($data->{timestamp});
$sth->finish;
return $data;
}
}
=head2 GetNewsToDisplay
-
+
$news = &GetNewsToDisplay($lang);
C<$news> is a ref to an array which containts
all news with expirationdate > today or expirationdate is null.
-
+
=cut
sub GetNewsToDisplay {
SELECT *,timestamp AS newdate
FROM opac_news
WHERE (
- expirationdate > CURRENT_DATE()
+ expirationdate >= CURRENT_DATE()
OR expirationdate IS NULL
OR expirationdate = '00-00-0000'
)
+ AND `timestamp` <= CURRENT_DATE()
AND lang = ?
ORDER BY number
"; # expirationdate field is NOT in ISO format?
my $count = 0;
while (my $row = $sth->fetchrow_hashref) {
push @opac_electronic, $row;
-
-
$count++;
}
return ($count,\@opac_electronic);
}
-END { } # module clean-up code here (global destructor)
-=back
+1;
+__END__
=head1 AUTHOR