mirror of https://github.com/procxx/kepka.git
Slightly refactored code in SendFilesBox.
This commit is contained in:
parent
627a105ba9
commit
abc7b8364c
|
@ -52,6 +52,23 @@ constexpr auto kDragDuration = crl::time(200);
|
||||||
const auto kStickerMimeString = qstr("image/webp");
|
const auto kStickerMimeString = qstr("image/webp");
|
||||||
const auto kAnimatedStickerMimeString = qstr("application/x-tgsticker");
|
const auto kAnimatedStickerMimeString = qstr("application/x-tgsticker");
|
||||||
|
|
||||||
|
inline bool CanAddUrls(const QList<QUrl> &urls) {
|
||||||
|
return !urls.isEmpty() && ranges::find_if(
|
||||||
|
urls,
|
||||||
|
[](const QUrl &url) { return !url.isLocalFile(); }
|
||||||
|
) == urls.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool IsFirstAlbumItem(const Storage::PreparedList &list) {
|
||||||
|
using AlbumType = Storage::PreparedFile::AlbumType;
|
||||||
|
return (list.files.size() > 0)
|
||||||
|
&& (list.files.front().type != AlbumType::None);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool IsSingleItem(const Storage::PreparedList &list) {
|
||||||
|
return list.files.size() == 1;
|
||||||
|
}
|
||||||
|
|
||||||
void PaintAlbumThumbButtons(
|
void PaintAlbumThumbButtons(
|
||||||
Painter &p,
|
Painter &p,
|
||||||
QPoint point,
|
QPoint point,
|
||||||
|
@ -1556,7 +1573,7 @@ void SendFilesBox::initPreview(rpl::producer<int> desiredPreviewHeight) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void SendFilesBox::prepareSingleFilePreview() {
|
void SendFilesBox::prepareSingleFilePreview() {
|
||||||
Expects(_list.files.size() == 1);
|
Expects(IsSingleItem(_list));
|
||||||
|
|
||||||
const auto &file = _list.files[0];
|
const auto &file = _list.files[0];
|
||||||
const auto media = SingleMediaPreview::Create(this, _controller, file);
|
const auto media = SingleMediaPreview::Create(this, _controller, file);
|
||||||
|
@ -1606,7 +1623,7 @@ void SendFilesBox::addThumbButtonHandlers() {
|
||||||
}
|
}
|
||||||
_albumPreview = nullptr;
|
_albumPreview = nullptr;
|
||||||
|
|
||||||
if (_list.files.size() == 1) {
|
if (IsSingleItem(_list)) {
|
||||||
_list.albumIsPossible = false;
|
_list.albumIsPossible = false;
|
||||||
if (_sendWay->value() == SendFilesWay::Album) {
|
if (_sendWay->value() == SendFilesWay::Album) {
|
||||||
_sendWay->setValue(SendFilesWay::Photos);
|
_sendWay->setValue(SendFilesWay::Photos);
|
||||||
|
@ -1798,7 +1815,7 @@ void SendFilesBox::refreshAlbumMediaCount() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void SendFilesBox::preparePreview() {
|
void SendFilesBox::preparePreview() {
|
||||||
if (_list.files.size() == 1) {
|
if (IsSingleItem(_list)) {
|
||||||
prepareSingleFilePreview();
|
prepareSingleFilePreview();
|
||||||
} else {
|
} else {
|
||||||
if (_list.albumIsPossible) {
|
if (_list.albumIsPossible) {
|
||||||
|
@ -1835,7 +1852,7 @@ void SendFilesBox::setupSendWayControls() {
|
||||||
addRadio(_sendAlbum, SendFilesWay::Album, tr::lng_send_album(tr::now));
|
addRadio(_sendAlbum, SendFilesWay::Album, tr::lng_send_album(tr::now));
|
||||||
}
|
}
|
||||||
if (!_list.albumIsPossible || _albumPhotosCount > 0) {
|
if (!_list.albumIsPossible || _albumPhotosCount > 0) {
|
||||||
addRadio(_sendPhotos, SendFilesWay::Photos, (_list.files.size() == 1)
|
addRadio(_sendPhotos, SendFilesWay::Photos, IsSingleItem(_list)
|
||||||
? tr::lng_send_photo(tr::now)
|
? tr::lng_send_photo(tr::now)
|
||||||
: (_albumVideosCount > 0)
|
: (_albumVideosCount > 0)
|
||||||
? tr::lng_send_separate_photos_videos(tr::now)
|
? tr::lng_send_separate_photos_videos(tr::now)
|
||||||
|
@ -1843,7 +1860,7 @@ void SendFilesBox::setupSendWayControls() {
|
||||||
? tr::lng_send_separate_photos(tr::now)
|
? tr::lng_send_separate_photos(tr::now)
|
||||||
: tr::lng_send_photos(tr::now, lt_count, _list.files.size())));
|
: tr::lng_send_photos(tr::now, lt_count, _list.files.size())));
|
||||||
}
|
}
|
||||||
addRadio(_sendFiles, SendFilesWay::Files, (_list.files.size() == 1)
|
addRadio(_sendFiles, SendFilesWay::Files, (IsSingleItem(_list))
|
||||||
? tr::lng_send_file(tr::now)
|
? tr::lng_send_file(tr::now)
|
||||||
: tr::lng_send_files(tr::now, lt_count, _list.files.size()));
|
: tr::lng_send_files(tr::now, lt_count, _list.files.size()));
|
||||||
}
|
}
|
||||||
|
@ -1970,16 +1987,9 @@ void SendFilesBox::captionResized() {
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SendFilesBox::canAddUrls(const QList<QUrl> &urls) const {
|
|
||||||
return !urls.isEmpty() && ranges::find_if(
|
|
||||||
urls,
|
|
||||||
[](const QUrl &url) { return !url.isLocalFile(); }
|
|
||||||
) == urls.end();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool SendFilesBox::canAddFiles(not_null<const QMimeData*> data) const {
|
bool SendFilesBox::canAddFiles(not_null<const QMimeData*> data) const {
|
||||||
const auto urls = data->hasUrls() ? data->urls() : QList<QUrl>();
|
const auto urls = data->hasUrls() ? data->urls() : QList<QUrl>();
|
||||||
auto filesCount = canAddUrls(urls) ? urls.size() : 0;
|
auto filesCount = CanAddUrls(urls) ? urls.size() : 0;
|
||||||
if (!filesCount && data->hasImage()) {
|
if (!filesCount && data->hasImage()) {
|
||||||
++filesCount;
|
++filesCount;
|
||||||
}
|
}
|
||||||
|
@ -1988,8 +1998,7 @@ bool SendFilesBox::canAddFiles(not_null<const QMimeData*> data) const {
|
||||||
return false;
|
return false;
|
||||||
} else if (_list.files.size() > 1 && !_albumPreview) {
|
} else if (_list.files.size() > 1 && !_albumPreview) {
|
||||||
return false;
|
return false;
|
||||||
} else if (_list.files.front().type
|
} else if (!IsFirstAlbumItem(_list)) {
|
||||||
== Storage::PreparedFile::AlbumType::None) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -1998,7 +2007,7 @@ bool SendFilesBox::canAddFiles(not_null<const QMimeData*> data) const {
|
||||||
bool SendFilesBox::addFiles(not_null<const QMimeData*> data) {
|
bool SendFilesBox::addFiles(not_null<const QMimeData*> data) {
|
||||||
auto list = [&] {
|
auto list = [&] {
|
||||||
const auto urls = data->hasUrls() ? data->urls() : QList<QUrl>();
|
const auto urls = data->hasUrls() ? data->urls() : QList<QUrl>();
|
||||||
auto result = canAddUrls(urls)
|
auto result = CanAddUrls(urls)
|
||||||
? Storage::PrepareMediaList(urls, st::sendMediaPreviewSize)
|
? Storage::PrepareMediaList(urls, st::sendMediaPreviewSize)
|
||||||
: Storage::PreparedList(
|
: Storage::PreparedList(
|
||||||
Storage::PreparedList::Error::EmptyFile,
|
Storage::PreparedList::Error::EmptyFile,
|
||||||
|
@ -2016,26 +2025,29 @@ bool SendFilesBox::addFiles(not_null<const QMimeData*> data) {
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}();
|
}();
|
||||||
if (_list.files.size() + list.files.size() > Storage::MaxAlbumItems()) {
|
return addFiles(std::move(list));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SendFilesBox::addFiles(Storage::PreparedList list) {
|
||||||
|
const auto sumFiles = _list.files.size() + list.files.size();
|
||||||
|
if (sumFiles > Storage::MaxAlbumItems()) {
|
||||||
return false;
|
return false;
|
||||||
} else if (list.error != Storage::PreparedList::Error::None) {
|
} else if (list.error != Storage::PreparedList::Error::None) {
|
||||||
return false;
|
return false;
|
||||||
} else if (list.files.size() != 1 && !list.albumIsPossible) {
|
} else if (!IsSingleItem(list) && !list.albumIsPossible) {
|
||||||
return false;
|
return false;
|
||||||
} else if (list.files.front().type
|
} else if (!IsFirstAlbumItem(list)) {
|
||||||
== Storage::PreparedFile::AlbumType::None) {
|
|
||||||
return false;
|
return false;
|
||||||
} else if (_list.files.size() > 1 && !_albumPreview) {
|
} else if (_list.files.size() > 1 && !_albumPreview) {
|
||||||
return false;
|
return false;
|
||||||
} else if (_list.files.front().type
|
} else if (!IsFirstAlbumItem(_list)) {
|
||||||
== Storage::PreparedFile::AlbumType::None) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
applyAlbumOrder();
|
applyAlbumOrder();
|
||||||
delete base::take(_preview);
|
delete base::take(_preview);
|
||||||
_albumPreview = nullptr;
|
_albumPreview = nullptr;
|
||||||
|
|
||||||
if (_list.files.size() == 1
|
if (IsSingleItem(_list)
|
||||||
&& _sendWay->value() == SendFilesWay::Photos) {
|
&& _sendWay->value() == SendFilesWay::Photos) {
|
||||||
_sendWay->setValue(SendFilesWay::Album);
|
_sendWay->setValue(SendFilesWay::Album);
|
||||||
}
|
}
|
||||||
|
|
|
@ -123,8 +123,8 @@ private:
|
||||||
void addThumbButtonHandlers();
|
void addThumbButtonHandlers();
|
||||||
|
|
||||||
bool canAddFiles(not_null<const QMimeData*> data) const;
|
bool canAddFiles(not_null<const QMimeData*> data) const;
|
||||||
bool canAddUrls(const QList<QUrl> &urls) const;
|
|
||||||
bool addFiles(not_null<const QMimeData*> data);
|
bool addFiles(not_null<const QMimeData*> data);
|
||||||
|
bool addFiles(Storage::PreparedList list);
|
||||||
|
|
||||||
const not_null<Window::SessionController*> _controller;
|
const not_null<Window::SessionController*> _controller;
|
||||||
const Api::SendType _sendType = Api::SendType();
|
const Api::SendType _sendType = Api::SendType();
|
||||||
|
|
Loading…
Reference in New Issue