/[Frey]/trunk/lib/Frey/Class/Browser.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/Class/Browser.pm

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

revision 545 by dpavlin, Wed Nov 26 20:47:13 2008 UTC revision 582 by dpavlin, Fri Nov 28 13:18:18 2008 UTC
# Line 4  use Moose; Line 4  use Moose;
4  extends 'Frey::ClassLoader';  extends 'Frey::ClassLoader';
5  with 'Frey::Web';  with 'Frey::Web';
6  with 'Frey::Session';  with 'Frey::Session';
7    with 'Frey::Web::CombineImages';
8    
9  use Frey::Run;  use Frey::Run;
10  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
# Line 18  has 'usage_on_top' => ( Line 19  has 'usage_on_top' => (
19  sub as_markup {  sub as_markup {
20          my $self = shift;          my $self = shift;
21          my $row;          my $row;
22            my @icons;
23    
24          my $usage = $self->session_dump( $self->usage );          my $usage = $self->session_dump( $self->usage );
25          #warn "# usage ",dump( $usage );          #warn "# usage ",dump( $usage );
26          foreach my $class ( $self->classes ) {          foreach my $class ( $self->classes ) {
27    
28                  my $icon = '';                  my $icon = '';
29                  if ( $self->can('icon_path') ) {                  if ( ! $self->can('icon_path') ) {
30                          $icon = $self->icon_path( $class );                          $self->TODO( "re-apply Frey::Web on $self" );
31                          $icon = qq|<img src="/$icon" alt="$class">| if $icon;                          Frey::Web->meta->apply( $self );
32                    }
33                    $icon = $self->icon_path( $class );
34                    if ($icon) {
35                            push @icons, $icon;
36                            $icon = qq|<!-- icon:$icon -->|;
37                  } else {                  } else {
38                          #warn "## $self doesn't know how to return icon_path";                          $icon = '';
39                  }                  }
40    
41                  my $html                  my $html
# Line 45  sub as_markup { Line 52  sub as_markup {
52                  }                  }
53    
54                  my @run = map {                  my @run = map {
55                            my $invoke = $_;
56                          s{^as_}{};                          s{^as_}{};
57                          qq|<a target="$class" href="/$class/as_$_" title="$class->as_$_">$_</a>|;                          s{_as_\w+}{};
58                            qq|<a target="$class" href="/$class/$invoke" title="$class->$invoke">$_</a>|;
59                  } $self->class_runnable( $class );                  } $self->class_runnable( $class );
60                  push @run, qq|<a target="$class" href="/Frey-ObjectBrowser?class=$class">collection</a>| if $class->can('collection_table');                  push @run, qq|<a target="$class" href="/Frey-ObjectBrowser?class=$class">collection</a>| if $class->can('collection_table');
61    
# Line 65  sub as_markup { Line 74  sub as_markup {
74                  $row->{$class} = $html;                  $row->{$class} = $html;
75          }          }
76    
77            my $icons_html = $self->combine_images( @icons );
78            sub icon {
79                    my ($icons_html,$path) = @_;
80                    $icons_html->{ $path } || die "can't find $path in ",dump($icons_html);
81            };
82    
83          return          return
84                  qq|<table>| . join("\n",                  qq|<table>| . join("\n",
85                          map { $row->{$_} }                          map {
86                                    my $html = $row->{$_};
87                                    $html =~ s{<!-- icon:(\S+) -->}{icon($icons_html,$1)}gse;
88                                    $html;
89                            }
90                          sort {                          sort {
91                                  if ( $usage->{$a} || $usage->{$b} ) {                                  if ( $usage->{$a} || $usage->{$b} ) {
92                                          $self->usage_on_top ? $usage->{$b} <=> $usage->{$a} : $usage->{$a} <=> $usage->{$b};                                          $self->usage_on_top ? $usage->{$b} <=> $usage->{$a} : $usage->{$a} <=> $usage->{$b};

Legend:
Removed from v.545  
changed lines
  Added in v.582

  ViewVC Help
Powered by ViewVC 1.1.26