// Copyright (c) 2017-2020, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
#include "MessagesMainWindow.hpp"
#include "application-messages/ApplicationMessages.hpp"
#include "application-messages/data/MessagesStyle.hpp"
#include "application-messages/data/SMSdata.hpp"
#include "application-messages/widgets/ThreadItem.hpp"
#include "application-messages/windows/SearchStart.hpp"
#include <service-appmgr/ApplicationManager.hpp>
#include <i18/i18.hpp>
#include <service-db/api/DBServiceAPI.hpp>
#include <application-phonebook/data/PhonebookItemData.hpp>
#include <Style.hpp>
#include <log/log.hpp>
#include <module-db/queries/notifications/QueryNotificationsClear.hpp>
#include <module-db/queries/messages/threads/QueryThreadGetByContactID.hpp>
#include <memory>
#include <cassert>
#include <module-services/service-db/messages/DBNotificationMessage.hpp>
namespace gui
{
MessagesMainWindow::MessagesMainWindow(app::Application *app) : AppWindow(app, gui::name::window::main_window)
{
buildInterface();
}
void MessagesMainWindow::rebuild()
{
if (list == nullptr) {
return;
}
list->rebuildList(style::listview::RebuildType::InPlace);
}
void MessagesMainWindow::buildInterface()
{
namespace msgThreadStyle = style::messages::threads;
AppWindow::buildInterface();
threadsModel = std::make_shared<ThreadsModel>(application);
list = new gui::ListView(this,
msgThreadStyle::listPositionX,
msgThreadStyle::ListPositionY,
msgThreadStyle::listWidth,
msgThreadStyle::listHeight,
threadsModel);
list->setScrollTopMargin(style::margins::small);
list->rebuildList();
bottomBar->setActive(BottomBar::Side::LEFT, true);
bottomBar->setActive(BottomBar::Side::CENTER, true);
bottomBar->setActive(BottomBar::Side::RIGHT, true);
bottomBar->setText(BottomBar::Side::LEFT, utils::localize.get(style::strings::common::options));
bottomBar->setText(BottomBar::Side::CENTER, utils::localize.get(style::strings::common::open));
bottomBar->setText(BottomBar::Side::RIGHT, utils::localize.get(style::strings::common::back));
topBar->setActive(TopBar::Elements::TIME, true);
setTitle(utils::localize.get("app_messages_title_main"));
leftArrowImage = new gui::Image(this, 30, 62, 0, 0, "arrow_left");
rightArrowImage = new gui::Image(this, 480 - 30 - 13, 62, 0, 0, "arrow_right");
newMessageImage = new gui::Image(this, 48, 55, 0, 0, "cross");
searchImage = new gui::Image(this, 480 - 48 - 26, 55, 0, 0, "search");
emptyListIcon = new Icon(this,
0,
style::header::height,
style::window_width,
style::window_height - style::header::height - style::footer::height,
"phonebook_empty_grey_circle_W_G",
utils::localize.get("app_messages_no_messages"));
list->setVisible(true);
list->focusChangedCallback = [this]([[maybe_unused]] gui::Item &item) {
bottomBar->setActive(BottomBar::Side::LEFT, true);
bottomBar->setActive(BottomBar::Side::CENTER, true);
rightArrowImage->setVisible(true);
searchImage->setVisible(true);
return true;
};
emptyListIcon->setVisible(false);
emptyListIcon->focusChangedCallback = [this]([[maybe_unused]] gui::Item &item) {
bottomBar->setActive(BottomBar::Side::LEFT, false);
bottomBar->setActive(BottomBar::Side::CENTER, false);
rightArrowImage->setVisible(false);
searchImage->setVisible(false);
return true;
};
setFocusItem(list);
}
void MessagesMainWindow::onBeforeShow(ShowMode mode, SwitchData *data)
{
LOG_INFO("Data: %s", data ? data->getDescription().c_str() : "");
{
auto pdata = dynamic_cast<PhonebookSearchReuqest *>(data);
if (pdata != nullptr) {
using db::query::ThreadGetByContactID;
auto query = std::make_unique<ThreadGetByContactID>(pdata->result->ID);
query->setQueryListener(db::QueryCallback::fromFunction([app = application](auto response) {
using db::query::ThreadGetByContactIDResult;
const auto result = dynamic_cast<ThreadGetByContactIDResult *>(response);
if ((result != nullptr) && result->getRecord().has_value()) {
auto thread = result->getRecord().value();
app->switchWindow(gui::name::window::thread_view,
std::make_unique<SMSThreadData>(std::make_unique<ThreadRecord>(thread)));
return true;
}
LOG_FATAL("No thread and thread not created!");
return false;
}));
DBServiceAPI::GetQuery(application, db::Interface::Name::Contact, std::move(query));
}
}
if (threadsModel->requestRecordsCount() == 0) {
emptyListIcon->setVisible(true);
setFocusItem(emptyListIcon);
}
else {
emptyListIcon->setVisible(false);
}
DBServiceAPI::GetQuery(application,
db::Interface::Name::Notifications,
std::make_unique<db::query::notifications::Clear>(NotificationsRecord::Key::Sms));
}
bool MessagesMainWindow::onInput(const InputEvent &inputEvent)
{
auto app = dynamic_cast<app::ApplicationMessages *>(application);
assert(app);
// check if any of the lower inheritance onInput methods catch the event
if (AppWindow::onInput(inputEvent)) {
return true;
}
if (inputEvent.state == InputEvent::State::keyReleasedShort) {
switch (inputEvent.keyCode) {
case gui::KeyCode::KEY_LEFT:
application->switchWindow(gui::name::window::new_sms, nullptr);
return true;
case gui::KeyCode::KEY_RIGHT:
app->switchWindow(gui::name::window::thread_sms_search, nullptr);
return true;
default:
LOG_DEBUG("SMS main window not handled key: %d", static_cast<int>(inputEvent.keyCode));
break;
}
}
return false;
}
bool MessagesMainWindow::onDatabaseMessage(sys::Message *msgl)
{
auto *msgNotification = dynamic_cast<db::NotificationMessage *>(msgl);
if (msgNotification != nullptr) {
if (msgNotification->interface == db::Interface::Name::SMSThread ||
msgNotification->interface == db::Interface::Name::SMS) {
if (msgNotification->dataModified()) {
rebuild();
return true;
}
}
}
return false;
}
} // namespace gui