Skip to content

Instantly share code, notes, and snippets.

@FiNGAHOLiC
Forked from ehynds/widget-template.js
Created December 1, 2011 12:36
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save FiNGAHOLiC/1416414 to your computer and use it in GitHub Desktop.
Save FiNGAHOLiC/1416414 to your computer and use it in GitHub Desktop.
UI Widget Factory template
(function($){
$.widget("ui.mywidget", {
options: {
autoOpen: true
},
_create: function(){
// by default, consider this thing closed.
this._isOpen = false;
// remember this instance
$.ui.mywidget.instances.push(this.element);
},
_init: function(){
// call open if this instance should be open by default
if( this.options.autoOpen ){
this.open();
}
},
open: function(){
this._isOpen = true;
// trigger beforeopen event. if beforeopen returns false,
// prevent bail out of this method.
if( this._trigger("beforeopen") === false ){
return;
}
// call methods on every other instance of this dialog
$.each( this._getOtherInstances(), function(){
var $this = $(this);
if($this.mywidget("isOpen")){
$this.mywidget("close");
}
});
// more open related code here
// trigger open event
this._trigger("open");
return this;
},
close: function(){
this._isOpen = false;
// trigger close event
this._trigger("close");
return this;
},
isOpen: function(){
return this._isOpen;
},
destroy: function(){
// remove this instance from $.ui.mywidget.instances
var element = this.element,
position = $.inArray(element, $.ui.mywidget.instances);
// if this instance was found, splice it off
if(position > -1){
$.ui.mywidget.instances.splice(position, 1);
}
// call the original destroy method since we overwrote it
$.Widget.prototype.destroy.call( this );
},
_getOtherInstances: function(){
var element = this.element;
return $.grep($.ui.mywidget.instances, function(el){
return el !== element;
});
},
_setOption: function(key, value){
this.options[key] = value;
switch(key){
case "something":
// perform some additional logic if just setting the new
// value in this.options is not enough.
break;
}
}
});
$.extend($.ui.mywidget, {
instances: []
});
})(jQuery);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment