~aleteoryx/muditaos

muditaos/module-apps/application-meditation/ApplicationMeditation.cpp -rw-r--r-- 6.1 KiB
a405cad6Aleteoryx trim readme 6 days ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
// Copyright (c) 2017-2024, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/blob/master/LICENSE.md

#include "ApplicationMeditation.hpp"
#include "MeditationOptionsWindows.hpp"
#include "MeditationTimerWindow.hpp"
#include "MeditationWindow.hpp"
#include "Names.hpp"
#include "MeditationParams.hpp"
#include "Constants.hpp"

#include <service-db/Settings.hpp>
#include <service-db/agents/settings/SystemSettings.hpp>

namespace app
{
    ApplicationMeditation::ApplicationMeditation(std::string name,
                                                 std::string parent,
                                                 StatusIndicators statusIndicators,
                                                 StartInBackground startInBackground)
        : Application{std::move(name), std::move(parent), statusIndicators, startInBackground}
    {}

    auto ApplicationMeditation::InitHandler() -> sys::ReturnCodes
    {
        const auto ret = Application::InitHandler();
        if (ret != sys::ReturnCodes::Success) {
            return ret;
        }

        const 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);
        };

        const 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{preparationTime, std::move(preparationTimeOnChangeCallback)},
            .showCounter{counterVisible, std::move(counterVisibleOnChangeCallback)}};

        state = std::make_unique<gui::OptionsData>(std::move(params));

        createUserInterface();

        return ret;
    }

    auto ApplicationMeditation::DataReceivedHandler(sys::DataMessage *msgl, sys::ResponseMessage *resp)
        -> sys::MessagePointer
    {
        const auto retMsg = Application::DataReceivedHandler(msgl);
        // if message was handled by application's template there is no need to process further.
        if (retMsg && (dynamic_cast<sys::ResponseMessage *>(retMsg.get())->retCode == sys::ReturnCodes::Success)) {
            return retMsg;
        }

        return handleAsyncResponse(resp);
    }

    auto ApplicationMeditation::SwitchPowerModeHandler([[maybe_unused]] 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) {
                const 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);
                };
                const 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        = durationInitValue,
                                        .onChangeCallback = std::move(durationOnChangeCallback)},
                    .intervalChime{.initValue        = intervalChimeInitValue,
                                   .onChangeCallback = std::move(intervalChimeOnChangeCallback)}};

                return std::make_unique<gui::MeditationWindow>(app, std::move(params));
            });
        windowsFactory.attach(app::window::name::meditation_timer, [](ApplicationCommon *app, const std::string &name) {
            return std::make_unique<gui::MeditationTimerWindow>(app);
        });
        windowsFactory.attach(app::window::name::meditation_options,
                              [](ApplicationCommon *app, const std::string &name) {
                                  return std::make_unique<gui::MeditationOptionsWindow>(app);
                              });
        windowsFactory.attach(app::window::name::meditation_preparation,
                              [](ApplicationCommon *app, const std::string &name) {
                                  return std::make_unique<gui::PreparationTimeWindow>(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 <typename T>
    T ApplicationMeditation::getLocalSettingsValue(const std::string &variableName, T defaultValue)
    {
        const auto &value = settings->getValue(variableName, settings::SettingsScope::AppLocal);
        return value.empty() ? defaultValue : utils::getNumericValue<T>(value);
    }
} // namespace app