package Gapp::ComboBox; { $Gapp::ComboBox::VERSION = '0.481'; } use Moose; use MooseX::SemiAffordanceAccessor; use Gapp::CellRenderer; use Gapp::Types qw( GappCellRenderer ); extends 'Gapp::Widget'; with 'Gapp::Meta::Widget::Native::Role::FormField'; use Gapp::Model::SimpleList; has '+gclass' => ( default => 'Gtk2::ComboBox', ); has 'data_column' => ( is => 'rw', isa => 'Int|Undef', default => 0, ); has 'data_func' => ( is => 'rw', isa => 'Str|CodeRef|Undef', ); has 'model' => ( is => 'rw', isa => 'Maybe[Object]', default => sub { Gapp::Model::SimpleList->new }, ); has 'renderer' => ( is => 'rw', isa => GappCellRenderer, default => sub { Gapp::CellRenderer->new( gclass => 'Gtk2::CellRendererText', property => 'markup' ) }, coerce => 1, ); has 'values' => ( is => 'rw', isa => 'ArrayRef|CodeRef|Undef', ); # returns the value of the widget sub get_field_value { my $self = shift; my $iter = $self->gobject->get_active_iter; return undef if ! $iter; my $value = $self->gobject->get_model->get( $iter, $self->data_column ); return $value; } # sets the value of the widget sub set_field_value { my ( $self, $value ) = @_; # clear widget if no value if ( ! defined $value ) { $self->gobject->set_active( -1 ); } # find value and set appropriately else { $self->gobject->get_model->foreach( sub{ my ( $model, $path, $iter ) = @_; my $check_value = $model->get( $iter, $self->data_column ); if ( ! defined $value && defined $check_value || defined $value && ! defined $check_value ) { return; } elsif ( ! defined $value && ! defined $check_value || $value eq $check_value ) { $self->gobject->set_active_iter( $iter ); return 1; } }); } } sub widget_to_stash { my ( $self, $stash ) = @_; $stash->store( $self->field, $self->get_field_value ); } sub stash_to_widget { my ( $self, $stash ) = @_; $self->set_field_value( $stash->fetch( $self->field ) ); } sub _connect_changed_handler { my ( $self ) = @_; $self->gobject->signal_connect ( changed => sub { $self->_widget_value_changed }, ); } 1; __END__ =pod =head1 NAME Gapp::ComboBox - ComboBox Widget =head1 OBJECT HIERARCHY =over 4 =item L<Gapp::Widget> =item +-- L<Gapp::ComboBox> =back =head2 Traits =over 4 =item L<Gapp::Meta::Widget::Native::Role::FormField> =back =head1 SYNOPSIS # basic combo-box Gapp::ComboBox->new( values => [ '', 'Option1', 'Option 2', 'Option 3' ], ); # in this example the combo is populated with array-refs # the text is displayed to the user, and and the integer # can be referenced for programmer user Gapp::ComboBox->new( values => [ [ 0, ' ' ], [ 1, 'Option 1' ], [ 2, 'Option 2' ], [ 3, 'Option 3' ], ], data_func => sub { $_->[1] }, ); # objects too Gapp::ComboBox->new( values => [ $object1, $object2, $object3 ], data_func => 'label', ); =head1 PROVIDED ATTRIBUTES =over 4 =item B<data_column> =over 4 =item isa Int =item default 0 =back This is the column in the model to the ComboBox will reference by default. The values in the column will appear as options to the user. You can manipulate this value using the C<data_func> attribute. =item B<data_func> =over 4 =item isa Str|CodeRef|Undef =back Use the C<data_func> to manipulate how an entry in the combo is rendered. The value returned by this function will be displayed to the user. C<$_> is set to the value held in the model at C<data_column> for your convienence. =item B<model> =over 4 =item isa Object|Undef =back If specified, sets the model of the C<ComboBox>. =item B<renderer> =over 4 =item isa L<Gapp::CellRenderer> =item default Gapp::CellRenderer->new( gclass => 'Gtk2::CellRendererText', property => 'markup' ); =back Sets the renderer for the C<ComboBox>. =item B<values> =over 4 =item isa ArrayRef|CodeRef|Undef If an C<ArrayRef> is given, the model is populated with the given values. If a C<CodeRef> is given, the model is populated with the return values of the C<CodeRef>. If C<Undef> no values will be added to the model. =back =back =head1 AUTHORS Jeffrey Ray Hallock E<lt>jeffrey.hallock at gmail dot comE<gt> =head1 COPYRIGHT & LICENSE Copyright (c) 2011-2012 Jeffrey Ray Hallock. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut