mirror of
https://github.com/telegramdesktop/tdesktop
synced 2025-04-01 23:00:58 +00:00
Remove counter from unread bar.
This commit is contained in:
parent
1980c1004e
commit
ee3e9af63a
@ -1369,7 +1369,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
|||||||
"lng_user_action_upload_file" = "{user} is sending a file";
|
"lng_user_action_upload_file" = "{user} is sending a file";
|
||||||
"lng_unread_bar#one" = "{count} unread message";
|
"lng_unread_bar#one" = "{count} unread message";
|
||||||
"lng_unread_bar#other" = "{count} unread messages";
|
"lng_unread_bar#other" = "{count} unread messages";
|
||||||
//"lng_unread_bar_some" = "Unread messages";
|
"lng_unread_bar_some" = "Unread messages";
|
||||||
|
|
||||||
"lng_maps_point" = "Location";
|
"lng_maps_point" = "Location";
|
||||||
"lng_save_photo" = "Save image";
|
"lng_save_photo" = "Save image";
|
||||||
|
@ -1367,8 +1367,8 @@ HistoryBlock *History::prepareBlockForAddingItem() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void History::viewReplaced(not_null<const Element*> was, Element *now) {
|
void History::viewReplaced(not_null<const Element*> was, Element *now) {
|
||||||
if (scrollTopItem == was) scrollTopItem= now;
|
if (scrollTopItem == was) scrollTopItem = now;
|
||||||
if (_firstUnreadView == was) _firstUnreadView= now;
|
if (_firstUnreadView == was) _firstUnreadView = now;
|
||||||
if (_unreadBarView == was) _unreadBarView = now;
|
if (_unreadBarView == was) _unreadBarView = now;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1803,14 +1803,6 @@ void History::setUnreadCount(int newUnreadCount) {
|
|||||||
calculateFirstUnreadMessage();
|
calculateFirstUnreadMessage();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_unreadBarView) {
|
|
||||||
const auto count = chatListUnreadCount();
|
|
||||||
if (count > 0) {
|
|
||||||
_unreadBarView->setUnreadBarCount(count);
|
|
||||||
} else {
|
|
||||||
_unreadBarView->setUnreadBarFreezed();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Notify::peerUpdatedDelayed(
|
Notify::peerUpdatedDelayed(
|
||||||
peer,
|
peer,
|
||||||
Notify::PeerUpdate::Flag::UnreadViewChanged);
|
Notify::PeerUpdate::Flag::UnreadViewChanged);
|
||||||
@ -2064,7 +2056,7 @@ void History::addUnreadBar() {
|
|||||||
}
|
}
|
||||||
if (const auto count = chatListUnreadCount()) {
|
if (const auto count = chatListUnreadCount()) {
|
||||||
_unreadBarView = _firstUnreadView;
|
_unreadBarView = _firstUnreadView;
|
||||||
_unreadBarView->setUnreadBarCount(count);
|
_unreadBarView->createUnreadBar();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2074,17 +2066,6 @@ void History::destroyUnreadBar() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool History::hasNotFreezedUnreadBar() const {
|
|
||||||
if (_firstUnreadView) {
|
|
||||||
if (const auto view = _unreadBarView) {
|
|
||||||
if (const auto bar = view->Get<HistoryView::UnreadBar>()) {
|
|
||||||
return !bar->freezed;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void History::unsetFirstUnreadMessage() {
|
void History::unsetFirstUnreadMessage() {
|
||||||
_firstUnreadView = nullptr;
|
_firstUnreadView = nullptr;
|
||||||
}
|
}
|
||||||
|
@ -205,7 +205,6 @@ public:
|
|||||||
bool changeMute(bool newMute);
|
bool changeMute(bool newMute);
|
||||||
void addUnreadBar();
|
void addUnreadBar();
|
||||||
void destroyUnreadBar();
|
void destroyUnreadBar();
|
||||||
[[nodiscard]] bool hasNotFreezedUnreadBar() const;
|
|
||||||
[[nodiscard]] Element *unreadBar() const;
|
[[nodiscard]] Element *unreadBar() const;
|
||||||
void calculateFirstUnreadMessage();
|
void calculateFirstUnreadMessage();
|
||||||
void unsetFirstUnreadMessage();
|
void unsetFirstUnreadMessage();
|
||||||
|
@ -2389,7 +2389,7 @@ void HistoryWidget::messagesReceived(PeerData *peer, const MTPmessages_Messages
|
|||||||
_preloadDownRequest = 0;
|
_preloadDownRequest = 0;
|
||||||
preloadHistoryIfNeeded();
|
preloadHistoryIfNeeded();
|
||||||
if (_history->loadedAtBottom()) {
|
if (_history->loadedAtBottom()) {
|
||||||
App::wnd()->checkHistoryActivation();
|
checkHistoryActivation();
|
||||||
}
|
}
|
||||||
} else if (_firstLoadRequest == requestId) {
|
} else if (_firstLoadRequest == requestId) {
|
||||||
if (toMigrated) {
|
if (toMigrated) {
|
||||||
@ -3138,7 +3138,7 @@ void HistoryWidget::doneShow() {
|
|||||||
handlePendingHistoryUpdate();
|
handlePendingHistoryUpdate();
|
||||||
}
|
}
|
||||||
preloadHistoryIfNeeded();
|
preloadHistoryIfNeeded();
|
||||||
App::wnd()->checkHistoryActivation();
|
checkHistoryActivation();
|
||||||
App::wnd()->setInnerFocus();
|
App::wnd()->setInnerFocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4986,7 +4986,6 @@ int HistoryWidget::countAutomaticScrollTop() {
|
|||||||
if (history->unreadBar() != nullptr) {
|
if (history->unreadBar() != nullptr) {
|
||||||
setMsgId(ShowAtUnreadMsgId);
|
setMsgId(ShowAtUnreadMsgId);
|
||||||
result = countInitialScrollTop();
|
result = countInitialScrollTop();
|
||||||
App::wnd()->checkHistoryActivation();
|
|
||||||
if (session().supportMode()) {
|
if (session().supportMode()) {
|
||||||
history->unsetFirstUnreadMessage();
|
history->unsetFirstUnreadMessage();
|
||||||
}
|
}
|
||||||
@ -5109,7 +5108,7 @@ void HistoryWidget::updateHistoryGeometry(
|
|||||||
_historyInited = true;
|
_historyInited = true;
|
||||||
_scrollToAnimation.stop();
|
_scrollToAnimation.stop();
|
||||||
}
|
}
|
||||||
auto newScrollTop = initial
|
const auto newScrollTop = initial
|
||||||
? countInitialScrollTop()
|
? countInitialScrollTop()
|
||||||
: countAutomaticScrollTop();
|
: countAutomaticScrollTop();
|
||||||
if (_scroll->scrollTop() == newScrollTop) {
|
if (_scroll->scrollTop() == newScrollTop) {
|
||||||
|
@ -127,14 +127,8 @@ TextSelection ShiftItemSelection(
|
|||||||
return ShiftItemSelection(selection, byText.length());
|
return ShiftItemSelection(selection, byText.length());
|
||||||
}
|
}
|
||||||
|
|
||||||
void UnreadBar::init(int newCount) {
|
void UnreadBar::init() {
|
||||||
if (freezed) {
|
text = tr::lng_unread_bar_some(tr::now);
|
||||||
return;
|
|
||||||
}
|
|
||||||
count = newCount;
|
|
||||||
text = /*(count == kCountUnknown) // #feed
|
|
||||||
? tr::lng_unread_bar_some(tr::now)
|
|
||||||
: */tr::lng_unread_bar(tr::now, lt_count, count);
|
|
||||||
width = st::semiboldFont->width(text);
|
width = st::semiboldFont->width(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -416,6 +410,18 @@ bool Element::computeIsAttachToPrevious(not_null<Element*> previous) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Element::createUnreadBar() {
|
||||||
|
if (!AddComponents(UnreadBar::Bit())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const auto bar = Get<UnreadBar>();
|
||||||
|
bar->init();
|
||||||
|
if (data()->mainView() == this) {
|
||||||
|
recountAttachToPreviousInBlocks();
|
||||||
|
}
|
||||||
|
history()->owner().requestViewResize(this);
|
||||||
|
}
|
||||||
|
|
||||||
void Element::destroyUnreadBar() {
|
void Element::destroyUnreadBar() {
|
||||||
if (!Has<UnreadBar>()) {
|
if (!Has<UnreadBar>()) {
|
||||||
return;
|
return;
|
||||||
@ -427,29 +433,6 @@ void Element::destroyUnreadBar() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Element::setUnreadBarCount(int count) {
|
|
||||||
const auto changed = AddComponents(UnreadBar::Bit());
|
|
||||||
const auto bar = Get<UnreadBar>();
|
|
||||||
if (bar->freezed) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
bar->init(count);
|
|
||||||
if (changed) {
|
|
||||||
if (data()->mainView() == this) {
|
|
||||||
recountAttachToPreviousInBlocks();
|
|
||||||
}
|
|
||||||
history()->owner().requestViewResize(this);
|
|
||||||
} else {
|
|
||||||
history()->owner().requestViewRepaint(this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void Element::setUnreadBarFreezed() {
|
|
||||||
if (const auto bar = Get<UnreadBar>()) {
|
|
||||||
bar->freezed = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int Element::displayedDateHeight() const {
|
int Element::displayedDateHeight() const {
|
||||||
if (auto date = Get<DateBadge>()) {
|
if (auto date = Get<DateBadge>()) {
|
||||||
return date->height();
|
return date->height();
|
||||||
|
@ -96,26 +96,15 @@ TextSelection ShiftItemSelection(
|
|||||||
// Any HistoryView::Element can have this Component for
|
// Any HistoryView::Element can have this Component for
|
||||||
// displaying the unread messages bar above the message.
|
// displaying the unread messages bar above the message.
|
||||||
struct UnreadBar : public RuntimeComponent<UnreadBar, Element> {
|
struct UnreadBar : public RuntimeComponent<UnreadBar, Element> {
|
||||||
void init(int newCount);
|
void init();
|
||||||
|
|
||||||
static int height();
|
static int height();
|
||||||
static int marginTop();
|
static int marginTop();
|
||||||
|
|
||||||
void paint(Painter &p, int y, int w) const;
|
void paint(Painter &p, int y, int w) const;
|
||||||
|
|
||||||
static constexpr auto kCountUnknown = std::numeric_limits<int>::max();
|
|
||||||
|
|
||||||
QString text;
|
QString text;
|
||||||
int width = 0;
|
int width = 0;
|
||||||
int count = 0;
|
|
||||||
|
|
||||||
// If unread bar is freezed the new messages do not
|
|
||||||
// increment the counter displayed by this bar.
|
|
||||||
//
|
|
||||||
// It happens when we've opened the conversation and
|
|
||||||
// we've seen the bar and new messages are marked as read
|
|
||||||
// as soon as they are added to the chat history.
|
|
||||||
bool freezed = false;
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -192,14 +181,9 @@ public:
|
|||||||
|
|
||||||
bool computeIsAttachToPrevious(not_null<Element*> previous);
|
bool computeIsAttachToPrevious(not_null<Element*> previous);
|
||||||
|
|
||||||
void setUnreadBarCount(int count);
|
void createUnreadBar();
|
||||||
void destroyUnreadBar();
|
void destroyUnreadBar();
|
||||||
|
|
||||||
// marks the unread bar as freezed so that unread
|
|
||||||
// messages count will not change for this bar
|
|
||||||
// when the new messages arrive in this chat history
|
|
||||||
void setUnreadBarFreezed();
|
|
||||||
|
|
||||||
int displayedDateHeight() const;
|
int displayedDateHeight() const;
|
||||||
bool displayDate() const;
|
bool displayDate() const;
|
||||||
bool isInOneDayWithPrevious() const;
|
bool isInOneDayWithPrevious() const;
|
||||||
|
@ -462,7 +462,7 @@ void ListWidget::checkUnreadBarCreation() {
|
|||||||
if (!_unreadBarElement) {
|
if (!_unreadBarElement) {
|
||||||
if (const auto index = _delegate->listUnreadBarView(_items)) {
|
if (const auto index = _delegate->listUnreadBarView(_items)) {
|
||||||
_unreadBarElement = _items[*index].get();
|
_unreadBarElement = _items[*index].get();
|
||||||
_unreadBarElement->setUnreadBarCount(UnreadBar::kCountUnknown);
|
_unreadBarElement->createUnreadBar();
|
||||||
refreshAttachmentsAtIndex(*index);
|
refreshAttachmentsAtIndex(*index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2497,14 +2497,9 @@ void ListWidget::viewReplaced(not_null<const Element*> was, Element *now) {
|
|||||||
if (_overElement == was) _overElement = now;
|
if (_overElement == was) _overElement = now;
|
||||||
if (_unreadBarElement == was) {
|
if (_unreadBarElement == was) {
|
||||||
const auto bar = _unreadBarElement->Get<UnreadBar>();
|
const auto bar = _unreadBarElement->Get<UnreadBar>();
|
||||||
const auto count = bar ? bar->count : 0;
|
|
||||||
const auto freezed = bar ? bar->freezed : false;
|
|
||||||
_unreadBarElement = now;
|
_unreadBarElement = now;
|
||||||
if (now && count) {
|
if (now && bar) {
|
||||||
_unreadBarElement->setUnreadBarCount(count);
|
_unreadBarElement->createUnreadBar();
|
||||||
if (freezed) {
|
|
||||||
_unreadBarElement->setUnreadBarFreezed();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user