org.vaadin.spring.navigator.Presenter Maven / Gradle / Ivy
/*
* Copyright 2015 The original authors
*
* Licensed 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.vaadin.spring.navigator;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import com.vaadin.spring.navigator.SpringViewProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.vaadin.spring.events.EventBus;
import org.vaadin.spring.navigator.annotation.VaadinPresenter;
import com.vaadin.navigator.View;
import com.vaadin.navigator.ViewProvider;
/**
* Base class for presentation.
* Derivatives must be annotated with {@link VaadinPresenter}.
* Works with {@link EventBus} to subscribe to events and set model data
* on an implementor of {@link com.vaadin.navigator.View}.
*
* @author Chris Phillipson ([email protected])
*
* @param an implementation of {@link com.vaadin.navigator.View}
*/
public abstract class Presenter {
private static Logger logger = LoggerFactory.getLogger(Presenter.class);
@Autowired
private SpringViewProvider viewProvider;
@Autowired
private EventBus.UIEventBus eventBus;
private String viewName;
@PostConstruct
protected void init() {
eventBus.subscribe(this);
viewName = getViewName();
}
public EventBus getEventBus() {
return this.eventBus;
}
private String getViewName() {
String result = null;
Class> clazz = getClass();
if (clazz.isAnnotationPresent(VaadinPresenter.class)) {
VaadinPresenter vp = clazz.getAnnotation(VaadinPresenter.class);
result = vp.viewName();
} else {
logger.error("Presenter [{}] does not have a @VaadinPresenter annotation!", clazz.getSimpleName());
}
return result;
}
/**
* Hands back the View that this Presenter works with
* A match is made if the ViewProvider finds a VaadinView annotated View whose name matches Presenter's viewName
* @return an implementor of {@link View}
*/
@SuppressWarnings("unchecked")
public V getView() {
V result = null;
if (viewName != null) {
result = (V) viewProvider.getView(viewName);
}
return result;
}
/**
* Allows this Presenter to (possibly) work with other views
* @return a ViewProvider
*/
public ViewProvider getViewProvider() {
return this.viewProvider;
}
@PreDestroy
// It's good manners to do this, even though we should be automatically unsubscribed
// when the UI is garbage collected
void destroy() {
getEventBus().unsubscribe(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy