Skip to content

An responsive overlay script that supports video and image galleries

Notifications You must be signed in to change notification settings

mtcmedia/overlay

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 

Repository files navigation

==Overview== version: 0.21
mtc_overlay is a jQuery plugin for responsive overlay windows

*ajax a whole page into overlay *ajax elements from a page into overlay

new to v0.21: *single image functionality *gallery functionality

new to v0.3:

  • youtube support
  • vimeo support
  • ajax support

new to v0.4:

  • resize improvements

  • responsive video

  • gallery without slick

  • store scroll position on open

  • fadein/out gallery images on switch

  • default styling for buttons, titles

new to v0.6:

  • video gallery
  • solve the touch issue
  • updated initialization code
  • changes in resize to support video gallery

new to v0.7:

  • options for margins, padding
  • max_width option added. All references in css to max-width has been removed and are not supported anymore.
  • title option removed, title now is set automatically via data-title instead of alt on image
  • perfect scrollbar option in overlay box
  • overlay scrollbar moved into the popup box (was fullheight before)
  • option for fullscreen iframe
  • changed variable names to proper format (from variableName to variable_name)
  • resize cleanup. Only one resize function called now, common for video and image
  • relative popup title support

new to v0.8:

  • html content galleries
  • refactored gallery code
  • fixed minor gallery bugs
  • loader icon
  • gallery can be closed if loading content fails

new to v0.9:

  • responsive option
  • swipe gestures for gallery

new to v1.0:

  • programmatic call
  • iframe support

==Options==

'''button_html'''
Use this to change the markup of the close button default: '

' datatype: string

'''content_class'''
Add custom class to wrap so you can change padding or whatever via CSS default: '' datatype: string

'''gallery'''
Set to true to activate gallery functionality. Don't forget to set data-rel for items default: false datatype: boolean

'''gallery_prev_html'''
Gallery previous button markup. Must have js_galleryNext class. default: ''; datatype: string

'''gallery_next_html'''
Gallery next button markup. Must have js_galleryNext class. default: ''; datatype: string

'''fullscreen_iframe'''
Special mode that will display iframe as tall as possible (useful for displaying pdfs) default: false datatype: boolean

'''margin_vertical'''
Vertical gap between overlay box and window default: 20 datatype: integer

'''margin_horizontal'''
Horizontal gap between overlay box and window default: 40 datatype: integer

'''max_width'''
Max width of the popup default: 1024 datatype: integer

'''fade_time'''
Overlay fade time in ms default: 300 datatype: integer

'''perfect_scroll'''
Sets if the perfectScroll plugin will be applied for the overlay scrollbar. This only matters for ajax popups since gallery and video will always be smaller or qual to window size. default: true datatype: boolean

'''site_wrapper'''
Site outer wrapper selector(one that's ONLY direct child of body). This is used for saving and restoring the scroll position on overlay open. default: '.siteWrapper' datatype: string

'''swipe'''
if gallery enabled, allow change the iamges with swipes. Does not work with video (because Iframe hijacks events) default: 'true' datatype: boolean

'''disable_perfect_scroll_on_touch'''
This option allows to turn off perfect scroll on touch devices. Useful for the galleries with ajax content - if perfect scrollbar is used then it will absorb all the events, and swipe won't work. default: 'true' datatype: boolean

'''arrow_controls'''
If set true allows to switch gallery with keyboard arrows. default: 'true' datatype: boolean

'''close_on_esc'''
Allows closing overlay with 'Escape' button. default: 'true' datatype: boolean

'''swipe'''
Allows changing gallery with swipe gesture on touchscreens. default: 'true' datatype: boolean

'''inline'''
If set true then content from same page (when using no-ajax) will be moved into overlay instead of copying it. Useful when you have forms with checkboxes and radios in popup - setting this to true solves issue with duplicate ids default: 'true' datatype: boolean

'''overlay_click_close'''
If set false disables overlay close on background click default: 'true' datatype: boolean

'''responsive'''
Slick style responsive parameter, allows to apply different settings at breakpoints. Desktop first.

default: [{ breakpoint: 640, settings: { margin_vertical: 10, margin_horizontal: 10, } }, { breakpoint: 640, settings: { margin_vertical: 5, margin_horizontal: 5, } }] datatype: object }

==Callbacks== '''beforeOpen'''
Used to provide callbacks before open of the overlay window (before visible) default: function () {} datatype: function

'''onOpen'''
Used to provide callbacks on open of the overlay window default: function () {} datatype: function

'''onClose'''
Used to provide callbacks on close of the overlay window default: function () {} datatype: function

==Install==

===Basic=== The following will ajax in a complete page/file

'''HTML''' click to view

'''jQuery''' $('.overlay').mtcOverlay();

===Element on the same page=== The following will load in an element on the same page

This is content of first popup
This is content of second popup
<ul>
    <li class="grid_3">
        <a class="mtcOverlay" href="#popup1" data-no-ajax="true">View</a>
    </li>
    <li class="grid_3">
        <a class="mtcOverlay" href="#popup2" data-no-ajax="true">View</a>
    </li>
</ul>

===Element within another page=== The following will ajax in an element within a page

'''HTML''' click to view

