slideshow 0.7.8 → 0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -50,6 +50,18 @@ class Opts
50
50
  get_boolean( 'generate', false )
51
51
  end
52
52
 
53
+ def list?
54
+ get_boolean( 'list', false )
55
+ end
56
+
57
+ def fetch?
58
+ get( 'fetch_uri', nil ) != nil
59
+ end
60
+
61
+ def fetch_uri
62
+ get( 'fetch_uri', '-fetch uri required-' )
63
+ end
64
+
53
65
  def has_includes?
54
66
  @hash[ :include ]
55
67
  end
@@ -71,6 +83,10 @@ class Opts
71
83
  get( 'manifest', 's6.txt' )
72
84
  end
73
85
 
86
+ def config_path
87
+ get( 'config_path', nil )
88
+ end
89
+
74
90
  def output_path
75
91
  get( 'output', '.' )
76
92
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: slideshow
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.8
4
+ version: "0.8"
5
5
  platform: ruby
6
6
  authors:
7
7
  - Gerald Bauer
@@ -9,7 +9,7 @@ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
11
 
12
- date: 2009-03-09 00:00:00 -04:00
12
+ date: 2009-03-14 00:00:00 -04:00
13
13
  default_executable:
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
@@ -86,22 +86,6 @@ files:
86
86
  - templates/s5/s5-core.css
87
87
  - templates/s5/slides.js
88
88
  - templates/s5/style.css.erb
89
- - templates/s5blank.txt.gen
90
- - templates/s5blank.txt.sample
91
- - templates/s5blank/blank.textile
92
- - templates/s5blank/footer.html.erb
93
- - templates/s5blank/header.html.erb
94
- - templates/s5blank/ui/default/blank.gif
95
- - templates/s5blank/ui/default/bodybg.gif
96
- - templates/s5blank/ui/default/framing.css
97
- - templates/s5blank/ui/default/iepngfix.htc
98
- - templates/s5blank/ui/default/opera.css
99
- - templates/s5blank/ui/default/outline.css
100
- - templates/s5blank/ui/default/pretty.css
101
- - templates/s5blank/ui/default/print.css
102
- - templates/s5blank/ui/default/s5-core.css
103
- - templates/s5blank/ui/default/slides.css
104
- - templates/s5blank/ui/default/slides.js
105
89
  - templates/s6.txt
106
90
  - templates/s6.txt.gen
107
91
  - templates/s6.txt.sample
