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.html;
16  
17  import static org.htmlunit.BrowserVersionFeatures.CSS_NOSCRIPT_DISPLAY_INLINE;
18  
19  import java.util.Map;
20  
21  import org.htmlunit.SgmlPage;
22  
23  /**
24   * Wrapper for the HTML element "noscript".
25   *
26   * @author <a href="mailto:mbowler@GargoyleSoftware.com">Mike Bowler</a>
27   * @author David K. Taylor
28   * @author <a href="mailto:cse@dynabean.de">Christian Sell</a>
29   * @author Ahmed Ashour
30   * @author Ronald Brill
31   * @author Frank Danek
32   */
33  public class HtmlNoScript extends HtmlElement {
34  
35      /** The HTML tag represented by this element. */
36      public static final String TAG_NAME = "noscript";
37  
38      /**
39       * Creates an instance of HtmlNoScript
40       *
41       * @param qualifiedName the qualified name of the element type to instantiate
42       * @param page the HtmlPage that contains this element
43       * @param attributes the initial attributes
44       */
45      HtmlNoScript(final String qualifiedName, final SgmlPage page,
46              final Map<String, DomAttr> attributes) {
47          super(qualifiedName, page, attributes);
48      }
49  
50      /**
51       * {@inheritDoc}
52       */
53      @Override
54      public DisplayStyle getDefaultStyleDisplay() {
55          if (!getPage().getWebClient().isJavaScriptEnabled()) {
56              return DisplayStyle.BLOCK;
57          }
58          if (hasFeature(CSS_NOSCRIPT_DISPLAY_INLINE)) {
59              return DisplayStyle.INLINE;
60          }
61          return DisplayStyle.NONE;
62      }
63  
64      /**
65       * Indicates if a node without children should be written in expanded form as XML
66       * (i.e. with closing tag rather than with "/&gt;")
67       * @return {@code true} to make generated XML readable as HTML
68       */
69      @Override
70      protected boolean isEmptyXmlTagExpanded() {
71          return true;
72      }
73  
74  }