Merge remote-tracking branch 'origin/new/bug_8585'
[koha.git] / tools / koha-news.pl
index 605a86b..afc5268 100755 (executable)
@@ -2,7 +2,7 @@
 
 # Script to manage the opac news.
 # written 11/04
-# Castañeda, Carlos Sebastian - seba3c@yahoo.com.ar - Physics Library UNLP Argentina
+# Castaeda, Carlos Sebastian - seba3c@yahoo.com.ar - Physics Library UNLP Argentina
 # Modified to include news to KOHA intranet - tgarip@neu.edu.tr NEU library -Cyprus
 # Copyright 2000-2002 Katipo Communications
 #
 # 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., 59 Temple Place,
-# Suite 330, Boston, MA  02111-1307 USA
+# 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; FIXME - Bug 2505
 use CGI;
-
 use C4::Auth;
 use C4::Koha;
 use C4::Context;
+use C4::Dates qw(format_date_in_iso);
 use C4::Output;
-use C4::Interface::CGI::Output;
 use C4::NewsChannels;
-
+use C4::Languages qw(getTranslatedLanguages);
+use Date::Calc qw/Date_to_Days Today/;
 
 my $cgi = new CGI;
 
-my $id         = $cgi->param('id');
-my $title      = $cgi->param('title');
-my $new                = $cgi->param('new');
-my $lang       = $cgi->param('lang');
+my $id             = $cgi->param('id');
+my $title          = $cgi->param('title');
+my $new            = $cgi->param('new');
+my $expirationdate = format_date_in_iso($cgi->param('expirationdate'));
+my $timestamp      = format_date_in_iso($cgi->param('timestamp'));
+my $number         = $cgi->param('number');
+my $lang           = $cgi->param('lang');
+
 my $new_detail = get_opac_new($id);
 
-my ($template, $borrowernumber, $cookie)
-    = get_template_and_user({template_name => "tools/koha-news.tmpl",
-                            query => $cgi,
-                            type => "intranet",
-                            authnotrequired => 0,
-                            flagsrequired => {management => 1},
-                            debug => 1,
-                            });
+my ( $template, $borrowernumber, $cookie ) = get_template_and_user(
+    {
+        template_name   => "tools/koha-news.tmpl",
+        query           => $cgi,
+        type            => "intranet",
+        authnotrequired => 0,
+        flagsrequired   => { tools => 'edit_news' },
+        debug           => 1,
+    }
+);
 
 # get lang list
 my @lang_list;
-
-foreach my $language (getalllanguages()) {
-       push @lang_list, { language => $language,
-                                               selected => ($new_detail->{lang} eq $language?1:0),
-                                       };
+my $tlangs = getTranslatedLanguages() ;
+foreach my $language ( @$tlangs ) {
+    push @lang_list,
+      {
+        language => $language->{'rfc4646_subtag'},
+        selected => ( $new_detail->{lang} eq $language->{'rfc4646_subtag'} ? 1 : 0 ),
+      };
 }
-$template->param(lang_list => \@lang_list);
-
-my $op = $cgi->param('op');
-
-if ($op eq 'add_form') {
-       $template->param(add_form => 1);
-       if ($id) {
-               $template->param(op => 'edit');
-               $template->param($new_detail);
-               $template->param(id => $new_detail->{'idnew'});
-       } else {
-               $template->param(op => 'add');
-       }
-       
-} elsif ($op eq 'add') {
-
-       add_opac_new($title, $new, $lang);
-       print $cgi->redirect('/cgi-bin/koha/tools/koha-news.pl');
 
-} elsif ($op eq 'edit') {
+$template->param( lang_list => \@lang_list );
 
-       upd_opac_new($id, $title, $new, $lang);
-       print $cgi->redirect('/cgi-bin/koha/tools/koha-news.pl');
-
-} elsif ($op eq 'del') {
-       my @ids = $cgi->param('ids');
-       del_opac_new(join ",", @ids);
-       print $cgi->redirect('/cgi-bin/koha/tools/koha-news.pl');
-
-} else { 
-
-       my ($opac_news_count, $opac_news) = &get_opac_news(undef, $lang);
-       $template->param($lang => 1);
-       $template->param(opac_news => $opac_news);
-       $template->param(opac_news_count => $opac_news_count);
+my $op = $cgi->param('op');
 
+if ( $op eq 'add_form' ) {
+    $template->param( add_form => 1 );
+    if ($id) {
+        if($new_detail->{lang} eq "slip"){ $template->param( slip => 1); }
+        $template->param( 
+            op => 'edit',
+            id => $new_detail->{'idnew'}
+        );
+        $template->{VARS}->{'new_detail'} = $new_detail;
+    }
+    else {
+        $template->param( op => 'add' );
+    }
+}
+elsif ( $op eq 'add' ) {
+    add_opac_new( $title, $new, $lang, $expirationdate, $timestamp, $number );
+    print $cgi->redirect("/cgi-bin/koha/tools/koha-news.pl");
+}
+elsif ( $op eq 'edit' ) {
+    upd_opac_new( $id, $title, $new, $lang, $expirationdate, $timestamp ,$number );
+    print $cgi->redirect("/cgi-bin/koha/tools/koha-news.pl");
+}
+elsif ( $op eq 'del' ) {
+    my @ids = $cgi->param('ids');
+    del_opac_new( join ",", @ids );
+    print $cgi->redirect("/cgi-bin/koha/tools/koha-news.pl");
 }
 
+else {
+
+    my ( $opac_news_count, $opac_news ) = &get_opac_news( undef, $lang );
+    
+    foreach my $new ( @$opac_news ) {
+        next unless $new->{'expirationdate'};
+               #$new->{'expirationdate'}=format_date_in_iso($new->{'expirationdate'});
+        my @date = split (/-/,$new->{'expirationdate'});
+        if ($date[0]*$date[1]*$date[2]>0 && Date_to_Days( @date ) < Date_to_Days(&Today) ){
+                       $new->{'expired'} = 1;
+        }
+    }
+    
+    $template->param(
+        $lang           => 1,
+        opac_news       => $opac_news,
+        opac_news_count => $opac_news_count,
+               );
+}
+$template->param(
+                               DHTMLcalendar_dateformat =>  C4::Dates->DHTMLcalendar(),
+                               dateformat    => C4::Context->preference("dateformat"),
+               );
 output_html_with_http_headers $cgi, $cookie, $template->output;