diff options
author | Robert Tari <robert@tari.in> | 2020-07-11 00:11:05 +0200 |
---|---|---|
committer | Robert Tari <robert@tari.in> | 2020-07-17 18:02:32 +0200 |
commit | b917e4ce17bc30772792a475af2eb0c64ae9f47b (patch) | |
tree | bfec00a17c4cd117576b6cbe8160f07c1d1a764f /include/datetime | |
parent | 6eac66d1ca86cbf85204b93f36b3ebe7082498b5 (diff) | |
download | ayatana-indicator-datetime-b917e4ce17bc30772792a475af2eb0c64ae9f47b.tar.gz ayatana-indicator-datetime-b917e4ce17bc30772792a475af2eb0c64ae9f47b.tar.bz2 ayatana-indicator-datetime-b917e4ce17bc30772792a475af2eb0c64ae9f47b.zip |
-Made GCC 10.1.0 friendly
-Fixed to work with ECal 2.0
-Added libaccounts-glib dependency
-Added mate-time-admin handler
Diffstat (limited to 'include/datetime')
-rw-r--r-- | include/datetime/appointment.h | 4 | ||||
-rw-r--r-- | include/datetime/engine-eds.h | 4 | ||||
-rw-r--r-- | include/datetime/myself.h | 62 |
3 files changed, 69 insertions, 1 deletions
diff --git a/include/datetime/appointment.h b/include/datetime/appointment.h index 700bb2e..950f4bb 100644 --- a/include/datetime/appointment.h +++ b/include/datetime/appointment.h @@ -39,8 +39,11 @@ struct Alarm DateTime time; bool operator== (const Alarm& that) const; + bool has_sound() const; + bool has_text() const; }; + /** * \brief An instance of an appointment; e.g. a calendar event or clock-app alarm * @@ -54,6 +57,7 @@ public: bool is_ubuntu_alarm() const { return type == UBUNTU_ALARM; } std::string uid; + std::string source_uid; std::string color; std::string summary; std::string activation_url; diff --git a/include/datetime/engine-eds.h b/include/datetime/engine-eds.h index d25a825..96b0f76 100644 --- a/include/datetime/engine-eds.h +++ b/include/datetime/engine-eds.h @@ -37,6 +37,8 @@ namespace datetime { ***** ****/ +class Myself; + /** * Class wrapper around EDS so multiple #EdsPlanners can share resources * @@ -45,7 +47,7 @@ namespace datetime { class EdsEngine: public Engine { public: - EdsEngine(); + EdsEngine(const std::shared_ptr<Myself> &myself); ~EdsEngine(); void get_appointments(const DateTime& begin, diff --git a/include/datetime/myself.h b/include/datetime/myself.h new file mode 100644 index 0000000..67e938d --- /dev/null +++ b/include/datetime/myself.h @@ -0,0 +1,62 @@ +/* + * Copyright 2016 Canonical Ltd. + * + * This program is free software: you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 3, as published + * by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranties of + * MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR + * PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see <http://www.gnu.org/licenses/>. + * + * Authors: + * Renato Araujo Oliveira Filho <renato.filho@canonical.com> + */ + +#ifndef INDICATOR_DATETIME_MYSELF_H +#define INDICATOR_DATETIME_MYSELF_H + +#include <core/property.h> + +#include <string> +#include <set> +#include <memory.h> +#include <glib.h> + +typedef struct _AgManager AgManager; + +namespace ayatana { +namespace indicator { +namespace datetime { + +class Myself +{ +public: + Myself(); + + const core::Property<std::set<std::string>>& emails() + { + return m_emails; + } + + bool isMyEmail(const std::string &email); + +private: + std::shared_ptr<AgManager> m_accounts_manager; + core::Property<std::set<std::string> > m_emails; + + static void on_accounts_changed(AgManager*, guint, Myself*); + void reloadEmails(); + +}; + + +} // namespace datetime +} // namespace indicator +} // namespace ayatana + +#endif // INDICATOR_DATETIME_MYSELF_H |