#include "client.h"
#include "networkmodel.h"
#include "jumpkeyhandler.h"
+#include "qtuisettings.h"
InputWidget::InputWidget(QWidget *parent)
- : QWidget(parent),
- validBuffer(false),
- _bufferModel(0),
- _selectionModel(0)
+ : AbstractItemView(parent),
+ _networkId(0)
{
ui.setupUi(this);
connect(ui.inputEdit, SIGNAL(sendText(QString)), this, SLOT(sendText(QString)));
connect(this, SIGNAL(userInput(BufferInfo, QString)), Client::instance(), SIGNAL(sendInput(BufferInfo, QString)));
setFocusProxy(ui.inputEdit);
+ ui.ownNick->setSizeAdjustPolicy(QComboBox::AdjustToContents);
ui.ownNick->installEventFilter(new MouseWheelFilter(this));
- ui.inputEdit->installEventFilter(new JumpKeyHandler(this));
-}
-
-InputWidget::~InputWidget() {
-}
+ ui.inputEdit->installEventFilter(new JumpKeyHandler(this));
-void InputWidget::setModel(BufferModel *bufferModel) {
- if(_bufferModel) {
- disconnect(_bufferModel, 0, this, 0);
+ QtUiSettings s;
+ bool useInputLineFont = s.value("UseInputLineFont", QVariant(false)).toBool();
+ if(useInputLineFont) {
+ ui.inputEdit->setFont(s.value("InputLineFont").value<QFont>());
}
- _bufferModel = bufferModel;
- connect(bufferModel, SIGNAL(dataChanged(QModelIndex, QModelIndex)),
- this, SLOT(dataChanged(QModelIndex, QModelIndex)));
}
-void InputWidget::setSelectionModel(QItemSelectionModel *selectionModel) {
- if(_selectionModel) {
- disconnect(_selectionModel, 0, this, 0);
- }
- _selectionModel = selectionModel;
- connect(selectionModel, SIGNAL(currentChanged(QModelIndex, QModelIndex)),
- this, SLOT(currentChanged(QModelIndex, QModelIndex)));
+InputWidget::~InputWidget() {
}
void InputWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) {
- Q_UNUSED(previous);
-
- validBuffer = current.isValid();
-
- if(!validBuffer)
- return;
-
- QVariant variant;
- variant = current.data(NetworkModel::BufferInfoRole);
- if(!variant.isValid())
+ if(current.data(NetworkModel::BufferInfoRole) == previous.data(NetworkModel::BufferInfoRole))
return;
- currentBufferInfo = current.data(NetworkModel::BufferInfoRole).value<BufferInfo>();
setNetwork(Client::networkModel()->networkByIndex(current));
updateNickSelector();
ui.inputEdit->setEnabled(current.data(NetworkModel::ItemActiveRole).value<bool>());
void InputWidget::dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight) {
QItemSelectionRange changedArea(topLeft, bottomRight);
- QModelIndex currentIndex = Client::bufferModel()->currentIndex();
+ QModelIndex currentIndex = selectionModel()->currentIndex();
if(changedArea.contains(currentIndex)) {
ui.inputEdit->setEnabled(currentIndex.data(NetworkModel::ItemActiveRole).value<bool>());
}
const Network *InputWidget::currentNetwork() const {
- if(!validBuffer)
- return 0;
-
return Client::network(_networkId);
}
+BufferInfo InputWidget::currentBufferInfo() const {
+ return selectionModel()->currentIndex().data(NetworkModel::BufferInfoRole).value<BufferInfo>();
+};
+
void InputWidget::setNetwork(const Network *network) {
if(!network || _networkId == network->networkId())
return;
}
if(net->me() && nickIdx < nicks.count())
- nicks[nickIdx] = net->myNick() + QString(" (%1)").arg(net->me()->userModes());
+ nicks[nickIdx] = net->myNick() + QString(" (+%1)").arg(net->me()->userModes());
ui.ownNick->addItems(nicks);
ui.ownNick->setCurrentIndex(nickIdx);
const Network *net = currentNetwork();
if(!net || net->isMyNick(newNick))
return;
- emit userInput(currentBufferInfo, QString("/nick %1").arg(newNick));
+ emit userInput(currentBufferInfo(), QString("/nick %1").arg(newNick));
}
void InputWidget::sendText(QString text) {
- emit userInput(currentBufferInfo, text);
+ emit userInput(currentBufferInfo(), text);
}