X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fclientsettings.cpp;h=3a1dbd88116a896699149fbae00f9c4e30e2c549;hb=1e626e57b97756088052bcd88a29305dd7412f58;hp=1fd1efbec2f77bdfb6f6281874a0314a00ff1807;hpb=28e33cd3255a838a045303bed073f4f9c40a3af4;p=quassel.git diff --git a/src/client/clientsettings.cpp b/src/client/clientsettings.cpp index 1fd1efbe..3a1dbd88 100644 --- a/src/client/clientsettings.cpp +++ b/src/client/clientsettings.cpp @@ -25,67 +25,104 @@ #include ClientSettings::ClientSettings(QString g) : Settings(g, Global::clientApplicationName) { - - } ClientSettings::~ClientSettings() { - - } /***********************************************************************************************/ -CoreAccountSettings::CoreAccountSettings() : ClientSettings("CoreAccounts") { +CoreAccountSettings::CoreAccountSettings(const QString &subgroup) : ClientSettings("CoreAccounts") { + _subgroup = subgroup; +} +QList CoreAccountSettings::knownAccounts() { + QList ids; + foreach(QString key, localChildGroups()) { + AccountId acc = key.toInt(); + if(acc.isValid()) ids << acc; + } + return ids; +} +AccountId CoreAccountSettings::lastAccount() { + return localValue("LastAccount", 0).toInt(); } -QStringList CoreAccountSettings::knownAccounts() { - return localChildKeys("Accounts"); +void CoreAccountSettings::setLastAccount(AccountId account) { + setLocalValue("LastAccount", account.toInt()); } -QString CoreAccountSettings::lastAccount() { - return localValue("LastAccount", "").toString(); +AccountId CoreAccountSettings::autoConnectAccount() { + return localValue("AutoConnectAccount", 0).toInt(); } -void CoreAccountSettings::setLastAccount(const QString &account) { - setLocalValue("LastAccount", account); +void CoreAccountSettings::setAutoConnectAccount(AccountId account) { + setLocalValue("AutoConnectAccount", account.toInt()); } -QString CoreAccountSettings::autoConnectAccount() { - return localValue("AutoConnectAccount", "").toString(); +void CoreAccountSettings::storeAccountData(AccountId id, const QVariantMap &data) { + setLocalValue(QString("%1/Connection").arg(id.toInt()), data); } -void CoreAccountSettings::setAutoConnectAccount(const QString &account) { - setLocalValue("AutoConnectAccount", account); +QVariantMap CoreAccountSettings::retrieveAccountData(AccountId id) { + return localValue(QString("%1/Connection").arg(id.toInt()), QVariant()).toMap(); } -void CoreAccountSettings::storeAccount(const QString name, const QVariantMap &data) { - setLocalValue(QString("Accounts/%2").arg(name), data); +void CoreAccountSettings::setAccountValue(const QString &key, const QVariant &value) { + if(!Client::currentCoreAccount().isValid()) return; + setLocalValue(QString("%1/%2/%3").arg(Client::currentCoreAccount().toInt()).arg(_subgroup).arg(key), value); } -QVariantMap CoreAccountSettings::retrieveAccount(const QString &name) { - return localValue(QString("Accounts/%2").arg(name), QVariant()).toMap(); +QVariant CoreAccountSettings::accountValue(const QString &key, const QVariant &def) { + if(!Client::currentCoreAccount().isValid()) return QVariant(); + return localValue(QString("%1/%2/%3").arg(Client::currentCoreAccount().toInt()).arg(_subgroup).arg(key), def); } -void CoreAccountSettings::storeAllAccounts(const QHash accounts) { - removeLocalKey(QString("Accounts")); - foreach(QString name, accounts.keys()) { - storeAccount(name, accounts[name]); +void CoreAccountSettings::setJumpKeyMap(const QHash &keyMap) { + QVariantMap variants; + QHash::const_iterator mapIter = keyMap.constBegin(); + while(mapIter != keyMap.constEnd()) { + variants[QString::number(mapIter.key())] = qVariantFromValue(mapIter.value()); + mapIter++; } + setLocalValue("JumpKeyMap", variants); } -QHash CoreAccountSettings::retrieveAllAccounts() { - QHash accounts; - foreach(QString name, knownAccounts()) { - accounts[name] = retrieveAccount(name); +QHash CoreAccountSettings::jumpKeyMap() { + QHash keyMap; + QVariantMap variants = localValue("JumpKeyMap", QVariant()).toMap(); + QVariantMap::const_iterator mapIter = variants.constBegin(); + while(mapIter != variants.constEnd()) { + keyMap[mapIter.key().toInt()] = mapIter.value().value(); + mapIter++; } - return accounts; + return keyMap; +} + +void CoreAccountSettings::removeAccount(AccountId id) { + removeLocalKey(QString("%1").arg(id.toInt())); } -void CoreAccountSettings::removeAccount(const QString &account) { - removeLocalKey(QString("Accounts/%1").arg(account)); + +/***********************************************************************************************/ +// NotificationSettings: + +NotificationSettings::NotificationSettings() : ClientSettings("Notification") { } +void NotificationSettings::setHighlightList(const QVariantList &highlightList) { + setLocalValue("highlightList", highlightList); +} +QVariantList NotificationSettings::highlightList() { + return localValue("highlightList").toList(); +} + +void NotificationSettings::setHighlightNick(NotificationSettings::HighlightNickType highlightNickType) { + setLocalValue("highlightNick", highlightNickType); +} + +NotificationSettings::HighlightNickType NotificationSettings::highlightNick() { + return (NotificationSettings::HighlightNickType) localValue("highlightNick", CurrentNick).toInt(); +}