package SBEAMS::Inkjet::HTMLPrinter; ############################################################################### # Program : SBEAMS::Inkjet::HTMLPrinter # Author : Eric Deutsch # $Id$ # # Description : This is part of the SBEAMS::Inkjet module which handles # standardized parts of generating HTML. # # This really begs to get a lot more object oriented such that # there are several different contexts under which the a user # can be in, and the header, button bar, etc. vary by context ############################################################################### use strict; use vars qw($sbeams $current_contact_id $current_username $current_work_group_id $current_work_group_name $current_project_id $current_project_name $current_user_context_id); use CGI::Carp qw(fatalsToBrowser croak); use SBEAMS::Connection::DBConnector; use SBEAMS::Connection::Settings; use SBEAMS::Connection::TableInfo; use SBEAMS::Inkjet::Settings; use SBEAMS::Inkjet::TableInfo; ############################################################################### # Constructor ############################################################################### sub new { my $this = shift; my $class = ref($this) || $this; my $self = {}; bless $self, $class; return($self); } ############################################################################### # printPageHeader ############################################################################### sub printPageHeader { my $self = shift; my %args = @_; my $navigation_bar = $args{'navigation_bar'} || "YES"; #### If the output mode is interactive text, display text header my $sbeams = $self->getSBEAMS(); if ($sbeams->output_mode() eq 'interactive') { $sbeams->printTextHeader(); return; } #### If the output mode is not html, then we don't want a header here if ($sbeams->output_mode() ne 'html') { return; } #### Obtain main SBEAMS object and use its http_header $sbeams = $self->getSBEAMS(); my $http_header = $sbeams->get_http_header(); print qq~$http_header $DBTITLE - Inkjet ~; $self->printJavascriptFunctions(); $self->printStyleSheet(); #### Determine the Title bar background decoration my $header_bkg = "bgcolor=\"$BGCOLOR\""; $header_bkg = "background=\"/images/plaintop.jpg\"" if ($DBVERSION =~ /Primary/); print qq~ ~; #print ">>>http_header=$http_header
\n"; if ($navigation_bar eq "YES") { print qq~
MICROARRAY LOGOUT
~; $current_work_group_name = $sbeams->getCurrent_work_group_name(); if ($current_work_group_name eq "Inkjet_admin" || $current_work_group_name eq "Admin" || 1) { print qq~ ~; } $current_work_group_name = $sbeams->getCurrent_work_group_name(); if ($current_work_group_name eq "Inkjet_admin" || $current_work_group_name eq "Admin") { print qq~ ~; } print qq~
~; } else { print qq~
~; } } # ############################################################################### # printStyleSheet # # Print the standard style sheet for pages. Use a font size of 10pt if # remote client is on Windows, else use 12pt. This ends up making fonts # appear the same size on Windows+IE and Linux+Netscape. Other tweaks for # different browsers might be appropriate. ############################################################################### sub printStyleSheet { my $self = shift; #### Obtain main SBEAMS object and use its style sheet $sbeams = $self->getSBEAMS(); $sbeams->printStyleSheet(); } ############################################################################### # printJavascriptFunctions # # Print the standard Javascript functions that should appear at the top of # most pages. There probably should be some customization allowance here. # Not sure how to design that yet. ############################################################################### sub printJavascriptFunctions { my $self = shift; my $javascript_includes = shift; print qq~ ~; } ############################################################################### # printPageFooter ############################################################################### sub printPageFooter { my $self = shift; #### Allow old-style single argument my $n_params = scalar @_; my %args; #### If the old-style single argument exists, create args hash with it if ($n_params == 1) { my $flag = shift; $args{close_tables} = 'NO'; $args{close_tables} = 'YES' if ($flag =~ /CloseTables/); $args{display_footer} = 'NO'; $args{display_footer} = 'YES' if ($flag =~ /Footer/); } else { %args = @_; } #### If the output mode is interactive text, display text header my $sbeams = $self->getSBEAMS(); if ($sbeams->output_mode() eq 'interactive') { $sbeams->printTextHeader(%args); return; } #### If the output mode is not html, then we don't want a header here if ($sbeams->output_mode() ne 'html') { return; } #### Process the arguments list my $close_tables = $args{'close_tables'} || 'YES'; my $display_footer = $args{'display_footer'} || 'YES'; my $separator_bar = $args{'separator_bar'} || 'NO'; #### If closing the content tables is desired if ($close_tables eq 'YES') { print qq~
~; } #### If displaying a fat bar separtor is desired if ($separator_bar eq 'YES') { print "


\n"; } #### If finishing up the page completely is desired if ($display_footer eq 'YES') { #### Default to the Core footer $sbeams->display_page_footer(display_footer=>'YES'); } } ############################################################################### # print_tabs ############################################################################### sub print_tabs { my $self= shift; my %args = @_; my $SUB_NAME = "print_tabs"; ## Decode argument list my $tab_titles_ref = $args{'tab_titles_ref'} || die "ERROR[$SUB_NAME]:tab_titles_ref not passed"; my $selected_tab = $args{'selected_tab'} || 0; my $page_link = $args{'page_link'} || die "ERROR[$SUB_NAME]:page_link not passed"; my $unselected_bg_color = $args{'unselected_bg_color'} || "\#224499"; my $unselected_font_color = $args{'unselected_font_color'} || "\#ffffff"; my $selected_bg_color = $args{'selected_bg_color'} || "\#ffcc33"; my $selected_font_color = $args{'selected_font_color'} || "\#000000"; my $line_color = $args{'line_color'} || "\#3366cc"; ## Define standard variables my @tab_titles = @{$tab_titles_ref}; my $counter = 0; ## Start TABLE print qq~ ~; ## for each desired tab, make one while (@tab_titles) { my $tab_title = shift(@tab_titles); my $link = $tab_title; while ($link =~ /\s+/) { $link =~ s(\s+)(_); } $link =~ tr/A-Z/a-z/; if ($counter == $selected_tab) { print qq~ ~; }else { print qq~ ~; } $counter++; } ## Draw line underneath tabs print qq~ ~; ## Finish table print qq~
  $tab_title  $tab_title 
~; return; } ############################################################################### # Print QuickLinks ############################################################################### sub printQuickLinks { my $self = shift; my $q = shift; } ############################################################################### 1; __END__ ############################################################################### ############################################################################### ############################################################################### =head1 NAME SBEAMS::WebInterface::HTMLPrinter - Perl extension for common HTML printing methods =head1 SYNOPSIS Used as part of this system use SBEAMS::WebInterface; $adb = new SBEAMS::WebInterface; $adb->printPageHeader(); $adb->printPageFooter(); $adb->getGoBackButton(); =head1 DESCRIPTION This module is inherited by the SBEAMS::WebInterface module, although it can be used on its own. Its main function is to encapsulate common HTML printing routines used by this application. =head1 METHODS =item B Prints the common HTML header used by all HTML pages generated by theis application =item B Prints the common HTML footer used by all HTML pages generated by this application =item B Returns a form button, coded with javascript, so that when it is clicked the user is returned to the previous page in the browser history. =head1 AUTHOR Eric Deutsch =head1 SEE ALSO perl(1). =cut