mirror of
https://github.com/Nheko-Reborn/nheko.git
synced 2024-11-22 19:08:58 +03:00
Allow uploading additional stickers
This commit is contained in:
parent
a57a15a2e0
commit
16d0190f4e
4 changed files with 97 additions and 5 deletions
|
@ -23,6 +23,9 @@ MouseArea {
|
||||||
// console.warn("Delta: ", wheel.pixelDelta.y);
|
// console.warn("Delta: ", wheel.pixelDelta.y);
|
||||||
// console.warn("Old position: ", flickable.contentY);
|
// console.warn("Old position: ", flickable.contentY);
|
||||||
// console.warn("New position: ", newPos);
|
// console.warn("New position: ", newPos);
|
||||||
|
// breaks ListView's with headers...
|
||||||
|
//if (typeof (flickableItem.headerItem) !== "undefined" && flickableItem.headerItem)
|
||||||
|
// minYExtent += flickableItem.headerItem.height;
|
||||||
|
|
||||||
id: root
|
id: root
|
||||||
|
|
||||||
|
@ -30,10 +33,6 @@ MouseArea {
|
||||||
property alias enabled: root.enabled
|
property alias enabled: root.enabled
|
||||||
|
|
||||||
function calculateNewPosition(flickableItem, wheel) {
|
function calculateNewPosition(flickableItem, wheel) {
|
||||||
// breaks ListView's with headers...
|
|
||||||
//if (typeof (flickableItem.headerItem) !== "undefined" && flickableItem.headerItem)
|
|
||||||
// minYExtent += flickableItem.headerItem.height;
|
|
||||||
|
|
||||||
//Nothing to scroll
|
//Nothing to scroll
|
||||||
if (flickableItem.contentHeight < flickableItem.height)
|
if (flickableItem.contentHeight < flickableItem.height)
|
||||||
return flickableItem.contentY;
|
return flickableItem.contentY;
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
import ".."
|
import ".."
|
||||||
import "../components"
|
import "../components"
|
||||||
|
import Qt.labs.platform 1.1
|
||||||
import QtQuick 2.12
|
import QtQuick 2.12
|
||||||
import QtQuick.Controls 2.12
|
import QtQuick.Controls 2.12
|
||||||
import QtQuick.Layouts 1.12
|
import QtQuick.Layouts 1.12
|
||||||
|
@ -78,6 +79,23 @@ ApplicationWindow {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
footer: Button {
|
||||||
|
palette: Nheko.colors
|
||||||
|
onClicked: addFilesDialog.open()
|
||||||
|
width: ListView.view.width
|
||||||
|
text: qsTr("Add images")
|
||||||
|
|
||||||
|
FileDialog {
|
||||||
|
id: addFilesDialog
|
||||||
|
|
||||||
|
folder: StandardPaths.writableLocation(StandardPaths.PicturesLocation)
|
||||||
|
fileMode: FileDialog.OpenFiles
|
||||||
|
nameFilters: [qsTr("Stickers (*.png *.webp)")]
|
||||||
|
onAccepted: imagePack.addStickers(files)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
delegate: AvatarListTile {
|
delegate: AvatarListTile {
|
||||||
id: packItem
|
id: packItem
|
||||||
|
|
||||||
|
|
|
@ -4,13 +4,18 @@
|
||||||
|
|
||||||
#include "SingleImagePackModel.h"
|
#include "SingleImagePackModel.h"
|
||||||
|
|
||||||
|
#include <QFile>
|
||||||
|
#include <QMimeDatabase>
|
||||||
|
|
||||||
#include "Cache_p.h"
|
#include "Cache_p.h"
|
||||||
#include "ChatPage.h"
|
#include "ChatPage.h"
|
||||||
|
#include "Logging.h"
|
||||||
#include "MatrixClient.h"
|
#include "MatrixClient.h"
|
||||||
|
#include "Utils.h"
|
||||||
#include "timeline/Permissions.h"
|
#include "timeline/Permissions.h"
|
||||||
#include "timeline/TimelineModel.h"
|
#include "timeline/TimelineModel.h"
|
||||||
|
|
||||||
#include "Logging.h"
|
Q_DECLARE_METATYPE(mtx::common::ImageInfo);
|
||||||
|
|
||||||
SingleImagePackModel::SingleImagePackModel(ImagePackInfo pack_, QObject *parent)
|
SingleImagePackModel::SingleImagePackModel(ImagePackInfo pack_, QObject *parent)
|
||||||
: QAbstractListModel(parent)
|
: QAbstractListModel(parent)
|
||||||
|
@ -19,11 +24,15 @@ SingleImagePackModel::SingleImagePackModel(ImagePackInfo pack_, QObject *parent)
|
||||||
, old_statekey_(statekey_)
|
, old_statekey_(statekey_)
|
||||||
, pack(std::move(pack_.pack))
|
, pack(std::move(pack_.pack))
|
||||||
{
|
{
|
||||||
|
[[maybe_unused]] static auto imageInfoType = qRegisterMetaType<mtx::common::ImageInfo>();
|
||||||
|
|
||||||
if (!pack.pack)
|
if (!pack.pack)
|
||||||
pack.pack = mtx::events::msc2545::ImagePack::PackDescription{};
|
pack.pack = mtx::events::msc2545::ImagePack::PackDescription{};
|
||||||
|
|
||||||
for (const auto &e : pack.images)
|
for (const auto &e : pack.images)
|
||||||
shortcodes.push_back(e.first);
|
shortcodes.push_back(e.first);
|
||||||
|
|
||||||
|
connect(this, &SingleImagePackModel::addImage, this, &SingleImagePackModel::addImageCb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -279,3 +288,61 @@ SingleImagePackModel::save()
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
SingleImagePackModel::addStickers(QList<QUrl> files)
|
||||||
|
{
|
||||||
|
for (const auto &f : files) {
|
||||||
|
auto file = QFile(f.toLocalFile());
|
||||||
|
if (!file.open(QFile::ReadOnly)) {
|
||||||
|
ChatPage::instance()->showNotification(
|
||||||
|
tr("Failed to open image: {}").arg(f.toLocalFile()));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto bytes = file.readAll();
|
||||||
|
auto img = utils::readImage(bytes);
|
||||||
|
|
||||||
|
mtx::common::ImageInfo info{};
|
||||||
|
|
||||||
|
auto sz = img.size() / 2;
|
||||||
|
if (sz.width() > 512 || sz.height() > 512) {
|
||||||
|
sz.scale(512, 512, Qt::AspectRatioMode::KeepAspectRatio);
|
||||||
|
}
|
||||||
|
|
||||||
|
info.h = sz.height();
|
||||||
|
info.w = sz.width();
|
||||||
|
info.size = bytes.size();
|
||||||
|
|
||||||
|
auto filename = f.fileName().toStdString();
|
||||||
|
http::client()->upload(
|
||||||
|
bytes.toStdString(),
|
||||||
|
QMimeDatabase().mimeTypeForFile(f.toLocalFile()).name().toStdString(),
|
||||||
|
filename,
|
||||||
|
[this, filename, info](const mtx::responses::ContentURI &uri,
|
||||||
|
mtx::http::RequestErr e) {
|
||||||
|
if (e) {
|
||||||
|
ChatPage::instance()->showNotification(
|
||||||
|
tr("Failed to upload image: {}")
|
||||||
|
.arg(QString::fromStdString(e->matrix_error.error)));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
emit addImage(uri.content_uri, filename, info);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void
|
||||||
|
SingleImagePackModel::addImageCb(std::string uri, std::string filename, mtx::common::ImageInfo info)
|
||||||
|
{
|
||||||
|
mtx::events::msc2545::PackImage img{};
|
||||||
|
img.url = uri;
|
||||||
|
img.info = info;
|
||||||
|
beginInsertRows(
|
||||||
|
QModelIndex(), static_cast<int>(shortcodes.size()), static_cast<int>(shortcodes.size()));
|
||||||
|
|
||||||
|
pack.images[filename] = img;
|
||||||
|
shortcodes.push_back(filename);
|
||||||
|
|
||||||
|
endInsertRows();
|
||||||
|
}
|
||||||
|
|
|
@ -5,6 +5,8 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <QAbstractListModel>
|
#include <QAbstractListModel>
|
||||||
|
#include <QList>
|
||||||
|
#include <QUrl>
|
||||||
|
|
||||||
#include <mtx/events/mscs/image_packs.hpp>
|
#include <mtx/events/mscs/image_packs.hpp>
|
||||||
|
|
||||||
|
@ -66,6 +68,7 @@ public:
|
||||||
void setIsEmotePack(bool val);
|
void setIsEmotePack(bool val);
|
||||||
|
|
||||||
Q_INVOKABLE void save();
|
Q_INVOKABLE void save();
|
||||||
|
Q_INVOKABLE void addStickers(QList<QUrl> files);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void globallyEnabledChanged();
|
void globallyEnabledChanged();
|
||||||
|
@ -76,6 +79,11 @@ signals:
|
||||||
void isEmotePackChanged();
|
void isEmotePackChanged();
|
||||||
void isStickerPackChanged();
|
void isStickerPackChanged();
|
||||||
|
|
||||||
|
void addImage(std::string uri, std::string filename, mtx::common::ImageInfo info);
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void addImageCb(std::string uri, std::string filename, mtx::common::ImageInfo info);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string roomid_;
|
std::string roomid_;
|
||||||
std::string statekey_, old_statekey_;
|
std::string statekey_, old_statekey_;
|
||||||
|
|
Loading…
Reference in a new issue