'''jQuery''' $('.overlay').mtcOverlay();

===Popup title=== The following will add an image to the overlay. *displaying image or video(single or gallery) *data-title attribute on link

As of version 0.7 there is no need to set a flag in the plugin options, title is read automatically if present. '''HTML'''

'''jQuery''' $('.overlay').mtcOverlay();

===Gallery of images=== The following will add a gallery to the overlay with titles on each image. *The image src must have an extension of jpg, jpeg, png or gif. *The alt tag will become a title. this can be left blank if none provided. *Each link must have a rel attr applied to it. This rel attr should be the same for each image in the same gallery *for older overlay versions try using rel instead of data-rel if it's not working right away

'''HTML'''

'''jQuery''' $('.overlay').mtcOverlay({ gallery: true });

===Changing Slick Options=== There must be an active gallery as that is only when slick is used. Any option available to slick normally is available here.

As if version 0.4 slick is depricated.

'''jQuery''' $('.overlay').mtcOverlay({ gallery: true, slick: { dots: true, arrows: false } });

=== Closing the overlay from another script ===

If you want to close the overlay on another event a simple method is triggering a click on the overlay close button (you may need to change the class if you have overridden it).

'''jQuery''' $('.overlayCloseButton').trigger('click');

===Video Options===

If video mode is set to true this supports Vimeo and Youtube, just paste in the url into the href and it will take out the video ID's automagically.

Such as: https://www.youtube.com/watch?v=KSFgolB7HHE Or: https://vimeo.com/22212265

Options that can be applied:

video_settings: { autoplay: true, width: 500, height: 280 }

Autoplay is default by false. Width and height are also self explanatory.

===Video Gallery===

As of version 0.6 it's possible to add youtube/vimeo iframes to the gallery.

Such as: https://www.youtube.com/watch?v=KSFgolB7HHE Or: https://vimeo.com/22212265

To enable videos in the gallery initialize plugin like this:

$('.mtcOverlayGallery').mtcOverlay({ gallery: true, video: true, video_settings: { width: 1024, height: 768 }, });

In the markup set the data-video to true for the video items. This is example of mixed galley of images and videos:

===HTML Gallery===

As of version 0.6 it's possible to add youtube/vimeo iframes to the gallery.

Such as: https://www.youtube.com/watch?v=KSFgolB7HHE Or: https://vimeo.com/22212265

To enable videos in the gallery initialize plugin like this:

$('.mtcOverlayGallery').mtcOverlay({ gallery: true });

In the markup set the data-ajax to true for the items:

If instead of using ajax you would like to show gallery from hidden blocks, simply use data-no-ajax instead of ajax and use selector in the href attribute:

This is content of first popup
This is content of second popup
<ul>
    <li class="grid_3">
        <a class="mtcOverlayGallery" href="#popup1" data-no-ajax="true" rel="GALLERY_NAME">View</a>
    </li>
    <li class="grid_3">
        <a class="mtcOverlayGallery" href="#popup2" data-no-ajax="true" rel="GALLERY_NAME">View</a>
    </li>
</ul>

===Open programmatically===

Version 1.0 added programmatic call to overlay - it now can be opened anywhere from javascript code with $.openMtcOverlay. All usual modes are available apart from gallery. Some examples of calls (note how overlay is called)

 $('.js_openOverlayImage').on('click', function (e) {
    e.preventDefault();
    $.openMtcOverlay({
        target: 'http://placehold.it/1024x600.png',
        image: true
    });
});

$('.js_openOverlayYoutube').on('click', function (e) {
    e.preventDefault();
    $.openMtcOverlay({
        target: 'http://www.youtube.com/watch?v=1Wh8RzcQZr4',
        video: true
    });
});

$('.js_openOverlayVimeo').on('click', function (e) {
    e.preventDefault();
    $.openMtcOverlay({
        target: 'https://vimeo.com/116046838',
        video: true
    });
});

 $('.js_openOverlayIframe').on('click', function (e) {
    e.preventDefault();
    $.openMtcOverlay({
        target: 'http://www.mtcmedia.co.uk/',
        iframe: true
    });
});

$('.js_openOverlayAjax').on('click', function (e) {
    e.preventDefault();
    $.openMtcOverlay({
        target: '/core/css/layouts/plugins/overlay/plugin_includes/mixed_popup.twig',
    });
});

 $('.js_openOverlayBlock').on('click', function (e) {
    e.preventDefault();
    $.openMtcOverlay({
        no_ajax: true,
        target: '#popup2',
    });
});

===Fullheight iframe popup=== This mode is useful for displaying stuff like pdf's in popup. Overlay code: Open

pdf popup code:

<iframe src="/uploads/pdf/sample.pdf"></iframe>

js code: $('.js_pdfOverlay').mtcOverlay({ fullscreen_iframe: true });

==Tips and tricks== ===Calling resize manually=== This is needed when popup has forms, and it changes the height on error or success messages. Overlay is bind to window resize, so one can trigger its resize function by: $(window).resize();

if one needs trigger ONLY overlay resize then: $(window).trigger('resize.overlay');

About

An responsive overlay script that supports video and image galleries

Resources

Stars

Watchers

Forks

Packages

No packages published