webgme
Version:
Web-based Generic Modeling Environment
302 lines (255 loc) • 10.5 kB
JavaScript
/* CSS zoom control jQuery plugin v 1.0.0 */
/* GitHub source: http://github.com/rkereskenyi/jquery.csszoom */
/* jQuery CSS zoom control based on Keith Wood's plugin framework code (http://keith-wood.name/pluginFramework.html) */
(function($) { // Hide scope, no $ conflict
/* CSSZomm manager. */
function CSSZoom() {
this._defaults = {
zoomLevels: [0.1, 0.25, 0.5, 1, 2, 5, 10], //default zoom level values
onZoom: null //callback when zoom level changes, receives one parameter: zoomLevel
};
}
$.extend(CSSZoom.prototype, {
/* Class name added to elements to indicate already configured by this plugin. */
markerClassName: 'css-zoom',
/* Name of the data property for instance settings. */
propertyName: 'CSSZoom',
/* Class name for the label */
_zoomLabelClass: 'css-zoom-label',
/* Override the default settings for all plugin instances.
@param options (object) the new settings to use as defaults
@return (Plugin) this object */
setDefaults: function(options) {
$.extend(this._defaults, options || {});
//make sure there is zoomLevel 1 and zoomValues are sorted
if (this._defaults.zoomLevels.indexOf(1) === -1) {
this._defaults.zoomLevels.push(1);
}
this._defaults.zoomLevels.sort(function(a,b){return a-b});
return this;
},
/* Attach the plugin functionality.
@param target (element) the control to affect
@param options (object) the custom options for this instance */
_attachPlugin: function(target, options) {
target = $(target);
if (target.hasClass(this.markerClassName)) {
return;
}
var inst = {options: $.extend({}, this._defaults),
zoomTarget: null,
zoomLevel: 1,
zoomLevels: [],
zoomLabel: undefined};
target.addClass(this.markerClassName).data(this.propertyName, inst);
target.slider({
orientation: "vertical",
min: 0,
max: this._defaults.zoomLevels.length - 1,
value: this._defaults.zoomLevels.indexOf(1),
slide: function( event, ui ) {
var inst = $(this).data(plugin.propertyName);
inst.zoomLevel = inst.zoomLevels[ui.value];
plugin._setZoom($(this));
}
});
var sliderHandle = target.find('.ui-slider-handle');
// Uncommented by pmeijer - do not show the magnifying glass.
//var iconZoom = $('<i/>');
//iconZoom.css({
// 'display': 'inline-block',
// 'width': '14px',
// 'height': '14px',
// 'background-image': 'url()',
// 'background-repeat': 'no-repeat'
//});
//sliderHandle.append(iconZoom);
inst.zoomLabel = $('<div/>', {'class': this._zoomLabelClass});
sliderHandle.append(inst.zoomLabel);
sliderHandle.on('dblclick.' + this.propertyName, function (event) {
if (!target.hasClass(plugin.propertyName + '-disabled')) {
inst.zoomLevel = 1;
plugin._setZoom(target);
event.stopPropagation();
event.preventDefault();
}
});
this._optionPlugin(target, options);
},
/* Retrieve or reconfigure the settings for a control.
@param target (element) the control to affect
@param options (object) the new options for this instance or
(string) an individual property name
@param value (any) the individual property value (omit if options
is an object or to retrieve the value of a setting)
@return (any) if retrieving a value */
_optionPlugin: function(target, options, value) {
target = $(target);
var inst = target.data(this.propertyName);
if (!options || (typeof options == 'string' && value == null)) { // Get option
var name = options;
options = (inst || {}).options;
return (options && name ? options[name] : options);
}
if (!target.hasClass(this.markerClassName)) {
return;
}
options = options || {};
if (typeof options == 'string') {
var name = options;
options = {};
options[name] = value;
}
$.extend(inst.options, options);
if (inst.zoomTarget && inst.zoomTarget.length > 0) { //remove old zoom-target
inst.zoomTarget.css({'transform-origin': '',
'transform': ''});
inst.zoomTarget = $([]);
}
if (options.zoomTarget) { //add new zoom-target
inst.zoomTarget = $(inst.options.zoomTarget);
}
if (options.zoomLevels) { //add new zoom-levels
inst.zoomLevels = [].concat(options.zoomLevels);
if (inst.zoomLevels.indexOf(1) === -1) {
inst.zoomLevels.push(1);
}
inst.zoomLevels.sort(function(a,b){return a-b});
} else {
inst.zoomLevels = [].concat(inst.options.zoomLevels);
}
target.slider( "option", "max", inst.zoomLevels.length - 1 );
this._setZoom(target);
},
/* Sets the zoom on zoomtarget accordingly */
_setZoom: function (target) {
var inst = target.data(this.propertyName);
var zoomLevel = inst.zoomLevel;
var zoomTarget = inst.zoomTarget;
var zoomLabel = inst.zoomLabel;
zoomTarget.css({'transform-origin': '0 0',
'transform': 'scale('+ zoomLevel + ', ' + zoomLevel + ')'});
zoomLabel.text( zoomLevel + "x" );
target.slider("option", "value", inst.zoomLevels.indexOf(zoomLevel));
if (inst.options.onZoom) {
inst.options.onZoom.apply(target, [zoomLevel]);
}
},
/* Add function for 'method' command.
Called by $(selector).pluginname('method').
@param target (element) the control to check */
_methodPlugin: function(target) {
var inst = target.data(this.propertyName);
// Implement functionality here
},
/* Enable the control.
@param target (element) the control to affect */
_enablePlugin: function(target) {
target = $(target);
if (!target.hasClass(this.markerClassName)) {
return;
}
target.prop('disabled', false).removeClass(this.propertyName + '-disabled');
var inst = target.data(this.propertyName);
target.slider( "enable" );
},
/* Disable the control.
@param target (element) the control to affect */
_disablePlugin: function(target) {
target = $(target);
if (!target.hasClass(this.markerClassName)) {
return;
}
target.prop('disabled', true).addClass(this.propertyName + '-disabled');
var inst = target.data(this.propertyName);
target.slider( "disable" );
},
/* Zoom in.
@param target (element) the control to affect */
_zoomInPlugin: function(target) {
target = $(target);
if (!target.hasClass(this.markerClassName)) {
return;
}
var inst = target.data(this.propertyName);
var zoomLevel = inst.zoomLevel;
var zoomLevels = inst.zoomLevels;
var idx = zoomLevels.indexOf(zoomLevel);
if (idx < zoomLevels.length - 1) {
inst.zoomLevel = zoomLevels[idx + 1];
}
this._setZoom(target);
},
/* Zoom out.
@param target (element) the control to affect */
_zoomOutPlugin: function(target) {
target = $(target);
if (!target.hasClass(this.markerClassName)) {
return;
}
var inst = target.data(this.propertyName);
var zoomLevel = inst.zoomLevel;
var zoomLevels = inst.zoomLevels;
var idx = zoomLevels.indexOf(zoomLevel);
if (idx > 0) {
inst.zoomLevel = zoomLevels[idx - 1];
}
this._setZoom(target);
},
/* Remove the plugin functionality from a control.
@param target (element) the control to affect */
_destroyPlugin: function(target) {
target = $(target);
if (!target.hasClass(this.markerClassName)) {
return;
}
var inst = target.data(this.propertyName);
if (inst.zoomTarget && inst.zoomTarget.length > 0) { //remove old zoom-target
inst.zoomTarget.css({'transform-origin': '',
'transform': ''});
inst.zoomTarget = $([]);
}
target.removeClass(this.markerClassName).
removeData(this.propertyName).
unbind('.' + this.propertyName);
target.slider( "destroy" );
}
});
// The list of methods that return values and don't permit chaining
var getters = [];
/* Determine whether a method is a getter and doesn't permit chaining.
@param method (string, optional) the method to run
@param otherArgs ([], optional) any other arguments for the method
@return true if the method is a getter, false if not */
function isNotChained(method, otherArgs) {
if (method == 'option' && (otherArgs.length == 0 ||
(otherArgs.length == 1 && typeof otherArgs[0] == 'string'))) {
return true;
}
return $.inArray(method, getters) > -1;
}
/* Attach the plugin functionality to a jQuery selection.
@param options (object) the new settings to use for these instances (optional) or
(string) the method to run (optional)
@return (jQuery) for chaining further calls or
(any) getter value */
$.fn.csszoom = function(options) {
var otherArgs = Array.prototype.slice.call(arguments, 1);
if (isNotChained(options, otherArgs)) {
return plugin['_' + options + 'Plugin'].apply(plugin, [this[0]].concat(otherArgs));
}
return this.each(function() {
if (typeof options == 'string') {
if (!plugin['_' + options + 'Plugin']) {
throw 'Unknown method: ' + options;
}
plugin['_' + options + 'Plugin'].apply(plugin, [this].concat(otherArgs));
}
else {
plugin._attachPlugin(this, options || {});
}
});
};
/* Initialise the plugin functionality. */
var plugin = $.csszoom = new CSSZoom(); // Singleton instance
})(jQuery);