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

react4j.annotations.OnInputChange Maven / Gradle / Ivy

The newest version!
package react4j.annotations;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Target;

/**
 * Identifies a method that is called when the value of one of the specified inputs is changed.
 * Each parameter of the method is mapped to a input that is tracked. The method will be called
 * before or after the update has occurred and will be passed the previous values of the inputs
 * as parameters.
 *
 * 

Each parameter is expected to be named according to the pattern "last[MyInput]", "prev[MyInput]" * or "[myInput]". If name of the parameter does not follow the pattern then the name can be explicitly * mapped via the {@link InputRef} annotation on a parameter.

* *

The method must also conform to the following constraints:

*
    *
  • Must not be annotated with any other react4j annotation
  • *
  • Must have 1 or more parameters. Each parameter must map to a input as described above.
  • *
  • Must not return a value
  • *
  • Must not be private
  • *
  • Must not be public
  • *
  • Must not be static
  • *
  • Must not be abstract
  • *
  • Must not throw exceptions
  • *
  • Must be accessible from the same package as the class annotated by {@link View}
  • *
  • * Should not be public as not expected to be invoked outside the view. A warning will be generated but can * be suppressed by the {@link SuppressWarnings} or {@link SuppressReact4jWarnings} annotations with a key * "React4j:PublicMethod". This warning is also suppressed by the annotation processor if it is implementing * an interface method. *
  • *
  • * Should not be protected if in the class annotated with the {@link View} annotation as the method is not * expected to be invoked outside the view. A warning will be generated but can be suppressed by the * {@link SuppressWarnings} or {@link SuppressReact4jWarnings} annotations with a key "React4j:ProtectedMethod". *
  • *
*/ @Documented @Target( ElementType.METHOD ) public @interface OnInputChange { /** * Phase in which method should be invoked. */ enum Phase { /** * Method should be invoked before update. */ PRE, /** * Method should be invoked after update. */ POST } /** * The phase in which the method should be invoked. * * @return the phase in which the method should be invoked. */ Phase phase() default Phase.PRE; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy