1 /*
2 * Copyright (c) 2002-2025 Gargoyle Software Inc.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 * https://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15 package org.htmlunit.javascript.host.html;
16
17 import org.htmlunit.html.DomElement;
18 import org.htmlunit.html.HtmlEmbed;
19 import org.htmlunit.javascript.configuration.JsxClass;
20 import org.htmlunit.javascript.configuration.JsxConstructor;
21 import org.htmlunit.javascript.configuration.JsxGetter;
22 import org.htmlunit.javascript.configuration.JsxSetter;
23
24 /**
25 * The JavaScript object {@code HTMLEmbedElement}.
26 *
27 * @author Ahmed Ashour
28 * @author Ronald Brill
29 */
30 @JsxClass(domClass = HtmlEmbed.class)
31 public class HTMLEmbedElement extends HTMLElement {
32
33 /**
34 * JavaScript constructor.
35 */
36 @Override
37 @JsxConstructor
38 public void jsConstructor() {
39 super.jsConstructor();
40 }
41
42 /**
43 * Returns the value of the {@code align} property.
44 * @return the value of the {@code align} property
45 */
46 @JsxGetter
47 public String getAlign() {
48 return getAlign(true);
49 }
50
51 /**
52 * Sets the value of the {@code align} property.
53 * @param align the value of the {@code align} property
54 */
55 @JsxSetter
56 public void setAlign(final String align) {
57 setAlign(align, false);
58 }
59
60 /**
61 * Returns the value of the {@code height} property.
62 * @return the value of the {@code height} property
63 */
64 @JsxGetter(propertyName = "height")
65 public String getHeight_js() {
66 return getDomNodeOrDie().getAttributeDirect("height");
67 }
68
69 /**
70 * Sets the value of the {@code height} property.
71 * @param height the value of the {@code height} property
72 */
73 @JsxSetter(propertyName = "height")
74 public void setHeight_js(final String height) {
75 getDomNodeOrDie().setAttribute("height", height);
76 }
77
78 /**
79 * Returns the value of the {@code width} property.
80 * @return the value of the {@code width} property
81 */
82 @JsxGetter(propertyName = "width")
83 public String getWidth_js() {
84 return getDomNodeOrDie().getAttributeDirect("width");
85 }
86
87 /**
88 * Sets the value of the {@code width} property.
89 * @param width the value of the {@code width} property
90 */
91 @JsxSetter(propertyName = "width")
92 public void setWidth_js(final String width) {
93 getDomNodeOrDie().setAttribute("width", width);
94 }
95
96 /**
97 * {@inheritDoc}
98 */
99 @Override
100 protected boolean isEndTagForbidden() {
101 return true;
102 }
103
104 /**
105 * Returns the {@code name} attribute.
106 * @return the {@code name} attribute
107 */
108 @JsxGetter
109 @Override
110 public String getName() {
111 return getDomNodeOrDie().getAttributeDirect(DomElement.NAME_ATTRIBUTE);
112 }
113
114 /**
115 * Sets the {@code name} attribute.
116 * @param name the {@code name} attribute
117 */
118 @JsxSetter
119 @Override
120 public void setName(final String name) {
121 getDomNodeOrDie().setAttribute(DomElement.NAME_ATTRIBUTE, name);
122 }
123
124 }