/[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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 358 - (hide annotations)
Sun Nov 16 16:36:53 2008 UTC (15 years, 5 months ago) by dpavlin
File size: 3817 byte(s)
if markup returns HASH, assume it's arguments for Frey::Web->page
1 dpavlin 180 package Frey::Run;
2     use Moose;
3 dpavlin 331 #extends 'Frey::ClassLoader';
4     extends 'Frey::PPI';
5 dpavlin 180 with 'Frey::Web';
6 dpavlin 222 with 'Frey::Config';
7 dpavlin 225 with 'Frey::Escape';
8 dpavlin 180
9 dpavlin 326 use Data::Dump qw/dump/;
10     use Frey::Dumper;
11    
12 dpavlin 180 =head1 NAME
13    
14     Frey::Run - display required form field for Class and run it
15    
16 dpavlin 206 =head1 DESCRIPTION
17    
18     This object will try to run other Moose objects from your application. It
19 dpavlin 314 will try to invoke C<data>, and C<markup> method on the.
20 dpavlin 206
21 dpavlin 180 =cut
22    
23 dpavlin 349 use Moose::Util::TypeConstraints;
24    
25     enum 'Runnable' => qw/data markup sponge/;
26    
27 dpavlin 339 sub runnable { qw/data markup sponge/ }
28 dpavlin 223
29 dpavlin 180 has 'class' => (
30     is => 'rw',
31     isa => 'Str',
32     required => 1,
33     );
34    
35 dpavlin 277 has 'params' => (
36     is => 'rw',
37     isa => 'HashRef',
38     default => sub { {} },
39     );
40    
41 dpavlin 349 has 'run' => (
42     is => 'rw',
43     isa => 'Runnable',
44 dpavlin 351 default => 'markup',
45 dpavlin 349 );
46    
47 dpavlin 277 sub html {
48     my ( $self ) = @_;
49 dpavlin 180
50     my $class = $self->class;
51    
52 dpavlin 317 $self->load_class( $class );
53    
54 dpavlin 180 my @required =
55     grep {
56 dpavlin 285 defined $_ && $_->can('name') && !defined( $self->params->{ $_->name } )
57 dpavlin 180 }
58     map {
59     my $attr = $class->meta->get_attribute($_);
60 dpavlin 285 $attr->is_required && $attr;
61 dpavlin 180 } $class->meta->get_attribute_list;
62    
63 dpavlin 285 warn "## required = ",dump( map { $_->name } @required ), " for $class";
64 dpavlin 180
65     my $html;
66 dpavlin 277 my $values = {};
67 dpavlin 324 $values = $self->config($class);
68     warn "# $class config = ",dump( $values );
69 dpavlin 180
70     if ( @required ) {
71 dpavlin 331 $html = qq|<h1>$class params</h1><form method="post">|;
72 dpavlin 336
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 dpavlin 331 my $attr = $class->meta->get_attribute( $name );
80 dpavlin 222 my $type = $name =~ m/^pass/ ? 'password' : 'text';
81 dpavlin 348 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 dpavlin 349 } 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 dpavlin 348 }
99     $value_html = qq|<input type="$type" name="$name" value="$value">| unless $value_html;
100    
101 dpavlin 285 #warn "# required $name ", $class->meta->get_attribute( $name )->dump( 2 );
102 dpavlin 348 $html .= qq|<label for="$name">$name</label>| . $value_html;
103 dpavlin 222 }
104 dpavlin 180 $html .= qq|<input type="submit" value="Run $class"></form>|;
105     } else {
106 dpavlin 353 eval {
107     my $o;
108     $o = $class->new( %{ $self->params } );
109     $o->depends if $o->can('depends');
110 dpavlin 351
111 dpavlin 353 if ( $self->run eq 'markup' ) {
112     warn "## using ",ref($o), "->markup";
113     $html = $o->markup;
114     warn ">>> markup $class ",length( $html ), " bytes\n";
115     } elsif ( $self->run eq 'sponge' ) {
116     my $data = $o->sponge;
117     confess "invalid data from sponge = ", dump( $data ) unless ref($data) eq 'HASH';
118 dpavlin 354 $html .= "<strong>" . $#{ $data->{rows} } . "</strong> rows from <code>$class->new" . dump( $self->params ) . "->sponge</code>";
119 dpavlin 351 $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 dpavlin 353 } elsif ( $self->run eq 'data' ) {
124     my $data = $o->data;
125 dpavlin 351 $html .= Frey::Dumper->new( data => $data )->markup;
126     $html .= '<hr/><code>' . $self->html_dump( $data ) . '</code>';
127 dpavlin 353 } else {
128     $html = $self->error( "IGNORE: $class ", $o->dump );
129 dpavlin 351 }
130 dpavlin 353 };
131    
132     $html .= $self->error( $@ ) if $@;
133 dpavlin 180 }
134    
135 dpavlin 358 return $self->page( %$html ) if ref($html) eq 'HASH';
136 dpavlin 277 return $self->page( title => $class, body => $html );
137 dpavlin 180 }
138    
139     1;

  ViewVC Help
Powered by ViewVC 1.1.26