mirror of
https://github.com/DanielnetoDotCom/YouPHPTube
synced 2025-10-03 09:49:28 +02:00
199 lines
No EOL
5.5 KiB
JavaScript
199 lines
No EOL
5.5 KiB
JavaScript
import extend from "./extend";
|
|
import window from "../global/window";
|
|
import DependencyLib from "./inputmask.dependencyLib";
|
|
import canUseDOM from "../canUseDOM";
|
|
|
|
export {on, off, trigger, Event};
|
|
|
|
function isValidElement(elem) {
|
|
return elem instanceof Element;
|
|
}
|
|
|
|
let Event;
|
|
if (typeof window.CustomEvent === "function") {
|
|
Event = window.CustomEvent;
|
|
} else {
|
|
if (canUseDOM) {
|
|
Event = function (event, params) {
|
|
params = params || {bubbles: false, cancelable: false, detail: undefined};
|
|
var evt = document.createEvent("CustomEvent");
|
|
evt.initCustomEvent(event, params.bubbles, params.cancelable, params.detail);
|
|
return evt;
|
|
};
|
|
Event.prototype = window.Event.prototype;
|
|
}
|
|
}
|
|
|
|
|
|
function on(events, handler) {
|
|
function addEvent(ev, namespace) {
|
|
//register domevent
|
|
if (elem.addEventListener) { // all browsers except IE before version 9
|
|
elem.addEventListener(ev, handler, false);
|
|
} else if (elem.attachEvent) { // IE before version 9
|
|
elem.attachEvent("on" + ev, handler);
|
|
}
|
|
eventRegistry[ev] = eventRegistry[ev] || {};
|
|
eventRegistry[ev][namespace] = eventRegistry[ev][namespace] || [];
|
|
eventRegistry[ev][namespace].push(handler);
|
|
}
|
|
|
|
if (isValidElement(this[0])) {
|
|
var eventRegistry = this[0].eventRegistry,
|
|
elem = this[0];
|
|
|
|
|
|
var _events = events.split(" ");
|
|
for (var endx = 0; endx < _events.length; endx++) {
|
|
var nsEvent = _events[endx].split("."),
|
|
ev = nsEvent[0],
|
|
namespace = nsEvent[1] || "global";
|
|
addEvent(ev, namespace);
|
|
}
|
|
}
|
|
return this;
|
|
}
|
|
|
|
function off(events, handler) {
|
|
var eventRegistry, elem;
|
|
|
|
function removeEvent(ev, namespace, handler) {
|
|
if (ev in eventRegistry === true) {
|
|
//unbind to dom events
|
|
if (elem.removeEventListener) { // all browsers except IE before version 9
|
|
elem.removeEventListener(ev, handler, false);
|
|
} else if (elem.detachEvent) { // IE before version 9
|
|
elem.detachEvent("on" + ev, handler);
|
|
}
|
|
if (namespace === "global") {
|
|
for (var nmsp in eventRegistry[ev]) {
|
|
eventRegistry[ev][nmsp].splice(eventRegistry[ev][nmsp].indexOf(handler), 1);
|
|
}
|
|
} else {
|
|
eventRegistry[ev][namespace].splice(eventRegistry[ev][namespace].indexOf(handler), 1);
|
|
}
|
|
}
|
|
}
|
|
|
|
function resolveNamespace(ev, namespace) {
|
|
var evts = [],
|
|
hndx, hndL;
|
|
if (ev.length > 0) {
|
|
if (handler === undefined) {
|
|
for (hndx = 0, hndL = eventRegistry[ev][namespace].length; hndx < hndL; hndx++) {
|
|
evts.push({
|
|
ev: ev,
|
|
namespace: namespace && namespace.length > 0 ? namespace : "global",
|
|
handler: eventRegistry[ev][namespace][hndx]
|
|
});
|
|
}
|
|
} else {
|
|
evts.push({
|
|
ev: ev,
|
|
namespace: namespace && namespace.length > 0 ? namespace : "global",
|
|
handler: handler
|
|
});
|
|
}
|
|
} else if (namespace.length > 0) {
|
|
for (var evNdx in eventRegistry) {
|
|
for (var nmsp in eventRegistry[evNdx]) {
|
|
if (nmsp === namespace) {
|
|
if (handler === undefined) {
|
|
for (hndx = 0, hndL = eventRegistry[evNdx][nmsp].length; hndx < hndL; hndx++) {
|
|
evts.push({
|
|
ev: evNdx,
|
|
namespace: nmsp,
|
|
handler: eventRegistry[evNdx][nmsp][hndx]
|
|
});
|
|
}
|
|
} else {
|
|
evts.push({
|
|
ev: evNdx,
|
|
namespace: nmsp,
|
|
handler: handler
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return evts;
|
|
}
|
|
|
|
if (isValidElement(this[0]) && events) {
|
|
eventRegistry = this[0].eventRegistry;
|
|
elem = this[0];
|
|
|
|
|
|
var _events = events.split(" ");
|
|
for (var endx = 0; endx < _events.length; endx++) {
|
|
var nsEvent = _events[endx].split("."),
|
|
offEvents = resolveNamespace(nsEvent[0], nsEvent[1]);
|
|
for (var i = 0, offEventsL = offEvents.length; i < offEventsL; i++) {
|
|
removeEvent(offEvents[i].ev, offEvents[i].namespace, offEvents[i].handler);
|
|
}
|
|
}
|
|
}
|
|
return this;
|
|
}
|
|
|
|
function trigger(events /* , args... */) {
|
|
if (isValidElement(this[0])) {
|
|
var eventRegistry = this[0].eventRegistry,
|
|
elem = this[0];
|
|
var _events = typeof events === "string" ? events.split(" ") : [events.type];
|
|
for (var endx = 0; endx < _events.length; endx++) {
|
|
var nsEvent = _events[endx].split("."),
|
|
ev = nsEvent[0],
|
|
namespace = nsEvent[1] || "global";
|
|
if (document !== undefined && namespace === "global") {
|
|
//trigger domevent
|
|
var evnt, i, params = {
|
|
bubbles: true,
|
|
cancelable: true,
|
|
detail: arguments[1]
|
|
};
|
|
// The custom event that will be created
|
|
if (document.createEvent) {
|
|
try {
|
|
switch (ev) {
|
|
case "input":
|
|
params.inputType = "insertText";
|
|
evnt = new InputEvent(ev, params);
|
|
break;
|
|
default:
|
|
evnt = new CustomEvent(ev, params);
|
|
}
|
|
} catch (e) {
|
|
evnt = document.createEvent("CustomEvent");
|
|
evnt.initCustomEvent(ev, params.bubbles, params.cancelable, params.detail);
|
|
}
|
|
if (events.type) extend(evnt, events);
|
|
elem.dispatchEvent(evnt);
|
|
} else {
|
|
evnt = document.createEventObject();
|
|
evnt.eventType = ev;
|
|
evnt.detail = arguments[1];
|
|
if (events.type) extend(evnt, events);
|
|
elem.fireEvent("on" + evnt.eventType, evnt);
|
|
}
|
|
} else if (eventRegistry[ev] !== undefined) {
|
|
arguments[0] = arguments[0].type ? arguments[0] : DependencyLib.Event(arguments[0]);
|
|
arguments[0].detail = arguments.slice(1);
|
|
if (namespace === "global") {
|
|
for (var nmsp in eventRegistry[ev]) {
|
|
for (i = 0; i < eventRegistry[ev][nmsp].length; i++) {
|
|
eventRegistry[ev][nmsp][i].apply(elem, arguments);
|
|
}
|
|
}
|
|
} else {
|
|
for (i = 0; i < eventRegistry[ev][namespace].length; i++) {
|
|
eventRegistry[ev][namespace][i].apply(elem, arguments);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return this;
|
|
} |