r31711@martha (orig r1246): groditi | 2009-10-02 17:01:17 -0400
[catagits/Reaction.git] / lib / Reaction / UI / ViewPort / Field / Role / Mutable / Simple.pm
1 package Reaction::UI::ViewPort::Field::Role::Mutable::Simple;
2
3 use MooseX::Role::Parameterized;
4
5 use aliased 'Reaction::UI::ViewPort::Field::Role::Mutable';
6
7 use namespace::clean -except => [ qw(meta) ];
8
9 parameter value_type => (
10     predicate => 'has_value_type'
11 );
12
13 role {
14
15 my $p = shift;
16
17 with Mutable, $p->has_value_type ? { value_type => $p->value_type } : ();
18
19 has value_string => (
20   is => 'rw', lazy_build => 1, trigger => sub { shift->adopt_value_string },
21   clearer => 'clear_value',
22 );
23
24 has '+is_modified' => (default => 0);
25
26 around value_string => sub {
27   my $orig = shift;
28   my $self = shift;
29   if (@_) {
30     # recursive call. be VERY careful we don't go infinite here
31     my $old = $self->value_string;
32     my $new = $_[0];
33     if ((defined $old xor defined $new) || (defined $old && $old ne $new)) {
34       $self->_set_modified(1);
35     } else {
36       return;
37     }
38   }
39   if (@_ && defined($_[0]) && !ref($_[0]) && $_[0] eq ''
40       && !$self->value_is_required) {
41     $self->clear_value;
42     return undef;
43   }
44   return $self->$orig(@_);
45 };
46
47 # the user needs to implement this because, honestly, you're always going
48 # to need to do something custom and the only common thing really is
49 # "you probably set $self->value at the end"
50 requires 'adopt_value_string';
51
52 around accept_events => sub { ('value_string', shift->(@_)) };
53
54 around force_events => sub { (value_string => '', shift->(@_)) };
55
56 };
57
58 1;