grapesjs-clot
Version:
Free and Open Source Web Builder Framework
154 lines (124 loc) • 3.88 kB
JavaScript
import { isObject, isString, each, isUndefined } from 'underscore';
export default ({ $ }) => {
if ($ && $.prototype && $.prototype.constructor.name !== 'jQuery') {
const fn = $.fn;
// Additional helpers
fn.hide = function() {
return this.css('display', 'none');
};
fn.show = function() {
return this.css('display', 'block');
};
fn.focus = function() {
const el = this.get(0);
el && el.focus();
return this;
};
// For SVGs in IE
// (fn.removeClass = function(c) {
// if (!arguments.length) {
// return this.attr('class', '');
// }
// const classes = isString(c) && c.match(/\S+/g);
// return classes
// ? this.each(function(el) {
// each(classes, function(c) {
// if (el.classList) {
// el.classList.remove(c);
// } else {
// const val = el.className;
// const bval = el.className.baseVal;
// if (!isUndefined(bval)) {
// val.baseVal = bval.replace(c, '');
// } else {
// el.className = val.replace(c, '');
// }
// }
// });
// })
// : this;
// }),
// (fn.remove = function() {
// return this.each(node => {
// return node.parentNode && node.parentNode.removeChild(node);
// });
// }),
// For spectrum compatibility
fn.bind = function(ev, h) {
return this.on(ev, h);
};
fn.unbind = function(ev, h) {
if (isObject(ev)) {
for (let name in ev) {
ev.hasOwnProperty(name) && this.off(name, ev[name]);
}
return this;
} else {
return this.off(ev, h);
}
};
fn.click = function(h) {
return h ? this.on('click', h) : this.trigger('click');
};
fn.change = function(h) {
return h ? this.on('change', h) : this.trigger('change');
};
fn.keydown = function(h) {
return h ? this.on('keydown', h) : this.trigger('keydown');
};
fn.delegate = function(selector, events, data, handler) {
if (!handler) {
handler = data;
}
return this.on(events, selector, function(e) {
e.data = data;
handler(e);
});
};
fn.scrollLeft = function() {
let el = this.get(0);
el = el.nodeType == 9 ? el.defaultView : el;
let win = el instanceof Window ? el : null;
return win ? win.pageXOffset : el.scrollLeft || 0;
};
fn.scrollTop = function() {
let el = this.get(0);
el = el.nodeType == 9 ? el.defaultView : el;
let win = el instanceof Window ? el : null;
return win ? win.pageYOffset : el.scrollTop || 0;
};
const offset = $.prototype.offset;
fn.offset = function(coords) {
let top, left;
if (coords) {
top = coords.top;
left = coords.left;
}
if (typeof top != 'undefined') {
this.css('top', `${top}px`);
}
if (typeof left != 'undefined') {
this.css('left', `${left}px`);
}
return offset.call(this);
};
$.map = function(items, clb) {
const ar = [];
for (var i = 0; i < items.length; i++) {
ar.push(clb(items[i], i));
}
return ar;
};
const indexOf = Array.prototype.indexOf;
$.inArray = function(val, arr, i) {
return arr == null ? -1 : indexOf.call(arr, val, i);
};
$.Event = function(src, props) {
if (!(this instanceof $.Event)) {
return new $.Event(src, props);
}
this.type = src;
this.isDefaultPrevented = () => false;
};
}
};