Возможно, что-то мне не хватает, но DatePicker в GWT (я использую версию 2.0.3) не дает вам возможности прокручивать назад и назад по годам, только месяц. Я что-то упускаю? Я знаю, что есть внешняя lib (code.google.com/p/gwt-datepicker/), которую я могу использовать, но я бы хотел избежать импорта еще одной сторонней библиотеки, когда вы сможете это сделать в DatePicker в ГВТ.GWT DatePicker, прокрутка по году
6
A
ответ
8
Вам необходимо создать подкласс DatePicker, который использует вашу собственную реализацию MonthSelector.
Там в последнее время поток на GWT группы Google по этой самой теме, с примерами кода:
Getting the default DateBox() picker to advance year at a time
2
я думаю, что вы хотите что-то вроде ниже.
здесь я изменил GWT DatePicker, чтобы добавить селектор месяца и года. Я уточнял диапазон каландра ДО 2100, вы можете изменить его по своему желанию, сделав некоторые небольшие изменения в нем
import com.google.gwt.user.datepicker.client.CalendarModel;
import com.google.gwt.user.datepicker.client.DatePicker;
import com.google.gwt.user.datepicker.client.DefaultCalendarView;
public class DatePickerWithYearSelectorNew extends DatePicker {
public DatePickerWithYearSelectorNew() {
super(new MonthAndYearSelectorWithYear(), new DefaultCalendarView(),
new CalendarModel());
MonthAndYearSelectorWithYear monthSelector = (MonthAndYearSelectorWithYear)
this.getMonthSelector();
monthSelector.setPicker(this);
monthSelector.setModel(this.getModel());
}
public void refreshComponents() {
super.refreshAll();
}
}
import java.util.Date;
import com.google.gwt.event.dom.client.ChangeEvent;
import com.google.gwt.event.dom.client.ChangeHandler;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.user.client.ui.Grid;
import com.google.gwt.user.client.ui.ListBox;
import com.google.gwt.user.client.ui.PushButton;
import com.google.gwt.user.client.ui.HTMLTable.CellFormatter;
import com.google.gwt.user.datepicker.client.CalendarModel;
import com.google.gwt.user.datepicker.client.MonthSelector;
public class MonthAndYearSelectorWithYear extends MonthSelector {
private static String BASE_NAME = "datePicker";
private PushButton backwards;
private PushButton forwards;
private PushButton backwardsYear;
private PushButton forwardsYear;
private Grid grid;
private int previousYearColumn = 0;
private int previousMonthColumn = 1;
private int nextMonthColumn = 4;
private int nextYearColumn = 5;
private CalendarModel model;
private DatePickerWithYearSelectorNew picker;
private ListBox monthListBox;
private ListBox yearListBox;
public MonthAndYearSelectorWithYear() {
yearListBox = new ListBox();
for (int i = 1900; i < 2100; i++) {
yearListBox.addItem(i + "");
}
String[] items = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul",
"Aug", "Sep", "Oct", "Nov", "Dec" };
monthListBox = new ListBox();
for (int i = 0; i < items.length; i++) {
monthListBox.addItem(items[i]);
}
}
public void setModel(CalendarModel model) {
this.model = model;
}
public void setPicker(DatePickerWithYearSelectorNew picker) {
this.picker = picker;
}
@Override
protected void refresh() {
int monthIndex = getModel().getCurrentMonth().getMonth();
monthListBox.setItemSelected(monthIndex, true);
int yearIndex = getModel().getCurrentMonth().getYear();
// System.out.println(yearIndex);
yearListBox.setItemSelected(yearIndex, true);
}
@Override
protected void setup() {
// Set up backwards.
backwards = new PushButton();
backwards.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
addMonths(-1);
}
});
backwards.getUpFace().setHTML("‹");
backwards.setStyleName(BASE_NAME + "PreviousButton");
forwards = new PushButton();
forwards.getUpFace().setHTML("›");
forwards.setStyleName(BASE_NAME + "NextButton");
forwards.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
if (model.getCurrentMonth().getYear() < 199) {
addMonths(+1);
}
else if(model.getCurrentMonth().getMonth()<11
&&model.getCurrentMonth().getYear()==199)
{
addMonths(+1);
}
}
});
// Set up backwards year
backwardsYear = new PushButton();
backwardsYear.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
addMonths(-12);
picker.refreshComponents();
}
});
backwardsYear.getUpFace().setHTML("«");
backwardsYear.setStyleName(BASE_NAME + "PreviousButton");
forwardsYear = new PushButton();
forwardsYear.getUpFace().setHTML("»");
forwardsYear.setStyleName(BASE_NAME + "NextButton");
forwardsYear.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
if (model.getCurrentMonth().getYear() < 199) {
addMonths(+12);
picker.refreshComponents();
}
}
});
yearListBox.addChangeHandler(new ChangeHandler() {
@Override
public void onChange(ChangeEvent event) {
// int yearIndex = yearListBox.getSelectedIndex();
//
setYear(Integer.parseInt(yearListBox.getValue(yearIndex)));
setYear(yearListBox.getSelectedIndex());
}
});
monthListBox.addChangeHandler(new ChangeHandler() {
@Override
public void onChange(ChangeEvent event) {
int monthIndex = monthListBox.getSelectedIndex();
setMonth(monthIndex);
}
});
// Set up grid.
grid = new Grid(1, 6);
grid.setWidget(0, previousYearColumn, backwardsYear);
grid.setWidget(0, previousMonthColumn, backwards);
grid.setWidget(0, 2, monthListBox);
grid.setWidget(0, 3, yearListBox);
grid.setWidget(0, nextMonthColumn, forwards);
grid.setWidget(0, nextYearColumn, forwardsYear);
CellFormatter formatter = grid.getCellFormatter();
formatter.setWidth(0, previousYearColumn, "1");
formatter.setWidth(0, previousMonthColumn, "1");
formatter.setWidth(0, nextMonthColumn, "1");
formatter.setWidth(0, nextYearColumn, "1");
grid.setStyleName(BASE_NAME + "MonthSelector");
initWidget(grid);
}
public void addMonths(int numMonths) {
model.shiftCurrentMonth(numMonths);
picker.refreshComponents();
}
@SuppressWarnings("deprecation")
public void setMonth(int month) {
Date tempMonth = new Date();
tempMonth.setMonth(month);
model.setCurrentMonth(tempMonth);
picker.refreshComponents();
}
@SuppressWarnings("deprecation")
public void setYear(int year) {
// to set year
model.getCurrentMonth().setYear(year);
picker.refreshComponents();
}
}
Смежные вопросы
- 1. Android DatePicker в следующем году
- 2. GWT DatePicker по умолчанию до полудня
- 3. Прокрутка таблицы таблицы GWT
- 4. Прокрутка в GWT
- 5. GWT DatePicker Locale
- 6. Gwt datepicker translations
- 7. datePicker in GWT
- 8. GWT DatePicker для отображения определенного дня недели
- 9. jquery datepicker datepicker beforeShowDay не работает в следующем году
- 10. Jquery Datepicker застрял на том же году
- 11. Получить LocalDateTime по году и году года
- 12. Пожертвования, показываемые вместе по году и году
- 13. Pivot SQL по году
- 14. R группа по году
- 15. Hive - раздел по году
- 16. FIlter alassets по году
- 17. Невозможно Группировать по году
- 18. Группа SSRS по году
- 19. Группировка данных по году
- 20. SUM всего по году
- 21. Группировка по году - mySQL
- 22. GWT Datepicker установить дату по умолчанию при открытии
- 23. Линия диаграммы фильтрации Dashboard Google по году
- 24. Сортировка по году по критерию по R
- 25. Использование DatePicker для получения текущего дня в году в VB.NET?
- 26. Горизонтальная прокрутка таблицы сотовых телефонов в GWT
- 27. Прокрутка панели с помощью перетаскивания gwt
- 28. GWT 2.1 Виджеты ячеек - непрерывная прокрутка
- 29. Листовая группа слайдеров по году
- 30. Выбор строк по последнему году
Вы всегда можете расширить виджет, чтобы добавить некоторые из ваших собственных функций. Это может быть приятный запрос функции. :) – markovuksanovic
Я надеялся избежать этого. Хм ... – stuff22