source: main/trunk/greenstone3/web/interfaces/default/transform/layouts/toc.xsl@ 25822

Last change on this file since 25822 was 25822, checked in by kjdon, 12 years ago

trying to get rid of toc box when have a simple doc type

  • Property svn:executable set to *
File size: 13.0 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<xsl:stylesheet version="1.0"
3 xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
4 xmlns:java="http://xml.apache.org/xslt/java"
5 xmlns:util="xalan://org.greenstone.gsdl3.util.XSLTUtil"
6 xmlns:gslib="http://www.greenstone.org/skinning"
7 xmlns:gsf="http://www.greenstone.org/greenstone3/schema/ConfigFormat"
8 extension-element-prefixes="java util"
9 exclude-result-prefixes="java util gsf">
10
11 <xsl:template name="rightSidebar">
12 <table id="rightSidebar">
13 <tr><td>
14 <xsl:call-template name="viewOptions"/>
15 </td></tr>
16 <tr><td>
17 <div id="contentsArea">
18 <!-- show the berry basket if it's turned on -->
19 <gslib:berryBasket/>
20
21 <!-- Need to be in the context of the top-level documentNode rather than the document for the gsf:metadata call to work -->
22 <xsl:for-each select="documentNode">
23 <xsl:variable name="hasCover"><gsf:metadata name="hascover"/></xsl:variable>
24 <xsl:if test="$hasCover = '1'">
25 <!-- the book's cover image -->
26 <div id="coverImage">
27 <xsl:attribute name="class">
28 <xsl:choose>
29 <xsl:when test="not(/page/pageResponse/format[@type='display']/gsf:option[@name='coverImage']) or /page/pageResponse/format[@type='display']/gsf:option[@name='coverImage']/@value='true'">visible</xsl:when>
30 <xsl:otherwise>hidden</xsl:otherwise>
31 </xsl:choose>
32 </xsl:attribute>
33 <gslib:coverImage/><xsl:text> </xsl:text>
34 </div>
35 </xsl:if>
36 </xsl:for-each>
37
38 <!-- the contents (if enabled) -->
39 <xsl:choose>
40 <xsl:when test="/page/pageResponse/document/@docType = 'simple'"></xsl:when>
41 <xsl:when test="/page/pageResponse/document/@docType = 'paged'">
42 <gsf:image type="Thumb"/>
43 <!-- Table of contents will be dynamically retrieved when viewing a paged document -->
44 <script type="text/javascript">
45 <xsl:text disable-output-escaping="yes">
46 $(window).load(function()
47 {
48 retrieveTableOfContentsAndTitles();
49 });
50 </xsl:text>
51 </script>
52 <div id="tableOfContents"><xsl:text> </xsl:text></div>
53 <div id="tocLoadingImage" style="text-align:center;">
54 <img src="{util:getInterfaceText($interface_name, /page/@lang, 'loading_image')}"/><xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'doc.loading')"/><xsl:text>...</xsl:text>
55 </div>
56 <table style="width:100%;"><tbody><tr>
57 <td><xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'doc.filter_pages')"/><xsl:text>: </xsl:text><input id="filterText" type="text" size="27"/></td>
58 </tr></tbody></table>
59 </xsl:when>
60 <xsl:when test="not(/page/pageRequest/paramList/param[@name = 'ed']/@value = '1')">
61 <div id="tableOfContents">
62 <div id="tocLoadingImage" style="text-align:center;">
63 <img src="{util:getInterfaceText($interface_name, /page/@lang, 'loading_image')}"/><xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'doc.loading')"/><xsl:text>...</xsl:text>
64 </div>
65 </div>
66 <script type="text/javascript">
67 <xsl:text disable-output-escaping="yes">
68 $(window).load(function()
69 {
70 retrieveFullTableOfContents();
71 });
72 </xsl:text>
73 </script>
74 </xsl:when>
75 <xsl:otherwise>
76 <div id="tableOfContents">
77 <xsl:attribute name="class">
78 <xsl:choose>
79 <xsl:when test="count(//documentNode) > 1 and not(/page/pageResponse/format[@type='display']/gsf:option[@name='TOC']) or /page/pageResponse/format[@type='display']/gsf:option[@name='TOC']/@value='true'">visible</xsl:when>
80 <xsl:otherwise>hidden</xsl:otherwise>
81 </xsl:choose>
82 </xsl:attribute>
83 <xsl:for-each select="documentNode">
84 <xsl:call-template name="documentNodeTOC"/>
85 </xsl:for-each>
86 </div>
87 </xsl:otherwise>
88 </xsl:choose>
89 </div>
90 </td></tr>
91 </table>
92 </xsl:template>
93
94 <!-- This template is used to display the table of contents -->
95 <xsl:template name="documentNodeTOC">
96
97 <!-- check if this is the currently selected table of contents item -->
98 <xsl:variable name="isCurrent" select="nodeContent"/>
99
100 <!-- formulate the link -->
101 <xsl:variable name="contentsLink">
102 <xsl:value-of select='$library_name'/>?a=d&amp;c=<gslib:collectionNameShort/>&amp;d=<xsl:value-of select='@nodeID'/><xsl:if test="documentNode">.pr</xsl:if>&amp;sib=1
103 </xsl:variable>
104
105 <ul>
106 <table><tr>
107 <!-- The expand/collapse button (not displayed for the top level node) -->
108 <xsl:if test="util:hashToDepthClass(@nodeID) != 'sectionHeaderDepthTitle'">
109 <td>
110 <xsl:choose>
111 <xsl:when test="not(nodeContent and not(documentNode))">
112 <img id="ttoggle{@nodeID}" onclick="toggleSection('{@nodeID}');" class="icon">
113 <xsl:attribute name="src">
114 <xsl:choose>
115 <xsl:when test="/page/pageRequest/paramList/param[@name = 'ed']/@value = '1' or /page/pageResponse/document/@selectedNode = @nodeID">
116 <xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'collapse_image')"/>
117 </xsl:when>
118 <xsl:otherwise>
119 <xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'expand_image')"/>
120 </xsl:otherwise>
121 </xsl:choose>
122 </xsl:attribute>
123 </img>
124 </xsl:when>
125 <xsl:otherwise>
126 <xsl:attribute name="class">emptyIcon</xsl:attribute>
127 </xsl:otherwise>
128 </xsl:choose>
129 </td>
130 </xsl:if>
131
132 <!-- The chapter/page icon -->
133 <td>
134 <img>
135 <xsl:if test="nodeContent and not(documentNode)">
136 <xsl:attribute name="class">leafNode</xsl:attribute>
137 </xsl:if>
138
139 <xsl:attribute name="src">
140 <xsl:choose>
141 <xsl:when test="nodeContent and not(documentNode)">
142 <xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'page_image')"/>
143 </xsl:when>
144 <xsl:otherwise>
145 <xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'chapter_image')"/>
146 </xsl:otherwise>
147 </xsl:choose>
148 </xsl:attribute>
149 </img>
150 </td>
151
152 <!-- The section name, links to the section in the document -->
153 <td>
154 <a id="toclink{@nodeID}">
155 <xsl:choose>
156 <xsl:when test="/page/pageResponse/document/@docType = 'paged'">
157 <xsl:attribute name="href"><xsl:value-of select="$library_name"/>?a=d&amp;c=<xsl:value-of select="/page/pageResponse/collection/@name"/>&amp;d=<xsl:value-of select="@nodeID"/>&amp;dt=<xsl:value-of select="@docType"/>&amp;p.a=b&amp;p.s=<xsl:value-of select="/page/pageResponse/service/@name"/></xsl:attribute>
158 </xsl:when>
159 <xsl:otherwise>
160 <xsl:attribute name="href">javascript:focusSection('<xsl:value-of select="@nodeID"/>');</xsl:attribute>
161 </xsl:otherwise>
162 </xsl:choose>
163 <xsl:if test="util:hashToSectionId(@nodeID)">
164 <xsl:value-of select="util:hashToSectionId(@nodeID)"/>
165 <xsl:text> </xsl:text>
166 </xsl:if>
167 <xsl:call-template name="sectionTitle"/>
168 </a>
169 </td>
170 </tr></table>
171
172 <!-- display any child items -->
173 <xsl:if test="documentNode">
174 <li id="toc{@nodeID}">
175 <xsl:attribute name="style">
176 <xsl:choose>
177 <xsl:when test="/page/pageRequest/paramList/param[@name = 'ed']/@value = '1' or /page/pageResponse/document/@selectedNode = @nodeID">
178 <xsl:text>display:block;</xsl:text>
179 </xsl:when>
180 <xsl:otherwise>
181 <xsl:text>display:none;</xsl:text>
182 </xsl:otherwise>
183 </xsl:choose>
184 </xsl:attribute>
185 <xsl:for-each select="documentNode">
186 <xsl:call-template name="documentNodeTOC"/>
187 </xsl:for-each>
188 </li>
189 </xsl:if>
190
191 </ul>
192 </xsl:template>
193
194 <xsl:template name="viewOptions">
195 <table class="viewOptions ui-state-default ui-corner-all"><tr>
196
197 <!-- Paged-image options -->
198 <xsl:if test="count(//documentNode/metadataList/metadata[@name = 'Screen']) > 0 or /page/pageResponse/document/documentNode/@docType = 'paged'">
199 <td>
200 <select id="viewSelection" onchange="changeView();">
201 <xsl:choose>
202 <xsl:when test="/page/pageRequest/paramList/param[@name = 'view']/@value = 'image'">
203 <option>Default view</option>
204 <option selected="true">Image view</option>
205 <option>Text view</option>
206 </xsl:when>
207 <xsl:when test="/page/pageRequest/paramList/param[@name = 'view']/@value = 'text'">
208 <option>Default view</option>
209 <option>Image view</option>
210 <option selected="true">Text view</option>
211 </xsl:when>
212 <xsl:otherwise>
213 <option selected="true">Default view</option>
214 <option>Image view</option>
215 <option>Text view</option>
216 </xsl:otherwise>
217 </xsl:choose>
218 </select>
219 </td>
220 </xsl:if>
221
222 <!-- Realistic books link -->
223 <xsl:if test="/page/pageResponse/collection[@name = $collName]/metadataList/metadata[@name = 'tidyoption'] = 'tidy'">
224 <td>
225 <img>
226 <xsl:attribute name="src"><xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'realistic_books_image')"/></xsl:attribute>
227 </img>
228 <input id="rbOption" type="checkbox" onclick="bookInit();" class="optionCheckBox"/>
229 </td>
230 </xsl:if>
231
232 <!-- Highlight on/off button -->
233 <xsl:if test="/page/pageRequest/paramList/param[@name = 'p.a']/@value = 'q' or /page/pageRequest/paramList/param[@name = 's1.query']">
234 <td>
235 <img>
236 <xsl:attribute name="src"><xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'highlight_image')"/></xsl:attribute>
237 </img>
238 <input id="highlightOption" type="checkbox" class="optionCheckBox" onclick="swapHighlight();">
239 <xsl:if test="/page/pageRequest/paramList/param[@name = 'hl']/@value = 'on'">
240 <xsl:attribute name="checked">true</xsl:attribute>
241 </xsl:if>
242 </input>
243 </td>
244 </xsl:if>
245 <td style="vertical-align:top; text-align:right;">
246 <xsl:if test="not(/page/pageResponse/document/@docType='simple') and (not(/page/pageResponse/format[@type='display']/gsf:option[@name='TOC']) or /page/pageResponse/format[@type='display']/gsf:option[@name='TOC']/@value='true')">
247 <span class="tableOfContentsTitle"><xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'doc.table_of_contents')"/></span>
248
249 <a id="sidebarMinimizeButton" href="javascript:minimizeSidebar();" style="float: right; font-size:0.6em;">
250 <img class="icon" style="padding-top:3px;">
251 <xsl:attribute name="src">
252 <xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'collapse_image')"/>
253 </xsl:attribute>
254 </img>
255 </a>
256 <a id="sidebarMaximizeButton" href="javascript:maximizeSidebar();" style="float: right; font-size:0.6em; display:none;">
257 <img class="icon" style="padding-top:3px;">
258 <xsl:attribute name="src">
259 <xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'expand_image')"/>
260 </xsl:attribute>
261 </img>
262 </a>
263 </xsl:if>
264 </td>
265 </tr>
266 <tr id="zoomOptions">
267 <!-- This is invisible unless it is made visible by Javascript controlling the image zooming -->
268 <xsl:attribute name="style">display: none;</xsl:attribute>
269 <td style="width:40%;">
270 <xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'doc.zoom')"/><input id="zoomToggle" type="checkbox"/>
271 <script type="text/javascript">
272 <xsl:text disable-output-escaping="yes">
273 $("#zoomToggle").change(function()
274 {
275 _imageZoomEnabled = !_imageZoomEnabled;
276 });
277 </xsl:text>
278 </script>
279 </td>
280 <td style="width:60%;">
281 <div>
282 <div style="float:left; width:30%;"><xsl:value-of select="util:getInterfaceText($interface_name, /page/@lang, 'doc.zoom_size')"/><xsl:text>:</xsl:text></div>
283 <div id="zoomSlider" style="float:right; width:65%; height:5px; margin-top:6px;"><xsl:text> </xsl:text></div>
284 <script type="text/javascript">
285 <xsl:text disable-output-escaping="yes">
286 $("#zoomSlider").slider(
287 {
288 change: function(event, ui)
289 {
290 var sliderValue = ui.value;
291 var divs = document.getElementsByTagName("DIV");
292 for(var i = 0; i &lt; divs.length; i++)
293 {
294 if(divs[i].getAttribute("id") &amp;&amp; divs[i].getAttribute("id").search(/^mover.*/) != -1)
295 {
296 divs[i].style.height = 200 + (2 * sliderValue) + "px";
297 divs[i].style.width = 200 + (2 * sliderValue) + "px";
298 }
299 }
300 }
301 });
302 </xsl:text>
303 </script>
304 <style>.ui-slider .ui-slider-handle{height:0.8em; width:1.0em;}</style>
305 <div style="float:clear;"><xsl:text> </xsl:text></div>
306 </div>
307 </td>
308 </tr>
309 </table>
310 </xsl:template>
311</xsl:stylesheet>
Note: See TracBrowser for help on using the repository browser.