Commit 06ecb0b2 authored by Ronan Abhamon's avatar Ronan Abhamon

fix(presence): refactoring

parent 877da996
...@@ -23,7 +23,7 @@ HEADERS = \ ...@@ -23,7 +23,7 @@ HEADERS = \
src/components/contacts/ContactsListModel.hpp \ src/components/contacts/ContactsListModel.hpp \
src/components/contacts/ContactsListProxyModel.hpp \ src/components/contacts/ContactsListProxyModel.hpp \
src/components/notification/Notification.hpp \ src/components/notification/Notification.hpp \
src/components/presence/PresenceModel.hpp \ src/components/presence/Presence.hpp \
src/components/settings/AccountSettingsListModel.hpp \ src/components/settings/AccountSettingsListModel.hpp \
src/components/settings/AccountSettingsModel.hpp \ src/components/settings/AccountSettingsModel.hpp \
src/components/settings/SettingsModel.hpp \ src/components/settings/SettingsModel.hpp \
......
#include "ContactModel.hpp" #include "ContactModel.hpp"
// =================================================================== // ===================================================================
QString ContactModel::getUsername () const {
return m_username;
}
void ContactModel::setUsername (const QString &username) {
m_username = username;
}
QString ContactModel::getAvatar () const {
return m_avatar;
}
void ContactModel::setAvatar (const QString &avatar) {
m_avatar = avatar;
}
Presence::PresenceStatus ContactModel::getPresenceStatus () const {
return m_presence_status;
}
Presence::PresenceLevel ContactModel::getPresenceLevel () const {
return Presence::getPresenceLevel(m_presence_status);
}
QStringList ContactModel::getSipAddresses () const {
return m_sip_addresses;
}
void ContactModel::setSipAddresses (const QStringList &sip_addresses) {
m_sip_addresses = sip_addresses;
}
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
#include <QObject> #include <QObject>
#include "../presence/PresenceModel.hpp" #include "../presence/Presence.hpp"
// =================================================================== // ===================================================================
...@@ -27,13 +27,13 @@ class ContactModel : public QObject { ...@@ -27,13 +27,13 @@ class ContactModel : public QObject {
); );
Q_PROPERTY( Q_PROPERTY(
PresenceModel::Presence presence Presence::PresenceStatus presenceStatus
READ getPresence READ getPresenceStatus
CONSTANT CONSTANT
); );
Q_PROPERTY( Q_PROPERTY(
PresenceModel::PresenceLevel presenceLevel Presence::PresenceLevel presenceLevel
READ getPresenceLevel READ getPresenceLevel
CONSTANT CONSTANT
); );
...@@ -50,12 +50,12 @@ public: ...@@ -50,12 +50,12 @@ public:
ContactModel ( ContactModel (
const QString &username, const QString &username,
const QString &avatar, const QString &avatar,
const PresenceModel::Presence &presence, const Presence::PresenceStatus &presence_status,
const QStringList &sip_addresses const QStringList &sip_addresses
): ContactModel() { ): ContactModel () {
m_username = username; m_username = username;
m_avatar = avatar; m_avatar = avatar;
m_presence = presence; m_presence_status = presence_status;
m_sip_addresses = sip_addresses; m_sip_addresses = sip_addresses;
} }
...@@ -63,41 +63,21 @@ signals: ...@@ -63,41 +63,21 @@ signals:
void contactUpdated (); void contactUpdated ();
private: private:
QString getUsername () const { QString getUsername () const;
return m_username; void setUsername (const QString &username);
}
void setUsername (const QString &username) {
m_username = username;
}
QString getAvatar () const { QString getAvatar () const;
return m_avatar; void setAvatar (const QString &avatar);
}
void setAvatar (const QString &avatar) { Presence::PresenceStatus getPresenceStatus () const;
m_avatar = avatar; Presence::PresenceLevel getPresenceLevel () const;
}
PresenceModel::Presence getPresence () const { QStringList getSipAddresses () const;
return m_presence; void setSipAddresses (const QStringList &sip_addresses);
}
PresenceModel::PresenceLevel getPresenceLevel () const {
return PresenceModel::getPresenceLevel(m_presence);
}
QStringList getSipAddresses () const {
return m_sip_addresses;
}
void setSipAddresses (const QStringList &sip_addresses) {
m_sip_addresses = sip_addresses;
}
QString m_username; QString m_username;
QString m_avatar; QString m_avatar;
PresenceModel::Presence m_presence = PresenceModel::Online; Presence::PresenceStatus m_presence_status = Presence::Offline;
QStringList m_sip_addresses; QStringList m_sip_addresses;
}; };
......
...@@ -4,18 +4,18 @@ ...@@ -4,18 +4,18 @@
ContactsListModel::ContactsListModel (QObject *parent): QAbstractListModel(parent) { ContactsListModel::ContactsListModel (QObject *parent): QAbstractListModel(parent) {
// TMP. // TMP.
m_list << new ContactModel("Toto Roi", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Toto Roi", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Mary Boreno", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Mary Boreno", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Cecelia Cyler", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Cecelia Cyler", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Daniel Elliott", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Daniel Elliott", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Effie Forton", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Effie Forton", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Agnes Hurner", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Agnes Hurner", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Luke Lemin", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Luke Lemin", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Claire Manning", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Claire Manning", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Isabella Ahornton", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Isabella Ahornton", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Mary Boreno", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Mary Boreno", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel("Aman Than", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel("Aman Than", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
m_list << new ContactModel(" abdoul", "", PresenceModel::Online, QStringList("toto.linphone.sip.linphone.org")); m_list << new ContactModel(" abdoul", "", Presence::Online, QStringList("toto.linphone.sip.linphone.org"));
} }
......
#ifndef PRESENCE_MODEL_H_ #ifndef PRESENCE_H_
#define PRESENCE_MODEL_H_ #define PRESENCE_H_
#include <QObject> #include <QObject>
// =================================================================== // ===================================================================
class PresenceModel : public QObject { class Presence : public QObject {
Q_OBJECT; Q_OBJECT;
public: public:
enum Presence { enum PresenceStatus {
Online, Online,
BeRightBack, BeRightBack,
Away, Away,
...@@ -20,7 +20,7 @@ public: ...@@ -20,7 +20,7 @@ public:
UsingAnotherMessagingService, UsingAnotherMessagingService,
Offline Offline
}; };
Q_ENUM(Presence); Q_ENUM(PresenceStatus);
enum PresenceLevel { enum PresenceLevel {
Green, Green,
...@@ -30,18 +30,18 @@ public: ...@@ -30,18 +30,18 @@ public:
}; };
Q_ENUM(PresenceLevel); Q_ENUM(PresenceLevel);
PresenceModel (QObject *parent = Q_NULLPTR) { } Presence (QObject *parent = Q_NULLPTR): QObject(parent) { }
static PresenceLevel getPresenceLevel (const Presence &presence) { static PresenceLevel getPresenceLevel (const PresenceStatus &presenceStatus) {
if (presence == Online) if (presenceStatus == Online)
return Green; return Green;
if (presence == DoNotDisturb) if (presenceStatus == DoNotDisturb)
return Red; return Red;
if (presence == Offline) if (presenceStatus == Offline)
return White; return White;
return Orange; return Orange;
} }
}; };
#endif // PRESENCE_MODEL_H_ #endif // PRESENCE_H_
#include <cstdlib>
#include <QMenu> #include <QMenu>
#include <QQmlApplicationEngine> #include <QQmlApplicationEngine>
...@@ -10,8 +9,6 @@ ...@@ -10,8 +9,6 @@
#include "app.hpp" #include "app.hpp"
#include "components/contacts/ContactsListProxyModel.hpp" #include "components/contacts/ContactsListProxyModel.hpp"
#include "components/contacts/ContactsListModel.hpp"
#include "components/notification/Notification.hpp" #include "components/notification/Notification.hpp"
// =================================================================== // ===================================================================
...@@ -50,7 +47,7 @@ void setTrayIcon (QQmlApplicationEngine &engine) { ...@@ -50,7 +47,7 @@ void setTrayIcon (QQmlApplicationEngine &engine) {
} }
void registerTypes () { void registerTypes () {
qmlRegisterUncreatableType<PresenceModel>( qmlRegisterUncreatableType<Presence>(
"Linphone", 1, 0, "Presence", "Presence is uncreatable" "Linphone", 1, 0, "Presence", "Presence is uncreatable"
); );
...@@ -62,7 +59,6 @@ void addContextProperties (QQmlApplicationEngine &engine) { ...@@ -62,7 +59,6 @@ void addContextProperties (QQmlApplicationEngine &engine) {
QQmlContext *context = engine.rootContext(); QQmlContext *context = engine.rootContext();
context->setContextProperty("Notification", new Notification()); context->setContextProperty("Notification", new Notification());
context->setContextProperty("ContactsListModel", new ContactsListProxyModel());
} }
int main (int argc, char *argv[]) { int main (int argc, char *argv[]) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment