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 "/>")
67 * @return {@code true} to make generated XML readable as HTML
68 */
69 @Override
70 protected boolean isEmptyXmlTagExpanded() {
71 return true;
72 }
73
74 }