{
const auto userModel = UserModel::instance();
const auto id = userModel->findUserIdForAccount(account);
- UserModel::instance()->switchCurrentUser(id);
+ UserModel::instance()->setCurrentUserId(id);
emit Systray::instance()->showWindow();
}
setupContextMenu();
#endif
- connect(UserModel::instance(), &UserModel::newUserSelected,
- this, &Systray::slotNewUserSelected);
+ connect(UserModel::instance(), &UserModel::currentUserChanged,
+ this, &Systray::slotCurrentUserChanged);
connect(UserModel::instance(), &UserModel::addAccount,
this, &Systray::openAccountWizard);
}
}
-void Systray::slotNewUserSelected()
+void Systray::slotCurrentUserChanged()
{
if (_trayEngine) {
// Change ActivityModel
void isOpenChanged();
public slots:
- void slotNewUserSelected();
+ void slotCurrentUserChanged();
void forceWindowInit(QQuickWindow *window) const;
void positionWindowAtTray(QQuickWindow *window) const;
Accessible.role: Accessible.Button\r
Accessible.name: qsTr("Switch to account") + " " + name\r
\r
- onClicked: if (!isCurrentUser) {\r
- UserModel.switchCurrentUser(id)\r
- } else {\r
- accountMenu.close()\r
+ onClicked: {\r
+ UserModel.currentUserId = id;\r
+ accountMenu.close();\r
}\r
\r
background: Item {\r
}
}
-Q_INVOKABLE int UserModel::numUsers()
+int UserModel::numUsers()
{
return _users.size();
}
-Q_INVOKABLE int UserModel::currentUserId() const
+int UserModel::currentUserId() const
{
return _currentUserId;
}
-Q_INVOKABLE bool UserModel::isUserConnected(const int id)
+bool UserModel::isUserConnected(const int id)
{
if (id < 0 || id >= _users.size())
return false;
return _users[id]->avatar();
}
-Q_INVOKABLE QString UserModel::currentUserServer()
+QString UserModel::currentUserServer()
{
if (_currentUserId < 0 || _currentUserId >= _users.size())
return {};
endInsertRows();
ConfigFile cfg;
u->setNotificationRefreshInterval(cfg.notificationRefreshInterval());
- emit newUserSelected();
+ emit currentUserChanged();
}
}
return _currentUserId;
}
-Q_INVOKABLE void UserModel::openCurrentAccountLocalFolder()
+void UserModel::openCurrentAccountLocalFolder()
{
if (_currentUserId < 0 || _currentUserId >= _users.size())
return;
_users[_currentUserId]->openLocalFolder();
}
-Q_INVOKABLE void UserModel::openCurrentAccountTalk()
+void UserModel::openCurrentAccountTalk()
{
if (!currentUser())
return;
}
}
-Q_INVOKABLE void UserModel::openCurrentAccountServer()
+void UserModel::openCurrentAccountServer()
{
if (_currentUserId < 0 || _currentUserId >= _users.size())
return;
QDesktopServices::openUrl(url);
}
-Q_INVOKABLE void UserModel::switchCurrentUser(const int id)
+void UserModel::setCurrentUserId(const int id)
{
- if (_currentUserId < 0 || _currentUserId >= _users.size())
+ if (_currentUserId == id || _currentUserId < 0 || _currentUserId >= _users.size())
return;
_users[_currentUserId]->setCurrentUser(false);
_users[id]->setCurrentUser(true);
_currentUserId = id;
- emit newUserSelected();
+ emit currentUserChanged();
}
-Q_INVOKABLE void UserModel::login(const int id)
+void UserModel::login(const int id)
{
if (id < 0 || id >= _users.size())
return;
_users[id]->login();
}
-Q_INVOKABLE void UserModel::logout(const int id)
+void UserModel::logout(const int id)
{
if (id < 0 || id >= _users.size())
return;
_users[id]->logout();
}
-Q_INVOKABLE void UserModel::removeAccount(const int id)
+void UserModel::removeAccount(const int id)
{
if (id < 0 || id >= _users.size())
return;
}
if (_users[id]->isCurrentUser() && _users.count() > 1) {
- id == 0 ? switchCurrentUser(1) : switchCurrentUser(0);
+ id == 0 ? setCurrentUserId(1) : setCurrentUserId(0);
}
_users[id]->logout();
class UserModel : public QAbstractListModel
{
Q_OBJECT
- Q_PROPERTY(User* currentUser READ currentUser NOTIFY newUserSelected)
- Q_PROPERTY(int currentUserId READ currentUserId NOTIFY newUserSelected)
+ Q_PROPERTY(User* currentUser READ currentUser NOTIFY currentUserChanged)
+ Q_PROPERTY(int currentUserId READ currentUserId WRITE setCurrentUserId NOTIFY currentUserChanged)
public:
static UserModel *instance();
~UserModel() override = default;
int currentUserIndex();
int rowCount(const QModelIndex &parent = QModelIndex()) const override;
-
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
QImage avatarById(const int id);
int findUserIdForAccount(AccountState *account) const;
- Q_INVOKABLE void fetchCurrentActivityModel();
- Q_INVOKABLE void openCurrentAccountLocalFolder();
- Q_INVOKABLE void openCurrentAccountTalk();
- Q_INVOKABLE void openCurrentAccountServer();
Q_INVOKABLE int numUsers();
Q_INVOKABLE QString currentUserServer();
int currentUserId() const;
+
Q_INVOKABLE bool isUserConnected(const int id);
- Q_INVOKABLE void switchCurrentUser(const int id);
- Q_INVOKABLE void login(const int id);
- Q_INVOKABLE void logout(const int id);
- Q_INVOKABLE void removeAccount(const int id);
Q_INVOKABLE std::shared_ptr<OCC::UserStatusConnector> userStatusConnector(int id);
AccountAppList appList() const;
signals:
- Q_INVOKABLE void addAccount();
- Q_INVOKABLE void newUserSelected();
+ void addAccount();
+ void currentUserChanged();
+
+public slots:
+ void fetchCurrentActivityModel();
+ void openCurrentAccountLocalFolder();
+ void openCurrentAccountTalk();
+ void openCurrentAccountServer();
+ void setCurrentUserId(const int id);
+ void login(const int id);
+ void logout(const int id);
+ void removeAccount(const int id);
protected:
QHash<int, QByteArray> roleNames() const override;