Projekt

Allgemein

Profil

Herunterladen (1,46 KB) Statistiken
| Zweig: | Markierung: | Revision:
package SL::Presenter::FileObject;

use strict;

use SL::Presenter::Tag qw(link_tag);
use SL::Presenter::EscapedText qw(escape is_escaped);

use Exporter qw(import);
our @EXPORT_OK = qw(file_object);

use Carp;

sub file_object {
my ($file_object, %params) = @_;


my $text = escape($file_object->file_name);
if (! delete $params{no_link}) {
my $href = 'controller.pl?action=File/download&id=' . $file_object->id;
$href .= '&version=' . $file_object->version if $file_object->version;
$text = link_tag($href, $text, %params);
}

is_escaped($text);
}

1;


__END__

=pod

=encoding utf8

=head1 NAME

SL::Presenter::FileObject - Presenter module for SL::File::Object(s), the
file objects of the filemanagement. (Note, that this are not instances of
SL::DB::File)

=head1 SYNOPSIS

my $file_object = SL::File->get(id => 1);
my $html = SL::Presenter::FileObject::file_object($file_object, no_link => 1);

=head1 FUNCTIONS

=over 4

=item C<file_object $file_object, %params>

Returns a rendered version (actually an instance of
L<SL::Presenter::EscapedText>) of the file object
C<$file_object>.

Remaining C<%params> are passed to the function
C<SL::Presenter::Tag::link_tag>. It can include:

=over 2

=item * no_link

If falsish (the default) then the file name of the object will be linked
to the "download action" for that file.

=back

=back

=head1 BUGS

Nothing here yet.

=head1 AUTHOR

Bernd Bleßmann E<lt>bernd@kivitendo-premium.deE<gt>

=cut
(12-12/34)