#include <KIO/Global>
-KItemListRoleEditor::KItemListRoleEditor(QWidget *parent) :
- KTextEdit(parent),
- m_role(),
- m_blockFinishedSignal(false)
+KItemListRoleEditor::KItemListRoleEditor(QWidget *parent)
+ : KTextEdit(parent)
+ , m_role()
+ , m_blockFinishedSignal(false)
{
setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setAcceptRichText(false);
enableFindReplace(false);
document()->setDocumentMargin(0);
+ setCheckSpellingEnabled(false);
if (parent) {
parent->installEventFilter(this);
{
}
-void KItemListRoleEditor::setRole(const QByteArray& role)
+void KItemListRoleEditor::setRole(const QByteArray &role)
{
m_role = role;
}
m_allowUpDownKeyChainEdit = allowChainEdit;
}
-bool KItemListRoleEditor::eventFilter(QObject* watched, QEvent* event)
+bool KItemListRoleEditor::eventFilter(QObject *watched, QEvent *event)
{
if (watched == parentWidget() && event->type() == QEvent::Resize) {
emitRoleEditingFinished();
return KTextEdit::eventFilter(watched, event);
}
-bool KItemListRoleEditor::event(QEvent* event)
+bool KItemListRoleEditor::event(QEvent *event)
{
if (event->type() == QEvent::FocusOut) {
- QFocusEvent* focusEvent = static_cast<QFocusEvent*>(event);
+ QFocusEvent *focusEvent = static_cast<QFocusEvent *>(event);
if (focusEvent->reason() != Qt::PopupFocusReason) {
emitRoleEditingFinished();
}
return KTextEdit::event(event);
}
-void KItemListRoleEditor::keyPressEvent(QKeyEvent* event)
+void KItemListRoleEditor::keyPressEvent(QKeyEvent *event)
{
switch (event->key()) {
case Qt::Key_Escape:
event->accept();
return;
}
+ break;
case Qt::Key_Backtab:
case Qt::Key_Up:
if (m_allowUpDownKeyChainEdit || event->key() == Qt::Key_Backtab) {
event->accept();
return;
}
+ break;
case Qt::Key_Left:
case Qt::Key_Right: {
QTextCursor cursor = textCursor();
case Qt::Key_Home:
case Qt::Key_End: {
if (event->modifiers() == Qt::NoModifier || event->modifiers() == Qt::ShiftModifier) {
- const QTextCursor::MoveOperation op = event->key() == Qt::Key_Home
- ? QTextCursor::Start
- : QTextCursor::End;
- const QTextCursor::MoveMode mode = event->modifiers() == Qt::NoModifier
- ? QTextCursor::MoveAnchor
- : QTextCursor::KeepAnchor;
+ const QTextCursor::MoveOperation op = event->key() == Qt::Key_Home ? QTextCursor::Start : QTextCursor::End;
+ const QTextCursor::MoveMode mode = event->modifiers() == Qt::NoModifier ? QTextCursor::MoveAnchor : QTextCursor::KeepAnchor;
QTextCursor cursor = textCursor();
cursor.movePosition(op, mode);
setTextCursor(cursor);
{
const qreal frameBorder = 2 * frameWidth();
+ const auto originalSize = size();
+ auto newSize = originalSize;
+
+ document()->adjustSize();
const qreal requiredWidth = document()->size().width();
const qreal availableWidth = size().width() - frameBorder;
if (requiredWidth > availableWidth) {
if (parentWidget() && pos().x() + newWidth > parentWidget()->width()) {
newWidth = parentWidget()->width() - pos().x();
}
- resize(newWidth, size().height());
+ newSize.setWidth(newWidth);
}
const qreal requiredHeight = document()->size().height();
if (parentWidget() && pos().y() + newHeight > parentWidget()->height()) {
newHeight = parentWidget()->height() - pos().y();
}
- resize(size().width(), newHeight);
+ newSize.setHeight(newHeight);
+ }
+
+ if (originalSize != newSize) {
+ resize(newSize);
}
+ // reset the document width to the widget width
+ // to allow alignment to be properly rendered
+ document()->setTextWidth(newSize.width());
}
void KItemListRoleEditor::emitRoleEditingFinished(EditResultDirection direction)
{
QVariant ret;
- ret.setValue(EditResult {KIO::encodeFileName(toPlainText()), direction});
+ ret.setValue(EditResult{KIO::encodeFileName(toPlainText()), direction});
if (!m_blockFinishedSignal) {
Q_EMIT roleEditingFinished(m_role, ret);
}
}
+#include "moc_kitemlistroleeditor.cpp"