java.lang.Object
org.apache.turbine.services.pull.tools.UITool
Alle implementierten Schnittstellen:
ApplicationTool

public class UITool extends Object implements ApplicationTool
Manages all UI elements for a Turbine Application. Any UI element can be accessed in any template using the $ui handle (assuming you use the default PullService configuration). So, for example, you could access the background color for your pages by using $ui.bgcolor

This implementation provides a single level of inheritance in that if a property does not exist in a non-default skin, the value from the default skin will be used. By only requiring values different to those stored in the default skin to appear in the non-default skins the amount of memory consumed in cases where the UserManager instance is used at a non-global scope will potentially be reduced due to the fact that a shared instance of the default skin properties can be used. Note that this inheritance only applies to property values - it does not apply to any images or stylesheets that may form part of your skins.

This is an application pull tool for the template system. You should not use it in a normal application! Within Java code you should use TurbineUI.

This is an application pull tool for the template system. You should only use it in a normal application to set the skin attribute for a user (setSkin(User user, String skin)) and to initialize it for the user, otherwise use TurbineUI is probably the way to go.

Version:
$Id$
Autor:
Jason van Zyl, James Coltman, Henning P. Schmiedehausen, Scott Eade
Siehe auch:
  • Felddetails

    • SKIN_ATTRIBUTE

      public static final String SKIN_ATTRIBUTE
      Attribute name of skinName value in User's temp hashmap.
  • Konstruktordetails

  • Methodendetails

    • refresh

      public void refresh()
      Refresh the tool.
      Angegeben von:
      refresh in Schnittstelle ApplicationTool
    • getSkinNames

      public String[] getSkinNames()
      Provide access to the list of available skin names.
      Gibt zurück:
      the available skin names.
    • getWebappSkinName

      Get the name of the default skin name for the web application from the TurbineResources.properties file. If the property is not present the name of the default skin will be returned. Note that the web application skin name may be something other than default, in which case its properties will default to the skin with the name "default".
      Gibt zurück:
      the name of the default skin for the web application.
    • get

      public String get(String key)
      Retrieve a skin property. If the property is not defined in the current skin the value for the default skin will be provided. If the current skin does not exist then the skin configured for the webapp will be used. If the webapp skin does not exist the default skin will be used. If the default skin does not exist then null will be returned.
      Parameter:
      key - the key to retrieve from the skin.
      Gibt zurück:
      the value of the property for the named skin (defaulting to the default skin), the webapp skin, the default skin or null, depending on whether or not the property or skins exist.
    • getSkin

      public String getSkin()
      Retrieve the skin name.
      Gibt zurück:
      the selected skin name
    • setSkin

      public void setSkin()
      Set the skin name to the skin from the TurbineResources.properties file. If the property is not present use the "default" skin.
    • setSkin

      public void setSkin(String skinName)
      Set the skin name to the specified skin.
      Parameter:
      skinName - the skin name to use.
    • setSkin

      protected void setSkin(RunData data)
      Set the skin name when the tool is configured to be loaded on a per-request basis. By default it calls getSkin to return the skin specified in TurbineResources.properties. Developers can write a subclass of UITool that overrides this method to determine the skin to use based on information held in the request.
      Parameter:
      data - a RunData instance
    • setSkin

      protected void setSkin(User user)
      Set the skin name when the tool is configured to be loaded on a per-session basis. If the user's temp hashmap contains a value in the attribute specified by the String constant SKIN_ATTRIBUTE then that is returned. Otherwise it calls getSkin to return the skin specified in TurbineResources.properties.
      Parameter:
      user - a User instance
    • setSkin

      public static void setSkin(User user, String skin)
      Set the skin name in the user's temp hashmap for the current session.
      Parameter:
      user - a User instance
      skin - the skin name for the session
    • image

      public String image(String imageId, RunData data)
      Retrieve the URL for an image that is part of the skin. The images are stored in the WEBAPP/resources/ui/skins/[SKIN]/images directory.

      Use this if for some reason your server name, server scheme, or server port change on a per request basis. I'm not sure if this would happen in a load balanced situation. I think in most cases the image(String image) method would probably be enough, but I'm not absolutely positive.

      Parameter:
      imageId - the id of the image whose URL will be generated.
      data - the RunData to use as the source of the ServerData to use as the basis for the URL.
      Gibt zurück:
      the image URL
    • image

      public String image(String imageId, ServerData serverData)
      Retrieve the URL for an image that is part of the skin. The images are stored in the WEBAPP/resources/ui/skins/[SKIN]/images directory.

      Use this if for some reason your server name, server scheme, or server port change on a per request basis. I'm not sure if this would happen in a load balanced situation. I think in most cases the image(String image) method would probably be enough, but I'm not absolutely positive.

      Parameter:
      imageId - the id of the image whose URL will be generated.
      serverData - the serverData to use as the basis for the URL.
      Gibt zurück:
      the image URL
    • image

      public String image(String imageId)
      Retrieve the URL for an image that is part of the skin. The images are stored in the WEBAPP/resources/ui/skins/[SKIN]/images directory.
      Parameter:
      imageId - the id of the image whose URL will be generated.
      Gibt zurück:
      the image URL
    • getStylecss

      public String getStylecss(RunData data)
      Retrieve the URL for the style sheet that is part of the skin. The style is stored in the WEBAPP/resources/ui/skins/[SKIN] directory with the filename skin.css

      Use this if for some reason your server name, server scheme, or server port change on a per request basis. I'm not sure if this would happen in a load balanced situation. I think in most cases the style() method would probably be enough, but I'm not absolutely positive.

      Parameter:
      data - the RunData to use as the source of the ServerData to use as the basis for the URL.
      Gibt zurück:
      the CSS URL
    • getStylecss

      public String getStylecss(ServerData serverData)
      Retrieve the URL for the style sheet that is part of the skin. The style is stored in the WEBAPP/resources/ui/skins/[SKIN] directory with the filename skin.css

      Use this if for some reason your server name, server scheme, or server port change on a per request basis. I'm not sure if this would happen in a load balanced situation. I think in most cases the style() method would probably be enough, but I'm not absolutely positive.

      Parameter:
      serverData - the serverData to use as the basis for the URL.
      Gibt zurück:
      the CSS URL
    • getStylecss

      public String getStylecss()
      Retrieve the URL for the style sheet that is part of the skin. The style is stored in the WEBAPP/resources/ui/skins/[SKIN] directory with the filename skin.css
      Gibt zurück:
      the CSS URL
    • getScript

      public String getScript(String filename, RunData data)
      Retrieve the URL for a given script that is part of the skin. The script is stored in the WEBAPP/resources/ui/skins/[SKIN] directory.

      Use this if for some reason your server name, server scheme, or server port change on a per request basis. I'm not sure if this would happen in a load balanced situation. I think in most cases the image(String image) method would probably be enough, but I'm not absolutely positive.

      Parameter:
      filename - the name of the script file whose URL will be generated.
      data - the RunDate to use as the source of the ServerData to use as the basis for the URL.
      Gibt zurück:
      the script URL
    • getScript

      public String getScript(String filename, ServerData serverData)
      Retrieve the URL for a given script that is part of the skin. The script is stored in the WEBAPP/resources/ui/skins/[SKIN] directory.

      Use this if for some reason your server name, server scheme, or server port change on a per request basis. I'm not sure if this would happen in a load balanced situation. I think in most cases the image(String image) method would probably be enough, but I'm not absolutely positive.

      Parameter:
      filename - the name of the script file whose URL will be generated.
      serverData - the serverData to use as the basis for the URL.
      Gibt zurück:
      the script URL
    • getScript

      public String getScript(String filename)
      Retrieve the URL for a given script that is part of the skin. The script is stored in the WEBAPP/resources/ui/skins/[SKIN] directory.
      Parameter:
      filename - the name of the script file whose URL will be generated.
      Gibt zurück:
      the script URL
    • init

      public void init(Object data)
      Initialize the UITool object.
      Angegeben von:
      init in Schnittstelle ApplicationTool
      Parameter:
      data - This is null, RunData or User depending upon specified tool scope.