an ability to change account, reconnection, error reporting

This commit is contained in:
Blue 2019-05-24 17:46:34 +03:00
parent 16f96c4f2b
commit 8432a574b9
12 changed files with 225 additions and 39 deletions

View file

@ -31,8 +31,9 @@ void Accounts::onAccountAccepted()
{
Account* acc = static_cast<Account*>(sender());
QMap<QString, QVariant> map = acc->value();
const Models::Account* mAcc = model->getAccount(m_ui->tableView->selectionModel()->selectedRows().at(0).row());
if (editing) {
emit changeAccount(map);
emit changeAccount(mAcc->getName(), map);
} else {
emit newAccount(map);
}

View file

@ -22,7 +22,7 @@ public:
signals:
void newAccount(const QMap<QString, QVariant>&);
void changeAccount(const QMap<QString, QVariant>&);
void changeAccount(const QString&, const QMap<QString, QVariant>&);
private slots:
void onAddButton(bool clicked = 0);

View file

@ -7,6 +7,7 @@ Models::Account::Account(const QMap<QString, QVariant>& data, Models::Item* pare
password(data.value("password").toString()),
server(data.value("server").toString()),
resource(data.value("resource").toString()),
error(data.value("error").toString()),
state(Shared::disconnected),
availability(Shared::offline)
{
@ -61,7 +62,7 @@ void Models::Account::setAvailability(Shared::Availability p_avail)
{
if (availability != p_avail) {
availability = p_avail;
changed(5);
changed(6);
}
}
@ -101,7 +102,7 @@ void Models::Account::setLogin(const QString& p_login)
{
if (login != p_login) {
login = p_login;
changed(3);
changed(4);
}
}
@ -109,7 +110,7 @@ void Models::Account::setPassword(const QString& p_password)
{
if (password != p_password) {
password = p_password;
changed(4);
changed(5);
}
}
@ -131,12 +132,14 @@ QVariant Models::Account::data(int column) const
case 2:
return Shared::connectionStateNames[state];
case 3:
return login;
return error;
case 4:
return password;
return login;
case 5:
return Shared::availabilityNames[availability];
return password;
case 6:
return Shared::availabilityNames[availability];
case 7:
return resource;
default:
return QVariant();
@ -145,7 +148,7 @@ QVariant Models::Account::data(int column) const
int Models::Account::columnCount() const
{
return 7;
return 8;
}
void Models::Account::update(const QString& field, const QVariant& value)
@ -164,6 +167,8 @@ void Models::Account::update(const QString& field, const QVariant& value)
setAvailability(value.toUInt());
} else if (field == "resource") {
setResource(value.toString());
} else if (field == "error") {
setError(value.toString());
}
}
@ -176,7 +181,20 @@ void Models::Account::setResource(const QString& p_resource)
{
if (resource != p_resource) {
resource = p_resource;
changed(6);
changed(7);
}
}
QString Models::Account::getError() const
{
return error;
}
void Models::Account::setError(const QString& p_resource)
{
if (error != p_resource) {
error = p_resource;
changed(3);
}
}

View file

@ -28,6 +28,9 @@ namespace Models {
void setResource(const QString& p_resource);
QString getResource() const;
void setError(const QString& p_resource);
QString getError() const;
void setAvailability(Shared::Availability p_avail);
void setAvailability(unsigned int p_avail);
Shared::Availability getAvailability() const;
@ -44,6 +47,7 @@ namespace Models {
QString password;
QString server;
QString resource;
QString error;
Shared::ConnectionState state;
Shared::Availability availability;
};

View file

@ -6,7 +6,8 @@
std::deque<QString> Models::Accounts::columns = {
"name",
"server",
"state"
"state",
"error"
};
Models::Accounts::Accounts(QObject* parent):

View file

@ -35,6 +35,7 @@ void Squawk::onAccounts()
accounts->setAttribute(Qt::WA_DeleteOnClose);
connect(accounts, SIGNAL(destroyed(QObject*)), this, SLOT(onAccountsClosed(QObject*)));
connect(accounts, SIGNAL(newAccount(const QMap<QString, QVariant>&)), this, SIGNAL(newAccountRequest(const QMap<QString, QVariant>&)));
connect(accounts, SIGNAL(changeAccount(const QString&, const QMap<QString, QVariant>&)), this, SIGNAL(modifyAccountRequest(const QString&, const QMap<QString, QVariant>&)));
accounts->show();
} else {
@ -96,14 +97,12 @@ void Squawk::onComboboxActivated(int index)
}
}
void Squawk::accountConnectionStateChanged(const QString& account, int state)
void Squawk::changeAccount(const QString& account, const QMap<QString, QVariant>& data)
{
rosterModel.updateAccount(account, "state", state);
}
void Squawk::accountAvailabilityChanged(const QString& account, int state)
{
rosterModel.updateAccount(account, "availability", state);
for (QMap<QString, QVariant>::const_iterator itr = data.begin(), end = data.end(); itr != end; ++itr) {
QString attr = itr.key();
rosterModel.updateAccount(account, attr, *itr);
}
}
void Squawk::addContact(const QString& account, const QString& jid, const QString& group, const QMap<QString, QVariant>& data)

View file

@ -28,6 +28,7 @@ public:
signals:
void newAccountRequest(const QMap<QString, QVariant>&);
void modifyAccountRequest(const QString&, const QMap<QString, QVariant>&);
void connectAccount(const QString&);
void disconnectAccount(const QString&);
void changeState(int state);
@ -36,8 +37,7 @@ signals:
public slots:
void newAccount(const QMap<QString, QVariant>& account);
void accountConnectionStateChanged(const QString& account, int state);
void accountAvailabilityChanged(const QString& account, int state);
void changeAccount(const QString& account, const QMap<QString, QVariant>& data);
void addGroup(const QString& account, const QString& name);
void removeGroup(const QString& account, const QString& name);
void addContact(const QString& account, const QString& jid, const QString& group, const QMap<QString, QVariant>& data);