509d673f10
Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com> Signed-off-by: Paul Poulain <paul.poulain@biblibre.com>
169 lines
4.5 KiB
Perl
169 lines
4.5 KiB
Perl
package C4::NewsChannels;
|
|
|
|
# Copyright 2000-2002 Katipo Communications
|
|
#
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 2 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with Koha; if not, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use C4::Context;
|
|
use C4::Dates qw(format_date);
|
|
|
|
use vars qw($VERSION @ISA @EXPORT);
|
|
|
|
BEGIN {
|
|
$VERSION = 3.07.00.049; # set the version for version checking
|
|
@ISA = qw(Exporter);
|
|
@EXPORT = qw(
|
|
&GetNewsToDisplay
|
|
&add_opac_new &upd_opac_new &del_opac_new &get_opac_new &get_opac_news
|
|
);
|
|
}
|
|
|
|
=head1 NAME
|
|
|
|
C4::NewsChannels - Functions to manage OPAC and intranet news
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
This module provides the functions needed to mange OPAC and intranet news.
|
|
|
|
=head1 FUNCTIONS
|
|
|
|
=cut
|
|
|
|
sub add_opac_new {
|
|
my ($title, $new, $lang, $expirationdate, $timestamp, $number) = @_;
|
|
my $dbh = C4::Context->dbh;
|
|
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, $timestamp,$number) = @_;
|
|
my $dbh = C4::Context->dbh;
|
|
my $sth = $dbh->prepare("
|
|
UPDATE opac_news SET
|
|
title = ?,
|
|
new = ?,
|
|
lang = ?,
|
|
expirationdate = ?,
|
|
timestamp = ?,
|
|
number = ?
|
|
WHERE idnew = ?
|
|
");
|
|
$sth->execute($title, $new, $lang, $expirationdate, $timestamp,$number,$idnew);
|
|
$sth->finish;
|
|
return 1;
|
|
}
|
|
|
|
sub del_opac_new {
|
|
my ($ids) = @_;
|
|
if ($ids) {
|
|
my $dbh = C4::Context->dbh;
|
|
my $sth = $dbh->prepare("DELETE FROM opac_news WHERE idnew IN ($ids)");
|
|
$sth->execute();
|
|
$sth->finish;
|
|
return 1;
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
sub get_opac_new {
|
|
my ($idnew) = @_;
|
|
my $dbh = C4::Context->dbh;
|
|
my $sth = $dbh->prepare("SELECT * FROM opac_news WHERE idnew = ?");
|
|
$sth->execute($idnew);
|
|
my $data = $sth->fetchrow_hashref;
|
|
$data->{$data->{'lang'}} = 1 if defined $data->{lang};
|
|
$data->{expirationdate} = format_date($data->{expirationdate});
|
|
$data->{timestamp} = format_date($data->{timestamp});
|
|
$sth->finish;
|
|
return $data;
|
|
}
|
|
|
|
sub get_opac_news {
|
|
my ($limit, $lang) = @_;
|
|
my $dbh = C4::Context->dbh;
|
|
my $query = "SELECT *, timestamp AS newdate FROM opac_news";
|
|
if ($lang) {
|
|
$query.= " WHERE lang = '" .$lang ."' ";
|
|
}
|
|
$query.= " ORDER BY timestamp DESC ";
|
|
#if ($limit) {
|
|
# $query.= "LIMIT 0, " . $limit;
|
|
#}
|
|
my $sth = $dbh->prepare($query);
|
|
$sth->execute();
|
|
my @opac_news;
|
|
my $count = 0;
|
|
while (my $row = $sth->fetchrow_hashref) {
|
|
if ((($limit) && ($count < $limit)) || (!$limit)) {
|
|
$row->{'newdate'} = format_date($row->{'newdate'});
|
|
$row->{'expirationdate'} = format_date($row->{'expirationdate'});
|
|
push @opac_news, $row;
|
|
}
|
|
$count++;
|
|
}
|
|
return ($count, \@opac_news);
|
|
}
|
|
|
|
=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 {
|
|
my $lang = shift;
|
|
my $dbh = C4::Context->dbh;
|
|
# SELECT *,DATE_FORMAT(timestamp, '%d/%m/%Y') AS newdate
|
|
my $query = "
|
|
SELECT *,timestamp AS newdate
|
|
FROM opac_news
|
|
WHERE (
|
|
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 $sth = $dbh->prepare($query);
|
|
$sth->execute($lang);
|
|
my @results;
|
|
while ( my $row = $sth->fetchrow_hashref ){
|
|
$row->{newdate} = format_date($row->{newdate});
|
|
push @results, $row;
|
|
}
|
|
return \@results;
|
|
}
|
|
|
|
1;
|
|
__END__
|
|
|
|
=head1 AUTHOR
|
|
|
|
TG
|
|
|
|
=cut
|