-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjquery.simpleSlide.js
executable file
·449 lines (379 loc) · 15.2 KB
/
jquery.simpleSlide.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
//
//
// simpleSlide 1.5
//
// website:http://www.simplesli.de/
// author: David Drew
// email: david@ddrewdesign.com
//
//
// simpleSlide is a jQuery plugin that addresses the problem of lack of designer control over
// their slideshow plugin. The philosophy was to create a plugin that would take care of the
// mundane issues of instantiating a slideshow plugin, but make it easy for a designer to
// manipulate the parts of the process that they would want control over, such as visual
// treatment, integration and additional functionality.
//
// Parameters
// ----------
//
// simpleSlide is instantiated, at minimum, like this:
//
// simpleSlide();
//
// Upon activating this function, simpleSlide goes into your DOM and finds several key
// elements. The simpleSlide HTML structure (and key elements) will look like this:
//
// <div class="simpleSlide-window" rel="group_name">
// <div class="simpleSlide-tray" rel="group_name">
// <div class="simpleSlide-slide" rel="group_name">
// /* Individual slide content. If content is merely an image, simpleSlide will
// * automatically configure each slide to accommodate the slide. If you have
// * opted to create content that doesn't have an apparent width or height, it
// * it may be in your best interest to give this content a defined width and
// * height. You do not, however, need to define the "simpleSlide-slide" class'
// * width and height. The function will take care of that for you.
// */
// </div>
// </div>
// </div>
//
// The user may also instantiate a graphical representative element vis-a-vis the simpleSlide
// status element. This element is entirely optional, and will or will not be placed based on the
// user's desire to place the following elements into their HTML:
//
// <div class="simpleSlideStatus-tray" rel="group_name">
// <div class="simpleSlideStatus-window" rel="group_name"></div>
// </div>
//
// Please visit http://www.simplesli.de and click on "features" for more configuration information.
//
// It should be noted, however, that after simpleSlide() has processed this structure, each slide
// will house an "alt" attribute with an integer as its value. This integer (counting up from '1')
// represents that slide's "page" placement among the slides in the window. This is to help the
// designer set up functionality that allows page jumping.
//
// The buttons that control the slideshow may be used in whatever manner you wish, and anywhere
// in the site's structure that you wish to place them. They only must have the same "rel" as
// the window (and accompanying elements) you wish for them to control. simpleSlide() automatically
// treats them as clickable regions. "jump-to" is special in that you also have to pass the
// desired "jump-to" page through the "alt" attribute.
//
// <div class="left-button" rel="group_name"></div>
// <div class="right-button" rel="group_name"></div>
// <div class="jump-to" rel="group_name" alt="1"></div>
//
// The user is also allowed several options that they may customize. They are instantiated like this:
//
// simpleSlide({
// 'status_width': 20, // Integer. Sets the width of the status slideshow's window element.
// 'status_color_inside': '#000', // String. Sets color of status window element.
// 'status_color_outside': '#FFF', // String. Sets color of status tray element.
// 'set_speed': 500, // Integer. Sets speed of all animations. Represented in milliseconds.
// 'fullscreen' : 'false', // String. 'true' sets slide window for full screen. For obvious reasons, cannot
// work with more than one simpleSlide window per page.
// 'swipe' : 'false', // String. 'true' turns on swipe functionality for touch devices.
// 'callback': 'function()' // String. Sets callback to actuate after simpleSlide initial config.
// });
//
// If you have any further questions on the usage of simpleSlide, or suggestions on making it better,
// please e-mail me at david@ddrewdesign.com, or visit http://www.ddrewdesign.com/contact/ to email me.
// Thank you for using this plugin, and I hope you enjoy it. I had a blast making it.
//
//
function simpleSlide(incoming_options) {
jQuery(function($) {
var options = {
'status_width': 20,
'status_color_inside': '#fff',
'status_color_outside': '#aaa',
'set_speed': 500,
'fullscreen' : 'false',
'swipe': 'false',
'callback': 'function()'
};
$.extend(options, incoming_options);
$.ss_options = options;
$('.simpleSlide-slide').css({
'opacity': '0'
});
$('.simpleSlide-window').prepend('<span id="ssLoading" style="color: #808080;font-family:Helvetica, Arial, sans-serif;font-size: 12px; margin: 10px 0 0 10px;display: block">Loading slides...</span>');
var no_of_images = $('.simpleSlide-slide img').size();
if(no_of_images > 0) {
var images = new Array();
var i = 0;
$('.simpleSlide-slide img').each( function() {
images[i] = $(this).attr('src');
i++;
});
i = 0;
$(images).each( function(){
var imageObj = new Image();
imageObj.src = images[i];
$(imageObj).load( function() {
no_of_images--;
i++;
if(no_of_images == 0){
ssInit();
};
});
});
} else {
ssInit();
};
});
};
function ssInit(){
/* Set the dimensions of each simpleSlide window and tray
* based on the size of the first 'slide' inside that window.
* Every slide within a given tray/window should be uniform in dimensions.
* Also, set Status Window size, if it's being used. Fire callback when finished.
*/
jQuery(function($) {
$('.simpleSlide-window').each( function() {
if($.ss_options.fullscreen == 'true'){
$('body').css('overflow', 'hidden');
}
var window_contents = $(this).html();
var cleaned_contents = removeWhiteSpace(window_contents);
$(this).html(cleaned_contents);
var slide_count = $(this).find('.simpleSlide-slide').size();
$(this).find('.simpleSlide-slide').css('display','block');
var window_height = $(this).find('.simpleSlide-slide').first().outerHeight();
if($.ss_options.fullscreen == 'true'){
fullScreen(this);
};
$(this).find('.simpleSlide-slide').css({
'display':'inline',
'float':'left'
});
var window_width = $(this).find('.simpleSlide-slide').first().outerWidth();
var window_rel = $(this).attr('rel');
if($.ss_options.fullscreen == 'false'){
$(this).css({
'height': window_height,
'width': window_width,
'position': 'relative'
});
};
$(this).css('overflow','hidden');
setTraySize(this, slide_count, window_width);
setSimpleSlideStatus(window_rel, window_height, window_width, slide_count);
setPaging(this);
$(this).find('#ssLoading').remove();
if($.ss_options.swipe = 'true'){
simpleSwipe(this);
};
$(this).find('.simpleSlide-slide').animate({
'opacity': '1'
}, 300, "swing");
});
/* Fire callback after completion of image load and simpleSlide initialization */
if(typeof($.ss_options.callback) == 'function'){
$.ss_options.callback.call(this);
};
/* Gives each slide an 'alt' with the slide number */
function setPaging(this_window) {
var page_count = 1;
$(this_window).find('.simpleSlide-slide').each( function() {
$(this).attr('alt', page_count);
page_count++;
});
};
function fullScreen(this_s_window){
var first_img = $(this_s_window).find('img').first();
var window_prop = $(window).width() / $(window).height();
var image_prop = first_img.width() / first_img.height();
if(window_prop > image_prop){
var new_height = ($(window).width() / first_img.width()) * first_img.height();
var height_offset = (new_height - $(window).height()) / 2;
$(this_s_window).find('img').attr('width', $(window).width()).attr('height', new_height);
$(this_s_window).css({
'marginTop':'-' + height_offset + 'px',
'height': $(window).height() + height_offset
});
} else {
var new_width = ($(window).height() / first_img.height()) * first_img.width();
var width_offset = (new_width - $(window).width()) / 2;
$(this_s_window).find('img').attr('height', $(window).height()).attr('width', new_width);
$(this_s_window).find('img').css({
'marginLeft': '-' + width_offset + 'px'
});
$(this_s_window).find('.simpleSlide-slide').css({
'width': $(window).width(),
'height': $(window).height(),
'overflow': 'hidden'
});
};
};
/* Sets size of the "tray" that holds the "slides" */
function setTraySize(slideWindow, count, viewer_width) {
var slider_width = count * viewer_width;
$(slideWindow).find('.simpleSlide-tray').css({
'width': slider_width + 'px'
});
$(slideWindow).find('.simpleSlide-slide').css('display','inline-block');
};
/* If user chooses to establish Status Window, this function will set
* the dimensions of the window based on the desired width.
* The window (and its inherent slide's) dimensions are a relative factor
* of the main window's size, so the status window will be proportionally
* the same as the main window and its tray.
*/
function setSimpleSlideStatus(this_rel, height, width, image_count) {
var ratio = $.ss_options.status_width/width;
var status_height = ratio*height;
$('.simpleSlideStatus-tray[rel="' + this_rel + '"]')
.css({
'width': $.ss_options.status_width * image_count,
'height': status_height,
'background-color': $.ss_options.status_color_outside
});
$('.simpleSlideStatus-window[rel="' + this_rel + '"]')
.css({
'width': $.ss_options.status_width,
'height': status_height,
'background-color': $.ss_options.status_color_inside
});
if(jQuery.support.opacity){
$('.simpleSlideStatus-window .simpleSlideStatus-tray[rel="' + this_rel + '"]')
.css({
'opacity': '.5',
'background-color': $.ss_options.status_color_inside
});
};
if(!jQuery.support.opacity){
$('.simpleSlideStatus-window .simpleSlideStatus-tray[rel="' + this_rel + '"]').css({
'filter': 'alpha(opacity=50)',
'background-color': $.ss_options.status_color_inside
});
};
};
/* Actuates upon the clicking of a left- or right-button classed element */
$('.left-button, .right-button, .jump-to').live('click', function() {
var rel = $(this).attr('rel');
if (!$('div.simpleSlide-tray[rel="' + rel + '"]').is(':animated')) {
simpleSlideAction(this, rel);
};
});
});
};
function simpleSwipe(this_window) {
// Default thresholds & swipe functions
var defaults = {
threshold: {
x: $(this_window).width() * .15,
y: $(this_window).height() * .1
},
swipeLeft: function() {
simpleSlideAction('.right-button', $(this_window).attr('rel'));
},
swipeRight: function() {
simpleSlideAction('.left-button', $(this_window).attr('rel'));
},
preventDefaultEvents: true
};
var options = $.extend(defaults, options);
if (!this_window) return false;
return $(this_window).each(function() {
var me = $(this_window);
// Private variables for each element
var originalCoord = { x: 0, y: 0 };
var finalCoord = { x: 0, y: 0 };
// Screen touched, store the original coordinate
function touchStart(event) {
originalCoord.x = event.targetTouches[0].pageX;
originalCoord.y = event.targetTouches[0].pageY;
};
// Store coordinates as finger is swiping
function touchMove(event) {
if (defaults.preventDefaultEvents){
event.preventDefault();
};
finalCoord.x = event.targetTouches[0].pageX; // Updated X,Y coordinates
finalCoord.y = event.targetTouches[0].pageY;
};
// Done Swiping
// Swipe should only be on X axis, ignore if swipe on Y axis
// Calculate if the swipe was left or right
function touchEnd(event) {
var changeY = originalCoord.y - finalCoord.y;
if(changeY < defaults.threshold.y && changeY > (defaults.threshold.y*-1)) {
changeX = originalCoord.x - finalCoord.x;
if(changeX > defaults.threshold.x) {
defaults.swipeLeft();
};
if(changeX < (defaults.threshold.x*-1)) {
defaults.swipeRight();
};
};
};
// Swipe was canceled
function touchCancel(event) {
console.log('Canceling swipe gesture...');
};
// Add gestures to all swipable areas
this_window.addEventListener("touchstart", touchStart, false);
this_window.addEventListener("touchmove", touchMove, false);
this_window.addEventListener("touchend", touchEnd, false);
this_window.addEventListener("touchcancel", touchCancel, false);
});
};
function simpleSlideAction(action, rel_no) {
jQuery(function($) {
var move_speed = $.ss_options.set_speed;
var image_count = $('.simpleSlide-window[rel="' + rel_no + '"]').find('.simpleSlide-slide').size();
var window_width = $('.simpleSlide-window[rel="' + rel_no + '"]').innerWidth();
var status_window_width = $('.simpleSlideStatus-window[rel="' + rel_no + '"]').innerWidth();
var status_tray_width = status_window_width * image_count;
var current_tray_margin = parseInt($('.simpleSlide-tray[rel="' + rel_no + '"]').css('marginLeft'), 10);
var current_status_window_margin = parseInt($('.simpleSlideStatus-tray .simpleSlideStatus-window[rel="' + rel_no + '"]').css('marginLeft'), 10);
var current_status_tray_margin = parseInt($('.simpleSlideStatus-window .simpleSlideStatus-tray[rel="' + rel_no + '"]').css('marginLeft'), 10);
if($(action).is('.jump-to')) {
var to_page = $(action).attr('alt');
var j_margin = (to_page - 1) * (window_width * (-1));
var st_margin = (to_page - 1) * (status_window_width * (-1));
var sw_margin = (to_page - 1) * (status_window_width);
move(j_margin, sw_margin, st_margin);
};
if($(action).is('.left-button')) {
if(current_tray_margin == 0) {
var j_margin = current_tray_margin - ((image_count - 1) * window_width);
var st_margin = current_status_tray_margin - ((image_count - 1) * status_window_width);
var sw_margin = current_status_window_margin + ((image_count - 1) * status_window_width);
} else {
var j_margin = current_tray_margin + window_width;
var st_margin = current_status_tray_margin + status_window_width;
var sw_margin = current_status_window_margin - status_window_width;
};
move(j_margin, sw_margin, st_margin);
};
if($(action).is('.right-button')) {
if(current_tray_margin == (image_count - 1) * (window_width * -1)) {
var j_margin = 0;
var st_margin = 0;
var sw_margin = 0;
} else {
var j_margin = current_tray_margin - window_width;
var st_margin = current_status_tray_margin - status_window_width;
var sw_margin = current_status_window_margin + status_window_width;
};
move(j_margin, sw_margin, st_margin);
};
function move(new_margin, new_swindow_margin, new_stray_margin) {
$('.simpleSlide-tray[rel="' + rel_no + '"]').animate({
'marginLeft': new_margin
}, move_speed, "swing");
$('.simpleSlideStatus-window .simpleSlideStatus-tray[rel="' + rel_no + '"]')
.animate({
'marginLeft': new_stray_margin
}, move_speed, "swing");
$('.simpleSlideStatus-tray .simpleSlideStatus-window[rel="' + rel_no + '"]').animate({
'marginLeft': new_swindow_margin
}, move_speed, "swing");
};
});
};
function removeWhiteSpace(raw) {
var cleaned_string = raw.replace(/[\r+\n+\t+]\s\s+/g, "");
return cleaned_string;
};