1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-25 14:17:36 +00:00

Calendar: Implement add event UI

This commit is contained in:
rhin123 2020-04-09 17:05:01 -05:00 committed by Andreas Kling
parent 4f48fcdb94
commit 06604c3786
6 changed files with 145 additions and 20 deletions

View file

@ -28,43 +28,78 @@
#include <LibCore/DateTime.h>
#include <LibGUI/BoxLayout.h>
#include <LibGUI/Button.h>
#include <LibGUI/ComboBox.h>
#include <LibGUI/Label.h>
#include <LibGUI/Layout.h>
#include <LibGUI/Painter.h>
#include <LibGUI/SpinBox.h>
#include <LibGUI/TextBox.h>
#include <LibGUI/Widget.h>
#include <LibGUI/Window.h>
#include <LibGfx/Color.h>
#include <LibGfx/Font.h>
AddEventDialog::AddEventDialog(Calendar* calendar, Window* parent_window)
AddEventDialog::AddEventDialog(RefPtr<Calendar> calendar, Core::DateTime date_time, Window* parent_window)
: Dialog(parent_window)
, m_calendar(calendar)
, m_date_time(date_time)
{
resize(230, 120);
resize(158, 100);
set_title("Add Event");
set_resizable(false);
auto& widget = set_main_widget<GUI::Widget>();
widget.set_fill_with_background_color(true);
widget.set_layout<GUI::HorizontalBoxLayout>();
widget.set_layout<GUI::VerticalBoxLayout>();
auto& main_container = widget.add<GUI::Widget>();
main_container.set_layout<GUI::VerticalBoxLayout>();
main_container.layout()->set_margins({ 4, 4, 4, 4 });
auto& top_container = widget.add<GUI::Widget>();
top_container.set_layout<GUI::VerticalBoxLayout>();
top_container.set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fixed);
top_container.set_preferred_size(0, 45);
top_container.layout()->set_margins({ 4, 4, 4, 4 });
auto make_label = [&](const StringView& text, bool bold = false) {
auto& label = main_container.add<GUI::Label>(text);
auto make_label = [&](const StringView& text, GUI::Widget& widget, bool bold = false) {
auto& label = widget.add<GUI::Label>(text);
label.set_text_alignment(Gfx::TextAlignment::CenterLeft);
label.set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fixed);
label.set_preferred_size(0, 14);
if (bold)
label.set_font(Gfx::Font::default_bold_font());
};
make_label("TODO: Implement add event dialog", true);
make_label("Add title & date:", top_container, true);
main_container.layout()->add_spacer();
auto& event_title_textbox = top_container.add<GUI::TextBox>();
event_title_textbox.set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fixed);
event_title_textbox.set_preferred_size(0, 20);
auto& button_container = main_container.add<GUI::Widget>();
auto& middle_container = widget.add<GUI::Widget>();
middle_container.set_layout<GUI::HorizontalBoxLayout>();
middle_container.set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fixed);
middle_container.set_preferred_size(0, 25);
middle_container.layout()->set_margins({ 4, 4, 4, 4 });
auto& starting_month_combo = middle_container.add<GUI::ComboBox>();
starting_month_combo.set_only_allow_values_from_model(true);
starting_month_combo.set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed);
starting_month_combo.set_preferred_size(50, 20);
starting_month_combo.set_model(MonthListModel::create());
starting_month_combo.set_selected_index(m_date_time.month() - 1);
auto& starting_day_combo = middle_container.add<GUI::SpinBox>();
starting_day_combo.set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed);
starting_day_combo.set_preferred_size(40, 20);
starting_day_combo.set_value(m_date_time.day());
starting_day_combo.set_min(1);
auto& starting_year_combo = middle_container.add<GUI::SpinBox>();
starting_year_combo.set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed);
starting_year_combo.set_preferred_size(55, 20);
starting_year_combo.set_range(0, 9999);
starting_year_combo.set_value(m_date_time.year());
widget.layout()->add_spacer();
auto& button_container = widget.add<GUI::Widget>();
button_container.set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fixed);
button_container.set_preferred_size(0, 20);
button_container.set_layout<GUI::HorizontalBoxLayout>();
@ -73,10 +108,59 @@ AddEventDialog::AddEventDialog(Calendar* calendar, Window* parent_window)
ok_button.set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed);
ok_button.set_preferred_size(80, 20);
ok_button.on_click = [this] {
dbg() << "TODO: Add event icon on specific tile";
done(Dialog::ExecOK);
};
event_title_textbox.set_focus(true);
}
AddEventDialog::~AddEventDialog()
{
}
AddEventDialog::MonthListModel::MonthListModel()
{
}
AddEventDialog::MonthListModel::~MonthListModel()
{
}
void AddEventDialog::MonthListModel::update()
{
}
int AddEventDialog::MonthListModel::row_count(const GUI::ModelIndex&) const
{
return 12;
}
String AddEventDialog::MonthListModel::column_name(int column) const
{
switch (column) {
case Column::Month:
return "Month";
default:
ASSERT_NOT_REACHED();
}
}
GUI::Model::ColumnMetadata AddEventDialog::MonthListModel::column_metadata([[maybe_unused]] int column) const
{
return {};
}
GUI::Variant AddEventDialog::MonthListModel::data(const GUI::ModelIndex& index, Role role) const
{
auto& month = Calendar::name_of_month(index.row() + 1);
if (role == Role::Display) {
switch (index.column()) {
case Column::Month:
return month;
default:
ASSERT_NOT_REACHED();
}
}
return {};
}

