Project

General

Profile

1
 /*
2
  *   '$RCSfile$'
3
  *     Purpose: Default style sheet for KNP project web pages 
4
  *              Using this stylesheet rather than placing styles directly in 
5
  *              the KNP web documents allows us to globally change the 
6
  *              formatting styles of the entire site in one easy place.
7
  *   Copyright: 2000 Regents of the University of California and the
8
  *               National Center for Ecological Analysis and Synthesis
9
  *     Authors: Matt Jones
10
  *
11
  *    '$Author: daigle $'
12
  *      '$Date: 2008-04-02 16:28:31 -0700 (Wed, 02 Apr 2008) $'
13
  *  '$Revision: 3780 $'
14
  *
15
  * This program is free software; you can redistribute it and/or modify
16
  * it under the terms of the GNU General Public License as published by
17
  * the Free Software Foundation; either version 2 of the License, or
18
  * (at your option) any later version.
19
  *
20
  * This program is distributed in the hope that it will be useful,
21
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
22
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23
  * GNU General Public License for more details.
24
  *
25
  * You should have received a copy of the GNU General Public License
26
  * along with this program; if not, write to the Free Software
27
  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
28
  */
29

    
30
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
31
 * * * * * *  CONFIGURATION SETTINGS - EDIT THESE FOR YOUR ENVIRONMENT * * * * 
32
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
33

    
34
 
35
//  These settings allow you to include and display common content (eg a common 
36
//  header) on all your pages, in much the same way as a frameset allows you to 
37
//  do, but through the use of iframes and a table instead. You can include up 
38
//  to 4 external pages, each one within the header, footer, left or right areas
39
//
40
//  looks like this (if you're using a fixed width font to display these notes):
41
//    ___________________
42
//    |     header      |
43
//    |-----------------|
44
//    | |             | |
45
//    | |             | |
46
//    |L|   content   |R|
47
//    | |             | |
48
//    | |             | |
49
//    |-----------------|
50
//    |     footer      | 
51
//    -------------------
52
//
53
//  Each area may display another page on the local site, or a page on a 
54
//  different server, or may be set to display nothing (in which case an iframe 
55
//  will not be drawn, although the containing table cell will still need to be 
56
//  resized using the css style - see below) 
57
//
58
//  NOTES:
59
//
60
//  1) if you have any links in the included documents, the target attribute for 
61
//     these *MUST* be set to _top, otherwise the new document will be displayed 
62
//     inside the small iframe areas, instead of replacing the entire page!
63
//     - example: <a href="index.html" target="_top">HOME</a>
64
//   
65
//  2) you will need to set the correct iframe size, in order to accomodate 
66
//     each of these areas on the page. The default location for these size 
67
//     settings is in the default.css file - see the "IFRAME_XXXXXX_CLASS" 
68
//     variables (below) for the name of the style to edit
69
//
70
//  3) you will also need to set the correct table cell sizes and/or overall 
71
//     table size for similar reasons. The default location for these size 
72
//     settings is in the default.css file - see the "TEMPLATE_XXXXXX_CLASS" 
73
//     variables (below) for the name of the style to edit
74

    
75

    
76

    
77
////////////////////////////////////////////////////////////////////////////////
78
//  Edit these variables to define the content that will be loaded into the 
79
//  various iframes. Each may be a relative path to another page on the local 
80
//  site, or a full URL to a page on a remote server, or may be set to the empty 
81
//  string if no content is required at that position on the page (and in which  
82
//  case an iframe will not be drawn, although an empty table cell will still  
83
//  exist unless it is resized smaller) . 
84
//  ( e.g. if you do not want a header to be included, set: HEADER_URL="";)
85
////////////////////////////////////////////////////////////////////////////////
86

    
87

    
88
//  Location of the header that will be displayed at the top of the page
89
var HEADER_URL = "style/skins/knp/header.jsp";
90

    
91
// Location of the search box that will be displayed above the  
92
//  results on the results page (optional)
93
var SEARCHBOX_URL = "";  //= "searchform.jsp"
94

    
95
//  Location of the header that will be displayed at the top of the page
96
var LEFTCOL_URL = "";
97
  
98
//  Location of the header that will be displayed at the top of the page
99
var RIGHTCOL_URL = "style/skins/knp/spatial/pma.html";
100
  
101
//  Location of the header that will be displayed at the top of the page
102
var FOOTER_URL = "style/skins/knp/footer.html";
103
  
