org.apache.myfaces.trinidadinternal.skin.SkinFactoryImpl 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.skin;
import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
import javax.faces.context.ExternalContext;
import javax.faces.context.FacesContext;
import org.apache.myfaces.trinidad.logging.TrinidadLogger;
import org.apache.myfaces.trinidad.skin.Skin;
import org.apache.myfaces.trinidad.skin.SkinFactory;
import org.apache.myfaces.trinidad.skin.SkinFeatures;
import org.apache.myfaces.trinidad.skin.SkinMetadata;
import org.apache.myfaces.trinidad.skin.SkinProvider;
import org.apache.myfaces.trinidad.skin.SkinVersion;
import org.apache.myfaces.trinidadinternal.skin.provider.ExternalSkinProvider;
/**
* Factory for creating Skin objects. To create and manage skins external to skin framework, use
* SkinProvider.
*
* @see org.apache.myfaces.trinidad.skin.SkinProvider
*/
public class SkinFactoryImpl extends SkinFactory
{
/**
* Constructor registers default and custom skins
*/
public SkinFactoryImpl()
{
super();
}
/**
* @inheritDoc
*/
@Override
public Skin createSkin(
ExternalContext externalContext,
SkinMetadata baseSkinMetadata,
SkinMetadata skinMetadata)
{
if (externalContext == null || baseSkinMetadata == null || skinMetadata == null)
throw new NullPointerException(_LOG.getMessage("NULL_FC_SKIN_BASE_SKIN_METADATA"));
if (baseSkinMetadata.getId() != null &&
!baseSkinMetadata.getId().equals(skinMetadata.getBaseSkinId()))
throw new IllegalArgumentException(_LOG.getMessage("INVALID_BASE_SKIN_ID"));
Skin baseSkin = SkinProvider.getCurrentInstance(externalContext).getSkin(externalContext, baseSkinMetadata);
if (baseSkin == null)
throw new IllegalArgumentException(_LOG.getMessage("INVALID_BASE_SKIN"));
return new SkinExtension(baseSkin, skinMetadata);
}
/**
* @inheritDoc
*/
@Override
public Skin createSkin(ExternalContext externalContext, SkinMetadata skinMetadata)
{
if (externalContext == null || skinMetadata == null)
throw new NullPointerException(_LOG.getMessage("NULL_FC_SKIN_METADATA"));
if (skinMetadata.getBaseSkinId() == null)
throw new NullPointerException(_LOG.getMessage("NULL_BASE_SKIN_ID"));
SkinMetadata baseSkinMetadata =
new SkinMetadata.Builder().id(skinMetadata.getBaseSkinId()).build();
return createSkin(externalContext, baseSkinMetadata, skinMetadata);
}
/**
* Register the specified {@link Skin} instance, associated with
* the specified skinId
, to be supported by this
* {@link SkinFactory}, replacing any previously registered
* {@link Skin} for this identifier.
*
* A warning will be logged if a previously registered {@link Skin} was replaced, since it could produce
* inconsistent results if the application cached the previously registered Skin.
*
* @param skinId Identifier of the {@link Skin} to register
* @param skin {@link Skin} instance that we are registering
* @deprecated use SkinProvider SPI to deal with externals skins
*/
@Override
@Deprecated
public void addSkin(String skinId, Skin skin)
{
if (skinId == null || skin == null)
{
_LOG.warning("CANNOT_ADD_SKIN");
return;
}
SkinMetadata.RenderKitId renderKitId = SkinMetadata.RenderKitId.fromId(skin.getRenderKitId());
SkinMetadata.Builder builder = new SkinMetadata.Builder().id(skinId)
.family(skin.getFamily())
.version(skin.getVersion())
.renderKitId(renderKitId);
if (skin.getBaseSkin() != null)
builder.baseSkinId(skin.getBaseSkin().getId());
if (skin.getSkinFeatures() != null)
builder.features(new SkinFeatures(skin.getSkinFeatures()));
Skin previousValue = _getExternalSkinProvider().addSkin(builder.build(), skin);
if (previousValue != null)
_LOG.warning("DUPLICATE_ADD_SKIN_TO_SKIN_FACTORY", skinId);
}
/**
* given the skinId, pass back the Skin.
*
* @param context FacesContext. If not available, pass in null.
* @param skinId
* @return Skin that is in this SkinFactory and has the skinId.
* @deprecated use SkinProvider to query skins
*/
@Deprecated
@Override
public Skin getSkin(FacesContext context, String skinId)
{
context = SkinUtils.getNonNullFacesContext(context);
if (skinId == null)
{
_LOG.warning("CANNOT_GET_SKIN_WITH_NULL_SKINID");
return null;
}
ExternalContext ec = context.getExternalContext();
SkinMetadata skinMetadata = new SkinMetadata.Builder().id(skinId).build();
return SkinProvider.getCurrentInstance(ec).getSkin(ec, skinMetadata);
}
/**
* given the skinFamily and renderKitId, pass back the Skin.
*
* @param context FacesContext for the request currently being processed, or null
* if none is available.
* @param family skin family of the requested {@link Skin} instance
* @param renderKitId RenderKit identifier of the requested: XhtmlConstants
* .APACHE_TRINIDAD_DESKTOP, XhtmlConstants.APACHE_TRINIDAD_PDA, or
* XhtmlConstants.APACHE_TRINIDAD_PORTLET {@link Skin} instance
* @deprecated use SkinProvider to query skins
*/
@Deprecated
@Override
public Skin getSkin(FacesContext context, String family, String renderKitId)
{
return getSkin(context, family, renderKitId, null);
}
/**
* Given the skin family, renderKitId, and version, return the best matched skin. The skin picking
* logic is: If an exact family, renderKitId, and version (including null or "") is found, return
* that skin Else if the user asks for version "default", return the skin with family and
* renderKitId with version marked default. If version wasn't default and does not match any
* version for the skins with family and renderKitId, then return the 'default' skin if there is
* one marked or return the last entry in the list of matching family/renderKitId skins.
*
* @param context
* @param family
* @param renderKitId
* @param version The version of the skin you want to return. This can be "default", or a
* version name (e.g., "v1"), or null or "" (if you want the skin that does not
* have a version set).
* @return the best matched Skin given the family, renderKitId, and version.
* @deprecated use SkinProvider to query skins
*/
@Deprecated
@Override
public Skin getSkin(
FacesContext context,
String family,
String renderKitId,
String version)
{
context = SkinUtils.getNonNullFacesContext(context);
// By setting the version to the empty string if version is null, we can
// get the skin that has a matching family and renderkit and has no skin version.
// (A Skin with no version returns SkinVersion.EMPTY_SKIN_VERSION for skin.getVersion(),
// and getName will be "")
if (version == null)
version = "";
// given a skinFamily and a renderKitId, figure out the skinId.
// If we don't have an exact match, use the simple skin that matches the
// renderKitId (simple.desktop or simple.pda)
if (family == null)
throw new NullPointerException("Null skin family");
SkinVersion skinVersion = new SkinVersion(version);
SkinMetadata.RenderKitId renderKitIdObj = SkinMetadata.RenderKitId.fromId(renderKitId);
SkinMetadata metadata = new SkinMetadata.Builder().family(family)
.version(skinVersion)
.renderKitId(renderKitIdObj)
.build();
ExternalContext ec = context.getExternalContext();
Skin matchingSkin = SkinProvider.getCurrentInstance(ec).getSkin(ec, metadata);
return (matchingSkin == null) ? null : new RequestSkinWrapper(matchingSkin);
}
/**
* @inheritDoc
*/
@Deprecated
@Override
public Iterator getSkinIds()
{
FacesContext context = SkinUtils.getNonNullFacesContext(null);
ExternalContext extContext = context.getExternalContext();
ExternalSkinProvider extSkinProvider = ExternalSkinProvider.getCurrentInstance(extContext);
Collection metadatas = extSkinProvider.getSkinMetadata(extContext);
Set ids = new HashSet();
for (SkinMetadata metadata : metadatas)
ids.add(metadata.getId());
return ids.iterator();
}
/**
* @inheritDoc
*/
@Deprecated
@Override
public void reload()
{
_getExternalSkinProvider().reload();
}
private ExternalSkinProvider _getExternalSkinProvider()
{
FacesContext context = SkinUtils.getNonNullFacesContext(null);
ExternalContext extContext = context.getExternalContext();
return ExternalSkinProvider.getCurrentInstance(extContext);
}
static private final TrinidadLogger _LOG = TrinidadLogger.createTrinidadLogger(SkinFactoryImpl.class);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy