]> mj.ucw.cz Git - pciids.git/blobdiff - PciIds/Html/List.pm
imgs do not allow border attribute
[pciids.git] / PciIds / Html / List.pm
index f4fbdb9dfdd5a16dcd481414e2c9ff7f79e88524..b2f3df058e57f9050306c5c4643baf68133236c5 100644 (file)
@@ -1,3 +1,21 @@
+#      PciIds web database
+#      Copyright (C) 2008 Michal Vaner (vorner@ucw.cz)
+#
+#      This program is free software; you can redistribute it and/or modify
+#      it under the terms of the GNU General Public License as published by
+#      he Free Software Foundation; either version 2 of the License, or
+#      (at your option) any later version.
+#
+#      This program is distributed in the hope that it will be useful,
+#      but WITHOUT ANY WARRANTY; without even the implied warranty of
+#      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+#
+#      GNU General Public License for more details.
+#
+#      You should have received a copy of the GNU General Public License
+#      along with this program; if not, write to the Free Software
+#      Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+
 package PciIds::Html::List;
 use strict;
 use warnings;
@@ -22,16 +40,15 @@ sub list( $$$$ ) {
        my( $req, $args, $tables, $auth ) = @_;
        my( $ok, $parent, $name, $note, $address, $mid ) = loadItem( $tables, $req->uri() );
        return NOT_FOUND unless( $ok );
-       my $id = $address->pretty();
-       genHtmlHead( $req, $id, undef );
+       my $id = $address->top()->pretty();
+       genHtmlHead( $req, $id, "<style type='text/css' media='screen,print'>col.id-col { width: ".$address->subIdSize()*1.25."ex; }</style>\n" );
        print "<div class='top'>\n";
-       print '<h1>'.encode( $id ).'</h1>';
        genMenu( $req, $address, $args, $auth, [ [ 'Help', 'help', 'list' ], $address->helpName() ? [ 'ID syntax', 'help', $address->helpName() ] : () ] );
+       print '<div class="bluesquare"><h1>The PCI ID Repository</h1><p class="home">The home of the <code>pci.ids</code> file</div>';
+       print "<div class='clear'></div></div>\n";
        genPath( $req, $address, 0 );
-       print "<div class='clear'></div>\n";
-       print "</div\n>";
-       print htmlDiv( 'name', '<p>'.encode( $name ) ) if defined( $name );
-       print htmlDiv( 'note', '<p>'.encode( $note ) ) if( defined( $note ) );
+       print htmlDiv( 'name', '<p>Name: '.encode( $name ) ) if defined $name && $name ne '';
+       print htmlDiv( 'note', '<p>Note: '.encode( $note ) ) if defined $note && $note ne '';
        my $diss = 0;
        my $history;
        foreach $history ( @{$tables->history( $address->get() )} ) {
@@ -56,27 +73,30 @@ sub list( $$$$ ) {
                print "<p class='time'>".encode( $time )."\n";
                print "</div>\n";
        }
-       print "</div>\n" if( $diss );
-       my $url_prefix = $args->{'full_links'} ? 'http://'.$req->hostname() : '';
+       if( $diss ) {
+               print "<p><a href='".buildExcept( 'action', $args )."?action=newhistory'>Discuss</a>\n";
+               print "</div>\n" if( $diss );
+       }
        unless( $address->leaf() ) {
-               print "<h2>Sub-items</h2>\n";
+               print "<h2>".encode( $address->subName() )."</h2>\n";
                my $restricts = $address->defaultRestrictList();
                if( scalar @{$restricts} ) {
                        print "<p>";
                        my $url = '/read/'.$address->get().buildExcept( 'restrict', $args ).'?restrict=';
                        foreach( @{$restricts} ) {
-                               print "<a href='".$url_prefix.$url.$_->[0]."'>".$_->[1]."</a> ";
+                               print "<a href='".$url.$_->[0]."'>".$_->[1]."</a> ";
                        }
                }
                my $url = '/read/'.$address->get().buildExcept( 'sort', $args );
                my $sort = ( $args->{'sort'} or 'id' );
                my( $sort_id, $sort_name ) = ( ( $sort eq 'id' ? 'rid' : 'id' ), ( $sort eq 'name' ? 'rname' : 'name' ) );
-               genTableHead( 'subnodes', [ '<a href="'.$url_prefix.$url.'?sort='.$sort_id.'">Id</a>', '<a href="'.$url_prefix.$url.'?sort='.$sort_name.'">Name</a>', 'Note' ], [ 'id-col', 'name-col', 'note-col' ] );
+               genTableHead( 'subnodes', [ '<a href="'.$url.'?sort='.$sort_id.'">Id</a>', '<a href="'.$url.'?sort='.$sort_name.'">Name</a>', 'Note' ], [ 'id-col', 'name-col', 'note-col' ] );
                $args->{'restrict'} = $address->defaultRestrict() unless( defined( $args->{'restrict'} ) );
-               $tables->nodes( $address->get(), $args, $url_prefix );
+               $tables->nodes( $address->get(), $args );
                genTableTail();
+               print "<p><a href='".buildExcept( 'action', $args )."?action=newitem'>Add item</a>\n";
        }
-       genHtmlTail();
+       genHtmlFooter( 1, $req, $args );
        return OK;
 }