View file

@ -28,6 +28,7 @@
#include "Calendar.h"
#include <LibGUI/Dialog.h>
#include <LibGUI/Model.h>
#include <LibGUI/Window.h>
class AddEventDialog final : public GUI::Dialog {
@ -35,14 +36,36 @@ class AddEventDialog final : public GUI::Dialog {
public:
virtual ~AddEventDialog() override;
static void show(Calendar* calendar, Window* parent_window = nullptr)
static void show(RefPtr<Calendar> calendar, Core::DateTime date_time, Window* parent_window = nullptr)
{
auto dialog = AddEventDialog::construct(calendar, parent_window);
auto dialog = AddEventDialog::construct(calendar, date_time, parent_window);
dialog->exec();
}
private:
AddEventDialog(Calendar* calendar, Window* parent_window = nullptr);
AddEventDialog(RefPtr<Calendar> calendar, Core::DateTime date_time, Window* parent_window = nullptr);
Calendar* m_calendar;
class MonthListModel final : public GUI::Model {
public:
enum Column {
Month,
__Count,
};
static NonnullRefPtr<MonthListModel> create() { return adopt(*new MonthListModel); }
virtual ~MonthListModel() override;
virtual int row_count(const GUI::ModelIndex& = GUI::ModelIndex()) const override;
virtual int column_count(const GUI::ModelIndex& = GUI::ModelIndex()) const override { return Column::__Count; }
virtual String column_name(int) const override;
virtual ColumnMetadata column_metadata(int) const override;
virtual GUI::Variant data(const GUI::ModelIndex&, Role = Role::Display) const override;
virtual void update() override;
private:
MonthListModel();
};
RefPtr<Calendar> m_calendar;
Core::DateTime m_date_time;
};

View file

@ -26,7 +26,7 @@
#include "Calendar.h"
const String name_of_month(int month)
const String Calendar::name_of_month(int month)
{
static const String month_names[] = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" };
return month_names[month - 1];

View file

@ -31,8 +31,10 @@
const String name_of_month(int month);
class Calendar final {
class Calendar final : public RefCounted<Calendar> {
public:
static const String name_of_month(int month);
Calendar(Core::DateTime date_time);
~Calendar();
@ -41,6 +43,7 @@ public:
int selected_year() const { return m_selected_year; }
int selected_month() const { return m_selected_month; }
bool is_today(Core::DateTime date_time) const;
void add_event(Core::DateTime date_time);
private:
Core::DateTime m_date_time;

View file

@ -101,7 +101,7 @@ CalendarWidget::CalendarWidget()
m_add_event_button->set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed);
m_add_event_button->set_preferred_size(100, 25);
m_add_event_button->on_click = [this] {
AddEventDialog::show(m_calendar, window());
show_add_event_window();
};
update_calendar_tiles(m_calendar->selected_year(), m_calendar->selected_month());
@ -110,6 +110,7 @@ CalendarWidget::CalendarWidget()
CalendarWidget::~CalendarWidget()
{
}
void CalendarWidget::resize_event(GUI::ResizeEvent& event)
{
if (event.size().width() < 350) {
@ -193,6 +194,11 @@ void CalendarWidget::update_calendar_tiles(int target_year, int target_month)
m_selected_date_label->set_text(m_calendar->selected_date_text());
}
void CalendarWidget::show_add_event_window()
{
AddEventDialog::show(*move(m_calendar), Core::DateTime::now(), window());
}
CalendarWidget::CalendarTile::CalendarTile(Calendar& calendar, int index, Core::DateTime date_time)
: m_index(index)
, m_date_time(date_time)
@ -213,13 +219,20 @@ void CalendarWidget::CalendarTile::update_values(Calendar& calendar, int index,
m_weekday_name = m_day_names[index];
}
m_display_date = (m_date_time.day() == 1) ? String::format("%s %d", name_of_month(m_date_time.month()).characters(), m_date_time.day()) : String::number(m_date_time.day());
m_display_date = (m_date_time.day() == 1) ? String::format("%s %d", Calendar::name_of_month(m_date_time.month()).characters(), m_date_time.day()) : String::number(m_date_time.day());
}
CalendarWidget::CalendarTile::~CalendarTile()
{
}
void CalendarWidget::CalendarTile::doubleclick_event(GUI::MouseEvent& event)
{
GUI::Widget::doubleclick_event(event);
//TOOD: Should be calling show_add_event_window. Would we just replace m_calender /w m_calender_widget?
AddEventDialog::show(&m_calendar, m_date_time, window());
}
void CalendarWidget::CalendarTile::paint_event(GUI::PaintEvent& event)
{
GUI::Frame::paint_event(event);

View file

@ -38,11 +38,12 @@ public:
CalendarWidget();
virtual ~CalendarWidget() override;
void show_add_event_window();
private:
virtual void resize_event(GUI::ResizeEvent&) override;
void update_calendar_tiles(int target_year, int target_month);
void show_add_event_window(Calendar* calendar);
OwnPtr<Calendar> m_calendar;
RefPtr<GUI::Widget> m_top_container;
@ -60,6 +61,7 @@ private:
virtual ~CalendarTile() override;
private:
virtual void doubleclick_event(GUI::MouseEvent&) override;
virtual void paint_event(GUI::PaintEvent&) override;
int m_index { 0 };