// Copyright (c) 2017-2020, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
#include "UiCommonActions.hpp"
#include "application-call/ApplicationCall.hpp"
#include "application-call/data/CallSwitchData.hpp"
#include "application-messages/ApplicationMessages.hpp"
#include "application-messages/data/SMSdata.hpp"
#include "application-messages/windows/SMSThreadViewWindow.hpp"
#include "application-phonebook/ApplicationPhonebook.hpp"
#include "application-phonebook/data/PhonebookItemData.hpp"
#include "application-special-input/ApplicationSpecialInput.hpp"
#include "service-appmgr/Controller.hpp"
#include "service-appmgr/messages/APMMessage.hpp"
#include <i18/i18.hpp>
#include <log/log.hpp>
#include <PhoneNumber.hpp>
#include <cassert>
#include <string>
#include <utility>
namespace app
{
auto call(Application *app, const ContactRecord &contact) -> bool
{
assert(app != nullptr);
if (contact.numbers.size() != 0) {
return call(app, contact.numbers[0].number);
}
else {
LOG_ERROR("No contact numbers!");
return false;
}
}
auto call(Application *app, const utils::PhoneNumber::View &phoneNumber) -> bool
{
assert(app != nullptr);
auto data = std::make_unique<ExecuteCallData>(phoneNumber);
data->disableAppClose = true;
return app::manager::Controller::switchApplication(app, name_call, window::name_enterNumber, std::move(data));
}
auto prepareCall(Application *app, const std::string &number) -> bool
{
assert(app != nullptr);
auto data = std::make_unique<EnterNumberData>(number);
return app::manager::Controller::switchApplication(app, name_call, window::name_enterNumber, std::move(data));
}
auto sms(Application *app, SmsOperation smsOperation, const utils::PhoneNumber::View &number, const UTF8 textData)
-> bool
{
assert(app != nullptr);
switch (smsOperation) {
case SmsOperation::New: {
auto data = std::make_unique<SMSSendRequest>(number, textData);
data->disableAppClose = true;
data->ignoreCurrentWindowOnStack = true;
return app::manager::Controller::switchApplication(
app, name_messages, gui::name::window::new_sms, std::move(data));
}
case SmsOperation::Template: {
return app::manager::Controller::switchApplication(
app, name_messages, gui::name::window::sms_templates, std::make_unique<SMSSendTemplateRequest>(number));
}
default: {
LOG_ERROR("SmsOperation not supported %" PRIu32, static_cast<uint32_t>(smsOperation));
return false;
}
}
}
auto contact(Application *app, ContactOperation contactOperation, const ContactRecord &contact) -> bool
{
auto data = std::make_unique<PhonebookItemData>(std::make_shared<ContactRecord>(contact));
data->disableAppClose = true;
assert(app != nullptr);
switch (contactOperation) {
case ContactOperation::Add: {
data->ignoreCurrentWindowOnStack = true;
return app::manager::Controller::switchApplication(
app, name_phonebook, gui::window::name::new_contact, std::move(data));
}
case ContactOperation::Details: {
return app::manager::Controller::switchApplication(
app, name_phonebook, gui::window::name::contact, std::move(data));
}
case ContactOperation::Edit: {
return app::manager::Controller::switchApplication(
app,
name_phonebook,
gui::window::name::new_contact, // TODO: need to be fixed when contact edition is working
std::move(data));
}
default: {
LOG_ERROR("ContactOperation not supported %" PRIu32, static_cast<uint32_t>(contactOperation));
return false;
}
}
}
auto contact(Application *app, ContactOperation contactOperation, const std::string &number) -> bool
{
assert(app != nullptr);
auto searchResults = DBServiceAPI::ContactSearch(app, "", "", number);
ContactRecord contactRec;
if (searchResults.get()->size() == 1) {
contactRec = searchResults->front();
LOG_INFO("Found contact matching search num %s : contact ID %" PRIu32 " - %s %s",
number.c_str(),
contactRec.ID,
contactRec.primaryName.c_str(),
contactRec.alternativeName.c_str());
if (contactOperation == ContactOperation::Add) {
return app::manager::Controller::switchApplication(
app,
name_phonebook,
gui::window::name::new_contact,
std::make_unique<PhonebookItemData>(std::make_shared<ContactRecord>(contactRec)));
}
}
else if (searchResults.get()->size() > 1) {
LOG_FATAL("Found more than one contact for number %s", number.c_str());
for (auto i : *searchResults) {
LOG_FATAL("ContactID = %" PRIu32, i.ID);
}
return false;
}
else if (contactOperation != ContactOperation::Add) {
LOG_ERROR("Invalid operation for not existing contact for number %s", number.c_str());
return false;
}
contactRec.numbers.emplace_back(ContactRecord::Number(utils::PhoneNumber(number).getView()));
return contact(app, contactOperation, contactRec);
}
auto contact(Application *app, ContactOperation contactOperation, uint32_t contactId) -> bool
{
assert(app != nullptr);
assert(contactOperation != ContactOperation::Add);
auto searchResults = DBServiceAPI::ContactGetByID(app, contactId);
if (searchResults.get()->size() == 1) {
ContactRecord contactRec = searchResults->front();
return contact(app, contactOperation, contactRec);
}
return false;
}
auto specialInput(Application *app, std::unique_ptr<gui::SwitchSpecialChar> &&switchData) -> bool
{
assert(app != nullptr);
switchData->disableAppClose = true;
if (gui::SwitchSpecialChar::Type::Request == switchData->type) {
return app::manager::Controller::switchApplication(
app, app::special_input, app::char_select, std::move(switchData));
}
return app::manager::Controller::switchBack(
app, std::make_unique<app::manager::APMSwitchPrevApp>(switchData->requester, std::move(switchData)));
}
} // namespace app