mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 05:54:58 +00:00
LibGUI: Add a date picker dialog
This adds a simple date picker dialog using the existing GUI::Calendar.
This commit is contained in:
parent
039114b728
commit
8e77c72a5c
4 changed files with 147 additions and 0 deletions
|
@ -1,6 +1,7 @@
|
|||
compile_gml(DynamicWidgetContainerControls.gml DynamicWidgetContainerControls.cpp)
|
||||
|
||||
stringify_gml(AboutDialog.gml AboutDialogGML.h about_dialog_gml)
|
||||
stringify_gml(DatePickerDialog.gml DatePickerDialogGML.h date_picker_dialog_gml)
|
||||
stringify_gml(EmojiInputDialog.gml EmojiInputDialogGML.h emoji_input_dialog_gml)
|
||||
stringify_gml(FontPickerDialog.gml FontPickerDialogGML.h font_picker_dialog_gml)
|
||||
stringify_gml(FilePickerDialog.gml FilePickerDialogGML.h file_picker_dialog_gml)
|
||||
|
@ -36,6 +37,7 @@ set(SOURCES
|
|||
CommonMenus.cpp
|
||||
ConnectionToWindowManagerServer.cpp
|
||||
ConnectionToWindowServer.cpp
|
||||
DatePicker.cpp
|
||||
Desktop.cpp
|
||||
Dialog.cpp
|
||||
DisplayLink.cpp
|
||||
|
@ -144,6 +146,7 @@ set(GENERATED_SOURCES
|
|||
../../Services/WindowServer/WindowManagerServerEndpoint.h
|
||||
../../Services/WindowServer/WindowServerEndpoint.h
|
||||
AboutDialogGML.h
|
||||
DatePickerDialogGML.h
|
||||
EmojiInputDialogGML.h
|
||||
FilePickerDialogGML.h
|
||||
FontPickerDialogGML.h
|
||||
|
|
87
Userland/Libraries/LibGUI/DatePicker.cpp
Normal file
87
Userland/Libraries/LibGUI/DatePicker.cpp
Normal file
|
@ -0,0 +1,87 @@
|
|||
/*
|
||||
* Copyright (c) 2023, David Ganz <david.g.ganz@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibGUI/Button.h>
|
||||
#include <LibGUI/ComboBox.h>
|
||||
#include <LibGUI/DatePicker.h>
|
||||
#include <LibGUI/DatePickerDialogGML.h>
|
||||
#include <LibGUI/ImageWidget.h>
|
||||
#include <LibGUI/Label.h>
|
||||
#include <LibGUI/SpinBox.h>
|
||||
#include <LibGUI/TextBox.h>
|
||||
|
||||
namespace GUI {
|
||||
|
||||
DatePicker::DatePicker(Window* parent_window, String const& title, Core::DateTime focused_date)
|
||||
: Dialog(parent_window)
|
||||
, m_selected_date(focused_date)
|
||||
{
|
||||
if (parent_window)
|
||||
set_icon(parent_window->icon());
|
||||
|
||||
set_resizable(false);
|
||||
set_title(title.to_byte_string());
|
||||
|
||||
auto widget = set_main_widget<Widget>();
|
||||
widget->load_from_gml(date_picker_dialog_gml).release_value_but_fixme_should_propagate_errors();
|
||||
|
||||
auto& calendar = *widget->find_descendant_of_type_named<GUI::Calendar>("calendar_view");
|
||||
calendar.on_tile_click = [&]() {
|
||||
m_selected_date = calendar.selected_date();
|
||||
m_month_box->set_selected_index(m_selected_date.month() - 1, AllowCallback::No);
|
||||
m_year_box->set_value(static_cast<int>(m_selected_date.year()), AllowCallback::No);
|
||||
};
|
||||
calendar.on_tile_doubleclick = [&]() {
|
||||
m_selected_date = calendar.selected_date();
|
||||
done(ExecResult::OK);
|
||||
};
|
||||
calendar.set_selected_date(focused_date);
|
||||
calendar.update_tiles(focused_date.year(), focused_date.month());
|
||||
|
||||
m_month_box = widget->find_descendant_of_type_named<GUI::ComboBox>("month_box");
|
||||
m_month_box->set_model(GUI::MonthListModel::create(GUI::MonthListModel::DisplayMode::Long));
|
||||
m_month_box->set_selected_index(focused_date.month() - 1, AllowCallback::No);
|
||||
m_month_box->on_change = [&](ByteString const&, ModelIndex const& index) {
|
||||
m_selected_date.set_time(static_cast<int>(m_selected_date.year()), index.row() + 1);
|
||||
calendar.set_selected_date(m_selected_date);
|
||||
calendar.update_tiles(m_selected_date.year(), m_selected_date.month());
|
||||
calendar.update();
|
||||
};
|
||||
|
||||
m_year_box = widget->find_descendant_of_type_named<GUI::SpinBox>("year_box");
|
||||
m_year_box->set_value(static_cast<int>(focused_date.year()), AllowCallback::No);
|
||||
m_year_box->on_change = [&](int year) {
|
||||
m_selected_date.set_time(year, static_cast<int>(m_selected_date.month()));
|
||||
calendar.set_selected_date(m_selected_date);
|
||||
calendar.update_tiles(m_selected_date.year(), m_selected_date.month());
|
||||
calendar.update();
|
||||
};
|
||||
|
||||
auto& ok_button = *widget->find_descendant_of_type_named<GUI::Button>("ok_button");
|
||||
ok_button.on_click = [&](auto) {
|
||||
dbgln("GUI::DatePicker: OK button clicked");
|
||||
m_selected_date = calendar.selected_date();
|
||||
done(ExecResult::OK);
|
||||
};
|
||||
|
||||
auto& cancel_button = *widget->find_descendant_of_type_named<GUI::Button>("cancel_button");
|
||||
cancel_button.on_click = [this](auto) {
|
||||
dbgln("GUI::DatePicker: Cancel button clicked");
|
||||
done(ExecResult::Cancel);
|
||||
};
|
||||
}
|
||||
|
||||
Optional<Core::DateTime> DatePicker::show(Window* parent_window, String title, Core::DateTime focused_date)
|
||||
{
|
||||
auto box = DatePicker::construct(parent_window, title, focused_date);
|
||||
if (box->exec() == ExecResult::OK) {
|
||||
return box->m_selected_date;
|
||||
}
|
||||
|
||||
return {};
|
||||
}
|
||||
|
||||
}
|
56
Userland/Libraries/LibGUI/DatePickerDialog.gml
Normal file
56
Userland/Libraries/LibGUI/DatePickerDialog.gml
Normal file
|
@ -0,0 +1,56 @@
|
|||
@GUI::Widget {
|
||||
shrink_to_fit: true
|
||||
fill_with_background_color: true
|
||||
layout: @GUI::VerticalBoxLayout {}
|
||||
|
||||
@GUI::Widget {
|
||||
fixed_height: 20
|
||||
fill_with_background_color: true
|
||||
layout: @GUI::HorizontalBoxLayout {}
|
||||
|
||||
@GUI::ComboBox {
|
||||
name: "month_box"
|
||||
model_only: true
|
||||
}
|
||||
|
||||
@GUI::SpinBox {
|
||||
name: "year_box"
|
||||
fixed_size: [55, 20]
|
||||
min: 0
|
||||
max: 9999
|
||||
}
|
||||
|
||||
@GUI::Layout::Spacer {}
|
||||
}
|
||||
|
||||
@GUI::Widget {
|
||||
fixed_width: 200
|
||||
fixed_height: 200
|
||||
layout: @GUI::VerticalBoxLayout {}
|
||||
|
||||
@GUI::Calendar {
|
||||
name: "calendar_view"
|
||||
}
|
||||
}
|
||||
|
||||
@GUI::Widget {
|
||||
fixed_height: 20
|
||||
fill_with_background_color: true
|
||||
layout: @GUI::HorizontalBoxLayout {}
|
||||
|
||||
@GUI::Layout::Spacer {}
|
||||
|
||||
@GUI::Button {
|
||||
name: "cancel_button"
|
||||
text: "Cancel"
|
||||
fixed_size: [80, 20]
|
||||
}
|
||||
|
||||
@GUI::Button {
|
||||
name: "ok_button"
|
||||
text: "OK"
|
||||
fixed_size: [80, 20]
|
||||
default: true
|
||||
}
|
||||
}
|
||||
}
|
|
@ -26,6 +26,7 @@ class CheckBox;
|
|||
class ComboBox;
|
||||
class Command;
|
||||
class CommandPalette;
|
||||
class DatePicker;
|
||||
class Dialog;
|
||||
class DialogButton;
|
||||
class DragEvent;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue