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

jakarta.faces.component.FacesComponent Maven / Gradle / Ivy

There is a newer version: 4.1.2
Show newest version
/*
 * Copyright (c) 1997, 2020 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package jakarta.faces.component;

import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

/**
 * 

The presence of this annotation on a * class automatically registers the class with the runtime as a {@link * jakarta.faces.component.UIComponent}. The value of the {@link #value} attribute is taken to * be the component-type and the fully qualified class name of * the class to which this annotation is attached is taken to be the * component-class. The implementation must guarantee that for * each class annotated with FacesComponent, found with the scanning algorithm in * section 11.4 "Annotations that correspond to and may take the place of entries in the Application Configuration Resources" of the Jakarta Faces Specification Document, * {@link jakarta.faces.application.Application#addComponent(java.lang.String,java.lang.String)} * is called, passing the derived component-type as the first * argument and the derived component-class as the second * argument. The implementation must guarantee that all such calls to * addComponent() happen during application startup time * and before any requests are serviced.

*/ /** *

* The presence of this annotation on a class that extends {@link UIComponent} * must cause the runtime to register this class as a component suitable for inclusion in a view. * If the createTag attribute is true, the runtime must create * a corresponding Facelet tag handler according to the rules specified in the attributes of this annotation. *

* */ @Retention(RUNTIME) @Target(TYPE) @Inherited public @interface FacesComponent { /** *

* Components that declare a createTag = true attribute will be placed into this tag namespace if the * namespace attribute is omitted. *

*/ public static final String NAMESPACE = "jakarta.faces.component"; /** *

* The value of this annotation attribute is taken to be the * component-type with which instances of this class of component can be instantiated by calling * {@link jakarta.faces.application.Application#createComponent(java.lang.String)}. If * no value is specified, or the value is null, the value is taken to be the return of calling * getSimpleName on the class to which this annotation is attached and lowercasing the first character. If * more than one component with this derived name is found, the results are undefined. *

* * @return the component type. */ String value() default ""; /** *

* If the value of this attribute is true, the runtime must create a Facelet tag handler, that extends from * {@link jakarta.faces.view.facelets.ComponentHandler}, suitable for use in pages under the tag library with namespace * given by the value of the {@link #namespace} attribute. *

* * @return true to create the Facelet tag handler, false otherwise. */ boolean createTag() default false; /** *

* If the value of the {@link #createTag} attribute is true, the runtime must use this value as the tag * name for including an instance of the component annotated with this annotation in a view. If this attribute is not * specified on a usage of this annotation, the simple name of the class on which this annotation is declared, with the * first character lowercased, is taken to be the value. *

* * @return the tag name. */ String tagName() default ""; /** *

* If the value of the {@link #createTag} attribute is true, the value of this attribute is taken to be the * tag library namespace into which this component is placed. *

* * @return the namespace. */ String namespace() default NAMESPACE; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy