/* * Copyright 2013 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 . * * Authors: * Charles Kerr */ #ifndef INDICATOR_DATETIME_APPOINTMENT_H #define INDICATOR_DATETIME_APPOINTMENT_H #include #include #include namespace ayatana { namespace indicator { namespace datetime { /** * \brief Basic information required to raise a notification about some Appointment. */ struct Alarm { enum Type { None = 0, EMAIL = 0x001, SOUND = 0x010, TEXT = 0x100 }; int type; std::string text; std::string audio_url; DateTime time; bool operator== (const Alarm& that) const; Alarm(); Alarm(int type_, const std::string &text_, const std::string& audio_url_, const DateTime &time_); }; /** * \brief An instance of an appointment; e.g. a calendar event or clock-app alarm * * @see Planner */ struct Appointment { public: enum Type { EVENT, UBUNTU_ALARM }; Type type = EVENT; 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; DateTime begin; DateTime end; std::vector alarms; bool operator== (const Appointment& that) const; }; } // namespace datetime } // namespace indicator } // namespace ayatana #endif // INDICATOR_DATETIME_APPOINTMENT_H