View Javadoc
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 static org.htmlunit.javascript.configuration.SupportedBrowser.CHROME;
18  import static org.htmlunit.javascript.configuration.SupportedBrowser.EDGE;
19  import static org.htmlunit.javascript.configuration.SupportedBrowser.FF;
20  
21  import org.htmlunit.html.HtmlDetails;
22  import org.htmlunit.javascript.JavaScriptEngine;
23  import org.htmlunit.javascript.configuration.JsxClass;
24  import org.htmlunit.javascript.configuration.JsxConstructor;
25  import org.htmlunit.javascript.configuration.JsxGetter;
26  import org.htmlunit.javascript.configuration.JsxSetter;
27  
28  /**
29   * The JavaScript object {@code HTMLDetailsElement}.
30   *
31   * @author Ahmed Ashour
32   * @author Ronald Brill
33   */
34  @JsxClass(domClass = HtmlDetails.class)
35  public class HTMLDetailsElement extends HTMLElement {
36  
37      /**
38       * JavaScript constructor.
39       */
40      @Override
41      @JsxConstructor
42      public void jsConstructor() {
43          super.jsConstructor();
44      }
45  
46      /**
47       * Returns the {@code open} property.
48       * @return the {@code open} property
49       */
50      @JsxGetter
51      public boolean isOpen() {
52          return ((HtmlDetails) getDomNodeOrDie()).isOpen();
53      }
54  
55      /**
56       * Sets the open attribute.
57       * @param newValue the new value to set
58       */
59      @JsxSetter
60      public void setOpen(final Object newValue) {
61          final boolean bool = JavaScriptEngine.toBoolean(newValue);
62  
63          ((HtmlDetails) getDomNodeOrDie()).setOpen(bool);
64      }
65  
66      /**
67       * Returns the {@code name} property.
68       * @return the {@code name} property
69       */
70      @JsxGetter({CHROME, EDGE, FF})
71      @Override
72      public String getName() {
73          return super.getName();
74      }
75  
76      /**
77       * Sets the name attribute.
78       * @param newValue the new value to set
79       */
80      @JsxSetter
81      @Override
82      public void setName(final String newValue) {
83          super.setName(newValue);
84      }
85  }