UNPKG

jsdom-se

Version:

jsdom fork for silent errors - A JavaScript implementation of the DOM and HTML standards

74 lines (64 loc) 2.12 kB
"use strict"; 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 } } };