-
Notifications
You must be signed in to change notification settings - Fork 470
Modal
The modal plugin allows you to create tooltips which 'dim' the rest of the page when shown, drawing users attention. This is quite useful as a simple replacement for plugins such as ThickBox and jQuery UI Dialog
When the modal plugin is in use on a tooltip, a new element becomes available within the API elements object, which references the overlay element used to dim the page:
$('.selector').qtip({
content: {
text: 'Modal plugin element'
},
events: {
render: function(event, api) {
// Grab the overlay element
var elem = api.elements.overlay;
}
}
})
When a qTip utilises the modal plugin (by setting show.modal.on to true) a separate z-index is applied from that of normal, non-modal qTips to prevent overlapping issues. The default z-index of modal qTips is simply 200 less than that of regular non-modals:
$.fn.qtip.zindex = 15000; // Non-modal z-index
$.fn.qtip.modal_zindex = 14800; // Modal-specific z-index
When overriding the normal z-index property, be sure to change the modal-specific one too, but keep in mind you'll need to set it to a value lower than the non-modal property! Otherwise you'll run into funny problems with overlapping when using several different tooltips.
To dim the page, the modal plugin uses fullscreen div element. You can modify the colour and other attributes of the overlay in your jquery.qtip.css CSS file. Here's the default settings for the 'overlay' element:
#qtip-overlay{
position: fixed;
left: -10000em;
top: -10000em;
}
/* Applied to modals with show.modal.blur set to true */
#qtip-overlay.blurs{ cursor: pointer; }
/* Change opacity of overlay here */
#qtip-overlay div{
position: absolute;
left: 0; top: 0;
width: 100%; height: 100%;
background-color: black;
opacity: 0.7;
filter:alpha(opacity=70);
-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=70)";
}
If this isn't already present in your CSS file you'll need to add it manually.
Note: If you need to adjust the opacity of the overlay, change the inner div's properties, not the #qtip-overlay element.
14800
Determines the base z-index of all modal qTips on the page of which no modal qTip z-index will drop below.
If you're using another plugin that happens to use a higher z-index than the default, increase it a little:
// Now your qTip's appear above the other plugin elements, yipeee!
$.fn.qtip.modal_zindex = 20000;
- Try to make sure this value stays below that of the $.fn.qtip.zindex property to prevent rendering issues.
- Updating this option after you've already created some tooltips can have some pretty weird after-effects!
['a[href]', 'area[href]', 'input', 'select', 'textarea', 'button', 'iframe', 'object', 'embed', '[tabindex]', '[contenteditable]']
An array of selectors used to determine which elements are considered "focusable" within the tooltip, for use with the stealfocus option.
true, false (Default: false)
Determines whether or not the tooltip is 'modal' e.g. dims the rest of the page when shown.
Let's make a really quick login form that dims the rest of our page and is centered on screen
$('.selector').qtip({
content: {
text: $('#LoginForm')
},
position: {
my: 'center',
at: 'center',
target: $(document.body)
},
show: {
modal: {
on: true
}
}
});
We can also use some shorthand notation instead:
$('.selector').qtip({
content: {
text: $('#LoginForm')
},
position: {
my: 'center',
at: 'center',
target: $(document.body)
},
show: {
modal: true // Omit the object and set it to true as short-hand
}
});
- To dim the page a fullscreen translucent div is used, so all controls with a z-index lower than that of the blanket, as defined in your CSS file, will appear below and will be un-interactable whilst the blanket is visible.
true, false (Default: true)
Determines whether or not clicking on the dimmed background of the page hides the tooltip and removes the dim. When enabled the overlay element has a 'blurs' class applied to it.
Let's modify our login tooltip so you can only hide the tooltip by clicking the title button or hitting escape:
$('.selector').qtip({
content: {
text: $('#LoginForm'),
text: 'Login',
button: true
},
position: {
my: 'center',
at: 'center',
target: $(document.body)
},
show: {
modal: {
on: true,
blur: false
}
}
});
- When enabled the overlay element has a 'blurs' class applied to it. See CSS section for more details.
- To dim the page a fullscreen translucent div is used, so all controls with a z-index lower than that of the blanket, as defined in your CSS file, will appear below and will be un-interactable whilst the blanket is visible.
true, false (Default: true)
Determines whether or not hitting the escape key will hide the tooltip.
Let's modify our login tooltip so you can only hide it by clicking the title button:
$('.selector').qtip({
content: {
text: $('#LoginForm'),
text: 'Login',
button: true
},
position: {
my: 'center',
at: 'center',
target: $(document.body)
},
show: {
modal: {
on: true,
blur: false,
escape: false
}
}
});
- You must have the window focused for the keyboard event to be detected properly
true, false (Default: true)
Determines whether or not users can focus inputs and elements outside of the tooltip when visible. Elements that gain focus outside the tooltip when this is enabled will be immediately blured and focus restored to the first focusable element within the tooltip.
Elements within the tooltip that are considered "focusable" are determined by the array of selectors in the $.fn.qtip.modal.focusable property.
function() {}, true, false (Default: true)
Determines the type of effect that takes place when showing and hiding the modal overlay. A custom method can also be used whose scope is the overlay element when called. If set to false, no animation takes place. If set to true, a default a fadeIn animation takes place with a duration of 90ms.
Let's create a modal tooltip whos overlay fades in to a custom opacity
$('.selector').qtip({
content: {
text: 'I\'m a model tooltip with a custom overlay opacity'
},
show: {
modal {
on: true,
effect: function(state) {
/*
"state" determines if its hiding/showing
"this" refers to the overlay
0.4 and 0 are the show and hide opacities respectively.
*/
$(this).fadeTo(90, state ? 0.4 : 0, function() {
if(!state) { $(this).hide(); }
});
}
}
}
});
- By default a fadeIn animation takes place with a duration of 90ms.