Package org.apache.beehive.netui.tags.html

Source Code of org.apache.beehive.netui.tags.html.Body

/*
* Copyright 2004 The Apache Software Foundation.
*
* 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
*
*     http://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.
*
* $Header:$
*/
package org.apache.beehive.netui.tags.html;

import org.apache.beehive.netui.tags.ErrorHandling;
import org.apache.beehive.netui.tags.javascript.IScriptReporter;
import org.apache.beehive.netui.tags.rendering.AbstractHtmlState;
import org.apache.beehive.netui.tags.rendering.BodyTag;
import org.apache.beehive.netui.tags.rendering.TagRenderingBase;
import org.apache.beehive.netui.tags.rendering.WriteRenderAppender;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.jsp.JspException;

/**
* @jsptagref.tagdescription <p>
* Renders an HTML &lt;body> tag with the attributes specified.
* </p>
* @netui:tag name="body" description="Output the &lt;body> container.  This tag allows the NetUI framework to output script and errors before the page is finished rendering."
*/
public class Body extends HtmlBaseTag
{
    private BodyTag.State _state = new BodyTag.State();
    private TagRenderingBase _br;
    private WriteRenderAppender _writer;
    private String _idScript;

    /**
     * Return the name of the Tag.
     */
    public String getTagName()
    {
        return "Body";
    }

    /**
     * This method will return the state associated with the tag.  This is used by this
     * base class to access the individual state objects created by the tags.
     * @return a subclass of the <code>AbstractHtmlState</code> class.
     */
    protected AbstractHtmlState getState()
    {
        return _state;
    }

    /**
     * Sets the onLoad javascript event.
     * @param onload the onLoad event.
     * @jsptagref.attributedescription The onLoad JavaScript event.
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_onLoad</i>
     * @netui:attribute required="false" rtexprvalue="true"
     * description="The onLoad JavaScript event."
     */
    public void setOnLoad(String onload)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_JAVASCRIPT, ONLOAD, onload);
    }

    /**
     * Sets the onUnload javascript event.
     * @param onunload the onUnload event.
     * @jsptagref.attributedescription The onLoad JavaScript event.
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_onUnload</i>
     * @netui:attribute required="false" rtexprvalue="true"
     * description="The onLoad JavaScript event."
     */
    public void setOnUnload(String onunload)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_JAVASCRIPT, ONUNLOAD, onunload);
    }

    /**
     * Sets the background image of the page.
     * @param background the background image of the page.
     * @jsptagref.attributedescription The background image of the page.
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_background</i>
     * @netui:attribute required="false"  rtexprvalue="true"
     * description="The background image of the page."
     */
    public void setBackground(String background)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_GENERAL, BACKGROUND, background);
    }

    /**
     * Sets the bgcolor of the page.
     * @param bgcolor the background color of the page.
     * @jsptagref.attributedescription The background color of the page.
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_bgcolor</i>
     * @netui:attribute required="false"  rtexprvalue="true"
     * description="The background color of the page."
     */
    public void setBgcolor(String bgcolor)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_GENERAL, BGCOLOR, bgcolor);
    }

    /**
     * Sets the foreground text color of the page.
     * @param text the foreground text color of the page.
     * @jsptagref.attributedescription The foreground text color of the page.
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_text</i>
     * @netui:attribute required="false"  rtexprvalue="true"
     * description="The foreground text color of the page."
     */
    public void setText(String text)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_GENERAL, TEXT, text);
    }

    /**
     * Sets the the color of text marking unvisited hypertext links.
     * @param link the color of text marking unvisited hypertext links of the page.
     * @jsptagref.attributedescription The color of text marking unvisited hypertext links of the page
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_link</i>
     * @netui:attribute required="false"  rtexprvalue="true"
     * description="The color of text marking unvisited hypertext links of the page."
     */
    public void setLink(String link)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_GENERAL, LINK, link);
    }

    /**
     * Sets the the color of text marking visited hypertext links.
     * @param vlink the color of text marking visited hypertext links of the page.
     * @jsptagref.attributedescription The color of text marking visited hypertext links of the page
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_vlink</i>
     * @netui:attribute required="false"  rtexprvalue="true"
     * description="The color of text marking visited hypertext links of the page."
     */
    public void setVlink(String vlink)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_GENERAL, VLINK, vlink);
    }

    /**
     * Sets the color of text marking hypertext links when selected by the user.
     * @param alink the color of text marking hypertext links when selected by the user.
     * @jsptagref.attributedescription The color of text marking hypertext links when selected by the user
     * @jsptagref.databindable false
     * @jsptagref.attributesyntaxvalue <i>string_alink</i>
     * @netui:attribute required="false"  rtexprvalue="true"
     * description="The color of text marking hypertext links when selected by the user."
     */
    public void setAlink(String alink)
    {
        _state.registerAttribute(AbstractHtmlState.ATTR_GENERAL, ALINK, alink);
    }

    /**
     * Process the start of the Button.
     * @throws javax.servlet.jsp.JspException if a JSP exception has occurred
     */
    public int doStartTag() throws JspException
    {
        // we assume that tagId will over have override id if both are defined.
        if (_state.id != null) {
            _idScript = renderNameAndId((HttpServletRequest) pageContext.getRequest(), _state, null);
        }

        // render the header...
        _writer = new WriteRenderAppender(pageContext);
        _br = TagRenderingBase.Factory.getRendering(TagRenderingBase.BODY_TAG, pageContext.getRequest());
        _br.doStartTag(_writer, _state);

        return EVAL_BODY_INCLUDE;
    }

    /**
     * Render the button.
     * @throws JspException if a JSP exception has occurred
     */
    public int doEndTag() throws JspException
    {
        // if there were errors lets report them.
        if (hasErrors()) {
            reportErrors();
        }

        // Get the script reporter
        IScriptReporter sr = getScriptReporter();
        if (sr != null) {
            //if (!sr.isInitScriptWritten()) {
            //    String s = Bundle.getString("Tags_ClientReqScriptHeader", null);
            //    registerTagError(s, null);
            //}

            // write out any errors
            ErrorHandling.reportCollectedErrors(pageContext, this);

            // write out the script before the end tag.
            sr.writeScript(_writer);

            if (sr instanceof Html) {
                Html htmlSr = (Html) sr;
                if (htmlSr.getIdScope() != null) {
                    htmlSr.endScope(_writer);
                }
            }
        }

        if (_idScript != null)
            write(_idScript);

        _br.doEndTag(_writer);

        // Evaluate the remainder of this page
        localRelease();
        return EVAL_PAGE;
    }

    public void localRelease()
    {
        super.localRelease();
        _state.clear();
        _br = null;
        _writer = null;
    }
}
TOP

Related Classes of org.apache.beehive.netui.tags.html.Body

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.