/[Frey]/trunk/lib/Frey/Run.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/lib/Frey/Run.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 204 by dpavlin, Thu Oct 30 22:20:02 2008 UTC revision 358 by dpavlin, Sun Nov 16 16:36:53 2008 UTC
# Line 1  Line 1 
1  package Frey::Run;  package Frey::Run;
2  use Moose;  use Moose;
3  extends 'Frey';  #extends 'Frey::ClassLoader';
4    extends 'Frey::PPI';
5  with 'Frey::Web';  with 'Frey::Web';
6    with 'Frey::Config';
7    with 'Frey::Escape';
8    
9    use Data::Dump qw/dump/;
10    use Frey::Dumper;
11    
12  =head1 NAME  =head1 NAME
13    
14  Frey::Run - display required form field for Class and run it  Frey::Run - display required form field for Class and run it
15    
16    =head1 DESCRIPTION
17    
18    This object will try to run other Moose objects from your application. It
19    will try to invoke C<data>, and C<markup> method on the.
20    
21  =cut  =cut
22    
23    use Moose::Util::TypeConstraints;
24    
25    enum 'Runnable' => qw/data markup sponge/;
26    
27    sub runnable { qw/data markup sponge/ }
28    
29  has 'class' => (  has 'class' => (
30          is => 'rw',          is => 'rw',
31          isa => 'Str',          isa => 'Str',
32          required => 1,          required => 1,
33  );  );
34    
35  use Data::Dump qw/dump/;  has 'params' => (
36            is => 'rw',
37            isa => 'HashRef',
38            default => sub { {} },
39    );
40    
41    has 'run' => (
42            is => 'rw',
43            isa => 'Runnable',
44            default => 'markup',
45    );
46    
47  sub html {  sub html {
48          my ( $self, $req ) = @_;          my ( $self ) = @_;
49    
         my %params = $req->params;  
50          my $class = $self->class;          my $class = $self->class;
51    
52            $self->load_class( $class );
53    
54          my @required =          my @required =
55                  grep {                  grep {
56                          defined $_ && !defined( $params{$_} )                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )
57                  }                  }
58                  map {                  map {
59                          my $attr = $class->meta->get_attribute($_);                          my $attr = $class->meta->get_attribute($_);
60                          $attr->is_required && $_                          $attr->is_required && $attr;
61                  } $class->meta->get_attribute_list;                  } $class->meta->get_attribute_list;
62    
63                  warn "## required = ",dump( @required );          warn "## required = ",dump( map { $_->name } @required ), " for $class";
                 warn "## params = ",dump( %params );  
64    
65          my $html;          my $html;
66            my $values = {};
67            $values = $self->config($class);
68            warn "# $class config = ",dump( $values );
69    
70          if ( @required ) {          if ( @required ) {
71                  $html = qq|<h1>Required params for $class</h1><form method="post">|;                  $html = qq|<h1>$class params</h1><form method="post">|;
72                  $html .= qq|<label for="$_">$_</label><input type="text" name="$_">| foreach @required;  
73                    my $a;
74                    my @attrs = map {  $a->{$_}++; $_ } $self->attribute_order;
75                    push @attrs, $_ foreach grep { ! $a->{$_} } map { $_->name } @required;
76                    warn "# attrs = ",dump( @attrs );
77    
78                    foreach my $name ( @attrs ) {
79                            my $attr = $class->meta->get_attribute( $name );
80                            my $type = $name =~ m/^pass/ ? 'password' : 'text';
81                            my $value = '';
82                            my $value_html = '';
83                            if ( ref($values) eq 'HASH' ) {
84                                    $value = $values->{$name};
85                            } elsif ( ref($values) eq 'ARRAY' ) {
86                                    $value_html = qq|<select name="$name">| . join("\n",
87                                            map {
88                                                    my $v = $_->{$name};
89                                                    qq|<option value="$v">$v</option>|
90                                            } @$values
91                                    ) . qq|</select>|;
92                            } elsif ( $attr->has_type_constraint && $attr->type_constraint->can('values') ) {
93                                    $value_html = qq|<select name="$name">| . join("\n",
94                                            map { qq|<option value="$_">$_</option>| } @{ $attr->type_constraint->values }
95                                    ) . qq|</select>|;
96                            } elsif ( $attr->has_default ) {
97                                    $value = $attr->default( $name );
98                            }
99                            $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;
100    
101    #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );
102                            $html .= qq|<label for="$name">$name</label>| . $value_html;
103                    }
104                  $html .= qq|<input type="submit" value="Run $class"></form>|;                  $html .= qq|<input type="submit" value="Run $class"></form>|;
105          } else {          } else {
106                  my $o = $class->new( %params );                  eval {
107                  $o->depends if $o->can('depends');                          my $o;
108                  if ( $o->can('html') ) {                          $o = $class->new( %{ $self->params } );
109                          warn "## turning over to $o->html";                          $o->depends if $o->can('depends');
110                          $o->html( $req );  
111                  } elsif ( $o->can('markup') ) {                          if ( $self->run eq 'markup' ) {
112                          warn "## using $o->markup";                                  warn "## using ",ref($o), "->markup";
113                          $html = $o->markup;                                  $html = $o->markup;
114                          warn ">>> markup $class ",length( $html ), " bytes\n";                                  warn ">>> markup $class ",length( $html ), " bytes\n";
115                  } else {                          } elsif ( $self->run eq 'sponge' ) {
116                          $html = "IGNORE: $class ", $o->dump;                                  my $data = $o->sponge;
117                          warn $html;                                  confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
118                  }                                  $html .= "<strong>" . $#{ $data->{rows} } . "</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
119                                    $html .= '<table>';
120                                    $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
121                                    $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
122                                    $html .= '</table>';
123                            } elsif ( $self->run eq 'data' ) {
124                                    my $data = $o->data;
125                                    $html .= Frey::Dumper->new( data => $data )->markup;
126                                    $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';
127                            } else {
128                                    $html = $self->error( "IGNORE: $class ", $o->dump );
129                            }
130                    };
131    
132                    $html .= $self->error( $@ ) if $@;
133          }          }
134    
135          $req->print( $self->page( title => $class, body => $html ) );          return $self->page( %$html ) if ref($html) eq 'HASH';
136            return $self->page( title => $class, body => $html );
137  }  }
138    
139  1;  1;

Legend:
Removed from v.204  
changed lines
  Added in v.358

  ViewVC Help
Powered by ViewVC 1.1.26