/[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 184 by dpavlin, Tue Sep 9 23:15:46 2008 UTC revision 348 by dpavlin, Sat Nov 15 23:52:22 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    sub runnable { qw/data markup sponge/ }
24    
25  has 'class' => (  has 'class' => (
26          is => 'rw',          is => 'rw',
27          isa => 'Str',          isa => 'Str',
28          required => 1,          required => 1,
29  );  );
30    
31  use Data::Dump qw/dump/;  has 'params' => (
32            is => 'rw',
33            isa => 'HashRef',
34            default => sub { {} },
35    );
36    
37  sub html {  sub html {
38          my ( $self, $req ) = @_;          my ( $self ) = @_;
39    
         my %params = $req->params;  
40          my $class = $self->class;          my $class = $self->class;
41    
42            $self->load_class( $class );
43    
44          my @required =          my @required =
45                  grep {                  grep {
46                          defined $_ && !defined( $params{$_} )                          defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )
47                  }                  }
48                  map {                  map {
49                          my $attr = $class->meta->get_attribute($_);                          my $attr = $class->meta->get_attribute($_);
50                          $attr->is_required && $_                          $attr->is_required && $attr;
51                  } $class->meta->get_attribute_list;                  } $class->meta->get_attribute_list;
52    
53                  warn "## required = ",dump( @required );          warn "## required = ",dump( map { $_->name } @required ), " for $class";
                 warn "## params = ",dump( %params );  
54    
55          my $html;          my $html;
56            my $values = {};
57            $values = $self->config($class);
58            warn "# $class config = ",dump( $values );
59    
60          if ( @required ) {          if ( @required ) {
61                  $html = qq|<h1>Required params for $class</h1><form method="post">|;                  $html = qq|<h1>$class params</h1><form method="post">|;
62                  $html .= qq|<label for="$_">$_</label><input type="text" name="$_">| foreach @required;  
63                    my $a;
64                    my @attrs = map {  $a->{$_}++; $_ } $self->attribute_order;
65                    push @attrs, $_ foreach grep { ! $a->{$_} } map { $_->name } @required;
66                    warn "# attrs = ",dump( @attrs );
67    
68                    foreach my $name ( @attrs ) {
69                            my $attr = $class->meta->get_attribute( $name );
70                            my $type = $name =~ m/^pass/ ? 'password' : 'text';
71                            my $value = '';
72                            my $value_html = '';
73                            if ( ref($values) eq 'HASH' ) {
74                                    $value = $values->{$name};
75                            } elsif ( ref($values) eq 'ARRAY' ) {
76                                    $value_html = qq|<select name="$name">| . join("\n",
77                                            map {
78                                                    my $v = $_->{$name};
79                                                    qq|<option value="$v">$v</option>|
80                                            } @$values
81                                    ) . qq|</select>|;
82                            } else {
83                                    $value = $attr->default( $name ) if $attr->has_default;
84                            }
85                            $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;
86    
87    #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );
88                            $html .= qq|<label for="$name">$name</label>| . $value_html;
89                    }
90                  $html .= qq|<input type="submit" value="Run $class"></form>|;                  $html .= qq|<input type="submit" value="Run $class"></form>|;
91          } else {          } else {
92                  my $o = $class->new( %params );                  my $o = $class->new( %{ $self->params } );
93                  $o->depends if $o->can('depends');                  $o->depends if $o->can('depends');
94                  if ( $o->can('html') ) {                  if ( $o->can('markup') ) {
95                          warn "## turning over to $o->html";                          warn "## using ",ref($o), "->markup";
96                          $o->html( $req );                          $html = eval { $o->markup };
97                            if ( $@ ) {
98                                    warn $@;
99                                    $html .= qq{<code>$@</code>};
100                            }
101                            warn ">>> markup $class ",length( $html ), " bytes\n";
102                    } elsif ( $o->can('sponge') ) {
103                            my $data = $o->sponge;
104                            $html .= '<table>';
105                            $html .= '<tr><th>' . join('</th><th>', @{$data->{NAME}} ) . '</th></tr>';
106                            $html .= '<tr><td>' . join('</td><td>', @$_ ) . '</td></tr>' foreach @{ $data->{rows} };
107                            $html .= '</table>';
108                    } elsif ( $o->can('data') ) {
109                            my $data = $o->data;
110                            $html .= Frey::Dumper->new( data => $data )->markup;
111                            $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';
112                  } else {                  } else {
113                          warn "## using $o->markup";                          $html = "IGNORE: $class ", $o->dump;
114                          $html = $o->markup;                          warn $html;
115                  }                  }
116          }          }
117    
118          warn ">>> markup $class ",length( $html ), " bytes\n";          return $self->page( title => $class, body => $html );
         $req->print( $self->page( title => $class, body => $html ) );  
119  }  }
120    
121  1;  1;

Legend:
Removed from v.184  
changed lines
  Added in v.348

  ViewVC Help
Powered by ViewVC 1.1.26