mirror of
https://github.com/mudita/MuditaOS.git
synced 2026-01-09 06:18:54 -05:00
* Adding document describing how to use logger * Adjusting logs to follow a new guide * Change order in log header: line number is now before function name
149 lines
6.0 KiB
C++
149 lines
6.0 KiB
C++
// Copyright (c) 2017-2023, Mudita Sp. z.o.o. All rights reserved.
|
|
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
|
|
|
|
#include "ApplicationCallLog.hpp"
|
|
#include "DialogMetadata.hpp"
|
|
#include "DialogMetadataMessage.hpp"
|
|
#include "data/CallLogInternals.hpp"
|
|
#include "windows/CallLogDetailsWindow.hpp"
|
|
#include "windows/CallLogMainWindow.hpp"
|
|
#include "windows/CallLogOptionsWindow.hpp"
|
|
|
|
#include <service-db/DBServiceAPI.hpp>
|
|
#include <Dialog.hpp>
|
|
#include <OptionWindow.hpp>
|
|
#include <i18n/i18n.hpp>
|
|
#include <log/log.hpp>
|
|
#include <MessageType.hpp>
|
|
#include <module-db/queries/calllog/QueryCalllogSetAllRead.hpp>
|
|
#include <module-db/queries/notifications/QueryNotificationsClear.hpp>
|
|
#include <utility>
|
|
|
|
using namespace calllog;
|
|
|
|
namespace
|
|
{
|
|
constexpr auto applicationCallLogStackSize = 1024 * 7;
|
|
}
|
|
|
|
namespace app
|
|
{
|
|
ApplicationCallLog::ApplicationCallLog(std::string name,
|
|
std::string parent,
|
|
StatusIndicators statusIndicators,
|
|
StartInBackground startInBackground)
|
|
: Application(
|
|
std::move(name), std::move(parent), statusIndicators, startInBackground, applicationCallLogStackSize)
|
|
{
|
|
bus.channels.push_back(sys::BusChannel::ServiceDBNotifications);
|
|
addActionReceiver(manager::actions::ShowCallLog, [this](auto &&data) {
|
|
switchWindow(gui::name::window::main_window, std::move(data));
|
|
return actionHandled();
|
|
});
|
|
}
|
|
|
|
ApplicationCallLog::~ApplicationCallLog()
|
|
{
|
|
}
|
|
|
|
// Invoked upon receiving data message
|
|
sys::MessagePointer ApplicationCallLog::DataReceivedHandler(sys::DataMessage *msgl, sys::ResponseMessage *resp)
|
|
{
|
|
// if message was handled by application's template there is no need to process further.
|
|
auto retMsg = Application::DataReceivedHandler(msgl);
|
|
if (auto responseMsg = dynamic_cast<sys::ResponseMessage *>(retMsg.get());
|
|
responseMsg != nullptr && responseMsg->retCode == sys::ReturnCodes::Success) {
|
|
return retMsg;
|
|
}
|
|
|
|
if (userInterfaceDBNotification(msgl,
|
|
[&]([[maybe_unused]] sys::Message *, [[maybe_unused]] const std::string &) {
|
|
return msgl->messageType == MessageType::DBServiceNotification;
|
|
})) {
|
|
return sys::msgHandled();
|
|
}
|
|
|
|
return handleAsyncResponse(resp);
|
|
}
|
|
|
|
// Invoked during initialization
|
|
sys::ReturnCodes ApplicationCallLog::InitHandler()
|
|
{
|
|
auto ret = Application::InitHandler();
|
|
if (ret != sys::ReturnCodes::Success) {
|
|
return ret;
|
|
}
|
|
|
|
createUserInterface();
|
|
return ret;
|
|
}
|
|
|
|
sys::ReturnCodes ApplicationCallLog::DeinitHandler()
|
|
{
|
|
return Application::DeinitHandler();
|
|
}
|
|
|
|
void ApplicationCallLog::createUserInterface()
|
|
{
|
|
windowsFactory.attach(calllog::settings::MainWindowStr, [](ApplicationCommon *app, const std::string &name) {
|
|
return std::make_unique<gui::CallLogMainWindow>(app);
|
|
});
|
|
windowsFactory.attach(calllog::settings::DetailsWindowStr, [](ApplicationCommon *app, const std::string &name) {
|
|
return std::make_unique<gui::CallLogDetailsWindow>(app);
|
|
});
|
|
windowsFactory.attach(window::name::option_window, [](ApplicationCommon *app, const std::string &name) {
|
|
return std::make_unique<gui::OptionWindow>(app, name);
|
|
});
|
|
windowsFactory.attach(calllog::settings::CallLogOptionsStr,
|
|
[](ApplicationCommon *app, const std::string &name) {
|
|
return std::make_unique<gui::CalllogWindowOptions>(app, name);
|
|
});
|
|
windowsFactory.attach(calllog::settings::DialogYesNoStr, [](ApplicationCommon *app, const std::string &name) {
|
|
return std::make_unique<gui::DialogYesNo>(app, name);
|
|
});
|
|
|
|
attachPopups({gui::popup::ID::Volume,
|
|
gui::popup::ID::Tethering,
|
|
gui::popup::ID::BluetoothAuthenticate,
|
|
gui::popup::ID::PhoneModes,
|
|
gui::popup::ID::PhoneLock,
|
|
gui::popup::ID::SimLock,
|
|
gui::popup::ID::Alarm});
|
|
}
|
|
|
|
void ApplicationCallLog::destroyUserInterface()
|
|
{}
|
|
|
|
bool ApplicationCallLog::removeCalllogEntry(const CalllogRecord &record)
|
|
{
|
|
LOG_DEBUG("Removing call log record: %" PRIu32, record.ID);
|
|
auto metaData = std::make_unique<gui::DialogMetadataMessage>(
|
|
gui::DialogMetadata{record.name,
|
|
"delete_128px_W_G",
|
|
utils::translate("app_calllog_delete_call_confirmation"),
|
|
"",
|
|
[=]() -> bool {
|
|
if (DBServiceAPI::CalllogRemove(this, record.ID) == false) {
|
|
LOG_ERROR("Call log remove id=%" PRIu32 " failed", record.ID);
|
|
return false;
|
|
}
|
|
this->switchWindow(calllog::settings::MainWindowStr);
|
|
return true;
|
|
}});
|
|
switchWindow(calllog::settings::DialogYesNoStr, gui::ShowMode::GUI_SHOW_INIT, std::move(metaData));
|
|
return true;
|
|
}
|
|
|
|
bool ApplicationCallLog::setAllEntriesRead()
|
|
{
|
|
// clear also notifications
|
|
DBServiceAPI::GetQuery(this,
|
|
db::Interface::Name::Notifications,
|
|
std::make_unique<db::query::notifications::Clear>(NotificationsRecord::Key::Calls));
|
|
const auto [succeed, _] = DBServiceAPI::GetQuery(
|
|
this, db::Interface::Name::Calllog, std::make_unique<db::query::calllog::SetAllRead>());
|
|
return succeed;
|
|
}
|
|
|
|
} /* namespace app */
|