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.HtmlHorizontalRule;
18 import org.htmlunit.javascript.configuration.JsxClass;
19 import org.htmlunit.javascript.configuration.JsxConstructor;
20 import org.htmlunit.javascript.configuration.JsxGetter;
21 import org.htmlunit.javascript.configuration.JsxSetter;
22
23 /**
24 * The JavaScript object {@code HTMLHRElement}.
25 *
26 * @author Ahmed Ashour
27 * @author Ronald Brill
28 */
29 @JsxClass(domClass = HtmlHorizontalRule.class)
30 public class HTMLHRElement extends HTMLElement {
31
32 /**
33 * JavaScript constructor.
34 */
35 @Override
36 @JsxConstructor
37 public void jsConstructor() {
38 super.jsConstructor();
39 }
40
41 /**
42 * {@inheritDoc}
43 */
44 @Override
45 protected boolean isEndTagForbidden() {
46 return true;
47 }
48
49 /**
50 * Returns the value of the {@code width} property.
51 * @return the value of the {@code width} property
52 */
53 @JsxGetter(propertyName = "width")
54 public String getWidth_js() {
55 return getWidthOrHeight("width", Boolean.TRUE);
56 }
57
58 /**
59 * Sets the value of the {@code width} property.
60 * @param width the value of the {@code width} property
61 */
62 @JsxSetter(propertyName = "width")
63 public void setWidth_js(final String width) {
64 setWidthOrHeight("width", width, true);
65 }
66
67 /**
68 * Returns the value of the {@code align} property.
69 * @return the value of the {@code align} property
70 */
71 @JsxGetter
72 public String getAlign() {
73 return getAlign(true);
74 }
75
76 /**
77 * Sets the value of the {@code align} property.
78 * @param align the value of the {@code align} property
79 */
80 @JsxSetter
81 public void setAlign(final String align) {
82 setAlign(align, false);
83 }
84
85 /**
86 * Gets the {@code color} property.
87 * @return the {@code color} property
88 */
89 @JsxGetter
90 public String getColor() {
91 return getDomNodeOrDie().getAttributeDirect("color");
92 }
93
94 /**
95 * Sets the {@code color} property.
96 * @param color the {@code color} property
97 */
98 @JsxSetter
99 public void setColor(final String color) {
100 getDomNodeOrDie().setAttribute("color", color);
101 }
102
103 }