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

org.apache.myfaces.custom.stylesheet.AbstractStylesheet Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.
 */
package org.apache.myfaces.custom.stylesheet;

import javax.faces.component.UIComponentBase;

import org.apache.myfaces.component.UserRoleAware;
import org.apache.myfaces.component.UserRoleUtils;


/**
 * Renders the path to a common CSS-file
 * 
 * @JSFComponent
 *   name = "t:stylesheet"
 *   class = "org.apache.myfaces.custom.stylesheet.Stylesheet"
 *   tagClass = "org.apache.myfaces.custom.stylesheet.StylesheetTag"
 * @since 1.1.7
 * @author mwessendorf (latest modification by $Author: lu4242 $)
 * @version $Revision: 691856 $ $Date: 2008-09-04 04:40:30 +0200 (Thu, 04 Sep 2008) $
 */
public abstract class AbstractStylesheet extends UIComponentBase
    implements UserRoleAware    
{
    public static final String COMPONENT_TYPE = "org.apache.myfaces.Stylesheet";
    public static final String COMPONENT_FAMILY = "javax.faces.Output";
    private static final String DEFAULT_RENDERER_TYPE = "org.apache.myfaces.Stylesheet";

    /**
     * URL for CSS-file.
     * 

* If this path starts with a slash, then the webapp context path will be prepended to it. * This makes it simple to reference stylesheets at an absolute path within the webapp. * A value like "/styles/style.css" becomes "/webappname/styles/style.css". *

*

* If this path does not start with a slash, then it is output unaltered. This supports * absolute urls ("http://host/path/style.css"). It also supports having css files relative * to the current page ("style.css" or "styles/style.css") but this needs to be used with * care as the standard JSF postback/internal-forward navigation style can cause browsers * to use an inappropriate base url when resolving relative references. *

* * @JSFProperty * required="true" */ public abstract String getPath(); /** * Inline the stylesheet file content as in contrast to referencing it as a link. *

* The file referenced by the path attribute is loaded, and its content is written * to the page wrapped in an <script> tag. *

*

* When this option is enabled, the path property must contain an absolute path * within the current webapp. External urls ("http://*") and paths relative to the * current page are not supported. *

* * @JSFProperty * defaultValue = "false" */ public abstract boolean isInline(); /** * Cause EL expressions in the stylesheet to be evaluated. *

* When true, any EL expression in the stylesheet will be evaluated and replaced * by its string representation on the first access. The stylesheet will be * processed only once. Every subsequent request will get a cached view. *

* * @JSFProperty * defaultValue = "false" */ public abstract boolean isFiltered(); /** * Define the target media of the styles: *
*
screen
*
Intended for non-paged computer screens.
*
tty
*
Intended for media using a fixed-pitch character grid, such * as teletypes, terminals, or portable devices with limited * display capabilities.
*
tv
*
Intended for television-type devices (low resolution, * color, limited scrollability).
*
projection
*
Intended for projectors.
*
handheld
*
Intended for handheld devices (small screen, monochrome, * bitmapped graphics, limited bandwidth).
*
print
*
Intended for paged, opaque material and for documents * viewed on screen in print preview mode.
*
braille
*
Intended for braille tactile feedback devices.
*
aural
*
Intended for speech synthesizers.
*
all
*
Suitable for all devices.
*
* Could be a comma separated list. * See also http://www.w3.org/TR/REC-html40/types.html#type-media-descriptors * * @JSFProperty */ public abstract String getMedia(); public boolean isRendered() { if (!UserRoleUtils.isVisibleOnUserRole(this)) { return false; } return super.isRendered(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy