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

org.apache.myfaces.trinidadinternal.ui.RendererManager 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.trinidadinternal.ui;

import org.apache.myfaces.trinidad.util.ArrayMap;

import org.apache.myfaces.trinidadinternal.ui.laf.base.desktop.BaseDesktopLookAndFeel;

/**
 * RendererManager maintains a table of RendererFactories, keyed
 * by namespace.  Clients can use a single RendererManager, or
 * create their own.
 * 

*

Setting up a RendererManager

* Clients can always set the RendererManager explicitly on * a RenderingContext, but our implementations of * the RenderingContext will use the following defaulting strategy: *
    *
  1. If the client explicitly set a RendererManager, use it *
  2. Check the context's Configuration object for a * RendererManager with the RENDERER_MANAGER key. *
  3. Retrieve the RendererManager from the LookAndFeel *
  4. Otherwise, use a default RendererManager containing * the Oracle browser-based look-and-feel and plain HTML (e.g, HTMLWebBean) support *
* @version $Name: $ ($Revision: adfrt/faces/adf-faces-impl/src/main/java/oracle/adfinternal/view/faces/ui/RendererManager.java#0 $) $Date: 10-nov-2005.18:50:19 $ * @deprecated This class comes from the old Java 1.2 UIX codebase and should not be used anymore. */ @Deprecated public class RendererManager { /** * Creates a new, empty RendererManager. */ public RendererManager() { this(UIConstants.FACET_DEFAULT); } /** * Creates a new, empty RendererManager. */ public RendererManager(String facet) { _facet = facet; } public String getFacet() { return _facet; } /** * Returns a globally shared instance of RendererManager. This * instance is initialized with the Oracle browser-based * look-and-feel renderer factory and the HTML renderer factory. *

* @deprecated RendererManagers should be retrieved from the * LookAndFeel returned from the LookAndFeelManager *

* @see org.apache.myfaces.trinidadinternal.ui.laf.LookAndFeelManager#getLookAndFeel * @see org.apache.myfaces.trinidadinternal.ui.laf.LookAndFeel#getRendererManager */ @Deprecated static public RendererManager getDefaultRendererManager() { if (_sDefaultInstance == null) _sDefaultInstance = createDefaultRendererManager(); return _sDefaultInstance; } /** * Returns a new RendererManager, initialized with the UIX * browser-based look-and-feel renderer factory and the HTML * renderer factory. *

* @deprecated RendererManagers should be retrieved from the * LookAndFeel returned from the LookAndFeelManager *

* @see org.apache.myfaces.trinidadinternal.ui.laf.LookAndFeelManager#getLookAndFeel * @see org.apache.myfaces.trinidadinternal.ui.laf.LookAndFeel#getRendererManager */ @Deprecated static public RendererManager createDefaultRendererManager() { return new BaseDesktopLookAndFeel().getRendererManager(); } /** * Utility method for retrieving a renderer for a UINode. */ final public Renderer getRenderer(UINode node) { RendererFactory factory = getFactory(node.getNamespaceURI()); if (factory == null) return null; return factory.getRenderer(node.getLocalName()); } /** * Utility method for retrieving a renderer by both * namespace and name. */ final public Renderer getRenderer(String namespace, String name) { RendererFactory factory = getFactory(namespace); if (factory == null) return null; return factory.getRenderer(name); } /** * Gets the factory registered for the namespace. */ public RendererFactory getFactory(String namespace) { return (RendererFactory) ArrayMap.get(_factories, namespace); } /** * Registers a factory for a namespace. */ synchronized public void registerFactory( String namespace, RendererFactory factory) { _factories = ArrayMap.put(_factories, namespace.intern(), factory); } /** * Unregisters a factory for a namespace. */ synchronized public void unregisterFactory(String namespace) { _factories = ArrayMap.remove(_factories, namespace); } private Object[] _factories; private String _facet; static private RendererManager _sDefaultInstance; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy