1 /***************************************************************************
2 * Copyright (C) 2005-08 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 "aliasesmodel.h"
24 #include <QStringList>
27 #include "signalproxy.h"
29 AliasesModel::AliasesModel(QObject *parent)
30 : QAbstractItemModel(parent),
33 // we need this signal for future connects to reset the data;
34 connect(Client::instance(), SIGNAL(connected()), this, SLOT(clientConnected()));
35 connect(Client::instance(), SIGNAL(disconnected()), this, SLOT(clientDisconnected()));
36 if(Client::isConnected())
39 emit modelReady(false);
42 QVariant AliasesModel::data(const QModelIndex &index, int role) const {
43 if(!index.isValid() || index.row() >= rowCount() || index.column() >= columnCount())
48 switch(index.column()) {
50 return "<b>The shortcut for the alias</b><br />"
51 "It can be used as a regular slash command.<br /><br />"
52 "<b>Example:</b> \"foo\" can be used per /foo";
54 return "<b>The string the shortcut will be expanded to</b><br />"
55 "<b>special variables:</b><br />"
56 " - <b>$i</b> represenents the i'th parameter.<br />"
57 " - <b>$0</b> the whole string.<br />"
58 " - <b>$currentnick</b> your current nickname<br />"
59 " - <b>$channelname</b> the name of the selected channel<br /><br />"
60 "Multiple commands can be separated with semicolons<br /><br />"
61 "<b>Example:</b> \"Test $1; Test $2; Test All $0\" will be expanded to three separate messages \"Test 1\", \"Test 2\" and \"Test All 1 2 3\" when called like /test 1 2 3";
67 switch(index.column()) {
69 return aliasManager()[index.row()].name;
71 return aliasManager()[index.row()].expansion;
80 bool AliasesModel::setData(const QModelIndex &index, const QVariant &value, int role) {
81 if(!index.isValid() || index.row() >= rowCount() || index.column() >= columnCount() || role != Qt::EditRole)
84 QString newValue = value.toString();
85 if(newValue.isEmpty())
88 switch(index.column()) {
90 if(aliasManager().contains(newValue)) {
93 cloneAliasManager()[index.row()].name = newValue;
97 cloneAliasManager()[index.row()].expansion = newValue;
104 void AliasesModel::newAlias() {
105 QString newName("alias");
107 AliasManager &manager = cloneAliasManager();
108 while(manager.contains(newName)) {
110 newName = QString("alias%1").arg(i);
112 beginInsertRows(QModelIndex(), rowCount(), rowCount());
113 manager.addAlias(newName, "Expansion");
117 void AliasesModel::removeAlias(int index) {
118 if(index < 0 || index >= rowCount())
121 AliasManager &manager = cloneAliasManager();
122 beginRemoveRows(QModelIndex(), index, index);
123 manager.removeAt(index);
127 Qt::ItemFlags AliasesModel::flags(const QModelIndex &index) const {
128 if(!index.isValid()) {
129 return Qt::ItemIsDropEnabled;
131 return Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable;
136 QVariant AliasesModel::headerData(int section, Qt::Orientation orientation, int role) const {
138 header << tr("Alias")
141 if(orientation == Qt::Horizontal && role == Qt::DisplayRole)
142 return header[section];
147 QModelIndex AliasesModel::index(int row, int column, const QModelIndex &parent) const {
149 if(row >= rowCount() || column >= columnCount())
150 return QModelIndex();
152 return createIndex(row, column);
156 const AliasManager &AliasesModel::aliasManager() const {
158 return _clonedAliasManager;
160 return _aliasManager;
163 AliasManager &AliasesModel::aliasManager() {
165 return _clonedAliasManager;
167 return _aliasManager;
170 AliasManager &AliasesModel::cloneAliasManager() {
171 if(!_configChanged) {
172 _clonedAliasManager = _aliasManager;
173 _configChanged = true;
174 emit configChanged(true);
176 return _clonedAliasManager;
179 void AliasesModel::revert() {
183 _configChanged = false;
184 emit configChanged(false);
188 void AliasesModel::commit() {
192 _aliasManager.requestUpdate(_clonedAliasManager.toVariantMap());
196 void AliasesModel::initDone() {
198 emit modelReady(true);
201 void AliasesModel::clientConnected() {
202 _aliasManager = AliasManager();
203 Client::signalProxy()->synchronize(&_aliasManager);
204 connect(&_aliasManager, SIGNAL(initDone()), this, SLOT(initDone()));
205 connect(&_aliasManager, SIGNAL(updated(const QVariantMap &)), this, SLOT(revert()));
208 void AliasesModel::clientDisconnected() {
209 // clear alias managers
210 _aliasManager = AliasManager();
211 _clonedAliasManager = AliasManager();
213 emit modelReady(false);