1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
|
package HTML::FormFu::Element::Label;
use Moose;
use MooseX::Attribute::Chained;
extends "HTML::FormFu::Element";
with 'HTML::FormFu::Role::Element::Field',
'HTML::FormFu::Role::Element::SingleValueField' => { -excludes => 'nested_name' },
'HTML::FormFu::Role::Element::Coercible';
use HTML::FormFu::Util qw( process_attrs );
use List::MoreUtils qw( none );
has field_type => ( is => 'rw', traits => ['Chained'] );
has label_filename => ( is => 'rw', traits => ['Chained'] );
has tag => (
is => 'rw',
default => 'span',
lazy => 1,
traits => ['Chained'],
);
after BUILD => sub {
my $self = shift;
$self->filename('label_tag');
$self->non_param(1);
#$self->field_type('label');
$self->model_config->{read_only} = 1;
return;
};
sub string {
my ( $self, $args ) = @_;
$args ||= {};
my $render
= exists $args->{render_data}
? $args->{render_data}
: $self->render_data;
# field wrapper template - start
my $html = $self->_string_field_start($render);
# input_tag template
$html .= $self->_string_field($render);
# field wrapper template - end
$html .= $self->_string_field_end($render);
return $html;
}
sub _string_field {
my ( $self, $render ) = @_;
my $html .= "<" . $self->tag;
$html .= sprintf "%s", process_attrs( $render->{attributes} || {} );
if ( defined $render->{nested_name} ) {
$html .= sprintf qq{ name="%s"}, $render->{nested_name};
}
$html .= ">";
if ( defined $render->{value} ) {
$html .= sprintf qq{%s}, $render->{value};
}
$html .= "</" . $self->tag . ">";
return $html;
}
sub process_input {
my ( $self, $input ) = @_;
my $form = $self->form;
my $name = $self->nested_name;
if ( $form->submitted
&& $form->nested_hash_key_exists( $input, $name ) )
{
my @fields = @{ $form->get_fields({ nested_name => $name }) };
if ( none { $_ == $self } @fields ) {
$form->delete_nested_hash_key( $input, $name );
}
}
return;
}
sub render_data_non_recursive {
my ( $self, $args ) = @_;
my $render = $self->SUPER::render_data_non_recursive( {
tag => $self->tag,
$args ? %$args : (),
} );
return $render;
}
__PACKAGE__->meta->make_immutable;
1;
__END__
=head1 NAME
HTML::FormFu::Element::Label - field for displaying only
=head1 DESCRIPTION
This element displays a value. This is useful if you use a model like
L<HTML::FormFu::Model::DBIC> and want to display a value from the database.
The value of this field cannot be set by the client.
See L<HTML::FormFu::Model::DBIC/"Set a field read only"> for more information
on read only fields.
=head1 METHODS
=head2 tag
Set the tag for this element.
=head1 SEE ALSO
Is a sub-class of, and inherits methods from
L<HTML::FormFu::Element::_Field>, L<HTML::FormFu::Element>
L<HTML::FormFu>
=head1 AUTHOR
Moritz Onken, C<< onken at houseofdesign.de >>
=head1 LICENSE
This library is free software, you can redistribute it and/or modify it under
the same terms as Perl itself.
|