}
);
+ my $patron = Koha::Patrons->find( $borrowernumber );
+ my $user_email = $patron->first_valid_email_address;
my $contents = $shelf->get_contents;
- my $marcflavour = C4::Context->preference('marcflavour');
+ my @biblionumbers;
my $iso2709;
- my @results;
while ( my $content = $contents->next ) {
- my $biblionumber = $content->biblionumber;
- my $biblio = Koha::Biblios->find( $biblionumber ) or next;
- my $dat = $biblio->unblessed;
- my $record = $biblio->metadata->record({ embed_items => 1 });
- my $marcauthorsarray = $biblio->get_marc_contributors;
- my $marcsubjctsarray = GetMarcSubjects( $record, $marcflavour );
-
- my $items = $biblio->items->search_ordered;
-
- $dat->{ISBN} = GetMarcISBN($record, $marcflavour);
- $dat->{MARCSUBJCTS} = $marcsubjctsarray;
- $dat->{MARCAUTHORS} = $marcauthorsarray;
- $dat->{'biblionumber'} = $biblionumber;
- $dat->{ITEM_RESULTS} = $items;
- $dat->{HASAUTHORS} = $dat->{'author'} || @$marcauthorsarray;
- my ( $host, $relatedparts ) = $biblio->get_marc_host;
- $dat->{HOSTITEMENTRIES} = $host;
- $dat->{RELATEDPARTS} = $relatedparts;
-
- $iso2709 .= $record->as_usmarc();
-
- push( @results, $dat );
- }
-
- $template2->param(
- BIBLIO_RESULTS => \@results,
- comment => $comment,
- shelfname => $shelf->shelfname,
- );
-
- # Getting template result
- my $template_res = $template2->output();
- my $body;
-
- my $subject;
- # Analysing information and getting mail properties
- if ( $template_res =~ /<SUBJECT>(?<subject>.*)<END_SUBJECT>/s ) {
- $subject = $+{subject};
- $subject =~ s|\n?(.*)\n?|$1|;
- }
- else {
- $subject = "no subject";
- }
-
- my $email_header = "";
- if ( $template_res =~ /<HEADER>(.*)<END_HEADER>/s ) {
- $email_header = $1;
- $email_header =~ s|\n?(.*)\n?|$1|;
- }
+ push @biblionumbers, $content->biblionumber;
+ my $biblio = Koha::Biblios->find($content->biblionumber);
+ $iso2709 .= $biblio->metadata->record->as_usmarc();
+ };
- if ( $template_res =~ /<MESSAGE>(.*)<END_MESSAGE>/s ) {
- $body = $1;
- $body =~ s|\n?(.*)\n?|$1|;
- }
+ if ( !defined $iso2709 ) {
+ carp "Error sending mail: empty basket";
+ $template->param( error => 1 );
+ } elsif ( !defined $user_email or $user_email eq '' ) {
+ carp "Error sending mail: sender's email address is invalid";
+ $template->param( error => 1 );
+ } else {
+ my %loops = (
+ biblio => \@biblionumbers,
+ );
- my $THE_body = <<END_OF_BODY;
-$email_header
-$body
-END_OF_BODY
-
- try {
- my $email = Koha::Email->create(
- {
- to => $to_address,
- subject => $subject,
- }
+ my %substitute = (
+ comment => $comment,
+ listname => $shelf->shelfname,
);
- $email->text_body( $THE_body );
- $email->attach(
- Encode::encode("UTF-8", $iso2709),
- content_type => 'application/octet-stream',
- name => 'shelf.iso2709',
- disposition => 'attachment',
+
+ my $letter = C4::Letters::GetPreparedLetter(
+ module => 'catalogue',
+ letter_code => 'LIST',
+ lang => $patron->lang,
+ tables => {
+ borrowers => $borrowernumber,
+ },
+ message_transport_type => 'email',
+ loops => \%loops,
+ substitute => \%substitute,
);
- my $library = Koha::Patrons->find( $borrowernumber )->library;
- $email->send_or_die({ transport => $library->smtp_server->transport });
- $template->param( SENT => "1" );
+ my $attachment = {
+ filename => 'shelf.iso2709',
+ type => 'application/octet-stream',
+ content => Encode::encode("UTF-8", $iso2709),
+ };
+
+ C4::Letters::EnqueueLetter({
+ letter => $letter,
+ message_transport_type => 'email',
+ borrowernumber => $patron->borrowernumber,
+ to_address => $to_address,
+ reply_address => $user_email,
+ attachments => [$attachment],
+ });
+
+ $template->param( SENT => 1 );
}
- catch {
- carp "Error sending mail: $_";
- $template->param( error => 1 );
- };
$template->param( email => $to_address );
output_html_with_http_headers $query, $cookie, $template->output;