--- trunk/lib/Frey/ObjectBrowser.pm 2008/07/10 15:41:17 83 +++ trunk/lib/Frey/ObjectBrowser.pm 2008/07/13 13:09:56 109 @@ -1,8 +1,14 @@ package Frey::ObjectBrowser; use Moose; -use MooseX::Method; extends 'Frey'; +with 'Frey::Web'; + +has 'fey_class' => ( + is => 'rw', + isa => 'Str', + required => 1, +); my @callbacks; @@ -24,53 +30,89 @@ #use Data::Dumper; #$Data::Dumper::Deparse = 1; use Data::Dump qw/dump/; -use Data::Structure::Util qw(unbless); +use Frey::Web::Row; -#method 'html' => positional( -# isa => 'Continuity::RequestHolder', -# required => 1, -#) => sub { sub html { my ( $self, $req ) = @_; - use Strix::User; - use Strix::View::User; - - my $s = Strix::User->rows(); - #warn "# s = ",dump( $s ); + my $f = { $req->params }; + my $layout = delete( $f->{layout} ) || 'div'; my @w; - while ( my $u = $s->next ) { - my $w = Strix::View::User->new( %{ $u } ); - $w->_fey( $u ); - warn "# w = ",dump( $w ) if $self->debug; - push @w, $w; - } - - my $f = { $req->params }; - while ( 1 ) { - warn "# got $#w elements: ",dump( map { $_->id } @w ); warn "<<< GOT REQUEST ",dump( $f ); - warn "does last element have id? ",dump( $w[$#w]->id ); + # re-apply (changed?) layout to elements + if ( defined $f->{layout} ) { + $layout = delete( $f->{layout} ); + warn "# new layout = $layout\n"; + } - if ( $w[ $#w ]->_fey ) { - warn "+++ added new widget\n"; - push @w, Strix::View::User->new( render_as => 'edit' ); + if ( ! @w || $f->{limit} || $f->{offset} ) { + my $s = $self->fey_class->collection( $f ); + warn "# s ",$self->fey_class," = ",dump( $s ) if $self->debug; + + @w = (); + + while ( my $u = $s->next ) { + my $w = Frey::Web::Row->new( fey_class => $self->fey_class, fey => $u, layout => $layout ); + warn "# w = ",dump( $w ) if $self->debug; + push @w, $w; + } + + warn "# got $#w elements: ",dump( map { $_->id } @w ); } - my $form = join('