jsdom
Version:
A JavaScript implementation of many web standards
377 lines (307 loc) • 11.9 kB
JavaScript
"use strict";
const conversions = require("webidl-conversions");
const utils = require("./utils.js");
const HTMLConstructor_helpers_html_constructor = require("../helpers/html-constructor.js").HTMLConstructor;
const ceReactionsPreSteps_helpers_custom_elements = require("../helpers/custom-elements.js").ceReactionsPreSteps;
const ceReactionsPostSteps_helpers_custom_elements = require("../helpers/custom-elements.js").ceReactionsPostSteps;
const implSymbol = utils.implSymbol;
const ctorRegistrySymbol = utils.ctorRegistrySymbol;
const HTMLElement = require("./HTMLElement.js");
const interfaceName = "HTMLOptionElement";
exports.is = value => {
return utils.isObject(value) && utils.hasOwn(value, implSymbol) && value[implSymbol] instanceof Impl.implementation;
};
exports.isImpl = value => {
return utils.isObject(value) && value instanceof Impl.implementation;
};
exports.convert = (globalObject, value, { context = "The provided value" } = {}) => {
if (exports.is(value)) {
return utils.implForWrapper(value);
}
throw new globalObject.TypeError(`${context} is not of type 'HTMLOptionElement'.`);
};
function makeWrapper(globalObject, newTarget) {
let proto;
if (newTarget !== undefined) {
proto = newTarget.prototype;
}
if (!utils.isObject(proto)) {
proto = globalObject[ctorRegistrySymbol]["HTMLOptionElement"].prototype;
}
return Object.create(proto);
}
exports.create = (globalObject, constructorArgs, privateData) => {
const wrapper = makeWrapper(globalObject);
return exports.setup(wrapper, globalObject, constructorArgs, privateData);
};
exports.createImpl = (globalObject, constructorArgs, privateData) => {
const wrapper = exports.create(globalObject, constructorArgs, privateData);
return utils.implForWrapper(wrapper);
};
exports._internalSetup = (wrapper, globalObject) => {
HTMLElement._internalSetup(wrapper, globalObject);
};
exports.setup = (wrapper, globalObject, constructorArgs = [], privateData = {}) => {
privateData.wrapper = wrapper;
exports._internalSetup(wrapper, globalObject);
Object.defineProperty(wrapper, implSymbol, {
value: new Impl.implementation(globalObject, constructorArgs, privateData),
configurable: true
});
wrapper[implSymbol][utils.wrapperSymbol] = wrapper;
if (Impl.init) {
Impl.init(wrapper[implSymbol]);
}
return wrapper;
};
exports.new = (globalObject, newTarget) => {
const wrapper = makeWrapper(globalObject, newTarget);
exports._internalSetup(wrapper, globalObject);
Object.defineProperty(wrapper, implSymbol, {
value: Object.create(Impl.implementation.prototype),
configurable: true
});
wrapper[implSymbol][utils.wrapperSymbol] = wrapper;
if (Impl.init) {
Impl.init(wrapper[implSymbol]);
}
return wrapper[implSymbol];
};
const exposed = new Set(["Window"]);
exports.install = (globalObject, globalNames) => {
if (!globalNames.some(globalName => exposed.has(globalName))) {
return;
}
const ctorRegistry = utils.initCtorRegistry(globalObject);
class HTMLOptionElement extends globalObject.HTMLElement {
constructor() {
return HTMLConstructor_helpers_html_constructor(globalObject, interfaceName, new.target);
}
get disabled() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get disabled' called on an object that is not a valid instance of HTMLOptionElement."
);
}
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
return esValue[implSymbol]._reflectGetTheContentAttribute("disabled") !== null;
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
set disabled(V) {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'set disabled' called on an object that is not a valid instance of HTMLOptionElement."
);
}
V = conversions["boolean"](V, {
context: "Failed to set the 'disabled' property on 'HTMLOptionElement': The provided value",
globals: globalObject
});
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
if (V) {
esValue[implSymbol]._reflectSetTheContentAttribute("disabled", "");
} else {
esValue[implSymbol]._reflectDeleteTheContentAttribute("disabled");
}
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
get form() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get form' called on an object that is not a valid instance of HTMLOptionElement."
);
}
return utils.tryWrapperForImpl(esValue[implSymbol]["form"]);
}
get label() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get label' called on an object that is not a valid instance of HTMLOptionElement."
);
}
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
return esValue[implSymbol]["label"];
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
set label(V) {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'set label' called on an object that is not a valid instance of HTMLOptionElement."
);
}
V = conversions["DOMString"](V, {
context: "Failed to set the 'label' property on 'HTMLOptionElement': The provided value",
globals: globalObject
});
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
esValue[implSymbol]["label"] = V;
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
get defaultSelected() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get defaultSelected' called on an object that is not a valid instance of HTMLOptionElement."
);
}
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
return esValue[implSymbol]._reflectGetTheContentAttribute("selected") !== null;
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
set defaultSelected(V) {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'set defaultSelected' called on an object that is not a valid instance of HTMLOptionElement."
);
}
V = conversions["boolean"](V, {
context: "Failed to set the 'defaultSelected' property on 'HTMLOptionElement': The provided value",
globals: globalObject
});
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
if (V) {
esValue[implSymbol]._reflectSetTheContentAttribute("selected", "");
} else {
esValue[implSymbol]._reflectDeleteTheContentAttribute("selected");
}
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
get selected() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get selected' called on an object that is not a valid instance of HTMLOptionElement."
);
}
return esValue[implSymbol]["selected"];
}
set selected(V) {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'set selected' called on an object that is not a valid instance of HTMLOptionElement."
);
}
V = conversions["boolean"](V, {
context: "Failed to set the 'selected' property on 'HTMLOptionElement': The provided value",
globals: globalObject
});
esValue[implSymbol]["selected"] = V;
}
get value() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get value' called on an object that is not a valid instance of HTMLOptionElement."
);
}
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
return esValue[implSymbol]["value"];
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
set value(V) {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'set value' called on an object that is not a valid instance of HTMLOptionElement."
);
}
V = conversions["DOMString"](V, {
context: "Failed to set the 'value' property on 'HTMLOptionElement': The provided value",
globals: globalObject
});
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
esValue[implSymbol]["value"] = V;
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
get text() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get text' called on an object that is not a valid instance of HTMLOptionElement."
);
}
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
return esValue[implSymbol]["text"];
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
set text(V) {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'set text' called on an object that is not a valid instance of HTMLOptionElement."
);
}
V = conversions["DOMString"](V, {
context: "Failed to set the 'text' property on 'HTMLOptionElement': The provided value",
globals: globalObject
});
ceReactionsPreSteps_helpers_custom_elements(globalObject);
try {
esValue[implSymbol]["text"] = V;
} finally {
ceReactionsPostSteps_helpers_custom_elements(globalObject);
}
}
get index() {
const esValue = this !== null && this !== undefined ? this : globalObject;
if (!exports.is(esValue)) {
throw new globalObject.TypeError(
"'get index' called on an object that is not a valid instance of HTMLOptionElement."
);
}
return esValue[implSymbol]["index"];
}
}
Object.defineProperties(HTMLOptionElement.prototype, {
disabled: { enumerable: true },
form: { enumerable: true },
label: { enumerable: true },
defaultSelected: { enumerable: true },
selected: { enumerable: true },
value: { enumerable: true },
text: { enumerable: true },
index: { enumerable: true },
[Symbol.toStringTag]: { value: "HTMLOptionElement", configurable: true }
});
ctorRegistry[interfaceName] = HTMLOptionElement;
Object.defineProperty(globalObject, interfaceName, {
configurable: true,
writable: true,
value: HTMLOptionElement
});
};
const Impl = require("../nodes/HTMLOptionElement-impl.js");