@Retention(value=SOURCE) @Target(value=FIELD) public @interface ListChangeListener
Annotates a property.
This transformation provides a convenient way to register ListChangeListeners on an ObservableList by leveraging Groovy's closures and the Groovy cast operator.
The following code exemplifies what must be written by hand in order to register a ChangeListener.
import griffon.transform.ListChangeListener
import griffon.transform.FXObservable
import javafx.collections.FXCollections
import javafx.collections.ObservableList
import griffon.core.artifact.GriffonModel
@griffon.metadata.ArtifactProviderFor(GriffonModel)
class SampleModel {
def controller
@FXObservable
@ListChangeListener(snoop)
ObservableList list = FXCollections.observableArrayList()
def snoop = { change -> ... }
}
Applying @ChangeListener to the previous snippet results in the following code
import javafx.collections.ListChangeListener
import javafx.collections.FXCollections
import javafx.collections.ObservableList
import griffon.core.artifact.GriffonModel
@griffon.metadata.ArtifactProviderFor(GriffonModel)
class SampleModel {
def controller
@FXObservable ObservableList list = FXCollections.observableArrayList()
def snoop = { change -> ... }
SampleModel() {
listProperty().addListener(snoopAll as ListChangeListener)
}
}
Any closures found as the annotation's value will be either transformed into inner classes that implement ListChangeListener (when the value is a closure defined in place) or be casted as a proxy of ListChangeListener (when the value is a property reference found in the same class).
List of closures are also supported.
public abstract String value