Pasteable textinput

This commit is contained in:
Nicolas Werner 2020-10-31 23:24:07 +01:00
parent 35066900d1
commit 7a74b86340
7 changed files with 104 additions and 3 deletions

View File

@ -252,6 +252,7 @@ set(SRC_FILES
# Timeline # Timeline
src/timeline/EventStore.cpp src/timeline/EventStore.cpp
src/timeline/InputBar.cpp
src/timeline/Reaction.cpp src/timeline/Reaction.cpp
src/timeline/TimelineViewManager.cpp src/timeline/TimelineViewManager.cpp
src/timeline/TimelineModel.cpp src/timeline/TimelineModel.cpp
@ -463,6 +464,7 @@ qt5_wrap_cpp(MOC_HEADERS
# Timeline # Timeline
src/timeline/EventStore.h src/timeline/EventStore.h
src/timeline/InputBar.h
src/timeline/Reaction.h src/timeline/Reaction.h
src/timeline/TimelineViewManager.h src/timeline/TimelineViewManager.h
src/timeline/TimelineModel.h src/timeline/TimelineModel.h

View File

@ -3,6 +3,8 @@ import QtQuick.Controls 2.3
import QtQuick.Layouts 1.2 import QtQuick.Layouts 1.2
import QtQuick.Window 2.2 import QtQuick.Window 2.2
import im.nheko 1.0
Rectangle { Rectangle {
color: colors.window color: colors.window
Layout.fillWidth: true Layout.fillWidth: true
@ -44,16 +46,36 @@ Rectangle {
Layout.fillWidth: true Layout.fillWidth: true
TextArea { TextArea {
id: textArea
placeholderText: qsTr("Write a message...") placeholderText: qsTr("Write a message...")
placeholderTextColor: colors.buttonText placeholderTextColor: colors.buttonText
color: colors.text color: colors.text
wrapMode: TextEdit.Wrap wrapMode: TextEdit.Wrap
onTextChanged: TimelineManager.timeline.input.updateState(selectionStart, selectionEnd, cursorPosition, text)
onCursorPositionChanged: TimelineManager.timeline.input.updateState(selectionStart, selectionEnd, cursorPosition, text)
onSelectionStartChanged: TimelineManager.timeline.input.updateState(selectionStart, selectionEnd, cursorPosition, text)
onSelectionEndChanged: TimelineManager.timeline.input.updateState(selectionStart, selectionEnd, cursorPosition, text)
Keys.onPressed: {
if (event.matches(StandardKey.Paste)) {
TimelineManager.timeline.input.paste(false) || textArea.paste()
event.accepted = true
}
else if (event.matches(StandardKey.InsertParagraphSeparator)) {
TimelineManager.timeline.input.send()
textArea.clear()
event.accepted = true
}
}
MouseArea { MouseArea {
// workaround for wrong cursor shape on some platforms // workaround for wrong cursor shape on some platforms
anchors.fill: parent anchors.fill: parent
acceptedButtons: Qt.NoButton acceptedButtons: Qt.MiddleButton
cursorShape: Qt.IBeamCursor cursorShape: Qt.IBeamCursor
onClicked: TimelineManager.timeline.input.paste(true) || textArea.paste()
} }
background: Rectangle { background: Rectangle {

View File

@ -234,8 +234,8 @@ Page {
ReplyPopup { ReplyPopup {
} }
//MessageInput { MessageInput {
//} }
} }

46
src/timeline/InputBar.cpp Normal file
View File

@ -0,0 +1,46 @@
#include "InputBar.h"
#include <QClipboard>
#include <QGuiApplication>
#include <QMimeData>
#include "Logging.h"
bool
InputBar::paste(bool fromMouse)
{
const QMimeData *md = nullptr;
if (fromMouse) {
if (QGuiApplication::clipboard()->supportsSelection()) {
md = QGuiApplication::clipboard()->mimeData(QClipboard::Selection);
}
} else {
md = QGuiApplication::clipboard()->mimeData(QClipboard::Clipboard);
}
if (!md)
return false;
if (md->hasImage()) {
return true;
} else {
nhlog::ui()->debug("formats: {}", md->formats().join(", ").toStdString());
return false;
}
}
void
InputBar::updateState(int selectionStart_, int selectionEnd_, int cursorPosition_, QString text_)
{
selectionStart = selectionStart_;
selectionEnd = selectionEnd_;
cursorPosition = cursorPosition_;
text = text_;
}
void
InputBar::send()
{
nhlog::ui()->debug("Send: {}", text.toStdString());
}

25
src/timeline/InputBar.h Normal file
View File

@ -0,0 +1,25 @@
#pragma once
#include <QObject>
class TimelineModel;
class InputBar : public QObject {
Q_OBJECT
public:
InputBar(TimelineModel *parent)
: QObject()
, room(parent)
{}
public slots:
void send();
bool paste(bool fromMouse);
void updateState(int selectionStart, int selectionEnd, int cursorPosition, QString text);
private:
TimelineModel *room;
QString text;
int selectionStart = 0, selectionEnd = 0, cursorPosition = 0;
};

View File

@ -1567,3 +1567,4 @@ TimelineModel::roomTopic() const
return utils::replaceEmoji(utils::linkifyMessage( return utils::replaceEmoji(utils::linkifyMessage(
utils::escapeBlacklistedHtml(QString::fromStdString(info[room_id_].topic)))); utils::escapeBlacklistedHtml(QString::fromStdString(info[room_id_].topic))));
} }

View File

@ -10,6 +10,7 @@
#include "CacheCryptoStructs.h" #include "CacheCryptoStructs.h"
#include "EventStore.h" #include "EventStore.h"
#include "InputBar.h"
#include "ui/UserProfile.h" #include "ui/UserProfile.h"
namespace mtx::http { namespace mtx::http {
@ -149,6 +150,7 @@ class TimelineModel : public QAbstractListModel
Q_PROPERTY(QString roomName READ roomName NOTIFY roomNameChanged) Q_PROPERTY(QString roomName READ roomName NOTIFY roomNameChanged)
Q_PROPERTY(QString roomAvatarUrl READ roomAvatarUrl NOTIFY roomAvatarUrlChanged) Q_PROPERTY(QString roomAvatarUrl READ roomAvatarUrl NOTIFY roomAvatarUrlChanged)
Q_PROPERTY(QString roomTopic READ roomTopic NOTIFY roomTopicChanged) Q_PROPERTY(QString roomTopic READ roomTopic NOTIFY roomTopicChanged)
Q_PROPERTY(InputBar *input READ input)
public: public:
explicit TimelineModel(TimelineViewManager *manager, explicit TimelineModel(TimelineViewManager *manager,
@ -271,6 +273,7 @@ public slots:
QString roomName() const; QString roomName() const;
QString roomTopic() const; QString roomTopic() const;
InputBar *input() { return &input_; }
QString roomAvatarUrl() const; QString roomAvatarUrl() const;
QString roomId() const { return room_id_; } QString roomId() const { return room_id_; }
@ -320,6 +323,8 @@ private:
TimelineViewManager *manager_; TimelineViewManager *manager_;
InputBar input_{this};
friend struct SendMessageVisitor; friend struct SendMessageVisitor;
}; };