Bug 18426: Allow to edit subscriptions in batch
[koha.git] / serials / subscription-batchedit.pl
1 #!/usr/bin/perl
2
3 # Copyright 2017 BibLibre
4 #
5 # This file is part of Koha.
6 #
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
11 #
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
16 #
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
19
20 use Modern::Perl;
21
22 use CGI qw( -utf8 );
23
24 use C4::Auth;
25 use C4::Output;
26 use Koha::Subscriptions;
27 use Koha::Acquisition::Booksellers;
28 use Koha::AdditionalField;
29 use Koha::DateUtils;
30
31 my $cgi = new CGI;
32
33 my ($template, $loggedinuser, $cookie) = get_template_and_user({
34     template_name => 'serials/subscription-batchedit.tt',
35     query => $cgi,
36     type => 'intranet',
37     authnotrequired => 0,
38     flagsrequired => {serials => 'edit_subscription'},
39 });
40
41 my @subscriptionids = $cgi->multi_param('subscriptionid');
42
43 my @subscriptions;
44 foreach my $subscriptionid (@subscriptionids) {
45     my $subscription = Koha::Subscriptions->find($subscriptionid);
46
47     push @subscriptions, $subscription if $subscription;
48 }
49
50 my $additional_fields = Koha::AdditionalField->all({tablename => 'subscription'});
51
52 my $batchedit = $cgi->param('batchedit');
53 if ($batchedit) {
54     my %params = (
55         aqbooksellerid => scalar $cgi->param('booksellerid'),
56         location => scalar $cgi->param('location'),
57         branchcode => scalar $cgi->param('branchcode'),
58         itemtype => scalar $cgi->param('itemtype'),
59         notes => scalar $cgi->param('notes'),
60         internalnotes => scalar $cgi->param('internalnotes'),
61         serialsadditems => scalar $cgi->param('serialsadditems'),
62         enddate => dt_from_string(scalar $cgi->param('enddate')),
63     );
64
65     my $field_values = {};
66     foreach my $field (@$additional_fields) {
67         my $value = $cgi->param('field_' . $field->{id});
68         $field_values->{$field->{id}} = $value;
69     }
70
71     foreach my $subscription (@subscriptions) {
72         while (my ($key, $value) = each %params) {
73             if (defined $value and $value ne '') {
74                 $subscription->$key($value);
75             }
76         }
77
78         foreach my $field (@$additional_fields) {
79             my $value = $field_values->{$field->{id}};
80             if (defined $value and $value ne '') {
81                 $field->{values} //= {};
82                 $field->{values}->{$subscription->subscriptionid} = $value;
83             }
84         }
85
86         $subscription->store;
87     }
88
89     foreach my $field (@$additional_fields) {
90         if (defined $field->{values}) {
91             $field->insert_values();
92         }
93     }
94
95     my $redirect_url = $cgi->param('referrer') // '/cgi-bin/koha/serials/serials-home.pl';
96     print $cgi->redirect($redirect_url);
97     exit;
98 }
99
100 $template->param(
101     subscriptions => \@subscriptions,
102     booksellers => [ Koha::Acquisition::Booksellers->search() ],
103     additional_fields => $additional_fields,
104     referrer => scalar $cgi->param('referrer'),
105 );
106
107 output_html_with_http_headers $cgi, $cookie, $template->output;