jsdom-se
Version:
jsdom fork for silent errors - A JavaScript implementation of the DOM and HTML standards
74 lines (64 loc) • 2.12 kB
JavaScript
;
const conversions = require("webidl-conversions");
const utils = require("../events/utils.js");
const Impl = require(".//Users/diego/Projects/diego/jsdom-se/lib/jsdom/living/events/UIEvent-impl.js");
const Event = require("./Event.js");
const impl = utils.implSymbols["UIEvent"];
function UIEvent(type) {
if (arguments.length < 1) {
throw new TypeError("Failed to construct 'UIEvent': 1 argument required, but only " + arguments.length + " present.");
}
const args = [];
for (let i = 0; i < arguments.length && i < 2; ++i) {
args[i] = arguments[i];
}
args[0] = conversions["DOMString"](args[0]);
module.exports.setup(this, args);
}
UIEvent.prototype.initUIEvent = function initUIEvent(typeArg, bubblesArg, cancelableArg, viewArg, detailArg) {
if (!this || !this[impl] || !(this instanceof UIEvent)) {
throw new TypeError("Illegal invocation");
}
if (arguments.length < 5) {
throw new TypeError("Failed to execute 'initUIEvent' on 'UIEvent': 5 argument required, but only " + arguments.length + " present.");
}
const args = [];
for (let i = 0; i < arguments.length && i < 5; ++i) {
args[i] = arguments[i];
}
args[0] = conversions["DOMString"](args[0]);
args[1] = conversions["boolean"](args[1]);
args[2] = conversions["boolean"](args[2]);
args[4] = conversions["long"](args[4]);
return this[impl].initUIEvent.apply(this[impl], args);
};
Object.defineProperty(UIEvent.prototype, "view", {
get() {
return this[impl].view
},
enumerable: true,
configurable: true
});
Object.defineProperty(UIEvent.prototype, "detail", {
get() {
return this[impl].detail
},
enumerable: true,
configurable: true
});
module.exports = {
create(constructorArgs, privateData) {
let obj = Object.create(UIEvent.prototype);
this.setup(obj, constructorArgs, privateData);
return obj;
},
setup(obj, constructorArgs, privateData) {
if (!privateData) privateData = {};
privateData.wrapper = obj;
Event.setup(obj, constructorArgs, privateData);
},
interface: UIEvent,
expose: {
Window: { UIEvent: UIEvent }
}
};