// Copyright (c) 2017-2023, Mudita Sp. z.o.o. All rights reserved. // For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md #include "ApplicationMeditation.hpp" #include "MeditationOptionsWindows.hpp" #include "MeditationTimerWindow.hpp" #include "MeditationWindow.hpp" #include "Names.hpp" #include "MeditationParams.hpp" #include "Constants.hpp" #include #include namespace app { ApplicationMeditation::ApplicationMeditation(std::string name, std::string parent, StatusIndicators statusIndicators, StartInBackground startInBackground) : Application{name, parent, statusIndicators, startInBackground} {} auto ApplicationMeditation::InitHandler() -> sys::ReturnCodes { const auto ret = Application::InitHandler(); if (ret != sys::ReturnCodes::Success) return ret; auto counterVisible = getLocalSettingsValue(settings::Meditation::showCounter, Constants::Params::defaultCounterVisible); auto counterVisibleOnChangeCallback = [this](bool newValue) { settings->setValue( settings::Meditation::showCounter, utils::to_string(newValue), settings::SettingsScope::AppLocal); }; auto preparationTime = std::chrono::seconds(getLocalSettingsValue( settings::Meditation::preparationTime, Constants::Params::defaultPreparationTime.count())); auto preparationTimeOnChangeCallback = [this](std::chrono::seconds newValue) { settings->setValue(settings::Meditation::preparationTime, utils::to_string(newValue.count()), settings::SettingsScope::AppLocal); }; gui::OptionsData::OptionParams params = { .preparationTime{std::move(preparationTime), std::move(preparationTimeOnChangeCallback)}, .showCounter{std::move(counterVisible), std::move(counterVisibleOnChangeCallback)}}; state = std::make_unique(std::move(params)); createUserInterface(); return ret; } auto ApplicationMeditation::DataReceivedHandler(sys::DataMessage *msgl, sys::ResponseMessage *resp) -> sys::MessagePointer { auto retMsg = Application::DataReceivedHandler(msgl); // if message was handled by application's template there is no need to process further. if (retMsg && (dynamic_cast(retMsg.get())->retCode == sys::ReturnCodes::Success)) { return retMsg; } return handleAsyncResponse(resp); } auto ApplicationMeditation::SwitchPowerModeHandler(sys::ServicePowerMode mode) -> sys::ReturnCodes { return sys::ReturnCodes::Success; } void ApplicationMeditation::createUserInterface() { windowsFactory.attach( app::window::name::meditation_main_window, [&](ApplicationCommon *app, const std::string &name) { auto durationInitValue = getLocalSettingsValue(settings::Meditation::duration, Constants::Params::defaultMeditationDuration); auto durationOnChangeCallback = [this](std::int32_t newValue) { settings->setValue( settings::Meditation::duration, utils::to_string(newValue), settings::SettingsScope::AppLocal); }; auto intervalChimeInitValue = std::chrono::minutes(getLocalSettingsValue( settings::Meditation::intervalChime, Constants::Params::defaultChimeInterval.count())); auto intervalChimeOnChangeCallback = [this](std::chrono::minutes newValue) { settings->setValue(settings::Meditation::intervalChime, utils::to_string(newValue.count()), settings::SettingsScope::AppLocal); }; MeditationParams params = { .meditationDuration{.initValue = std::move(durationInitValue), .onChangeCallback = std::move(durationOnChangeCallback)}, .intervalChime{.initValue = std::move(intervalChimeInitValue), .onChangeCallback = std::move(intervalChimeOnChangeCallback)}}; return std::make_unique(app, std::move(params)); }); windowsFactory.attach(app::window::name::meditation_timer, [](ApplicationCommon *app, const std::string &name) { return std::make_unique(app); }); windowsFactory.attach(app::window::name::meditation_options, [](ApplicationCommon *app, const std::string &name) { return std::make_unique(app); }); windowsFactory.attach(app::window::name::meditation_preparation, [](ApplicationCommon *app, const std::string &name) { return std::make_unique(app); }); 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 ApplicationMeditation::destroyUserInterface() {} template T ApplicationMeditation::getLocalSettingsValue(const std::string &variableName, T defaultValue) { const std::string value = settings->getValue(variableName, settings::SettingsScope::AppLocal); return value.empty() ? defaultValue : utils::getNumericValue(value); } } // namespace app