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 java.util.Map;
18
19 import org.htmlunit.SgmlPage;
20
21 /**
22 * Wrapper for the HTML element "title".
23 *
24 * @author Mike Bowler
25 * @author Christian Sell
26 * @author Chris Erskine
27 * @author Marc Guillemot
28 * @author Ahmed Ashour
29 * @author Frank Danek
30 */
31 public class HtmlTitle extends HtmlElement {
32
33 /** The HTML tag represented by this element. */
34 public static final String TAG_NAME = "title";
35
36 /**
37 * Creates an instance of HtmlTitle.
38 *
39 * @param qualifiedName the qualified name of the element type to instantiate
40 * @param page the HtmlPage that contains this element
41 * @param attributes the initial attributes
42 */
43 HtmlTitle(final String qualifiedName, final SgmlPage page,
44 final Map<String, DomAttr> attributes) {
45 super(qualifiedName, page, attributes);
46 }
47
48 /**
49 * Allows the text value for the title element be replaced.
50 * {@inheritDoc}
51 */
52 @Override
53 public void setNodeValue(final String message) {
54 final DomNode child = getFirstChild();
55 if (child == null) {
56 final DomNode textNode = new DomText(getPage(), message);
57 appendChild(textNode);
58 }
59 else if (child instanceof DomText) {
60 ((DomText) child).setData(message);
61 }
62 else {
63 throw new IllegalStateException("For title tag, this should be a text node");
64 }
65 }
66
67 /**
68 * {@inheritDoc}
69 */
70 @Override
71 protected boolean isEmptyXmlTagExpanded() {
72 return true;
73 }
74
75 /**
76 * {@inheritDoc}
77 */
78 @Override
79 public DisplayStyle getDefaultStyleDisplay() {
80 return DisplayStyle.NONE;
81 }
82
83 /**
84 * Returns the {@code text} attribute.
85 * @return the {@code text} attribute
86 */
87 public String getText() {
88 final DomNode firstChild = getFirstChild();
89 if (firstChild != null) {
90 return firstChild.getNodeValue();
91 }
92 return "";
93 }
94
95 /**
96 * Sets the {@code text} attribute.
97 * @param text the {@code text} attribute
98 */
99 public void setText(final String text) {
100 DomNode firstChild = getFirstChild();
101 if (firstChild == null) {
102 firstChild = new DomText(getPage(), text);
103 appendChild(firstChild);
104 }
105 else {
106 firstChild.setNodeValue(text);
107 }
108 }
109 }