All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.htmlunit.cyberneko.html.dom.HTMLOptionElementImpl Maven / Gradle / Ivy

/*
 * Copyright (c) 2002-2009 Andy Clark, Marc Guillemot
 * Copyright (c) 2017-2024 Ronald Brill
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.htmlunit.cyberneko.html.dom;

import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.w3c.dom.Text;
import org.w3c.dom.html.HTMLElement;
import org.w3c.dom.html.HTMLOptionElement;
import org.w3c.dom.html.HTMLSelectElement;

/**
 * @author Assaf Arkin
 * @see org.w3c.dom.html.HTMLOptionElement
 * @see org.htmlunit.cyberneko.xerces.dom.ElementImpl
 */
public class HTMLOptionElementImpl extends HTMLElementImpl implements HTMLOptionElement {

    @Override
    public boolean getDefaultSelected() {
        // ! NOT FULLY IMPLEMENTED !
        return getBinary("default-selected");
    }

    @Override
    public void setDefaultSelected(final boolean defaultSelected) {
        // ! NOT FULLY IMPLEMENTED !
        setAttribute("default-selected", defaultSelected);
    }

    @Override
    public String getText() {
        Node child;
        final StringBuilder text = new StringBuilder();

        // Find the Text nodes contained within this element and return their
        // concatenated value. Required to go around comments, entities, etc.
        child = getFirstChild();
        while (child != null) {
            if (child instanceof Text) {
                text.append(((Text) child).getData());
            }
            child = child.getNextSibling();
        }
        return text.toString();
    }

    @Override
    public int getIndex() {
        Node parent;
        final NodeList options;
        int i;

        // Locate the parent SELECT. Note that this OPTION might be inside a
        // OPTGROUP inside the SELECT. Or it might not have a parent SELECT.
        // Everything is possible. If no parent is found, return -1.
        parent = getParentNode();
        while (parent != null && !(parent instanceof HTMLSelectElement)) {
            parent = parent.getParentNode();
        }
        if (parent != null) {
            // Use getElementsByTagName() which creates a snapshot of all the
            // OPTION elements under the SELECT. Access to the returned NodeList
            // is very fast and the snapshot solves many synchronization problems.
            options = ((HTMLElement) parent).getElementsByTagName("OPTION");
            for (i = 0; i < options.getLength(); ++i) {
                if (options.item(i) == this) {
                    return i;
                }
            }
        }
        return -1;
    }

    @Override
    public boolean getDisabled() {
        return getBinary("disabled");
    }

    @Override
    public void setDisabled(final boolean disabled) {
        setAttribute("disabled", disabled);
    }

    @Override
    public String getLabel() {
        return capitalize(getAttribute("label"));
    }

    @Override
    public void setLabel(final String label) {
        setAttribute("label", label);
    }

    @Override
    public boolean getSelected() {
        return getBinary("selected");
    }

    @Override
    public void setSelected(final boolean selected) {
        setAttribute("selected", selected);
    }

    @Override
    public String getValue() {
        return getAttribute("value");
    }

    @Override
    public void setValue(final String value) {
        setAttribute("value", value);
    }

    /**
     * Constructor requires owner document.
     *
     * @param owner The owner HTML document
     */
    public HTMLOptionElementImpl(final HTMLDocumentImpl owner, final String name) {
        super(owner, name);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy