ui.ownNick->setSizeAdjustPolicy(QComboBox::AdjustToContents);
ui.ownNick->installEventFilter(new MouseWheelFilter(this));
ui.inputEdit->installEventFilter(new JumpKeyHandler(this));
+ ui.inputEdit->installEventFilter(this);
ui.inputEdit->setMinHeight(1);
ui.inputEdit->setMaxHeight(5);
ui.inputEdit->setMode(MultiLineEdit::MultiLine);
+ ui.inputEdit->setPasteProtectionEnabled(true);
new TabCompleter(ui.inputEdit);
s.notify("MaxNumLines", this, SLOT(setMaxLines(QVariant)));
setMaxLines(s.value("MaxNumLines", 5));
- s.notify("EnableScrollBars", this, SLOT(setEnableScrollBars(QVariant)));
- setEnableScrollBars(s.value("EnableScrollBars", true));
+ s.notify("EnableScrollBars", this, SLOT(setScrollBarsEnabled(QVariant)));
+ setScrollBarsEnabled(s.value("EnableScrollBars", true));
+
+ s.notify("EnableMultiLine", this, SLOT(setMultiLineEnabled(QVariant)));
+ setMultiLineEnabled(s.value("EnableMultiLine", true));
ActionCollection *coll = QtUi::actionCollection();
ui.inputEdit->setMaxHeight(v.toInt());
}
-void InputWidget::setEnableScrollBars(const QVariant &v) {
+void InputWidget::setScrollBarsEnabled(const QVariant &v) {
ui.inputEdit->setScrollBarsEnabled(v.toBool());
}
+void InputWidget::setMultiLineEnabled(const QVariant &v) {
+ ui.inputEdit->setMode(v.toBool()? MultiLineEdit::MultiLine : MultiLineEdit::SingleLine);
+}
+
bool InputWidget::eventFilter(QObject *watched, QEvent *event) {
if(event->type() != QEvent::KeyPress)
return false;
+ QKeyEvent *keyEvent = static_cast<QKeyEvent*>(event);
+
// keys from BufferView should be sent to (and focus) the input line
BufferView *view = qobject_cast<BufferView *>(watched);
if(view) {
- QKeyEvent *keyEvent = static_cast<QKeyEvent*>(event);
if(keyEvent->text().length() == 1 && !(keyEvent->modifiers() & (Qt::ControlModifier ^ Qt::AltModifier)) ) { // normal key press
QChar c = keyEvent->text().at(0);
if(c.isLetterOrNumber() || c.isSpace() || c.isPunct() || c.isSymbol()) {
setFocus();
QCoreApplication::sendEvent(inputLine(), keyEvent);
return true;
- } else
- return false;
+ }
}
- }
- return false;
-}
-
-void InputWidget::keyPressEvent(QKeyEvent * event) {
- if(event->matches(QKeySequence::Find)) {
- QAction *act = GraphicalUi::actionCollection()->action("ToggleSearchBar");
- if(act) {
- act->toggle();
- return;
+ return false;
+ } else if(watched == ui.inputEdit) {
+ if(keyEvent->matches(QKeySequence::Find)) {
+ QAction *act = GraphicalUi::actionCollection()->action("ToggleSearchBar");
+ if(act) {
+ act->toggle();
+ return true;
+ }
}
+ return false;
}
- AbstractItemView::keyPressEvent(event);
+ return false;
}
void InputWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) {
if(!me->userModes().isEmpty())
nicks[nickIdx] += QString(" (+%1)").arg(me->userModes());
}
-
+
ui.ownNick->addItems(nicks);
if(me && me->isAway())