Skip to content

Instantly share code, notes, and snippets.

@swallentin
Created September 19, 2014 13:40
Show Gist options
  • Save swallentin/f17103012d3a84fe9a9f to your computer and use it in GitHub Desktop.
Save swallentin/f17103012d3a84fe9a9f to your computer and use it in GitHub Desktop.
jquery.popup plugin
/*!
* jQuery lightweight plugin boilerplate
* Original author: @ajpiano
* Further changes, comments: @addyosmani
* Licensed under the MIT license
*/
// the semi-colon before the function invocation is a safety
// net against concatenated scripts and/or other plugins
// that are not closed properly.
;(function ($, window, document, undefined) {
// undefined is used here as the undefined global
// variable in ECMAScript 3 and is mutable (i.e. it can
// be changed by someone else). undefined isn't really
// being passed in so we can ensure that its value is
// truly undefined. In ES5, undefined can no longer be
// modified.
// window and document are passed through as local
// variables rather than as globals, because this (slightly)
// quickens the resolution process and can be more
// efficiently minified (especially when both are
// regularly referenced in our plugin).
// Create the defaults once
var pluginName = "popup",
defaults = {
features: {
location: "yes",
menubar: "yes",
toolbar: "yes",
scrollbars: "yes",
resizable: "yes",
height: null,
width: null,
left: null,
top: null
}
};
// The actual plugin constructor
function Plugin(element, options) {
this.element = element;
// jQuery has an extend method that merges the
// contents of two or more objects, storing the
// result in the first object. The first object
// is generally empty because we don't want to alter
// the default options for future instances of the plugin
this.options = $.extend({}, defaults, options);
console.log(element, options);
this._defaults = defaults;
this._name = pluginName;
this.init();
}
Plugin.prototype.init = function () {
// Place initialization logic here
// We already have access to the DOM element and
// the options via the instance, e.g. this.element
// and this.options
console.log('payment.popup.js:init()');
};
// A really lightweight plugin wrapper around the constructor,
// preventing against multiple instantiations
$.fn[pluginName] = function (options) {
return this.each(function () {
if (!$.data(this, pluginName)) {
$.data(this, pluginName, new Plugin(this, options));
}
});
};
$(document).on('click', '[data-popup]', function (e) {
var $this = $(this);
$.data(this, pluginName, new Plugin($this, $this.data()));
e.preventDefault();
});
})(jQuery, window, document);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment