mirror of https://github.com/procxx/kepka.git
Refresh filtered results on more dialogs.
This commit is contained in:
parent
df389a365c
commit
219b824338
|
@ -215,7 +215,7 @@ void ShareBox::prepare() {
|
|||
setDimensions(st::boxWideWidth, st::boxMaxListHeight);
|
||||
|
||||
_select->setQueryChangedCallback([=](const QString &query) {
|
||||
onFilterUpdate(query);
|
||||
applyFilterUpdate(query);
|
||||
});
|
||||
_select->setItemRemovedCallback([=](uint64 itemId) {
|
||||
if (const auto peer = App::peerLoaded(itemId)) {
|
||||
|
@ -403,7 +403,7 @@ void ShareBox::createButtons() {
|
|||
addButton(langFactory(lng_cancel), [=] { closeBox(); });
|
||||
}
|
||||
|
||||
void ShareBox::onFilterUpdate(const QString &query) {
|
||||
void ShareBox::applyFilterUpdate(const QString &query) {
|
||||
onScrollToY(0);
|
||||
_inner->updateFilter(query);
|
||||
}
|
||||
|
|
|
@ -60,7 +60,7 @@ private:
|
|||
|
||||
void scrollTo(Ui::ScrollToRequest request);
|
||||
void needSearchByUsername();
|
||||
void onFilterUpdate(const QString &query);
|
||||
void applyFilterUpdate(const QString &query);
|
||||
void selectedChanged();
|
||||
void createButtons();
|
||||
int getTopScrollSkip() const;
|
||||
|
|
|
@ -1598,7 +1598,7 @@ void DialogsInner::handlePeerNameChange(
|
|||
update();
|
||||
}
|
||||
|
||||
void DialogsInner::onFilterUpdate(QString newFilter, bool force) {
|
||||
void DialogsInner::applyFilterUpdate(QString newFilter, bool force) {
|
||||
const auto mentionsSearch = (newFilter == qstr("@"));
|
||||
const auto words = mentionsSearch
|
||||
? QStringList(newFilter)
|
||||
|
|
|
@ -88,7 +88,7 @@ public:
|
|||
|
||||
void searchInChat(Dialogs::Key key, UserData *from);
|
||||
|
||||
void onFilterUpdate(QString newFilter, bool force = false);
|
||||
void applyFilterUpdate(QString newFilter, bool force = false);
|
||||
void onHashtagFilterUpdate(QStringRef newFilter);
|
||||
|
||||
PeerData *updateFromParentDrag(QPoint globalPosition);
|
||||
|
|
|
@ -165,13 +165,20 @@ DialogsWidget::DialogsWidget(QWidget *parent, not_null<Window::Controller*> cont
|
|||
connect(_inner, SIGNAL(cancelSearchInChat()), this, SLOT(onCancelSearchInChat()));
|
||||
subscribe(_inner->searchFromUserChanged, [this](UserData *user) {
|
||||
setSearchInChat(_searchInChat, user);
|
||||
onFilterUpdate(true);
|
||||
applyFilterUpdate(true);
|
||||
});
|
||||
connect(_scroll, SIGNAL(geometryChanged()), _inner, SLOT(onParentGeometryChanged()));
|
||||
connect(_scroll, SIGNAL(scrolled()), this, SLOT(onListScroll()));
|
||||
connect(_filter, SIGNAL(cancelled()), this, SLOT(onCancel()));
|
||||
connect(_filter, SIGNAL(changed()), this, SLOT(onFilterUpdate()));
|
||||
connect(_filter, SIGNAL(cursorPositionChanged(int,int)), this, SLOT(onFilterCursorMoved(int,int)));
|
||||
connect(_filter, &Ui::FlatInput::cancelled, [=] {
|
||||
onCancel();
|
||||
});
|
||||
connect(_filter, &Ui::FlatInput::changed, [=] {
|
||||
applyFilterUpdate();
|
||||
});
|
||||
connect(
|
||||
_filter,
|
||||
&Ui::FlatInput::cursorPositionChanged,
|
||||
[=](int from, int to) { onFilterCursorMoved(from, to); });
|
||||
|
||||
if (!Core::UpdaterDisabled()) {
|
||||
Core::UpdateChecker checker;
|
||||
|
@ -395,7 +402,7 @@ void DialogsWidget::animationCallback() {
|
|||
updateJumpToDateVisibility(true);
|
||||
updateSearchFromVisibility(true);
|
||||
|
||||
onFilterUpdate();
|
||||
applyFilterUpdate();
|
||||
if (App::wnd()) App::wnd()->setInnerFocus();
|
||||
}
|
||||
}
|
||||
|
@ -442,6 +449,7 @@ void DialogsWidget::dialogsReceived(
|
|||
if (!_dialogsRequestId) {
|
||||
refreshLoadMoreButton();
|
||||
}
|
||||
refreshSupportFilteredResults();
|
||||
|
||||
Auth().data().moreChatsLoaded().notify();
|
||||
if (_dialogsFull && _pinnedDialogsReceived) {
|
||||
|
@ -450,6 +458,15 @@ void DialogsWidget::dialogsReceived(
|
|||
Auth().api().requestContacts();
|
||||
}
|
||||
|
||||
void DialogsWidget::refreshSupportFilteredResults() {
|
||||
if (!Auth().supportMode()) {
|
||||
return;
|
||||
}
|
||||
const auto top = _scroll->scrollTop();
|
||||
applyFilterUpdate(true);
|
||||
_scroll->scrollToY(top);
|
||||
}
|
||||
|
||||
void DialogsWidget::updateDialogsOffset(
|
||||
const QVector<MTPDialog> &dialogs,
|
||||
const QVector<MTPMessage> &messages) {
|
||||
|
@ -741,7 +758,7 @@ void DialogsWidget::searchMessages(
|
|||
}
|
||||
_filter->setText(query);
|
||||
_filter->updatePlaceholder();
|
||||
onFilterUpdate(true);
|
||||
applyFilterUpdate(true);
|
||||
_searchTimer.stop();
|
||||
onSearchMessages();
|
||||
|
||||
|
@ -1115,11 +1132,11 @@ void DialogsWidget::onListScroll() {
|
|||
_inner->setVisibleTopBottom(scrollTop, scrollTop + _scroll->height());
|
||||
}
|
||||
|
||||
void DialogsWidget::onFilterUpdate(bool force) {
|
||||
void DialogsWidget::applyFilterUpdate(bool force) {
|
||||
if (_a_show.animating() && !force) return;
|
||||
|
||||
auto filterText = _filter->getLastText();
|
||||
_inner->onFilterUpdate(filterText, force);
|
||||
_inner->applyFilterUpdate(filterText, force);
|
||||
if (filterText.isEmpty() && !_searchFromUser) {
|
||||
clearSearchCache();
|
||||
}
|
||||
|
@ -1146,7 +1163,7 @@ void DialogsWidget::onFilterUpdate(bool force) {
|
|||
void DialogsWidget::searchInChat(Dialogs::Key chat) {
|
||||
onCancelSearch();
|
||||
setSearchInChat(chat);
|
||||
onFilterUpdate(true);
|
||||
applyFilterUpdate(true);
|
||||
}
|
||||
|
||||
void DialogsWidget::setSearchInChat(Dialogs::Key chat, UserData *from) {
|
||||
|
@ -1202,7 +1219,7 @@ void DialogsWidget::showSearchFrom() {
|
|||
crl::guard(this, [=](not_null<UserData*> user) {
|
||||
Ui::hideLayer();
|
||||
setSearchInChat(chat, user);
|
||||
onFilterUpdate(true);
|
||||
applyFilterUpdate(true);
|
||||
}),
|
||||
crl::guard(this, [=] { _filter->setFocus(); }));
|
||||
}
|
||||
|
@ -1239,7 +1256,7 @@ void DialogsWidget::onCompleteHashtag(QString tag) {
|
|||
r = t.mid(0, start + 1) + tag + ' ' + t.mid(cur);
|
||||
_filter->setText(r);
|
||||
_filter->setCursorPosition(start + 1 + tag.size() + 1);
|
||||
onFilterUpdate(true);
|
||||
applyFilterUpdate(true);
|
||||
return;
|
||||
}
|
||||
break;
|
||||
|
@ -1248,7 +1265,7 @@ void DialogsWidget::onCompleteHashtag(QString tag) {
|
|||
}
|
||||
_filter->setText(t.mid(0, cur) + '#' + tag + ' ' + t.mid(cur));
|
||||
_filter->setCursorPosition(cur + 1 + tag.size() + 1);
|
||||
onFilterUpdate(true);
|
||||
applyFilterUpdate(true);
|
||||
}
|
||||
|
||||
void DialogsWidget::resizeEvent(QResizeEvent *e) {
|
||||
|
@ -1451,7 +1468,7 @@ void DialogsWidget::scrollToEntry(const Dialogs::RowDescriptor &entry) {
|
|||
|
||||
void DialogsWidget::removeDialog(Dialogs::Key key) {
|
||||
_inner->removeDialog(key);
|
||||
onFilterUpdate();
|
||||
applyFilterUpdate(true);
|
||||
}
|
||||
|
||||
Dialogs::IndexedList *DialogsWidget::contactsList() {
|
||||
|
@ -1488,7 +1505,7 @@ bool DialogsWidget::onCancelSearch() {
|
|||
_inner->clearFilter();
|
||||
_filter->clear();
|
||||
_filter->updatePlaceholder();
|
||||
onFilterUpdate();
|
||||
applyFilterUpdate();
|
||||
return clearing;
|
||||
}
|
||||
|
||||
|
@ -1512,7 +1529,7 @@ void DialogsWidget::onCancelSearchInChat() {
|
|||
_inner->clearFilter();
|
||||
_filter->clear();
|
||||
_filter->updatePlaceholder();
|
||||
onFilterUpdate();
|
||||
applyFilterUpdate();
|
||||
if (!Adaptive::OneColumn() && !App::main()->selectingPeer()) {
|
||||
emit cancelled();
|
||||
}
|
||||
|
|
|
@ -100,7 +100,6 @@ public slots:
|
|||
void onCancel();
|
||||
void onListScroll();
|
||||
void activate();
|
||||
void onFilterUpdate(bool force = false);
|
||||
bool onCancelSearch();
|
||||
void onCancelSearchInChat();
|
||||
|
||||
|
@ -162,6 +161,8 @@ private:
|
|||
void updateForwardBar();
|
||||
void checkUpdateStatus();
|
||||
|
||||
void applyFilterUpdate(bool force = false);
|
||||
void refreshSupportFilteredResults();
|
||||
bool loadingBlockedByDate() const;
|
||||
void refreshLoadMoreButton();
|
||||
|
||||
|
|
|
@ -234,15 +234,19 @@ void CountrySelectBox::prepare() {
|
|||
setTitle(langFactory(lng_country_select));
|
||||
|
||||
_select->resizeToWidth(st::boxWidth);
|
||||
_select->setQueryChangedCallback([this](const QString &query) { onFilterUpdate(query); });
|
||||
_select->setSubmittedCallback([this](Qt::KeyboardModifiers) { onSubmit(); });
|
||||
_select->setQueryChangedCallback([=](const QString &query) {
|
||||
applyFilterUpdate(query);
|
||||
});
|
||||
_select->setSubmittedCallback([=](Qt::KeyboardModifiers) {
|
||||
submit();
|
||||
});
|
||||
|
||||
_inner = setInnerWidget(
|
||||
object_ptr<Inner>(this, _type),
|
||||
st::countriesScroll,
|
||||
_select->height());
|
||||
|
||||
addButton(langFactory(lng_close), [this] { closeBox(); });
|
||||
addButton(langFactory(lng_close), [=] { closeBox(); });
|
||||
|
||||
setDimensions(st::boxWidth, st::boxMaxListHeight);
|
||||
|
||||
|
@ -250,7 +254,7 @@ void CountrySelectBox::prepare() {
|
|||
connect(_inner, SIGNAL(countryChosen(const QString&)), this, SIGNAL(countryChosen(const QString&)));
|
||||
}
|
||||
|
||||
void CountrySelectBox::onSubmit() {
|
||||
void CountrySelectBox::submit() {
|
||||
_inner->chooseCountry();
|
||||
}
|
||||
|
||||
|
@ -277,7 +281,7 @@ void CountrySelectBox::resizeEvent(QResizeEvent *e) {
|
|||
_inner->resizeToWidth(width());
|
||||
}
|
||||
|
||||
void CountrySelectBox::onFilterUpdate(const QString &query) {
|
||||
void CountrySelectBox::applyFilterUpdate(const QString &query) {
|
||||
onScrollToY(0);
|
||||
_inner->updateFilter(query);
|
||||
}
|
||||
|
|
|
@ -77,11 +77,9 @@ protected:
|
|||
void keyPressEvent(QKeyEvent *e) override;
|
||||
void resizeEvent(QResizeEvent *e) override;
|
||||
|
||||
private slots:
|
||||
void onSubmit();
|
||||
|
||||
private:
|
||||
void onFilterUpdate(const QString &query);
|
||||
void submit();
|
||||
void applyFilterUpdate(const QString &query);
|
||||
|
||||
Type _type = Type::Phones;
|
||||
object_ptr<Ui::MultiSelect> _select;
|
||||
|
|
Loading…
Reference in New Issue