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

com.sun.jsftemplating.layout.descriptors.LayoutAttribute Maven / Gradle / Ivy

/*
 * The contents of this file are subject to the terms 
 * of the Common Development and Distribution License 
 * (the License).  You may not use this file except in
 * compliance with the License.
 * 
 * You can obtain a copy of the license at 
 * https://jsftemplating.dev.java.net/cddl1.html or
 * jsftemplating/cddl1.txt.
 * See the License for the specific language governing 
 * permissions and limitations under the License.
 * 
 * When distributing Covered Code, include this CDDL 
 * Header Notice in each file and include the License file 
 * at jsftemplating/cddl1.txt.  
 * If applicable, add the following below the CDDL Header, 
 * with the fields enclosed by brackets [] replaced by
 * you own identifying information: 
 * "Portions Copyrighted [year] [name of copyright owner]"
 * 
 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
 */
package com.sun.jsftemplating.layout.descriptors;

import java.io.IOException;

import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;


/**
 *  

This class defines a LayoutAttribute. A LayoutAttribute provides a * means to write an attribute for the current markup tag. A markup tag * must be started, but not yet closed for this to work.

* * @author Ken Paulsen (ken.paulsen@sun.com) */ public class LayoutAttribute extends LayoutElementBase implements LayoutElement { private static final long serialVersionUID = 1L; /** *

Constructor.

*/ public LayoutAttribute(LayoutElement parent, String name, String value, String property) { super(parent, name); _name = name; _value = value; _property = property; } /** * */ public String getName() { return _name; } /** * */ public String getValue() { return _value; } /** * */ public String getProperty() { return _property; } /** *

This method displays the text described by this component. If the * text includes an EL expression, it will be evaluated. It returns * false to avoid attempting to render children.

* * @param context The FacesContext * @param component The UIComponent * * @return false */ protected boolean encodeThis(FacesContext context, UIComponent component) throws IOException { // Get the ResponseWriter ResponseWriter writer = context.getResponseWriter(); // Render... Object value = resolveValue(context, component, getValue()); if ((value != null) && !value.toString().trim().equals("")) { String name = getName(); String prop = getProperty(); if (prop == null) { // Use the name if property is not supplied prop = name; } else if (prop.equals("null")) { prop = null; } writer.writeAttribute(name, value, prop); } // No children return false; } private String _name = null; private String _value = null; private String _property = null; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy