2016-11-24 94 views
0

我只是延長Vaadin的導航和重寫一些一些方法:定製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> 
} 

}

這是我如何設置導航:

@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); 
} 

}

而且這是我如何獲得導航器並將視圖重定向到另一個:

@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){ 

} 
} 

由於某種原因,按鈕不響應點擊事件。

替換爲標準導航器 - 它的工作原理。

我做錯了什麼?

感謝建議

+0

您應該查看視圖更改偵聽器。你不需要重寫導航器。我會張貼一些代碼,但我今天不在我的電腦附近。 –

+0

@ChrisM聽起來很有趣,我會繼續關注。 – Reborn

+0

還有SpringNavigator類,其中包括SpringViewProvider。 – nyg

回答

1

我還以爲你可以使用Vaadin的導航和查看變化監聽這樣的:

 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) { 

     } 
    }); 

如果您在beforeViewChange返回false將停止從視圖改變發生。

+0

這是假設要在每個視圖中指定,我使用或什麼? – Reborn

+1

不,您在創建時將其添加到導航器中。我犯了一個錯誤,我會在一秒之內改變。 –

+0

啊,呃!謝謝,關於乾淨的代碼(我想使UI.init()儘可能清潔)如果我想使自己的ViewChangeListener實現,那麼如何從導航器中獲取導航狀態?(如果可能的話) – Reborn