hobix 0.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (156) hide show
  1. data/COPYING +18 -0
  2. data/README +18 -0
  3. data/Rakefile +96 -0
  4. data/bin/hobix +94 -0
  5. data/contrib/blosxom-to-hobix.rb +253 -0
  6. data/contrib/txp-to-hobix.rb +56 -0
  7. data/contrib/webrick-all-mine.rb +20 -0
  8. data/doc/CHANGELOG +285 -0
  9. data/doc/rdoc/classes/Hobix/API.html +382 -0
  10. data/doc/rdoc/classes/Hobix/Article.html +111 -0
  11. data/doc/rdoc/classes/Hobix/BaseContent.html +692 -0
  12. data/doc/rdoc/classes/Hobix/BaseEntry.html +218 -0
  13. data/doc/rdoc/classes/Hobix/BaseFacet.html +205 -0
  14. data/doc/rdoc/classes/Hobix/BaseOutput.html +122 -0
  15. data/doc/rdoc/classes/Hobix/BasePlugin.html +201 -0
  16. data/doc/rdoc/classes/Hobix/BaseProperties/ClassMethods.html +243 -0
  17. data/doc/rdoc/classes/Hobix/BaseProperties.html +218 -0
  18. data/doc/rdoc/classes/Hobix/BasePublish.html +157 -0
  19. data/doc/rdoc/classes/Hobix/BaseStorage.html +417 -0
  20. data/doc/rdoc/classes/Hobix/BixWik/Entry.html +196 -0
  21. data/doc/rdoc/classes/Hobix/BixWik/IndexEntry.html +170 -0
  22. data/doc/rdoc/classes/Hobix/BixWik/WikiRedCloth.html +111 -0
  23. data/doc/rdoc/classes/Hobix/BixWik.html +418 -0
  24. data/doc/rdoc/classes/Hobix/BixWikPlugin.html +158 -0
  25. data/doc/rdoc/classes/Hobix/CommandLine.html +1970 -0
  26. data/doc/rdoc/classes/Hobix/Comment.html +113 -0
  27. data/doc/rdoc/classes/Hobix/Config.html +212 -0
  28. data/doc/rdoc/classes/Hobix/DataMarsh.html +667 -0
  29. data/doc/rdoc/classes/Hobix/Entry.html +178 -0
  30. data/doc/rdoc/classes/Hobix/EntryEnum.html +162 -0
  31. data/doc/rdoc/classes/Hobix/Enumerable.html +170 -0
  32. data/doc/rdoc/classes/Hobix/Facets/WikiEdit.html +180 -0
  33. data/doc/rdoc/classes/Hobix/Facets.html +111 -0
  34. data/doc/rdoc/classes/Hobix/LinkList.html +182 -0
  35. data/doc/rdoc/classes/Hobix/Out/Quick.html +412 -0
  36. data/doc/rdoc/classes/Hobix/Out.html +119 -0
  37. data/doc/rdoc/classes/Hobix/Page.html +381 -0
  38. data/doc/rdoc/classes/Hobix/Trackback.html +113 -0
  39. data/doc/rdoc/classes/Hobix/UriStr.html +198 -0
  40. data/doc/rdoc/classes/Hobix/WebApp/QueryString.html +207 -0
  41. data/doc/rdoc/classes/Hobix/WebApp/QueryValidationFailure.html +111 -0
  42. data/doc/rdoc/classes/Hobix/WebApp.html +1383 -0
  43. data/doc/rdoc/classes/Hobix/Weblog/AuthorNotFound.html +111 -0
  44. data/doc/rdoc/classes/Hobix/Weblog.html +2082 -0
  45. data/doc/rdoc/classes/Hobix.html +399 -0
  46. data/doc/rdoc/classes/Kernel.html +139 -0
  47. data/doc/rdoc/classes/Regexp.html +154 -0
  48. data/doc/rdoc/classes/YAML/Omap.html +144 -0
  49. data/doc/rdoc/classes/YAML.html +111 -0
  50. data/doc/rdoc/created.rid +1 -0
  51. data/doc/rdoc/files/COPYING.html +129 -0
  52. data/doc/rdoc/files/README.html +131 -0
  53. data/doc/rdoc/files/doc/CHANGELOG.html +101 -0
  54. data/doc/rdoc/files/lib/hobix/api_rb.html +119 -0
  55. data/doc/rdoc/files/lib/hobix/article_rb.html +126 -0
  56. data/doc/rdoc/files/lib/hobix/base_rb.html +128 -0
  57. data/doc/rdoc/files/lib/hobix/bixwik_rb.html +126 -0
  58. data/doc/rdoc/files/lib/hobix/commandline_rb.html +140 -0
  59. data/doc/rdoc/files/lib/hobix/comments_rb.html +126 -0
  60. data/doc/rdoc/files/lib/hobix/config_rb.html +125 -0
  61. data/doc/rdoc/files/lib/hobix/datamarsh_rb.html +108 -0
  62. data/doc/rdoc/files/lib/hobix/entry_rb.html +118 -0
  63. data/doc/rdoc/files/lib/hobix/linklist_rb.html +127 -0
  64. data/doc/rdoc/files/lib/hobix/publisher_rb.html +126 -0
  65. data/doc/rdoc/files/lib/hobix/trackbacks_rb.html +128 -0
  66. data/doc/rdoc/files/lib/hobix/webapp_rb.html +127 -0
  67. data/doc/rdoc/files/lib/hobix/weblog_rb.html +135 -0
  68. data/doc/rdoc/files/lib/hobix_rb.html +127 -0
  69. data/doc/rdoc/fr_class_index.html +67 -0
  70. data/doc/rdoc/fr_file_index.html +44 -0
  71. data/doc/rdoc/fr_method_index.html +307 -0
  72. data/doc/rdoc/index.html +24 -0
  73. data/doc/rdoc/rdoc-style.css +208 -0
  74. data/git_hobix_update.php +13 -0
  75. data/lib/hobix/api.rb +91 -0
  76. data/lib/hobix/article.rb +22 -0
  77. data/lib/hobix/base.rb +480 -0
  78. data/lib/hobix/bixwik.rb +200 -0
  79. data/lib/hobix/commandline.rb +677 -0
  80. data/lib/hobix/comments.rb +98 -0
  81. data/lib/hobix/config.rb +39 -0
  82. data/lib/hobix/datamarsh.rb +110 -0
  83. data/lib/hobix/entry.rb +84 -0
  84. data/lib/hobix/facets/comments.rb +99 -0
  85. data/lib/hobix/facets/publisher.rb +314 -0
  86. data/lib/hobix/facets/trackbacks.rb +80 -0
  87. data/lib/hobix/linklist.rb +81 -0
  88. data/lib/hobix/out/atom.rb +101 -0
  89. data/lib/hobix/out/erb.rb +64 -0
  90. data/lib/hobix/out/okaynews.rb +55 -0
  91. data/lib/hobix/out/quick.rb +314 -0
  92. data/lib/hobix/out/rdf.rb +97 -0
  93. data/lib/hobix/out/redrum.rb +26 -0
  94. data/lib/hobix/out/rss.rb +128 -0
  95. data/lib/hobix/plugin/akismet.rb +196 -0
  96. data/lib/hobix/plugin/bloglines.rb +73 -0
  97. data/lib/hobix/plugin/calendar.rb +212 -0
  98. data/lib/hobix/plugin/flickr.rb +110 -0
  99. data/lib/hobix/plugin/recent_comments.rb +84 -0
  100. data/lib/hobix/plugin/sections.rb +91 -0
  101. data/lib/hobix/plugin/tags.rb +60 -0
  102. data/lib/hobix/publish/ping.rb +53 -0
  103. data/lib/hobix/publish/replicate.rb +283 -0
  104. data/lib/hobix/publisher.rb +18 -0
  105. data/lib/hobix/search/dictionary.rb +141 -0
  106. data/lib/hobix/search/porter_stemmer.rb +203 -0
  107. data/lib/hobix/search/simple.rb +209 -0
  108. data/lib/hobix/search/vector.rb +100 -0
  109. data/lib/hobix/storage/filesys.rb +408 -0
  110. data/lib/hobix/trackbacks.rb +93 -0
  111. data/lib/hobix/util/objedit.rb +193 -0
  112. data/lib/hobix/util/patcher.rb +155 -0
  113. data/lib/hobix/webapp/cli.rb +195 -0
  114. data/lib/hobix/webapp/htmlform.rb +107 -0
  115. data/lib/hobix/webapp/message.rb +177 -0
  116. data/lib/hobix/webapp/urigen.rb +141 -0
  117. data/lib/hobix/webapp/webrick-servlet.rb +90 -0
  118. data/lib/hobix/webapp.rb +723 -0
  119. data/lib/hobix/weblog.rb +893 -0
  120. data/lib/hobix.rb +230 -0
  121. data/share/default-blog/hobix.yaml +16 -0
  122. data/share/default-blog/htdocs/site.css +174 -0
  123. data/share/default-blog/skel/entry.html.quick +0 -0
  124. data/share/default-blog/skel/index.atom.atom +0 -0
  125. data/share/default-blog/skel/index.html.quick-summary +0 -0
  126. data/share/default-blog/skel/index.xml.rss +0 -0
  127. data/share/default-blog/skel/index.yaml.okaynews +0 -0
  128. data/share/default-blog/skel/monthly.html.quick-archive +0 -0
  129. data/share/default-blog/skel/section.html.quick-archive +0 -0
  130. data/share/default-blog/skel/yearly.html.quick-archive +0 -0
  131. data/share/default-blog-modes.yaml +7 -0
  132. data/share/default-blog.apache-cgi.patch +8 -0
  133. data/share/default-blog.apache-ssi.patch +38 -0
  134. data/share/default-blog.apache2-ssi.patch +3 -0
  135. data/share/default-blog.cgi.patch +8 -0
  136. data/share/default-blog.comments.patch +5 -0
  137. data/share/default-blog.prototype.patch +766 -0
  138. data/share/default-blog.publisher.patch +5 -0
  139. data/share/default-blog.wiki.patch +29 -0
  140. data/share/publisher/css/control.css +90 -0
  141. data/share/publisher/css/form.css +238 -0
  142. data/share/publisher/css/form.import.css +72 -0
  143. data/share/publisher/css/main-menu.css +134 -0
  144. data/share/publisher/i/hobix-emblazen-1.png +0 -0
  145. data/share/publisher/i/hobix-emblazen-2.png +0 -0
  146. data/share/publisher/i/hobix-emblazen-3.png +0 -0
  147. data/share/publisher/i/hobix-emblazen-4.png +0 -0
  148. data/share/publisher/i/hobix-emblazen-5.png +0 -0
  149. data/share/publisher/i/hobix-emblazen-6.png +0 -0
  150. data/share/publisher/i/hobix-emblazen-7.png +0 -0
  151. data/share/publisher/index.erb +66 -0
  152. data/share/publisher/js/controls.js +261 -0
  153. data/share/publisher/js/dragdrop.js +476 -0
  154. data/share/publisher/js/effects.js +570 -0
  155. data/share/publisher/js/prototype.js +1011 -0
  156. metadata +230 -0
@@ -0,0 +1,570 @@
1
+ // Copyright (c) 2005 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us)
2
+ //
3
+ // Parts (c) 2005 Justin Palmer (http://encytemedia.com/)
4
+ // Parts (c) 2005 Mark Pilgrim (http://diveintomark.org/)
5
+ //
6
+ // Permission is hereby granted, free of charge, to any person obtaining
7
+ // a copy of this software and associated documentation files (the
8
+ // "Software"), to deal in the Software without restriction, including
9
+ // without limitation the rights to use, copy, modify, merge, publish,
10
+ // distribute, sublicense, and/or sell copies of the Software, and to
11
+ // permit persons to whom the Software is furnished to do so, subject to
12
+ // the following conditions:
13
+ //
14
+ // The above copyright notice and this permission notice shall be
15
+ // included in all copies or substantial portions of the Software.
16
+ //
17
+ // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
18
+ // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
+ // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20
+ // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
21
+ // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
22
+ // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
23
+ // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24
+
25
+
26
+ Effect = {}
27
+ Effect2 = Effect; // deprecated
28
+
29
+ /* ------------- transitions ------------- */
30
+
31
+ Effect.Transitions = {}
32
+
33
+ Effect.Transitions.linear = function(pos) {
34
+ return pos;
35
+ }
36
+ Effect.Transitions.sinoidal = function(pos) {
37
+ return (-Math.cos(pos*Math.PI)/2) + 0.5;
38
+ }
39
+ Effect.Transitions.reverse = function(pos) {
40
+ return 1-pos;
41
+ }
42
+ Effect.Transitions.flicker = function(pos) {
43
+ return ((-Math.cos(pos*Math.PI)/4) + 0.75) + Math.random(0.25);
44
+ }
45
+ Effect.Transitions.wobble = function(pos) {
46
+ return (-Math.cos(pos*Math.PI*(9*pos))/2) + 0.5;
47
+ }
48
+ Effect.Transitions.pulse = function(pos) {
49
+ return (Math.floor(pos*10) % 2 == 0 ?
50
+ (pos*10-Math.floor(pos*10)) : 1-(pos*10-Math.floor(pos*10)));
51
+ }
52
+
53
+ Effect.Transitions.none = function(pos) {
54
+ return 0;
55
+ }
56
+ Effect.Transitions.full = function(pos) {
57
+ return 1;
58
+ }
59
+
60
+ /* ------------- core effects ------------- */
61
+
62
+ Effect.Base = function() {};
63
+ Effect.Base.prototype = {
64
+ setOptions: function(options) {
65
+ this.options = {
66
+ transition: Effect.Transitions.sinoidal,
67
+ duration: 1.0, // seconds
68
+ fps: 25.0, // max. 100fps
69
+ sync: false, // true for combining
70
+ from: 0.0,
71
+ to: 1.0
72
+ }.extend(options || {});
73
+ },
74
+ start: function(options) {
75
+ this.setOptions(options || {});
76
+ this.currentFrame = 0;
77
+ this.startOn = new Date().getTime();
78
+ this.finishOn = this.startOn + (this.options.duration*1000);
79
+ if(this.options.beforeStart) this.options.beforeStart(this);
80
+ if(!this.options.sync) this.loop();
81
+ },
82
+ loop: function() {
83
+ timePos = new Date().getTime();
84
+ if(timePos >= this.finishOn) {
85
+ this.render(this.options.to);
86
+ if(this.finish) this.finish();
87
+ if(this.options.afterFinish) this.options.afterFinish(this);
88
+ return;
89
+ }
90
+ pos = (timePos - this.startOn) / (this.finishOn - this.startOn);
91
+ frame = Math.round(pos * this.options.fps * this.options.duration);
92
+ if(frame > this.currentFrame) {
93
+ this.render(pos);
94
+ this.currentFrame = frame;
95
+ }
96
+ this.timeout = setTimeout(this.loop.bind(this), 10);
97
+ },
98
+ render: function(pos) {
99
+ if(this.options.transition) pos = this.options.transition(pos);
100
+ pos = pos * (this.options.to-this.options.from);
101
+ pos += this.options.from;
102
+ if(this.options.beforeUpdate) this.options.beforeUpdate(this);
103
+ if(this.update) this.update(pos);
104
+ if(this.options.afterUpdate) this.options.afterUpdate(this);
105
+ },
106
+ cancel: function() {
107
+ if(this.timeout) clearTimeout(this.timeout);
108
+ }
109
+ }
110
+
111
+ Effect.Parallel = Class.create();
112
+ Effect.Parallel.prototype = (new Effect.Base()).extend({
113
+ initialize: function(effects) {
114
+ this.effects = effects || [];
115
+ this.start(arguments[1]);
116
+ },
117
+ update: function(position) {
118
+ for (var i = 0; i < this.effects.length; i++)
119
+ this.effects[i].render(position);
120
+ },
121
+ finish: function(position) {
122
+ for (var i = 0; i < this.effects.length; i++)
123
+ if(this.effects[i].finish) this.effects[i].finish(position);
124
+ }
125
+ });
126
+
127
+ // Internet Explorer caveat: works only on elements the have
128
+ // a 'layout', meaning having a given width or height.
129
+ // There is no way to safely set this automatically.
130
+ Effect.Opacity = Class.create();
131
+ Effect.Opacity.prototype = (new Effect.Base()).extend({
132
+ initialize: function(element) {
133
+ this.element = $(element);
134
+ options = {
135
+ from: 0.0,
136
+ to: 1.0
137
+ }.extend(arguments[1] || {});
138
+ this.start(options);
139
+ },
140
+ update: function(position) {
141
+ this.setOpacity(position);
142
+ },
143
+ setOpacity: function(opacity) {
144
+ opacity = (opacity == 1) ? 0.99999 : opacity;
145
+ this.element.style.opacity = opacity;
146
+ this.element.style.filter = "alpha(opacity:"+opacity*100+")";
147
+ }
148
+ });
149
+
150
+ Effect.MoveBy = Class.create();
151
+ Effect.MoveBy.prototype = (new Effect.Base()).extend({
152
+ initialize: function(element, toTop, toLeft) {
153
+ this.element = $(element);
154
+ this.originalTop = parseFloat(this.element.style.top || '0');
155
+ this.originalLeft = parseFloat(this.element.style.left || '0');
156
+ this.toTop = toTop;
157
+ this.toLeft = toLeft;
158
+ if(this.element.style.position == "")
159
+ this.element.style.position = "relative";
160
+ this.start(arguments[3]);
161
+ },
162
+ update: function(position) {
163
+ topd = this.toTop * position + this.originalTop;
164
+ leftd = this.toLeft * position + this.originalLeft;
165
+ this.setPosition(topd, leftd);
166
+ },
167
+ setPosition: function(topd, leftd) {
168
+ this.element.style.top = topd + "px";
169
+ this.element.style.left = leftd + "px";
170
+ }
171
+ });
172
+
173
+ Effect.Scale = Class.create();
174
+ Effect.Scale.prototype = (new Effect.Base()).extend({
175
+ initialize: function(element, percent) {
176
+ this.element = $(element)
177
+ options = {
178
+ scaleX: true,
179
+ scaleY: true,
180
+ scaleContent: true,
181
+ scaleFromCenter: false,
182
+ scaleMode: 'box', // 'box' or 'contents' or {} with provided values
183
+ scaleFrom: 100.0
184
+ }.extend(arguments[2] || {});
185
+ this.originalTop = this.element.offsetTop;
186
+ this.originalLeft = this.element.offsetLeft;
187
+ if (this.element.style.fontSize=="") this.sizeEm = 1.0;
188
+ if (this.element.style.fontSize && this.element.style.fontSize.indexOf("em")>0)
189
+ this.sizeEm = parseFloat(this.element.style.fontSize);
190
+ this.factor = (percent/100.0) - (options.scaleFrom/100.0);
191
+ if(options.scaleMode=='box') {
192
+ this.originalHeight = this.element.clientHeight;
193
+ this.originalWidth = this.element.clientWidth;
194
+ } else
195
+ if(options.scaleMode=='contents') {
196
+ this.originalHeight = this.element.scrollHeight;
197
+ this.originalWidth = this.element.scrollWidth;
198
+ } else {
199
+ this.originalHeight = options.scaleMode.originalHeight;
200
+ this.originalWidth = options.scaleMode.originalWidth;
201
+ }
202
+ this.start(options);
203
+ },
204
+
205
+ update: function(position) {
206
+ currentScale = (this.options.scaleFrom/100.0) + (this.factor * position);
207
+ if(this.options.scaleContent && this.sizeEm)
208
+ this.element.style.fontSize = this.sizeEm*currentScale + "em";
209
+ this.setDimensions(
210
+ this.originalWidth * currentScale,
211
+ this.originalHeight * currentScale);
212
+ },
213
+
214
+ setDimensions: function(width, height) {
215
+ if(this.options.scaleX) this.element.style.width = width + 'px';
216
+ if(this.options.scaleY) this.element.style.height = height + 'px';
217
+ if(this.options.scaleFromCenter) {
218
+ topd = (height - this.originalHeight)/2;
219
+ leftd = (width - this.originalWidth)/2;
220
+ if(this.element.style.position=='absolute') {
221
+ if(this.options.scaleY) this.element.style.top = this.originalTop-topd + "px";
222
+ if(this.options.scaleX) this.element.style.left = this.originalLeft-leftd + "px";
223
+ } else {
224
+ if(this.options.scaleY) this.element.style.top = -topd + "px";
225
+ if(this.options.scaleX) this.element.style.left = -leftd + "px";
226
+ }
227
+ }
228
+ }
229
+ });
230
+
231
+ Effect.Highlight = Class.create();
232
+ Effect.Highlight.prototype = (new Effect.Base()).extend({
233
+ initialize: function(element) {
234
+ this.element = $(element);
235
+
236
+ // try to parse current background color as default for endcolor
237
+ // browser stores this as: "rgb(255, 255, 255)", convert to "#ffffff" format
238
+ var endcolor = "#ffffff";
239
+ var current = this.element.style.backgroundColor;
240
+ if(current && current.slice(0,4) == "rgb(") {
241
+ endcolor = "#";
242
+ var cols = current.slice(4,current.length-1).split(',');
243
+ var i=0; do { endcolor += parseInt(cols[i]).toColorPart() } while (++i<3); }
244
+
245
+ var options = {
246
+ startcolor: "#ffff99",
247
+ endcolor: endcolor
248
+ }.extend(arguments[1] || {});
249
+
250
+ // init color calculations
251
+ this.colors_base = [
252
+ parseInt(options.startcolor.slice(1,3),16),
253
+ parseInt(options.startcolor.slice(3,5),16),
254
+ parseInt(options.startcolor.slice(5),16) ];
255
+ this.colors_delta = [
256
+ parseInt(options.endcolor.slice(1,3),16)-this.colors_base[0],
257
+ parseInt(options.endcolor.slice(3,5),16)-this.colors_base[1],
258
+ parseInt(options.endcolor.slice(5),16)-this.colors_base[2] ];
259
+
260
+ this.start(options);
261
+ },
262
+ update: function(position) {
263
+ var colors = [
264
+ Math.round(this.colors_base[0]+(this.colors_delta[0]*position)),
265
+ Math.round(this.colors_base[1]+(this.colors_delta[1]*position)),
266
+ Math.round(this.colors_base[2]+(this.colors_delta[2]*position)) ];
267
+ this.element.style.backgroundColor = "#" +
268
+ colors[0].toColorPart() + colors[1].toColorPart() + colors[2].toColorPart();
269
+ }
270
+ });
271
+
272
+
273
+ /* ------------- prepackaged effects ------------- */
274
+
275
+ Effect.Fade = function(element) {
276
+ options = {
277
+ from: 1.0,
278
+ to: 0.0,
279
+ afterFinish: function(effect)
280
+ { Element.hide(effect.element);
281
+ effect.setOpacity(1); }
282
+ }.extend(arguments[1] || {});
283
+ new Effect.Opacity(element,options);
284
+ }
285
+
286
+ Effect.Appear = function(element) {
287
+ options = {
288
+ from: 0.0,
289
+ to: 1.0,
290
+ beforeStart: function(effect)
291
+ { effect.setOpacity(0);
292
+ Element.show(effect.element); },
293
+ afterUpdate: function(effect)
294
+ { Element.show(effect.element); }
295
+ }.extend(arguments[1] || {});
296
+ new Effect.Opacity(element,options);
297
+ }
298
+
299
+ Effect.Puff = function(element) {
300
+ new Effect.Parallel(
301
+ [ new Effect.Scale(element, 200, { sync: true, scaleFromCenter: true }),
302
+ new Effect.Opacity(element, { sync: true, to: 0.0, from: 1.0 } ) ],
303
+ { duration: 1.0,
304
+ afterUpdate: function(effect)
305
+ { effect.effects[0].element.style.position = 'absolute'; },
306
+ afterFinish: function(effect)
307
+ { Element.hide(effect.effects[0].element); }
308
+ }
309
+ );
310
+ }
311
+
312
+ Effect.BlindUp = function(element) {
313
+ $(element)._overflow = $(element).style.overflow || 'visible';
314
+ $(element).style.overflow = 'hidden';
315
+ new Effect.Scale(element, 0,
316
+ { scaleContent: false,
317
+ scaleX: false,
318
+ afterFinish: function(effect)
319
+ {
320
+ Element.hide(effect.element);
321
+ effect.element.style.overflow = effect.element._overflow;
322
+ }
323
+ }.extend(arguments[1] || {})
324
+ );
325
+ }
326
+
327
+ Effect.BlindDown = function(element) {
328
+ $(element).style.height = '0px';
329
+ $(element)._overflow = $(element).style.overflow || 'visible';
330
+ $(element).style.overflow = 'hidden';
331
+ Element.show(element);
332
+ new Effect.Scale(element, 100,
333
+ { scaleContent: false,
334
+ scaleX: false,
335
+ scaleMode: 'contents',
336
+ scaleFrom: 0,
337
+ afterFinish: function(effect) {
338
+ effect.element.style.overflow = effect.element._overflow;
339
+ }
340
+ }.extend(arguments[1] || {})
341
+ );
342
+ }
343
+
344
+ Effect.SwitchOff = function(element) {
345
+ new Effect.Appear(element,
346
+ { duration: 0.4,
347
+ transition: Effect.Transitions.flicker,
348
+ afterFinish: function(effect)
349
+ { effect.element.style.overflow = 'hidden';
350
+ new Effect.Scale(effect.element, 1,
351
+ { duration: 0.3, scaleFromCenter: true,
352
+ scaleX: false, scaleContent: false,
353
+ afterUpdate: function(effect) {
354
+ if(effect.element.style.position=="")
355
+ effect.element.style.position = 'relative'; },
356
+ afterFinish: function(effect) { Element.hide(effect.element); }
357
+ } )
358
+ }
359
+ } )
360
+ }
361
+
362
+ Effect.DropOut = function(element) {
363
+ new Effect.Parallel(
364
+ [ new Effect.MoveBy(element, 100, 0, { sync: true }),
365
+ new Effect.Opacity(element, { sync: true, to: 0.0, from: 1.0 } ) ],
366
+ { duration: 0.5,
367
+ afterFinish: function(effect)
368
+ { Element.hide(effect.effects[0].element); }
369
+ });
370
+ }
371
+
372
+ Effect.Shake = function(element) {
373
+ new Effect.MoveBy(element, 0, 20,
374
+ { duration: 0.05, afterFinish: function(effect) {
375
+ new Effect.MoveBy(effect.element, 0, -40,
376
+ { duration: 0.1, afterFinish: function(effect) {
377
+ new Effect.MoveBy(effect.element, 0, 40,
378
+ { duration: 0.1, afterFinish: function(effect) {
379
+ new Effect.MoveBy(effect.element, 0, -40,
380
+ { duration: 0.1, afterFinish: function(effect) {
381
+ new Effect.MoveBy(effect.element, 0, 40,
382
+ { duration: 0.1, afterFinish: function(effect) {
383
+ new Effect.MoveBy(effect.element, 0, -20,
384
+ { duration: 0.05, afterFinish: function(effect) {
385
+ }}) }}) }}) }}) }}) }});
386
+ }
387
+
388
+ Effect.SlideDown = function(element) {
389
+ $(element)._overflow = $(element).style.overflow || 'visible';
390
+ $(element).style.height = '0px';
391
+ $(element).style.overflow = 'hidden';
392
+ $(element).firstChild.style.position = 'relative';
393
+ Element.show(element);
394
+ new Effect.Scale(element, 100,
395
+ { scaleContent: false,
396
+ scaleX: false,
397
+ scaleMode: 'contents',
398
+ scaleFrom: 0,
399
+ afterUpdate: function(effect)
400
+ { effect.element.firstChild.style.bottom =
401
+ (effect.originalHeight - effect.element.clientHeight) + 'px'; },
402
+ afterFinish: function(effect)
403
+ { effect.element.style.overflow = effect.element._overflow; }
404
+ }.extend(arguments[1] || {})
405
+ );
406
+ }
407
+
408
+ Effect.SlideUp = function(element) {
409
+ $(element)._overflow = $(element).style.overflow || 'visible';
410
+ $(element).style.overflow = 'hidden';
411
+ $(element).firstChild.style.position = 'relative';
412
+ Element.show(element);
413
+ new Effect.Scale(element, 0,
414
+ { scaleContent: false,
415
+ scaleX: false,
416
+ afterUpdate: function(effect)
417
+ { effect.element.firstChild.style.bottom =
418
+ (effect.originalHeight - effect.element.clientHeight) + 'px'; },
419
+ afterFinish: function(effect)
420
+ {
421
+ Element.hide(effect.element);
422
+ effect.element.style.overflow = effect.element._overflow;
423
+ }
424
+ }.extend(arguments[1] || {})
425
+ );
426
+ }
427
+
428
+ Effect.Squish = function(element) {
429
+ new Effect.Scale(element, 0,
430
+ { afterFinish: function(effect) { Element.hide(effect.element); } });
431
+ }
432
+
433
+ Effect.Grow = function(element) {
434
+ element = $(element);
435
+ var options = arguments[1] || {};
436
+
437
+ var originalWidth = element.clientWidth;
438
+ var originalHeight = element.clientHeight;
439
+ element.style.overflow = 'hidden';
440
+ Element.show(element);
441
+
442
+ var direction = options.direction || 'center';
443
+ var moveTransition = options.moveTransition || Effect.Transitions.sinoidal;
444
+ var scaleTransition = options.scaleTransition || Effect.Transitions.sinoidal;
445
+ var opacityTransition = options.opacityTransition || Effect.Transitions.full;
446
+
447
+ var initialMoveX, initialMoveY;
448
+ var moveX, moveY;
449
+
450
+ switch (direction) {
451
+ case 'top-left':
452
+ initialMoveX = initialMoveY = moveX = moveY = 0;
453
+ break;
454
+ case 'top-right':
455
+ initialMoveX = originalWidth;
456
+ initialMoveY = moveY = 0;
457
+ moveX = -originalWidth;
458
+ break;
459
+ case 'bottom-left':
460
+ initialMoveX = moveX = 0;
461
+ initialMoveY = originalHeight;
462
+ moveY = -originalHeight;
463
+ break;
464
+ case 'bottom-right':
465
+ initialMoveX = originalWidth;
466
+ initialMoveY = originalHeight;
467
+ moveX = -originalWidth;
468
+ moveY = -originalHeight;
469
+ break;
470
+ case 'center':
471
+ initialMoveX = originalWidth / 2;
472
+ initialMoveY = originalHeight / 2;
473
+ moveX = -originalWidth / 2;
474
+ moveY = -originalHeight / 2;
475
+ break;
476
+ }
477
+
478
+ new Effect.MoveBy(element, initialMoveY, initialMoveX, {
479
+ duration: 0.01,
480
+ beforeUpdate: function(effect) { $(element).style.height = '0px'; },
481
+ afterFinish: function(effect) {
482
+ new Effect.Parallel(
483
+ [ new Effect.Opacity(element, { sync: true, to: 1.0, from: 0.0, transition: opacityTransition }),
484
+ new Effect.MoveBy(element, moveY, moveX, { sync: true, transition: moveTransition }),
485
+ new Effect.Scale(element, 100, {
486
+ scaleMode: { originalHeight: originalHeight, originalWidth: originalWidth },
487
+ sync: true, scaleFrom: 0, scaleTo: 100, transition: scaleTransition })],
488
+ options); }
489
+ });
490
+ }
491
+
492
+ Effect.Shrink = function(element) {
493
+ element = $(element);
494
+ var options = arguments[1] || {};
495
+
496
+ var originalWidth = element.clientWidth;
497
+ var originalHeight = element.clientHeight;
498
+ element.style.overflow = 'hidden';
499
+ Element.show(element);
500
+
501
+ var direction = options.direction || 'center';
502
+ var moveTransition = options.moveTransition || Effect.Transitions.sinoidal;
503
+ var scaleTransition = options.scaleTransition || Effect.Transitions.sinoidal;
504
+ var opacityTransition = options.opacityTransition || Effect.Transitions.none;
505
+
506
+ var moveX, moveY;
507
+
508
+ switch (direction) {
509
+ case 'top-left':
510
+ moveX = moveY = 0;
511
+ break;
512
+ case 'top-right':
513
+ moveX = originalWidth;
514
+ moveY = 0;
515
+ break;
516
+ case 'bottom-left':
517
+ moveX = 0;
518
+ moveY = originalHeight;
519
+ break;
520
+ case 'bottom-right':
521
+ moveX = originalWidth;
522
+ moveY = originalHeight;
523
+ break;
524
+ case 'center':
525
+ moveX = originalWidth / 2;
526
+ moveY = originalHeight / 2;
527
+ break;
528
+ }
529
+
530
+ new Effect.Parallel(
531
+ [ new Effect.Opacity(element, { sync: true, to: 0.0, from: 1.0, transition: opacityTransition }),
532
+ new Effect.Scale(element, 0, { sync: true, transition: moveTransition }),
533
+ new Effect.MoveBy(element, moveY, moveX, { sync: true, transition: scaleTransition }) ],
534
+ options);
535
+ }
536
+
537
+ Effect.Pulsate = function(element) {
538
+ var options = arguments[1] || {};
539
+ var transition = options.transition || Effect.Transitions.sinoidal;
540
+ var reverser = function(pos){ return transition(1-Effect.Transitions.pulse(pos)) };
541
+ reverser.bind(transition);
542
+ new Effect.Opacity(element,
543
+ { duration: 3.0,
544
+ afterFinish: function(effect) { Element.show(effect.element); }
545
+ }.extend(options).extend({transition: reverser}));
546
+ }
547
+
548
+ Effect.Fold = function(element) {
549
+ $(element).style.overflow = 'hidden';
550
+ new Effect.Scale(element, 5, {
551
+ scaleContent: false,
552
+ scaleTo: 100,
553
+ scaleX: false,
554
+ afterFinish: function(effect) {
555
+ new Effect.Scale(element, 1, {
556
+ scaleContent: false,
557
+ scaleTo: 0,
558
+ scaleY: false,
559
+ afterFinish: function(effect) { Element.hide(effect.element) } });
560
+ }}.extend(arguments[1] || {}));
561
+ }
562
+
563
+ // old: new Effect.ContentZoom(element, percent)
564
+ // new: Element.setContentZoom(element, percent)
565
+
566
+ Element.setContentZoom = function(element, percent) {
567
+ var element = $(element);
568
+ element.style.fontSize = (percent/100) + "em";
569
+ if(navigator.appVersion.indexOf('AppleWebKit')>0) window.scrollBy(0,0);
570
+ }