@@ -1,17 +0,0 @@
1
- # manifest to generate sample template package using S5 v1.1 blank package
2
-
3
- s5blank.txt s5blank.txt.sample
4
- blank.textile s5blank/blank.textile
5
- header.html.erb s5blank/header.html.erb
6
- footer.html.erb s5blank/footer.html.erb
7
- ui/default/blank.gif s5blank/ui/default/blank.gif
8
- ui/default/bodybg.gif s5blank/ui/default/bodybg.gif
9
- ui/default/framing.css s5blank/ui/default/framing.css
10
- ui/default/iepngfix.htc s5blank/ui/default/iepngfix.htc
11
- ui/default/opera.css s5blank/ui/default/opera.css
12
- ui/default/outline.css s5blank/ui/default/outline.css
13
- ui/default/pretty.css s5blank/ui/default/pretty.css
14
- ui/default/print.css s5blank/ui/default/print.css
15
- ui/default/s5-core.css s5blank/ui/default/s5-core.css
16
- ui/default/slides.css s5blank/ui/default/slides.css
17
- ui/default/slides.js s5blank/ui/default/slides.js
@@ -1,28 +0,0 @@
1
- # Sample template package manifest using S5.11 blank package
2
- # Change as desired/needed
3
- #
4
- # Configured to use the following headers in header.html.erb:
5
- #
6
- # author: Your Name Here
7
- # company: Your Company Here
8
- # title: Your Slide Show Title Here
9
- # subtitle: Your Subtitle Here
10
- # footer: Your Footer Here
11
- # subfooter: Your Subfooter Here
12
- #
13
- # Questions? Comments?
14
- # Send them along to the Free Web Slide Show Alternatives (S5, S6, S9 And Friends) Forum/Mailing List.
15
- # http://groups.google.com/group/webslideshow
16
-
17
- __file__.html header.html.erb + footer.html.erb
18
- ui/default/blank.gif
19
- ui/default/bodybg.gif
20
- ui/default/framing.css
21
- ui/default/iepngfix.htc
22
- ui/default/opera.css
23
- ui/default/outline.css
24
- ui/default/pretty.css
25
- ui/default/print.css
26
- ui/default/s5-core.css
27
- ui/default/slides.css
28
- ui/default/slides.js
@@ -1,20 +0,0 @@
1
- author: Your Name Here
2
- company: Your Company Here
3
- title: Your Slide Show Title Here
4
- subtitle: Your Subtitle Here
5
- footer: Your Footer Here
6
- subfooter: Your Subfooter Here
7
-
8
-
9
- h1. Slide Title Here
10
-
11
- * Point One Here
12
- * Point Two Here
13
-
14
- h1. Another Slide Title Here
15
-
16
- Questions? Comments?
17
-
18
- Send them along to the
19
- "Free Web Slide Show Alternatives (S5, S6, S9 And Friends) Forum/Mailing List":http://groups.google.com/group/webslideshow.
20
- Thanks!
@@ -1,4 +0,0 @@
1
- </div>
2
-
3
- </body>
4
- </html>
@@ -1,48 +0,0 @@
1
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3
-
4
- <html xmlns="http://www.w3.org/1999/xhtml">
5
-
6
- <head>
7
- <title><%= @headers['title'] %></title>
8
- <!-- metadata -->
9
- <meta name="generator" content="Slide Show (S9)" />
10
- <meta name="version" content="S5 1.1" />
11
- <meta name="author" content="<%= @headers['author']%>" />
12
- <meta name="company" content="<%= @headers['company']%>" />
13
- <!-- configuration parameters -->
14
- <meta name="defaultView" content="slideshow" />
15
- <meta name="controlVis" content="hidden" />
16
- <!-- style sheet links -->
17
- <link rel="stylesheet" href="ui/default/slides.css" type="text/css" media="projection" id="slideProj" />
18
- <link rel="stylesheet" href="ui/default/outline.css" type="text/css" media="screen" id="outlineStyle" />
19
- <link rel="stylesheet" href="ui/default/print.css" type="text/css" media="print" id="slidePrint" />
20
- <link rel="stylesheet" href="ui/default/opera.css" type="text/css" media="projection" id="operaFix" />
21
- <!-- S5 JS -->
22
- <script src="ui/default/slides.js" type="text/javascript"></script>
23
- </head>
24
- <body>
25
-
26
- <div class="layout">
27
- <div id="controls"><!-- DO NOT EDIT --></div>
28
- <div id="currentSlide"><!-- DO NOT EDIT --></div>
29
- <div id="header"></div>
30
- <div id="footer">
31
- <h1><%= @headers['footer'] %></h1>
32
- <h2><%= @headers['subfooter'] %></h2>
33
- </div>
34
-
35
- </div>
36
-
37
-
38
- <div class="presentation">
39
-
40
- <div class="slide">
41
- <h1><%= @headers['title'] %></h1>
42
- <h2><%= @headers['subtitle'] %></h2>
43
- <h3><%= @headers['author']%></h3>
44
- <h4><%= @headers['company']%></h4>
45
- </div>
46
-
47
-
48
-
@@ -1,23 +0,0 @@
1
- /* The following styles size, place, and layer the slide components.
2
- Edit these if you want to change the overall slide layout.
3
- The commented lines can be uncommented (and modified, if necessary)
4
- to help you with the rearrangement process. */
5
-
6
- /* target = 1024x768 */
7
-
8
- div#header, div#footer, .slide {width: 100%; top: 0; left: 0;}
9
- div#header {top: 0; height: 3em; z-index: 1;}
10
- div#footer {top: auto; bottom: 0; height: 2.5em; z-index: 5;}
11
- .slide {top: 0; width: 92%; padding: 3.5em 4% 4%; z-index: 2; list-style: none;}
12
- div#controls {left: 50%; bottom: 0; width: 50%; z-index: 100;}
13
- div#controls form {position: absolute; bottom: 0; right: 0; width: 100%;
14
- margin: 0;}
15
- #currentSlide {position: absolute; width: 10%; left: 45%; bottom: 1em; z-index: 10;}
16
- html>body #currentSlide {position: fixed;}
17
-
18
- /*
19
- div#header {background: #FCC;}
20
- div#footer {background: #CCF;}
21
- div#controls {background: #BBD;}
22
- div#currentSlide {background: #FFC;}
23
- */
@@ -1,42 +0,0 @@
1
- <public:component>
2
- <public:attach event="onpropertychange" onevent="doFix()" />
3
-
4
- <script>
5
-
6
- // IE5.5+ PNG Alpha Fix v1.0 by Angus Turnbull http://www.twinhelix.com
7
- // Free usage permitted as long as this notice remains intact.
8
-
9
- // This must be a path to a blank image. That's all the configuration you need here.
10
- var blankImg = 'ui/default/blank.gif';
11
-
12
- var f = 'DXImageTransform.Microsoft.AlphaImageLoader';
13
-
14
- function filt(s, m) {
15
- if (filters[f]) {
16
- filters[f].enabled = s ? true : false;
17
- if (s) with (filters[f]) { src = s; sizingMethod = m }
18
- } else if (s) style.filter = 'progid:'+f+'(src="'+s+'",sizingMethod="'+m+'")';
19
- }
20
-
21
- function doFix() {
22
- if ((parseFloat(navigator.userAgent.match(/MSIE (\S+)/)[1]) < 5.5) ||
23
- (event && !/(background|src)/.test(event.propertyName))) return;
24
-
25
- if (tagName == 'IMG') {
26
- if ((/\.png$/i).test(src)) {
27
- filt(src, 'image'); // was 'scale'
28
- src = blankImg;
29
- } else if (src.indexOf(blankImg) < 0) filt();
30
- } else if (style.backgroundImage) {
31
- if (style.backgroundImage.match(/^url[("']+(.*\.png)[)"']+$/i)) {
32
- var s = RegExp.$1;
33
- style.backgroundImage = '';
34
- filt(s, 'crop');
35
- } else filt();
36
- }
37
- }
38
-
39
- doFix();
40
-
41
- </script>
42
- </public:component>
@@ -1,7 +0,0 @@
1
- /* DO NOT CHANGE THESE unless you really want to break Opera Show */
2
- .slide {
3
- visibility: visible !important;
4
- position: static !important;
5
- page-break-before: always;
6
- }
7
- #slide0 {page-break-before: avoid;}
@@ -1,15 +0,0 @@
1
- /* don't change this unless you want the layout stuff to show up in the outline view! */
2
-
3
- .layout div, #footer *, #controlForm * {display: none;}
4
- #footer, #controls, #controlForm, #navLinks, #toggle {
5
- display: block; visibility: visible; margin: 0; padding: 0;}
6
- #toggle {float: right; padding: 0.5em;}
7
- html>body #toggle {position: fixed; top: 0; right: 0;}
8
-
9
- /* making the outline look pretty-ish */
10
-
11
- #slide0 h1, #slide0 h2, #slide0 h3, #slide0 h4 {border: none; margin: 0;}
12
- #slide0 h1 {padding-top: 1.5em;}
13
- .slide h1 {margin: 1.5em 0 0; padding-top: 0.25em;
14
- border-top: 1px solid #888; border-bottom: 1px solid #AAA;}
15
- #toggle {border: 1px solid; border-width: 0 0 1px 1px; background: #FFF;}
@@ -1,86 +0,0 @@
1
- /* Following are the presentation styles -- edit away! */
2
-
3
- body {background: #FFF url(bodybg.gif) -16px 0 no-repeat; color: #000; font-size: 2em;}
4
- :link, :visited {text-decoration: none; color: #00C;}
5
- #controls :active {color: #88A !important;}
6
- #controls :focus {outline: 1px dotted #227;}
7
- h1, h2, h3, h4 {font-size: 100%; margin: 0; padding: 0; font-weight: inherit;}
8
- ul, pre {margin: 0; line-height: 1em;}
9
- html, body {margin: 0; padding: 0;}
10
-
11
- blockquote, q {font-style: italic;}
12
- blockquote {padding: 0 2em 0.5em; margin: 0 1.5em 0.5em; text-align: center; font-size: 1em;}
13
- blockquote p {margin: 0;}
14
- blockquote i {font-style: normal;}
15
- blockquote b {display: block; margin-top: 0.5em; font-weight: normal; font-size: smaller; font-style: normal;}
16
- blockquote b i {font-style: italic;}
17
-
18
- kbd {font-weight: bold; font-size: 1em;}
19
- sup {font-size: smaller; line-height: 1px;}
20
-
21
- .slide code {padding: 2px 0.25em; font-weight: bold; color: #533;}
22
- .slide code.bad, code del {color: red;}
23
- .slide code.old {color: silver;}
24
- .slide pre {padding: 0; margin: 0.25em 0 0.5em 0.5em; color: #533; font-size: 90%;}
25
- .slide pre code {display: block;}
26
- .slide ul {margin-left: 5%; margin-right: 7%; list-style: disc;}
27
- .slide li {margin-top: 0.75em; margin-right: 0;}
28
- .slide ul ul {line-height: 1;}
29
- .slide ul ul li {margin: .2em; font-size: 85%; list-style: square;}
30
- .slide img.leader {display: block; margin: 0 auto;}
31
-
32
- div#header, div#footer {background: #005; color: #AAB;
33
- font-family: Verdana, Helvetica, sans-serif;}
34
- div#header {background: #005 url(bodybg.gif) -16px 0 no-repeat;
35
- line-height: 1px;}
36
- div#footer {font-size: 0.5em; font-weight: bold; padding: 1em 0;}
37
- #footer h1, #footer h2 {display: block; padding: 0 1em;}
38
- #footer h2 {font-style: italic;}
39
-
40
- div.long {font-size: 0.75em;}
41
- .slide h1 {position: absolute; top: 0.7em; left: 87px; z-index: 1;
42
- margin: 0; padding: 0.3em 0 0 50px; white-space: nowrap;
43
- font: bold 150%/1em Helvetica, sans-serif; text-transform: capitalize;
44
- color: #DDE; background: #005;}
45
- .slide h3 {font-size: 130%;}
46
- h1 abbr {font-variant: small-caps;}
47
-
48
- div#controls {position: absolute; left: 50%; bottom: 0;
49
- width: 50%;
50
- text-align: right; font: bold 0.9em Verdana, Helvetica, sans-serif;}
51
- html>body div#controls {position: fixed; padding: 0 0 1em 0;
52
- top: auto;}
53
- div#controls form {position: absolute; bottom: 0; right: 0; width: 100%;
54
- margin: 0; padding: 0;}
55
- #controls #navLinks a {padding: 0; margin: 0 0.5em;
56
- background: #005; border: none; color: #779;
57
- cursor: pointer;}
58
- #controls #navList {height: 1em;}
59
- #controls #navList #jumplist {position: absolute; bottom: 0; right: 0; background: #DDD; color: #227;}
60
-
61
- #currentSlide {text-align: center; font-size: 0.5em; color: #449;}
62
-
63
- #slide0 {padding-top: 3.5em; font-size: 90%;}
64
- #slide0 h1 {position: static; margin: 1em 0 0; padding: 0;
65
- font: bold 2em Helvetica, sans-serif; white-space: normal;
66
- color: #000; background: transparent;}
67
- #slide0 h2 {font: bold italic 1em Helvetica, sans-serif; margin: 0.25em;}
68
- #slide0 h3 {margin-top: 1.5em; font-size: 1.5em;}
69
- #slide0 h4 {margin-top: 0; font-size: 1em;}
70
-
71
- ul.urls {list-style: none; display: inline; margin: 0;}
72
- .urls li {display: inline; margin: 0;}
73
- .note {display: none;}
74
- .external {border-bottom: 1px dotted gray;}
75
- html>body .external {border-bottom: none;}
76
- .external:after {content: " \274F"; font-size: smaller; color: #77B;}
77
-
78
- .incremental, .incremental *, .incremental *:after {color: #DDE; visibility: visible;}
79
- img.incremental {visibility: hidden;}
80
- .slide .current {color: #B02;}
81
-
82
-
83
- /* diagnostics
84
-
85
- li:after {content: " [" attr(class) "]"; color: #F88;}
86
- */
@@ -1 +0,0 @@
1
- /* The following rule is necessary to have all slides appear in print! DO NOT REMOVE IT! */
@@ -1,9 +0,0 @@
1
- /* Do not edit or override these styles! The system will likely break if you do. */
2
-
3
- div#header, div#footer, div#controls, .slide {position: absolute;}
4
- html>body div#header, html>body div#footer,
5
- html>body div#controls, html>body .slide {position: fixed;}
6
- .handout {display: none;}
7
- .layout {display: block;}
8
- .slide, .hideme, .incremental {visibility: hidden;}
9
- #slide0 {visibility: visible;}
@@ -1,3 +0,0 @@
1
- @import url(s5-core.css); /* required to make the slide show run at all */
2
- @import url(framing.css); /* sets basic placement and size of slide components */
3
- @import url(pretty.css); /* stuff that makes the slides look better than blah */
@@ -1,553 +0,0 @@
1
- // S5 v1.1 slides.js -- released into the Public Domain
2
- //
3
- // Please see http://www.meyerweb.com/eric/tools/s5/credits.html for information
4
- // about all the wonderful and talented contributors to this code!
5
-
6
- var undef;
7
- var slideCSS = '';
8
- var snum = 0;
9
- var smax = 1;
10
- var incpos = 0;
11
- var number = undef;
12
- var s5mode = true;
13
- var defaultView = 'slideshow';
14
- var controlVis = 'visible';
15
-
16
- var isIE = navigator.appName == 'Microsoft Internet Explorer' && navigator.userAgent.indexOf('Opera') < 1 ? 1 : 0;
17
- var isOp = navigator.userAgent.indexOf('Opera') > -1 ? 1 : 0;
18
- var isGe = navigator.userAgent.indexOf('Gecko') > -1 && navigator.userAgent.indexOf('Safari') < 1 ? 1 : 0;
19
-
20
- function hasClass(object, className) {
21
- if (!object.className) return false;
22
- return (object.className.search('(^|\\s)' + className + '(\\s|$)') != -1);
23
- }
24
-
25
- function hasValue(object, value) {
26
- if (!object) return false;
27
- return (object.search('(^|\\s)' + value + '(\\s|$)') != -1);
28
- }
29
-
30
- function removeClass(object,className) {
31
- if (!object) return;
32
- object.className = object.className.replace(new RegExp('(^|\\s)'+className+'(\\s|$)'), RegExp.$1+RegExp.$2);
33
- }
34
-
35
- function addClass(object,className) {
36
- if (!object || hasClass(object, className)) return;
37
- if (object.className) {
38
- object.className += ' '+className;
39
- } else {
40
- object.className = className;
41
- }
42
- }
43
-
44
- function GetElementsWithClassName(elementName,className) {
45
- var allElements = document.getElementsByTagName(elementName);
46
- var elemColl = new Array();
47
- for (var i = 0; i< allElements.length; i++) {
48
- if (hasClass(allElements[i], className)) {
49
- elemColl[elemColl.length] = allElements[i];
50
- }
51
- }
52
- return elemColl;
53
- }
54
-
55
- function isParentOrSelf(element, id) {
56
- if (element == null || element.nodeName=='BODY') return false;
57
- else if (element.id == id) return true;
58
- else return isParentOrSelf(element.parentNode, id);
59
- }
60
-
61
- function nodeValue(node) {
62
- var result = "";
63
- if (node.nodeType == 1) {
64
- var children = node.childNodes;
65
- for (var i = 0; i < children.length; ++i) {
66
- result += nodeValue(children[i]);
67
- }
68
- }
69
- else if (node.nodeType == 3) {
70
- result = node.nodeValue;
71
- }
72
- return(result);
73
- }
74
-
75
- function slideLabel() {
76
- var slideColl = GetElementsWithClassName('*','slide');
77
- var list = document.getElementById('jumplist');
78
- smax = slideColl.length;
79
- for (var n = 0; n < smax; n++) {
80
- var obj = slideColl[n];
81
-
82
- var did = 'slide' + n.toString();
83
- obj.setAttribute('id',did);
84
- if (isOp) continue;
85
-
86
- var otext = '';
87
- var menu = obj.firstChild;
88
- if (!menu) continue; // to cope with empty slides
89
- while (menu && menu.nodeType == 3) {
90
- menu = menu.nextSibling;
91
- }
92
- if (!menu) continue; // to cope with slides with only text nodes
93
-
94
- var menunodes = menu.childNodes;
95
- for (var o = 0; o < menunodes.length; o++) {
96
- otext += nodeValue(menunodes[o]);
97
- }
98
- list.options[list.length] = new Option(n + ' : ' + otext, n);
99
- }
100
- }
101
-
102
- function currentSlide() {
103
- var cs;
104
- if (document.getElementById) {
105
- cs = document.getElementById('currentSlide');
106
- } else {
107
- cs = document.currentSlide;
108
- }
109
- cs.innerHTML = '<span id="csHere">' + snum + '<\/span> ' +
110
- '<span id="csSep">\/<\/span> ' +
111
- '<span id="csTotal">' + (smax-1) + '<\/span>';
112
- if (snum == 0) {
113
- cs.style.visibility = 'hidden';
114
- } else {
115
- cs.style.visibility = 'visible';
116
- }
117
- }
118
-
119
- function go(step) {
120
- if (document.getElementById('slideProj').disabled || step == 0) return;
121
- var jl = document.getElementById('jumplist');
122
- var cid = 'slide' + snum;
123
- var ce = document.getElementById(cid);
124
- if (incrementals[snum].length > 0) {
125
- for (var i = 0; i < incrementals[snum].length; i++) {
126
- removeClass(incrementals[snum][i], 'current');
127
- removeClass(incrementals[snum][i], 'incremental');
128
- }
129
- }
130
- if (step != 'j') {
131
- snum += step;
132
- lmax = smax - 1;
133
- if (snum > lmax) snum = lmax;
134
- if (snum < 0) snum = 0;
135
- } else
136
- snum = parseInt(jl.value);
137
- var nid = 'slide' + snum;
138
- var ne = document.getElementById(nid);
139
- if (!ne) {
140
- ne = document.getElementById('slide0');
141
- snum = 0;
142
- }
143
- if (step < 0) {incpos = incrementals[snum].length} else {incpos = 0;}
144
- if (incrementals[snum].length > 0 && incpos == 0) {
145
- for (var i = 0; i < incrementals[snum].length; i++) {
146
- if (hasClass(incrementals[snum][i], 'current'))
147
- incpos = i + 1;
148
- else
149
- addClass(incrementals[snum][i], 'incremental');
150
- }
151
- }
152
- if (incrementals[snum].length > 0 && incpos > 0)
153
- addClass(incrementals[snum][incpos - 1], 'current');
154
- ce.style.visibility = 'hidden';
155
- ne.style.visibility = 'visible';
156
- jl.selectedIndex = snum;
157
- currentSlide();
158
- number = 0;
159
- }
160
-
161
- function goTo(target) {
162
- if (target >= smax || target == snum) return;
163
- go(target - snum);
164
- }
165
-
166
- function subgo(step) {
167
- if (step > 0) {
168
- removeClass(incrementals[snum][incpos - 1],'current');
169
- removeClass(incrementals[snum][incpos], 'incremental');
170
- addClass(incrementals[snum][incpos],'current');
171
- incpos++;
172
- } else {
173
- incpos--;
174
- removeClass(incrementals[snum][incpos],'current');
175
- addClass(incrementals[snum][incpos], 'incremental');
176
- addClass(incrementals[snum][incpos - 1],'current');
177
- }
178
- }
179
-
180
- function toggle() {
181
- var slideColl = GetElementsWithClassName('*','slide');
182
- var slides = document.getElementById('slideProj');
183
- var outline = document.getElementById('outlineStyle');
184
- if (!slides.disabled) {
185
- slides.disabled = true;
186
- outline.disabled = false;
187
- s5mode = false;
188
- fontSize('1em');
189
- for (var n = 0; n < smax; n++) {
190
- var slide = slideColl[n];
191
- slide.style.visibility = 'visible';
192
- }
193
- } else {
194
- slides.disabled = false;
195
- outline.disabled = true;
196
- s5mode = true;
197
- fontScale();
198
- for (var n = 0; n < smax; n++) {
199
- var slide = slideColl[n];
200
- slide.style.visibility = 'hidden';
201
- }
202
- slideColl[snum].style.visibility = 'visible';
203
- }
204
- }
205
-
206
- function showHide(action) {
207
- var obj = GetElementsWithClassName('*','hideme')[0];
208
- switch (action) {
209
- case 's': obj.style.visibility = 'visible'; break;
210
- case 'h': obj.style.visibility = 'hidden'; break;
211
- case 'k':
212
- if (obj.style.visibility != 'visible') {
213
- obj.style.visibility = 'visible';
214
- } else {
215
- obj.style.visibility = 'hidden';
216
- }
217
- break;
218
- }
219
- }
220
-
221
- // 'keys' code adapted from MozPoint (http://mozpoint.mozdev.org/)
222
- function keys(key) {
223
- if (!key) {
224
- key = event;
225
- key.which = key.keyCode;
226
- }
227
- if (key.which == 84) {
228
- toggle();
229
- return;
230
- }
231
- if (s5mode) {
232
- switch (key.which) {
233
- case 10: // return
234
- case 13: // enter
235
- if (window.event && isParentOrSelf(window.event.srcElement, 'controls')) return;
236
- if (key.target && isParentOrSelf(key.target, 'controls')) return;
237
- if(number != undef) {
238
- goTo(number);
239
- break;
240
- }
241
- case 32: // spacebar
242
- case 34: // page down
243
- case 39: // rightkey
244
- case 40: // downkey
245
- if(number != undef) {
246
- go(number);
247
- } else if (!incrementals[snum] || incpos >= incrementals[snum].length) {
248
- go(1);
249
- } else {
250
- subgo(1);
251
- }
252
- break;
253
- case 33: // page up
254
- case 37: // leftkey
255
- case 38: // upkey
256
- if(number != undef) {
257
- go(-1 * number);
258
- } else if (!incrementals[snum] || incpos <= 0) {
259
- go(-1);
260
- } else {
261
- subgo(-1);
262
- }
263
- break;
264
- case 36: // home
265
- goTo(0);
266
- break;
267
- case 35: // end
268
- goTo(smax-1);
269
- break;
270
- case 67: // c
271
- showHide('k');
272
- break;
273
- }
274
- if (key.which < 48 || key.which > 57) {
275
- number = undef;
276
- } else {
277
- if (window.event && isParentOrSelf(window.event.srcElement, 'controls')) return;
278
- if (key.target && isParentOrSelf(key.target, 'controls')) return;
279
- number = (((number != undef) ? number : 0) * 10) + (key.which - 48);
280
- }
281
- }
282
- return false;
283
- }
284
-
285
- function clicker(e) {
286
- number = undef;
287
- var target;
288
- if (window.event) {
289
- target = window.event.srcElement;
290
- e = window.event;
291
- } else target = e.target;
292
- if (target.getAttribute('href') != null || hasValue(target.rel, 'external') || isParentOrSelf(target, 'controls') || isParentOrSelf(target,'embed') || isParentOrSelf(target,'object')) return true;
293
- if (!e.which || e.which == 1) {
294
- if (!incrementals[snum] || incpos >= incrementals[snum].length) {
295
- go(1);
296
- } else {
297
- subgo(1);
298
- }
299
- }
300
- }
301
-
302
- function findSlide(hash) {
303
- var target = null;
304
- var slides = GetElementsWithClassName('*','slide');
305
- for (var i = 0; i < slides.length; i++) {
306
- var targetSlide = slides[i];
307
- if ( (targetSlide.name && targetSlide.name == hash)
308
- || (targetSlide.id && targetSlide.id == hash) ) {
309
- target = targetSlide;
310
- break;
311
- }
312
- }
313
- while(target != null && target.nodeName != 'BODY') {
314
- if (hasClass(target, 'slide')) {
315
- return parseInt(target.id.slice(5));
316
- }
317
- target = target.parentNode;
318
- }
319
- return null;
320
- }
321
-
322
- function slideJump() {
323
- if (window.location.hash == null) return;
324
- var sregex = /^#slide(\d+)$/;
325
- var matches = sregex.exec(window.location.hash);
326
- var dest = null;
327
- if (matches != null) {
328
- dest = parseInt(matches[1]);
329
- } else {
330
- dest = findSlide(window.location.hash.slice(1));
331
- }
332
- if (dest != null)
333
- go(dest - snum);
334
- }
335
-
336
- function fixLinks() {
337
- var thisUri = window.location.href;
338
- thisUri = thisUri.slice(0, thisUri.length - window.location.hash.length);
339
- var aelements = document.getElementsByTagName('A');
340
- for (var i = 0; i < aelements.length; i++) {
341
- var a = aelements[i].href;
342
- var slideID = a.match('\#slide[0-9]{1,2}');
343
- if ((slideID) && (slideID[0].slice(0,1) == '#')) {
344
- var dest = findSlide(slideID[0].slice(1));
345
- if (dest != null) {
346
- if (aelements[i].addEventListener) {
347
- aelements[i].addEventListener("click", new Function("e",
348
- "if (document.getElementById('slideProj').disabled) return;" +
349
- "go("+dest+" - snum); " +
350
- "if (e.preventDefault) e.preventDefault();"), true);
351
- } else if (aelements[i].attachEvent) {
352
- aelements[i].attachEvent("onclick", new Function("",
353
- "if (document.getElementById('slideProj').disabled) return;" +
354
- "go("+dest+" - snum); " +
355
- "event.returnValue = false;"));
356
- }
357
- }
358
- }
359
- }
360
- }
361
-
362
- function externalLinks() {
363
- if (!document.getElementsByTagName) return;
364
- var anchors = document.getElementsByTagName('a');
365
- for (var i=0; i<anchors.length; i++) {
366
- var anchor = anchors[i];
367
- if (anchor.getAttribute('href') && hasValue(anchor.rel, 'external')) {
368
- anchor.target = '_blank';
369
- addClass(anchor,'external');
370
- }
371
- }
372
- }
373
-
374
- function createControls() {
375
- var controlsDiv = document.getElementById("controls");
376
- if (!controlsDiv) return;
377
- var hider = ' onmouseover="showHide(\'s\');" onmouseout="showHide(\'h\');"';
378
- var hideDiv, hideList = '';
379
- if (controlVis == 'hidden') {
380
- hideDiv = hider;
381
- } else {
382
- hideList = hider;
383
- }
384
- controlsDiv.innerHTML = '<form action="#" id="controlForm"' + hideDiv + '>' +
385
- '<div id="navLinks">' +
386
- '<a accesskey="t" id="toggle" href="javascript:toggle();">&#216;<\/a>' +
387
- '<a accesskey="z" id="prev" href="javascript:go(-1);">&laquo;<\/a>' +
388
- '<a accesskey="x" id="next" href="javascript:go(1);">&raquo;<\/a>' +
389
- '<div id="navList"' + hideList + '><select id="jumplist" onchange="go(\'j\');"><\/select><\/div>' +
390
- '<\/div><\/form>';
391
- if (controlVis == 'hidden') {
392
- var hidden = document.getElementById('navLinks');
393
- } else {
394
- var hidden = document.getElementById('jumplist');
395
- }
396
- addClass(hidden,'hideme');
397
- }
398
-
399
- function fontScale() { // causes layout problems in FireFox that get fixed if browser's Reload is used; same may be true of other Gecko-based browsers
400
- if (!s5mode) return false;
401
- var vScale = 22; // both yield 32 (after rounding) at 1024x768
402
- var hScale = 32; // perhaps should auto-calculate based on theme's declared value?
403
- if (window.innerHeight) {
404
- var vSize = window.innerHeight;
405
- var hSize = window.innerWidth;
406
- } else if (document.documentElement.clientHeight) {
407
- var vSize = document.documentElement.clientHeight;
408
- var hSize = document.documentElement.clientWidth;
409
- } else if (document.body.clientHeight) {
410
- var vSize = document.body.clientHeight;
411
- var hSize = document.body.clientWidth;
412
- } else {
413
- var vSize = 700; // assuming 1024x768, minus chrome and such
414
- var hSize = 1024; // these do not account for kiosk mode or Opera Show
415
- }
416
- var newSize = Math.min(Math.round(vSize/vScale),Math.round(hSize/hScale));
417
- fontSize(newSize + 'px');
418
- if (isGe) { // hack to counter incremental reflow bugs
419
- var obj = document.getElementsByTagName('body')[0];
420
- obj.style.display = 'none';
421
- obj.style.display = 'block';
422
- }
423
- }
424
-
425
- function fontSize(value) {
426
- if (!(s5ss = document.getElementById('s5ss'))) {
427
- if (!isIE) {
428
- document.getElementsByTagName('head')[0].appendChild(s5ss = document.createElement('style'));
429
- s5ss.setAttribute('media','screen, projection');
430
- s5ss.setAttribute('id','s5ss');
431
- } else {
432
- document.createStyleSheet();
433
- document.s5ss = document.styleSheets[document.styleSheets.length - 1];
434
- }
435
- }
436
- if (!isIE) {
437
- while (s5ss.lastChild) s5ss.removeChild(s5ss.lastChild);
438
- s5ss.appendChild(document.createTextNode('body {font-size: ' + value + ' !important;}'));
439
- } else {
440
- document.s5ss.addRule('body','font-size: ' + value + ' !important;');
441
- }
442
- }
443
-
444
- function notOperaFix() {
445
- slideCSS = document.getElementById('slideProj').href;
446
- var slides = document.getElementById('slideProj');
447
- var outline = document.getElementById('outlineStyle');
448
- slides.setAttribute('media','screen');
449
- outline.disabled = true;
450
- if (isGe) {
451
- slides.setAttribute('href','null'); // Gecko fix
452
- slides.setAttribute('href',slideCSS); // Gecko fix
453
- }
454
- if (isIE && document.styleSheets && document.styleSheets[0]) {
455
- document.styleSheets[0].addRule('img', 'behavior: url(ui/default/iepngfix.htc)');
456
- document.styleSheets[0].addRule('div', 'behavior: url(ui/default/iepngfix.htc)');
457
- document.styleSheets[0].addRule('.slide', 'behavior: url(ui/default/iepngfix.htc)');
458
- }
459
- }
460
-
461
- function getIncrementals(obj) {
462
- var incrementals = new Array();
463
- if (!obj)
464
- return incrementals;
465
- var children = obj.childNodes;
466
- for (var i = 0; i < children.length; i++) {
467
- var child = children[i];
468
- if (hasClass(child, 'incremental')) {
469
- if (child.nodeName == 'OL' || child.nodeName == 'UL') {
470
- removeClass(child, 'incremental');
471
- for (var j = 0; j < child.childNodes.length; j++) {
472
- if (child.childNodes[j].nodeType == 1) {
473
- addClass(child.childNodes[j], 'incremental');
474
- }
475
- }
476
- } else {
477
- incrementals[incrementals.length] = child;
478
- removeClass(child,'incremental');
479
- }
480
- }
481
- if (hasClass(child, 'show-first')) {
482
- if (child.nodeName == 'OL' || child.nodeName == 'UL') {
483
- removeClass(child, 'show-first');
484
- if (child.childNodes[isGe].nodeType == 1) {
485
- removeClass(child.childNodes[isGe], 'incremental');
486
- }
487
- } else {
488
- incrementals[incrementals.length] = child;
489
- }
490
- }
491
- incrementals = incrementals.concat(getIncrementals(child));
492
- }
493
- return incrementals;
494
- }
495
-
496
- function createIncrementals() {
497
- var incrementals = new Array();
498
- for (var i = 0; i < smax; i++) {
499
- incrementals[i] = getIncrementals(document.getElementById('slide'+i));
500
- }
501
- return incrementals;
502
- }
503
-
504
- function defaultCheck() {
505
- var allMetas = document.getElementsByTagName('meta');
506
- for (var i = 0; i< allMetas.length; i++) {
507
- if (allMetas[i].name == 'defaultView') {
508
- defaultView = allMetas[i].content;
509
- }
510
- if (allMetas[i].name == 'controlVis') {
511
- controlVis = allMetas[i].content;
512
- }
513
- }
514
- }
515
-
516
- // Key trap fix, new function body for trap()
517
- function trap(e) {
518
- if (!e) {
519
- e = event;
520
- e.which = e.keyCode;
521
- }
522
- try {
523
- modifierKey = e.ctrlKey || e.altKey || e.metaKey;
524
- }
525
- catch(e) {
526
- modifierKey = false;
527
- }
528
- return modifierKey || e.which == 0;
529
- }
530
-
531
- function startup() {
532
- defaultCheck();
533
- if (!isOp)
534
- createControls();
535
- slideLabel();
536
- fixLinks();
537
- externalLinks();
538
- fontScale();
539
- if (!isOp) {
540
- notOperaFix();
541
- incrementals = createIncrementals();
542
- slideJump();
543
- if (defaultView == 'outline') {
544
- toggle();
545
- }
546
- document.onkeyup = keys;
547
- document.onkeypress = trap;
548
- document.onclick = clicker;
549
- }
550
- }
551
-
552
- window.onload = startup;
553
- window.onresize = function(){setTimeout('fontScale()', 50);}