1 /***************************************************************************
2 * Copyright (C) 2009 by the Quassel Project *
3 * devel@quassel-irc.org *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) version 3. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the *
17 * Free Software Foundation, Inc., *
18 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
19 ***************************************************************************/
21 #include "coreaccountsettingspage.h"
24 #include "clientsettings.h"
25 #include "coreaccountmodel.h"
26 #include "iconloader.h"
28 CoreAccountSettingsPage::CoreAccountSettingsPage(QWidget *parent)
29 : SettingsPage(tr("Remote Cores"), QString(), parent),
31 _lastAutoConnectId(0),
36 ui.addAccountButton->setIcon(SmallIcon("list-add"));
37 ui.editAccountButton->setIcon(SmallIcon("document-edit"));
38 ui.deleteAccountButton->setIcon(SmallIcon("edit-delete"));
40 _model = new CoreAccountModel(Client::coreAccountModel(), this);
41 _filteredModel = new FilteredCoreAccountModel(_model, this);
43 ui.accountView->setModel(filteredModel());
44 ui.autoConnectAccount->setModel(filteredModel());
46 connect(filteredModel(), SIGNAL(rowsAboutToBeRemoved(QModelIndex, int, int)), SLOT(rowsAboutToBeRemoved(QModelIndex, int, int)));
47 connect(filteredModel(), SIGNAL(rowsInserted(QModelIndex, int, int)), SLOT(rowsInserted(QModelIndex, int, int)));
49 connect(ui.accountView->selectionModel(), SIGNAL(selectionChanged(QItemSelection, QItemSelection)), SLOT(setWidgetStates()));
50 connect(ui.autoConnectAccount, SIGNAL(currentIndexChanged(int)), SLOT(widgetHasChanged()));
54 void CoreAccountSettingsPage::setStandAlone(bool standalone) {
55 _standalone = standalone;
58 void CoreAccountSettingsPage::load() {
59 model()->update(Client::coreAccountModel());
62 CoreAccountSettings s;
64 if(Quassel::runMode() != Quassel::Monolithic) {
65 // make sure we don't have selected the internal account as autoconnect account
67 if(s.autoConnectOnStartup() && s.autoConnectToFixedAccount()) {
68 CoreAccount acc = model()->account(s.autoConnectAccount());
70 ui.autoConnectOnStartup->setChecked(false);
73 ui.accountView->setCurrentIndex(filteredModel()->index(0, 0));
74 ui.accountView->selectionModel()->select(filteredModel()->index(0, 0), QItemSelectionModel::Select);
76 QModelIndex idx = filteredModel()->mapFromSource(model()->accountIndex(s.autoConnectAccount()));
77 ui.autoConnectAccount->setCurrentIndex(idx.isValid() ? idx.row() : 0);
78 ui.autoConnectAccount->setProperty("storedValue", ui.autoConnectAccount->currentIndex());
82 void CoreAccountSettingsPage::save() {
84 Client::coreAccountModel()->update(model());
85 Client::coreAccountModel()->save();
86 CoreAccountSettings s;
87 AccountId id = filteredModel()->index(ui.autoConnectAccount->currentIndex(), 0).data(CoreAccountModel::AccountIdRole).value<AccountId>();
88 s.setAutoConnectAccount(id);
89 ui.autoConnectAccount->setProperty("storedValue", ui.autoConnectAccount->currentIndex());
92 // TODO: Qt 4.6 - replace by proper rowsMoved() semantics
93 // NOTE: This is the filtered model
94 void CoreAccountSettingsPage::rowsAboutToBeRemoved(const QModelIndex &index, int start, int end) {
95 _lastAutoConnectId = _lastAccountId = 0;
96 if(index.isValid() || start != end)
99 // the current index is removed, so remember it in case it's reinserted immediately afterwards
100 AccountId id = filteredModel()->index(start, 0).data(CoreAccountModel::AccountIdRole).value<AccountId>();
101 if(start == ui.accountView->currentIndex().row())
103 if(start == ui.autoConnectAccount->currentIndex())
104 _lastAutoConnectId = id;
107 void CoreAccountSettingsPage::rowsInserted(const QModelIndex &index, int start, int end) {
108 if(index.isValid() || start != end)
111 // check if the inserted index was just removed and select it in that case
112 AccountId id = filteredModel()->index(start, 0).data(CoreAccountModel::AccountIdRole).value<AccountId>();
113 if(id == _lastAccountId)
114 ui.accountView->setCurrentIndex(filteredModel()->index(start, 0));
115 if(id == _lastAutoConnectId)
116 ui.autoConnectAccount->setCurrentIndex(start);
117 _lastAccountId = _lastAutoConnectId = 0;
120 AccountId CoreAccountSettingsPage::selectedAccount() const {
121 QModelIndex index = ui.accountView->currentIndex();
124 return index.data(CoreAccountModel::AccountIdRole).value<AccountId>();
127 void CoreAccountSettingsPage::setSelectedAccount(AccountId accId) {
128 QModelIndex index = filteredModel()->mapFromSource(model()->accountIndex(accId));
130 ui.accountView->setCurrentIndex(index);
133 void CoreAccountSettingsPage::on_addAccountButton_clicked() {
134 CoreAccountEditDlg dlg(CoreAccount(), this);
135 if(dlg.exec() == QDialog::Accepted) {
136 AccountId id =model()->createOrUpdateAccount(dlg.account());
137 ui.accountView->setCurrentIndex(filteredModel()->mapFromSource(model()->accountIndex(id)));
142 void CoreAccountSettingsPage::on_editAccountButton_clicked() {
143 QModelIndex idx = ui.accountView->selectionModel()->currentIndex();
150 void CoreAccountSettingsPage::editAccount(const QModelIndex &index) {
154 CoreAccountEditDlg dlg(model()->account(filteredModel()->mapToSource(index)), this);
155 if(dlg.exec() == QDialog::Accepted) {
156 AccountId id = model()->createOrUpdateAccount(dlg.account());
157 ui.accountView->setCurrentIndex(filteredModel()->mapFromSource(model()->accountIndex(id)));
162 void CoreAccountSettingsPage::on_deleteAccountButton_clicked() {
163 if(!ui.accountView->selectionModel()->selectedIndexes().count())
166 AccountId id = ui.accountView->selectionModel()->selectedIndexes().at(0).data(CoreAccountModel::AccountIdRole).value<AccountId>();
168 model()->removeAccount(id);
173 void CoreAccountSettingsPage::on_accountView_doubleClicked(const QModelIndex &index) {
178 emit connectToCore(index.data(CoreAccountModel::AccountIdRole).value<AccountId>());
183 void CoreAccountSettingsPage::setWidgetStates() {
184 AccountId accId = selectedAccount();
185 bool editable = accId.isValid() && accId != model()->internalAccount();
187 ui.editAccountButton->setEnabled(editable);
188 ui.deleteAccountButton->setEnabled(editable);
191 void CoreAccountSettingsPage::widgetHasChanged() {
192 setChangedState(testHasChanged());
196 bool CoreAccountSettingsPage::testHasChanged() {
197 if(ui.autoConnectAccount->currentIndex() != ui.autoConnectAccount->property("storedValue").toInt())
199 if(!(*model() == *Client::coreAccountModel()))
205 /*****************************************************************************************
207 *****************************************************************************************/
208 CoreAccountEditDlg::CoreAccountEditDlg(const CoreAccount &acct, QWidget *parent)
215 ui.hostName->setText(acct.hostName());
216 ui.port->setValue(acct.port());
217 ui.accountName->setText(acct.accountName());
218 ui.user->setText(acct.user());
219 ui.password->setText(acct.password());
220 ui.rememberPassword->setChecked(acct.storePassword());
221 ui.useProxy->setChecked(acct.useProxy());
222 ui.proxyHostName->setText(acct.proxyHostName());
223 ui.proxyPort->setValue(acct.proxyPort());
224 ui.proxyType->setCurrentIndex(acct.proxyType() == QNetworkProxy::Socks5Proxy ? 0 : 1);
225 ui.proxyUser->setText(acct.proxyUser());
226 ui.proxyPassword->setText(acct.proxyPassword());
228 if(acct.accountId().isValid())
229 setWindowTitle(tr("Edit Core Account"));
231 setWindowTitle(tr("Add Core Account"));
234 CoreAccount CoreAccountEditDlg::account() {
235 _account.setAccountName(ui.accountName->text().trimmed());
236 _account.setHostName(ui.hostName->text().trimmed());
237 _account.setPort(ui.port->value());
238 _account.setUser(ui.user->text().trimmed());
239 _account.setPassword(ui.password->text());
240 _account.setStorePassword(ui.rememberPassword->isChecked());
241 _account.setUseProxy(ui.useProxy->isChecked());
242 _account.setProxyHostName(ui.proxyHostName->text().trimmed());
243 _account.setProxyPort(ui.proxyPort->value());
244 _account.setProxyType(ui.proxyType->currentIndex() == 0 ? QNetworkProxy::Socks5Proxy : QNetworkProxy::HttpProxy);
245 _account.setProxyUser(ui.proxyUser->text().trimmed());
246 _account.setProxyPassword(ui.proxyPassword->text());
250 void CoreAccountEditDlg::setWidgetStates() {
251 bool ok = !ui.accountName->text().trimmed().isEmpty()
252 && !ui.user->text().trimmed().isEmpty()
253 && !ui.hostName->text().isEmpty();
254 ui.buttonBox->button(QDialogButtonBox::Ok)->setEnabled(ok);
257 void CoreAccountEditDlg::on_hostName_textChanged(const QString &text) {
262 void CoreAccountEditDlg::on_accountName_textChanged(const QString &text) {
267 void CoreAccountEditDlg::on_user_textChanged(const QString &text) {
272 /*****************************************************************************************
273 * FilteredCoreAccountModel
274 *****************************************************************************************/
276 FilteredCoreAccountModel::FilteredCoreAccountModel(CoreAccountModel *model, QObject *parent) : QSortFilterProxyModel(parent) {
277 _internalAccount = model->internalAccount();
278 setSourceModel(model);
281 bool FilteredCoreAccountModel::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const {
282 if(Quassel::runMode() == Quassel::Monolithic)
285 if(!_internalAccount.isValid())
288 return _internalAccount != sourceModel()->index(source_row, 0, source_parent).data(CoreAccountModel::AccountIdRole).value<AccountId>();