104
var LOGINBOX_URL = "style/skins/knp/SaeonLogin.jspx";
105

    
106

    
107

    
108
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
109
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
110
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
111
/* * * * * * * * *  MAY CHANGE THE FOLLOWING, BUT SHOULDN'T NEED TO* * * * * */ 
112
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
113
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
114
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
115

    
116
  
117
////////////////////////////////////////////////////////////////////////////////
118
//  Edit the default.css file to set the correct iframe sizes to accomodate the 
119
//  header, footer, left and right areas.
120
//  The following variables set the names of the styles that will be applied to 
121
//  each of the iframes - they can be anythign you wish, provided you use the 
122
//  same names for your classes in the css file
123
//  NOTE: these styles apply only to each container frame, *NOT* to the document
124
//  within it!
125
////////////////////////////////////////////////////////////////////////////////
126

    
127
//header iframe class
128
var IFRAME_HEADER_CLASS         = "iframeheaderclass";
129

    
130
//(metacat only) search box iframe class
131
var IFRAME_SEARCHBOX_CLASS      = "iframesearchboxclass";
132

    
133
//left column iframe class
134
var IFRAME_LEFTCOL_CLASS        = "iframeleftcolclass";
135

    
136
//right column iframe class
137
var IFRAME_RIGHTCOL_CLASS       = "mapFrame";
138

    
139
//footer iframe class
140
var IFRAME_FOOTER_CLASS         = "iframefooterclass";
141

    
142
//(metacat only) login box iframe class
143
var IFRAME_LOGINBOX_CLASS      = "iframeloginboxclass";
144

    
145
////////////////////////////////////////////////////////////////////////////////
146
//  Edit the default.css file to set the correct table sizes to accomodate the 
147
//  header, footer, left and right iframes.
148
//  The following variables set the names of the styles that will be applied to 
149
//  each of the table cells (or the table itself - see below) - they can be 
150
//  anything you wish, provided you use the same names for your classes in the 
151
//  css file
152
//  NOTE: these styles apply only to each table cell, *NOT* to the document 
153
//  inside the iframe that is nested within it! (the exception is 
154
//  TEMPLATE_CONTENTAREA_CLASS, since the content probably isn't within an 
155
//  iframe - so style elements in this class will apply to the content istelf)
156
////////////////////////////////////////////////////////////////////////////////
157

    
158
//entire table class
159
var TEMPLATE_TABLE_CLASS        = "templatetableclass";
160

    
161
//header table-cell class. Note you should not set css "width" on this, since it 
162
//includes a colspan
163
var TEMPLATE_HEADERROW_CLASS    = "templateheaderrowclass";
164

    
165
//left column table-cell class. Note that restricting css "height" on this may 
166
//affect visibility of the main content, since it's in the same table row 
167
var TEMPLATE_LEFTCOL_CLASS      = "templateleftcolclass";
168

    
169
//main central content table-cell class. Note that css attributes set here may 
170
//apply to the content nested inside this cell
171
var TEMPLATE_CONTENTAREA_CLASS  = "templatecontentareaclass";
172

    
173
//rigth column table-cell class. Note that restricting css "height" on this may 
174
//affect visibility of the main content, since it's in the same table row 
175
var TEMPLATE_RIGHTCOL_CLASS     = "templaterightcolclass";
176

    
177
//footer table-cell class. Note you should not set "width" on this, since it 
178
//includes a colspan
179
var TEMPLATE_FOOTERROW_CLASS    = "templatefooterrowclass";
180

    
181
//
182
// Skin specific functions
183
function submitform(formObj) {
184

    
185
  if (trim(formObj.elements["loginAction"].value)!="Login") return true;
186
  //trim username & passwd:
187
  var username = trim(formObj.elements["uid"].value);
188
  var organization  = trim(formObj.elements["organization"].value);
189
  var password      = trim(formObj.elements["password"].value);
190

    
191
  if (username=="") {
192
    alert("You must type a username. \n"+popupMsg);
193
        formObj.elements["uid"].focus();
194
    return false;
195
  }
196

    
197
  if (organization=="") {
198
    alert("You must select an organization. \n"+popupMsg);
199
        formObj.elements["organization"].focus();
200
    return false;
201
  }
202

    
203
  if (password=="") {
204
    alert("You must type a password. \n"+popupMsg);
205
        formObj.elements["password"].focus();
206
    return false;
207
  }
208

    
209
  formObj.username.value="uid="+formObj.elements["uid"].value+",o="+formObj.elements["organization"].value+",dc=ecoinformatics,dc=org";
210
  return true;
211
}
212

    
213
function trim(stringToTrim) {
214
  return stringToTrim.replace(/^\s*/, '').replace(/\s*$/,'');
215
}
(13-13/15)