var _____WB$wombat$assign$function_____ = function(name) {return (self._wb_wombat && self._wb_wombat.local_init && self._wb_wombat.local_init(name)) || self[name]; };
if (!self.__WB_pmw) { self.__WB_pmw = function(obj) { this.__WB_source = obj; return this; } }
{
let window = _____WB$wombat$assign$function_____("window");
let self = _____WB$wombat$assign$function_____("self");
let document = _____WB$wombat$assign$function_____("document");
let location = _____WB$wombat$assign$function_____("location");
let top = _____WB$wombat$assign$function_____("top");
let parent = _____WB$wombat$assign$function_____("parent");
let frames = _____WB$wombat$assign$function_____("frames");
let opener = _____WB$wombat$assign$function_____("opener");
/**
* An adapter for the Shadowbox media viewer and the jQuery JavaScript library.
*
* This file is part of Shadowbox.
*
* Shadowbox is free software: you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation, either version 3 of the License, or (at your option)
* any later version.
*
* Shadowbox is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
* more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Shadowbox. If not, see .
*
* @author Michael J. I. Jackson
* @copyright 2007 Michael J. I. Jackson
* @license http://www.gnu.org/licenses/lgpl-3.0.txt GNU LGPL 3.0
* @version SVN: $Id: shadowbox-jquery.js 55 2008-01-29 09:42:41Z mjijackson $
*/
if(typeof jQuery == 'undefined'){
throw 'Unable to load Shadowbox, jQuery library not found.';
}
// create the Shadowbox object first
var Shadowbox = {};
Shadowbox.lib = {
/**
* Gets the value of the style on the given element.
*
* @param {HTMLElement} el The DOM element
* @param {String} style The name of the style (e.g. margin-top)
* @return {mixed} The value of the given style
* @public
*/
getStyle: function(el, style){
return jQuery(el).css(style);
},
/**
* Sets the style on the given element to the given value. May be an
* object to specify multiple values.
*
* @param {HTMLElement} el The DOM element
* @param {String/Object} style The name of the style to set if a
* string, or an object of name =>
* value pairs
* @param {String} value The value to set the given style to
* @return void
* @public
*/
setStyle: function(el, style, value){
if(typeof style != 'object'){
var temp = {};
temp[style] = value;
style = temp;
}
jQuery(el).css(style);
},
/**
* Gets a reference to the given element.
*
* @param {String/HTMLElement} el The element to fetch
* @return {HTMLElement} A reference to the element
* @public
*/
get: function(el){
return (typeof el == 'string') ? document.getElementById(el) : el;
},
/**
* Removes an element from the DOM.
*
* @param {HTMLElement} el The element to remove
* @return void
* @public
*/
remove: function(el){
jQuery(el).remove();
},
/**
* Gets the target of the given event. The event object passed will be
* the same object that is passed to listeners registered with
* addEvent().
*
* @param {mixed} e The event object
* @return {HTMLElement} The event's target element
* @public
*/
getTarget: function(e){
return e.target;
},
/**
* Prevents the event's default behavior. The event object passed will
* be the same object that is passed to listeners registered with
* addEvent().
*
* @param {mixed} e The event object
* @return void
* @public
*/
preventDefault: function(e){
e = e.browserEvent || e;
if(e.preventDefault){
e.preventDefault();
}else{
e.returnValue = false;
}
},
/**
* Adds an event listener to the given element. It is expected that this
* function will be passed the event as its first argument.
*
* @param {HTMLElement} el The DOM element to listen to
* @param {String} name The name of the event to register
* (i.e. 'click', 'scroll', etc.)
* @param {Function} handler The event handler function
* @return void
* @public
*/
addEvent: function(el, name, handler){
jQuery(el).bind(name, handler);
},
/**
* Removes an event listener from the given element.
*
* @param {HTMLElement} el The DOM element to stop listening to
* @param {String} name The name of the event to stop
* listening for (i.e. 'click')
* @param {Function} handler The event handler function
* @return void
* @public
*/
removeEvent: function(el, name, handler){
jQuery(el).unbind(name, handler);
},
/**
* Animates numerous styles of the given element. The second parameter
* of this function will be an object of the type that is expected by
* YAHOO.util.Anim. See http://developer.yahoo.com/yui/docs/YAHOO.util.Anim.html
* for more information.
*
* @param {HTMLElement} el The DOM element to animate
* @param {Object} obj The animation attributes/parameters
* @param {Number} duration The duration of the animation
* (in seconds)
* @param {Function} callback A callback function to call when
* the animation completes
* @return void
* @public
*/
animate: function(el, obj, duration, callback){
duration = Math.round(duration * 1000); // convert to milliseconds
var o = {};
for(var p in obj){
for(var p in obj){
o[p] = String(obj[p].to);
if(p != 'opacity') o[p] += 'px';
}
}
jQuery(el).animate(o, duration, null, callback);
}
};
/**
* Passes the selected elements to the Shadowbox.setup() function. Supports
* embedded height and width attributes within the class attribute.
*
* @param {Object} options The options to pass to setup() for all
* selected elements
* @public
* @author Mike Alsup
*/
jQuery.fn.shadowbox = function(options){
return this.each(function(){
var $this = $(this);
// support jQuery metadata plugin
var opts = $.extend({}, options || {}, $.metadata ? $this.metadata() : $.meta ? $this.data() : {});
// support embedded opts (for w/h) within the class attr
var cls = this.className || '';
opts.width = parseInt((cls.match(/w:(\d+)/)||[])[1]) || opts.width;
opts.height = parseInt((cls.match(/h:(\d+)/)||[])[1]) || opts.height;
Shadowbox.setup($this, opts);
});
};
}