|
|
(9 intermediate revisions not shown) |
Line 1: |
Line 1: |
- | <html><script src="text/javascript"> | + | <html> |
- | (function($) {
| + | |
- | | + | |
- | $.fn.lightbox_me = function(options) {
| + | |
- | | + | |
- | return this.each(function() {
| + | |
- | | + | |
- | var
| + | |
- | opts = $.extend({}, $.fn.lightbox_me.defaults, options),
| + | |
- | $overlay = $(),
| + | |
- | $self = $(this),
| + | |
- | $iframe = $('<iframe id="foo" style="z-index: ' + (opts.zIndex + 1) + ';border: none; margin: 0; padding: 0; position: absolute; width: 100%; height: 100%; top: 0; left: 0; filter: mask();"/>'),
| + | |
- | ie6 = ($.browser.msie && $.browser.version < 7);
| + | |
- | | + | |
- | if (opts.showOverlay) {
| + | |
- | //check if there's an existing overlay, if so, make subequent ones clear
| + | |
- | var $currentOverlays = $(".js_lb_overlay:visible");
| + | |
- | if ($currentOverlays.length > 0){
| + | |
- | $overlay = $('<div class="lb_overlay_clear js_lb_overlay"/>');
| + | |
- | } else {
| + | |
- | $overlay = $('<div class="' + opts.classPrefix + '_overlay js_lb_overlay"/>');
| + | |
- | }
| + | |
- | }
| + | |
- | | + | |
- | /*----------------------------------------------------
| + | |
- | DOM Building
| + | |
- | ---------------------------------------------------- */
| + | |
- | if (ie6) {
| + | |
- | var src = /^https/i.test(window.location.href || '') ? 'javascript:false' : 'about:blank';
| + | |
- | $iframe.attr('src', src);
| + | |
- | $('body').append($iframe);
| + | |
- | } // iframe shim for ie6, to hide select elements
| + | |
- | $('body').append($self.hide()).append($overlay);
| + | |
- | | + | |
- | | + | |
- | /*----------------------------------------------------
| + | |
- | Overlay CSS stuffs
| + | |
- | ---------------------------------------------------- */
| + | |
- | | + | |
- | // set css of the overlay
| + | |
- | if (opts.showOverlay) {
| + | |
- | setOverlayHeight(); // pulled this into a function because it is called on window resize.
| + | |
- | $overlay.css({ position: 'absolute', width: '100%', top: 0, left: 0, right: 0, bottom: 0, zIndex: (opts.zIndex + 2), display: 'none' });
| + | |
- | if (!$overlay.hasClass('lb_overlay_clear')){
| + | |
- | $overlay.css(opts.overlayCSS);
| + | |
- | }
| + | |
- | }
| + | |
- | | + | |
- | /*----------------------------------------------------
| + | |
- | Animate it in.
| + | |
- | ---------------------------------------------------- */
| + | |
- | //
| + | |
- | if (opts.showOverlay) {
| + | |
- | $overlay.fadeIn(opts.overlaySpeed, function() {
| + | |
- | setSelfPosition();
| + | |
- | $self[opts.appearEffect](opts.lightboxSpeed, function() { setOverlayHeight(); setSelfPosition(); opts.onLoad()});
| + | |
- | });
| + | |
- | } else {
| + | |
- | setSelfPosition();
| + | |
- | $self[opts.appearEffect](opts.lightboxSpeed, function() { opts.onLoad()});
| + | |
- | }
| + | |
- | | + | |
- | /*----------------------------------------------------
| + | |
- | Hide parent if parent specified (parentLightbox should be jquery reference to any parent lightbox)
| + | |
- | ---------------------------------------------------- */
| + | |
- | if (opts.parentLightbox) {
| + | |
- | opts.parentLightbox.fadeOut(200);
| + | |
- | }
| + | |
- | | + | |
- | | + | |
- | /*----------------------------------------------------
| + | |
- | Bind Events
| + | |
- | ---------------------------------------------------- */
| + | |
- | | + | |
- | $(window).resize(setOverlayHeight)
| + | |
- | .resize(setSelfPosition)
| + | |
- | .scroll(setSelfPosition)
| + | |
- | .keyup(observeKeyPress);
| + | |
- | if (opts.closeClick) {
| + | |
- | $overlay.click(function(e) { closeLightbox(); e.preventDefault; });
| + | |
- | }
| + | |
- | $self.delegate(opts.closeSelector, "click", function(e) {
| + | |
- | closeLightbox(); e.preventDefault();
| + | |
- | });
| + | |
- | $self.bind('close', closeLightbox);
| + | |
- | $self.bind('reposition', setSelfPosition);
| + | |
- | | + | |
- |
| + | |
- | | + | |
- | /*--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
| + | |
- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- */
| + | |
- | | + | |
- | | + | |
- | /*----------------------------------------------------
| + | |
- | Private Functions
| + | |
- | ---------------------------------------------------- */
| + | |
- | | + | |
- | /* Remove or hide all elements */
| + | |
- | function closeLightbox() {
| + | |
- | var s = $self[0].style;
| + | |
- | if (opts.destroyOnClose) {
| + | |
- | $self.add($overlay).remove();
| + | |
- | } else {
| + | |
- | $self.add($overlay).hide();
| + | |
- | }
| + | |
- | | + | |
- | //show the hidden parent lightbox
| + | |
- | if (opts.parentLightbox) {
| + | |
- | opts.parentLightbox.fadeIn(200);
| + | |
- | }
| + | |
- | | + | |
- | $iframe.remove();
| + | |
- |
| + | |
- | // clean up events.
| + | |
- | $self.undelegate(opts.closeSelector, "click");
| + | |
- | | + | |
- | $(window).unbind('reposition', setOverlayHeight);
| + | |
- | $(window).unbind('reposition', setSelfPosition);
| + | |
- | $(window).unbind('scroll', setSelfPosition);
| + | |
- | $(document).unbind('keyup', observeKeyPress);
| + | |
- | if (ie6)
| + | |
- | s.removeExpression('top');
| + | |
- | opts.onClose();
| + | |
- | }
| + | |
- | | + | |
- | | + | |
- | /* Function to bind to the window to observe the escape/enter key press */
| + | |
- | function observeKeyPress(e) {
| + | |
- | if((e.keyCode == 27 || (e.DOM_VK_ESCAPE == 27 && e.which==0)) && opts.closeEsc) closeLightbox();
| + | |
- | }
| + | |
- | | + | |
- | | + | |
- | /* Set the height of the overlay
| + | |
- | : if the document height is taller than the window, then set the overlay height to the document height.
| + | |
- | : otherwise, just set overlay height: 100%
| + | |
- | */
| + | |
- | function setOverlayHeight() {
| + | |
- | if ($(window).height() < $(document).height()) {
| + | |
- | $overlay.css({height: $(document).height() + 'px'});
| + | |
- | $iframe.css({height: $(document).height() + 'px'});
| + | |
- | } else {
| + | |
- | $overlay.css({height: '100%'});
| + | |
- | if (ie6) {
| + | |
- | $('html,body').css('height','100%');
| + | |
- | $iframe.css('height', '100%');
| + | |
- | } // ie6 hack for height: 100%; TODO: handle this in IE7
| + | |
- | }
| + | |
- | }
| + | |
- | | + | |
- | | + | |
- | /* Set the position of the modal'd window ($self)
| + | |
- | : if $self is taller than the window, then make it absolutely positioned
| + | |
- | : otherwise fixed
| + | |
- | */
| + | |
- | function setSelfPosition() {
| + | |
- | var s = $self[0].style;
| + | |
- | | + | |
- | // reset CSS so width is re-calculated for margin-left CSS
| + | |
- | $self.css({left: '50%', marginLeft: ($self.outerWidth() / 2) * -1, zIndex: (opts.zIndex + 3) });
| + | |
- | | + | |
- | | + | |
- | /* we have to get a little fancy when dealing with height, because lightbox_me
| + | |
- | is just so fancy.
| + | |
- | */
| + | |
- | | + | |
- | // if the height of $self is bigger than the window and self isn't already position absolute
| + | |
- | if (($self.height() + 80 >= $(window).height()) && ($self.css('position') != 'absolute' || ie6)) {
| + | |
- | | + | |
- | // we are going to make it positioned where the user can see it, but they can still scroll
| + | |
- | // so the top offset is based on the user's scroll position.
| + | |
- | var topOffset = $(document).scrollTop() + 40;
| + | |
- | $self.css({position: 'absolute', top: topOffset + 'px', marginTop: 0})
| + | |
- | if (ie6) {
| + | |
- | s.removeExpression('top');
| + | |
- | }
| + | |
- | } else if ($self.height()+ 80 < $(window).height()) {
| + | |
- | //if the height is less than the window height, then we're gonna make this thing position: fixed.
| + | |
- | // in ie6 we're gonna fake it.
| + | |
- | if (ie6) {
| + | |
- | s.position = 'absolute';
| + | |
- | if (opts.centered) {
| + | |
- | s.setExpression('top', '(document.documentElement.clientHeight || document.body.clientHeight) / 2 - (this.offsetHeight / 2) + (blah = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + "px"')
| + | |
- | s.marginTop = 0;
| + | |
- | } else {
| + | |
- | var top = (opts.modalCSS && opts.modalCSS.top) ? parseInt(opts.modalCSS.top) : 0;
| + | |
- | s.setExpression('top', '((blah = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + '+top+') + "px"')
| + | |
- | }
| + | |
- | } else {
| + | |
- | if (opts.centered) {
| + | |
- | $self.css({ position: 'fixed', top: '50%', marginTop: ($self.outerHeight() / 2) * -1})
| + | |
- | } else {
| + | |
- | $self.css({ position: 'fixed'}).css(opts.modalCSS);
| + | |
- | }
| + | |
- | | + | |
- | }
| + | |
- | }
| + | |
- | }
| + | |
- | | + | |
- | });
| + | |
- | | + | |
- | | + | |
- | | + | |
- | };
| + | |
- | | + | |
- | $.fn.lightbox_me.defaults = {
| + | |
- | | + | |
- | // animation
| + | |
- | appearEffect: "fadeIn",
| + | |
- | appearEase: "",
| + | |
- | overlaySpeed: 250,
| + | |
- | lightboxSpeed: 300,
| + | |
- | | + | |
- | // close
| + | |
- | closeSelector: ".close",
| + | |
- | closeClick: true,
| + | |
- | closeEsc: true,
| + | |
- | | + | |
- | // behavior
| + | |
- | destroyOnClose: false,
| + | |
- | showOverlay: true,
| + | |
- | parentLightbox: false,
| + | |
- | | + | |
- | // callbacks
| + | |
- | onLoad: function() {},
| + | |
- | onClose: function() {},
| + | |
- | | + | |
- | // style
| + | |
- | classPrefix: 'lb',
| + | |
- | zIndex: 999,
| + | |
- | centered: false,
| + | |
- | modalCSS: {top: '40px'},
| + | |
- | overlayCSS: {background: 'black', opacity: .3}
| + | |
- | }
| + | |
- | })(jQuery);
| + | |
- | </script>
| + | |
| <script type="text/javascript"> | | <script type="text/javascript"> |
| $(function(){ | | $(function(){ |
| $('span.footnote > a').bind('click', function(){ | | $('span.footnote > a').bind('click', function(){ |
| var url = $(this).attr('href'); | | var url = $(this).attr('href'); |
| + | var title = $(this).text(); |
| $('<div>').load(url + ' div#bodyContent', function(data){ | | $('<div>').load(url + ' div#bodyContent', function(data){ |
- | var $box = $('<div>').addClass('footnote-box'); | + | var $box = $('<div>').addClass('footnote-box').append($('<h2>').append(title)); |
| var $footnote = $(data).find('div#contentSub').nextAll('p'); | | var $footnote = $(data).find('div#contentSub').nextAll('p'); |
- | $box.append($footnote); | + | $box.append($('<div>').append($footnote).addClass('footnote-content')); |
| $('body').append($box); | | $('body').append($box); |
| $box.append($('<span>').addClass('close').addClass('close-btn-32')).lightbox_me({ | | $box.append($('<span>').addClass('close').addClass('close-btn-32')).lightbox_me({ |
- | destroyOnClose : true | + | destroyOnClose : true, |
| + | modalCSS : { 'top' : '100px' } |
| }); | | }); |
| }); | | }); |
Line 252: |
Line 20: |
| </script> | | </script> |
| <style> | | <style> |
- | div.footnote-box {
| |
- | background-color: #d9d9d9;
| |
- | margin 0 auto;
| |
- | display: block;
| |
- | padding: 50px 30px;
| |
- | width: 40%;
| |
- | height: 40%;
| |
- | overflow: scroll;
| |
- | }
| |
| .close-btn-32 { | | .close-btn-32 { |
| display: block; | | display: block; |
Line 297: |
Line 56: |
| line-height: 32px; | | line-height: 32px; |
| font-family: "Helvetica Neue", Consolas, Verdana, Tahoma, Calibri, Helvetica, Menlo, "Droid Sans", sans-serif; | | font-family: "Helvetica Neue", Consolas, Verdana, Tahoma, Calibri, Helvetica, Menlo, "Droid Sans", sans-serif; |
| + | } |
| + | div.footnote-box { |
| + | background: rgb(125,126,125); |
| + | background: -moz-linear-gradient(top, rgba(125,126,125,0.85) 0%, rgba(14,14,14,0.85) 100%); |
| + | background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(125,126,125,0.85)), color-stop(100%,rgba(14,14,14,0.85))); |
| + | background: -webkit-linear-gradient(top, rgba(125,126,125,0.85) 0%,rgba(14,14,14,0.85) 100%); |
| + | background: -o-linear-gradient(top, rgba(125,126,125,0.85) 0%,rgba(14,14,14,0.85) 100%); |
| + | background: -ms-linear-gradient(top, rgba(125,126,125,0.85) 0%,rgba(14,14,14,0.85) 100%); |
| + | filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#7d7e7d', endColorstr='#0e0e0e',GradientType=0 ); |
| + | background: linear-gradient(top, rgba(125,126,125,0.85) 0%,rgba(14,14,14,0.85) 100%); |
| + | margin 0 auto; |
| + | border: 3px solid #dfdfdf; |
| + | border-radius: 10px; |
| + | -moz-border-radius: 10px; |
| + | -webkit-border-radius: 10px; |
| + | display: block; |
| + | padding: 20px 20px; |
| + | width: 60%; |
| + | min-width: 650px; |
| + | height: auto; |
| + | max-height: 60%; |
| + | overflow: auto; |
| + | box-shadow: 3px 3px 5px #333; |
| + | -moz-box-shadow: 3px 3px 5px #333; |
| + | -webkit-box-shadow: 3px 3px 5px #333; |
| + | } |
| + | .footnote-box div.footnote-content { |
| + | color: #fefefe; |
| + | font-size: large !important; |
| + | margin: 0px auto 10px; |
| + | width: 80%; |
| + | height: 100%; |
| + | } |
| + | .footnote-box h2 { |
| + | color: #fefefe; |
| + | height : 80%; |
| + | margin-bottom: 10px; |
| + | border-bottom-width: 5px; |
| + | padding-left: 8px; |
| + | padding-bottom: 3px; |
| + | font-size: 250%; |
| + | text-align: center; |
| } | | } |
| </style> | | </style> |
- |
| |
| </html> | | </html> |