简体   繁体   English

自定义Vaadin导航器

[英]Customize Vaadin Navigator

I just extended Vaadin's navigator and overriden some some methods: 我只是扩展了Vaadin的导航器,并覆盖了一些方法:

public class MyNavigator extends Navigator {

final SpringViewProvider viewProvider;

public MyNavigator(UI ui, SingleComponentContainer container, SpringViewProvider viewProvider) {
    super(ui, container);
    this.viewProvider = viewProvider;
    addProvider(this.viewProvider);
}

@Override
public void navigateTo(String navigationState) {
    if(ViewTokens.AVAILABLE_TOKENS.contains(navigationState)) {
        if(viewProvider.getView(navigationState) == null) {
            String uriFragment = parseViewToken();
            if(uriFragment.equals(navigationState)) {
                super.navigateTo(ViewTokens.HOME);
            }
        } else {
            //if nothing found, redirect
            super.navigateTo(ViewTokens.HOME);
        }
    }
}

private String parseViewToken() {
   <ommitted>
}

} }

This is how I set up Navigator: 这是我设置导航器的方式:

@SpringUI(path="/")
@Theme(ValoTheme.THEME_NAME)
public class MyFancyUI extends UI {

@Autowired
SpringViewProvider viewProvider;

@Override
protected void init(VaadinRequest vaadinRequest) {
    MyNavigator navigator = new MyNavigator(UI.getCurrent(), this, viewProvider);
    setNavigator(navigator);
    navigator.navigateTo(ViewTokens.SIGNIN);
}

} }

And this is how i attempt to get navigator and redirect view to another: 这就是我尝试获取导航器并将视图重定向到另一个的方法:

@UIScope
@SpringView(name=ViewTokens.HOME)
public class SplashScreen extends VerticalLayout implements View {
private ComponentHelper componentHelper;
private Button toLoginPage;

public SplashScreen() {
    initComponents();
    buildSplashView();
}

protected void initComponents() {
    componentHelper = ComponentHelper.getInstance();
    toLoginPage = componentHelper.createFriendlyButton("To Login Page",220, 60);
    toLoginPage.addClickListener(this::redirect);
}

private void buildSplashView() {
    addComponent(toLoginPage);
    setComponentAlignment(toLoginPage, Alignment.MIDDLE_CENTER);
    setHeight(100, Unit.PERCENTAGE);
}

public void redirect(Button.ClickEvent event) {
    getUI().getNavigator().navigateTo(ViewTokens.SIGNIN);
}

@Override
public void enter(ViewChangeListener.ViewChangeEvent viewChangeEvent){

} 
}

And for some reason, button doesn't react to click event. 由于某种原因,按钮对点击事件没有反应。

Replacing to standard Navigator - it works. 取代标准的Navigator-可以使用。

What i'm doing wrong? 我做错了什么?

Thanks for suggestions 感谢您的建议

I would have thought that you could use Vaadin's Navigator and a View Change Listener like this: 我本以为您可以使用Vaadin的Navigator和这样的View Change Listener:

        navigator.addViewChangeListener(new ViewChangeListener() {

        @Override
        public boolean beforeViewChange(ViewChangeEvent event) {
            // check you're happy to change

            if (ViewTokens.AVAILABLE_TOKENS.contains(navigationState)) {
                if (viewProvider.getView(event.getViewName()) == null) {
                    String uriFragment = parseViewToken();
                    if (uriFragment.equals(event.getViewName())) {
                        navigator.navigateTo(ViewTokens.HOME);
                        return false;
                    }
                } else {
                    // if nothing found, redirect
                    navigator.navigateTo(ViewTokens.HOME);
                    return false;
                }
                // Let the view change happen.
                return true;
            }

        }

        @Override
        public void afterViewChange(ViewChangeEvent event) {

        }
    });

If you return false in the beforeViewChange it will stop the view change from happening. 如果在beforeViewChange中返回false,它将阻止视图更改。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM