-
Notifications
You must be signed in to change notification settings - Fork 23
Documentation
jQuery-hotspot is a jQuery plugin for creating Hotspots in an HTML element. This plugin operates in two modes, admin and display. The admin mode enables user to create hotspots on desired HTML elements. The display mode is used for only displaying the hotspots to the end user. The design of the hotspot created are fully customizable. User can add their own CSS class to style the hotspots.
Include jquery.hotspot.js
at the bottom of the HTML page before the closing body tag. Wrap the HTML element for which the hotspot is to be obtained with another element. Also include the jquery.hotspot.css
file to go with some of the default design decision.
<div id="theElement">
<img src="theImage.jpg" width="600" height="400">
</div>
The plugin instance will be called with this element.
Note: The CSS property, position for this element should not be set be absolute. Infact the appropriate CSS property for this element should be
#theElement {
position: relative;
display: inline-block;
}
The data associated with the hotspots can be passed in directly to the plugin. The data can also be fetched from an ajax call.
There are three options given for hotspot-interactivity - hover, click and none.
- hover : The data associated with the hotspot will show up on hovering over spot.
- click : The data associated will show up on clicking the spot.
- none : The data will be static and would not be affected by any events.
$('#theElement').hotspot(
data: [
{ "x":288, "y":390, "Title":"The Title","Message":"Create the Message here" },
{ "x":143, "y":400, "Title":"jQuery Hotspot","Message":"This jQuery Plugin lets you create hotspot to any HTML element." }
],
tag: 'img', //optional (default is img)
interactivity: "hover", // options : click, none (default is hover)
hotspotClass: 'Hotspot'
);
The data
object above can be populated with any number of properties and can be designed with appropriate CSS. The tag
variable passed to the plugin determines the type of HTML tag for which the hotspot is obtained. The hotspotClass
is class of the hotspots created. One can change the look of the hotspot by applying some CSS to this class.
$("#theElement").hotspot({
ajax: true, // Switching on the ajax
ajaxOptions: {
url: 'parse.php',
type: 'GET',
...
},
interactivity: "hover" // options : click, none (default is hover)
});
The data coming from the server-side is expected to be JSON encoded. The object ajaxOptions
can be utilized to change the http headers, etc.
$("#theElement").hotspot({
mode: "admin", // Switching to admin mode
ajax: true, // Turn on ajax
ajaxOptions: {
url: 'parse.php',
type: 'POST',
...
},
interactivity: "hover" // options : click, none (default is hover)
});
ajax
and ajaxOptions
are required here so that the hotspot that are being created in the admin mode get stored in the server. However if someone turn off the ajax, then the data get be stored in the browser's LocalStorage.
######1. Any number of messages/nodes can be stuffed in a single hotspot. To do so the dataStuff
parameter is passed to the plugin. By default there are two nodes (Title and Message)
$("#theElement").hotspot({
mode: "admin", // Switching to admin mode
ajax: true, // Turn on ajax
ajaxOptions: {
url: 'parse.php',
type: 'POST',
...
},
dataStuff: [
{
'property': 'Time',
'default': '5:40am'
},
{
'property': 'Date',
'default': '12/11/2014'
},
{
'property': 'Place',
'default': 'Siberia'
},
]
});
The default
property in the dataStuff
object above will be overwritten everytime a new hotspot is created.
######2. The plugin also provides some basic functions that can be invoked after certain events in the process of creation of hotspots.
$("#theElement").hotspot({
mode: "admin", // Switching to admin mode
ajax: true, // Turn on ajax
ajaxOptions: {
url: 'parse.php',
type: 'POST',
...
},
afterSave: function(message) {
alert(message);
},
afterRemove: function(message) {
alert(message);
window.location.reload();
},
afterSyncToServer: function(message) {
alert(message);
}
});
These functions can be utilized to keep track of the flow of hotspot creation.
######3. The plugin can be used with any number of HTML elements in a page. However to do so, the LS_Variable
passed to the plugin should be named uniquely for every instance. This helps plugin to avoid conflicts and while using HTML5 LocalStorage. Also the save, remove and server syncing button should be given seperate id's for each of the instances.
#####HTML :
<div id="theElement-a">
<img src="theImage-a.jpg" width="600" height="400">
</div>
<div id="theElement-b">
<img src="theImage-b.jpg" width="600" height="400">
</div>
#####JavaScript :
$("#theElement-a").hotspot({
mode: "admin",
...
LS_Variable: "HotspotPlugin-a",
done_btnId: 'done-a',
remove_btnId: 'remove-a',
server_btnId: 'server-a',
});
$("#theElement-b").hotspot({
mode: "admin",
...
LS_Variable: "HotspotPlugin-b",
done_btnId: 'done-b',
remove_btnId: 'remove-b',
server_btnId: 'server-b',
});
#####For better clearity the examples folder can be checked