DatePicker で使用される DefaultDateMonthSelector (com.google.gwt.user.datepicker.client) はこれらのウィジェットを公開しないため、これらのボタンを直接無効にすることはできません。
この機能を実装するには、新しい DateMonthSelector を作成します (DefaultMonthSelector のソースhttp://code.google.com/p/google-web-toolkit/source/browse/trunk/user/src/com/google/から始めることができます)。 gwt/user/datepicker/client/DefaultMonthSelector.java )。たとえば、
public final class LimitedMonthSelector extends MonthSelector {
// Keep the PushButtons disabled
// Modified from the original DefaultMonthSelector
@Override
protected void setup() {
// Set up backwards.
backwards = new PushButton();
backwards.getUpFace().setHTML("«");
backwards.setStyleName(css().previousButton());
backwards.setEnabled(false); // Disable the back button
forwards = new PushButton();
forwards.getUpFace().setHTML("»");
forwards.setStyleName(css().nextButton());
forwards.setEnabled(false); // Disable the forward button
// Set up grid.
grid = new Grid(1, 3);
grid.setWidget(0, 0, backwards);
grid.setWidget(0, 2, forwards);
CellFormatter formatter = grid.getCellFormatter();
formatter.setStyleName(0, 1, css().month());
formatter.setWidth(0, 0, "1");
formatter.setWidth(0, 1, "100%");
formatter.setWidth(0, 2, "1");
grid.setStyleName(css().monthSelector());
initWidget(grid);
}
}
そして、この MonthSelector 実装を DatePicker 実装で使用します。お気に入り、
public class LimitedDatePicker extends DatePicker {
public MonthYearDatePicker() {
super(new LimitedMonthSelector(), new DefaultCalendarView(), new CalendarModel());
}
}
この新しい LimitedDatePicker では、戻る/進むボタンが無効になります。