mirror of https://github.com/procxx/kepka.git
Display empty event log placeholder.
Also hide the filter button for now.
This commit is contained in:
parent
ae56c5266f
commit
8c04bed572
|
@ -1321,7 +1321,7 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
|||
"lng_admin_log_no_results_title" = "No events found";
|
||||
"lng_admin_log_no_results_text" = "No recent events that match your query have been found.";
|
||||
"lng_admin_log_no_events_title" = "No events yet";
|
||||
"lng_admin_log_no_events_text" = "There were no service actions taken by the group's members and admins in the last 48 hours.";
|
||||
"lng_admin_log_no_events_text" = "There were no service actions\ntaken by the group's members\nand admins in the last 48 hours.";
|
||||
|
||||
"lng_admin_log_empty_text" = "Empty";
|
||||
"lng_admin_log_changed_title_group" = "{from} changed group name to «{title}»";
|
||||
|
|
|
@ -445,3 +445,6 @@ historyVideoMessageMute: icon {{ "volume_mute", historyFileThumbIconFg }};
|
|||
historyVideoMessageMuteSelected: icon {{ "volume_mute", historyFileThumbIconFgSelected }};
|
||||
historyVideoMessageMuteSize: 25px;
|
||||
historyVideoMessageProgressOpacity: 0.72;
|
||||
|
||||
historyAdminLogEmptyWidth: 260px;
|
||||
historyAdminLogEmptyPadding: margins(10px, 12px, 10px, 12px);
|
||||
|
|
|
@ -38,7 +38,8 @@ namespace AdminLog {
|
|||
namespace {
|
||||
|
||||
constexpr auto kScrollDateHideTimeout = 1000;
|
||||
constexpr auto kEventsPerPage = 1;
|
||||
constexpr auto kEventsFirstPage = 20;
|
||||
constexpr auto kEventsPerPage = 50;
|
||||
|
||||
} // namespace
|
||||
|
||||
|
@ -203,7 +204,8 @@ InnerWidget::InnerWidget(QWidget *parent, gsl::not_null<Window::Controller*> con
|
|||
, _channel(channel)
|
||||
, _history(App::history(channel))
|
||||
, _scrollTo(std::move(scrollTo))
|
||||
, _scrollDateCheck([this] { scrollDateCheck(); }) {
|
||||
, _scrollDateCheck([this] { scrollDateCheck(); })
|
||||
, _emptyText(st::historyAdminLogEmptyWidth - st::historyAdminLogEmptyPadding.left() - st::historyAdminLogEmptyPadding.left()) {
|
||||
setMouseTracking(true);
|
||||
_scrollDateHideTimer.setCallback([this] { scrollDateHideByTimer(); });
|
||||
subscribe(AuthSession::Current().data().repaintLogEntry(), [this](gsl::not_null<const HistoryItem*> historyItem) {
|
||||
|
@ -221,6 +223,7 @@ InnerWidget::InnerWidget(QWidget *parent, gsl::not_null<Window::Controller*> con
|
|||
*query.isVisible = true;
|
||||
}
|
||||
});
|
||||
updateEmptyText();
|
||||
}
|
||||
|
||||
void InnerWidget::setVisibleTopBottom(int visibleTop, int visibleBottom) {
|
||||
|
@ -311,6 +314,17 @@ void InnerWidget::checkPreloadMore() {
|
|||
void InnerWidget::applyFilter(MTPDchannelAdminLogEventsFilter::Flags flags, const std::vector<gsl::not_null<UserData*>> &admins) {
|
||||
_filterFlags = flags;
|
||||
_filterAdmins = admins;
|
||||
updateEmptyText();
|
||||
}
|
||||
|
||||
void InnerWidget::updateEmptyText() {
|
||||
auto options = _defaultOptions;
|
||||
options.flags |= TextParseMono; // For italic :/
|
||||
auto hasFilter = (_filterFlags != 0) || !_filterAdmins.empty();
|
||||
auto text = TextWithEntities { lang(hasFilter ? lng_admin_log_no_results_title : lng_admin_log_no_events_title) };
|
||||
text.entities.append(EntityInText(EntityInTextBold, 0, text.text.size()));
|
||||
text.text.append(qstr("\n\n") + lang(hasFilter ? lng_admin_log_no_results_text : lng_admin_log_no_events_text));
|
||||
_emptyText.setMarkedText(st::defaultTextStyle, text, options);
|
||||
}
|
||||
|
||||
QString InnerWidget::tooltipText() const {
|
||||
|
@ -374,7 +388,8 @@ void InnerWidget::preloadMore(Direction direction) {
|
|||
auto query = QString();
|
||||
auto maxId = (direction == Direction::Up) ? _minId : 0;
|
||||
auto minId = (direction == Direction::Up) ? 0 : _maxId;
|
||||
requestId = request(MTPchannels_GetAdminLog(MTP_flags(flags), _channel->inputChannel, MTP_string(query), filter, MTP_vector<MTPInputUser>(admins), MTP_long(maxId), MTP_long(minId), MTP_int(kEventsPerPage))).done([this, &requestId, &loadedFlag, direction](const MTPchannels_AdminLogResults &result) {
|
||||
auto perPage = _items.empty() ? kEventsFirstPage : kEventsPerPage;
|
||||
requestId = request(MTPchannels_GetAdminLog(MTP_flags(flags), _channel->inputChannel, MTP_string(query), filter, MTP_vector<MTPInputUser>(admins), MTP_long(maxId), MTP_long(minId), MTP_int(perPage))).done([this, &requestId, &loadedFlag, direction](const MTPchannels_AdminLogResults &result) {
|
||||
Expects(result.type() == mtpc_channels_adminLogResults);
|
||||
requestId = 0;
|
||||
|
||||
|
@ -568,14 +583,15 @@ void InnerWidget::paintEvent(QPaintEvent *e) {
|
|||
}
|
||||
|
||||
void InnerWidget::paintEmpty(Painter &p) {
|
||||
//style::font font(st::msgServiceFont);
|
||||
//int32 w = font->width(lang(lng_willbe_history)) + st::msgPadding.left() + st::msgPadding.right(), h = font->height + st::msgServicePadding.top() + st::msgServicePadding.bottom() + 2;
|
||||
//QRect tr((width() - w) / 2, (height() - _field->height() - 2 * st::historySendPadding - h) / 2, w, h);
|
||||
//HistoryLayout::ServiceMessagePainter::paintBubble(p, tr.x(), tr.y(), tr.width(), tr.height());
|
||||
style::font font(st::msgServiceFont);
|
||||
auto rectWidth = st::historyAdminLogEmptyWidth;
|
||||
auto innerWidth = rectWidth - st::historyAdminLogEmptyPadding.left() - st::historyAdminLogEmptyPadding.right();
|
||||
auto rectHeight = st::historyAdminLogEmptyPadding.top() + _emptyText.countHeight(innerWidth) + st::historyAdminLogEmptyPadding.bottom();
|
||||
auto rect = QRect((width() - rectWidth) / 2, (height() - rectHeight) / 3, rectWidth, rectHeight);
|
||||
HistoryLayout::ServiceMessagePainter::paintBubble(p, rect.x(), rect.y(), rect.width(), rect.height());
|
||||
|
||||
//p.setPen(st::msgServiceFg);
|
||||
//p.setFont(font->f);
|
||||
//p.drawText(tr.left() + st::msgPadding.left(), tr.top() + st::msgServicePadding.top() + 1 + font->ascent, lang(lng_willbe_history));
|
||||
p.setPen(st::msgServiceFg);
|
||||
_emptyText.draw(p, rect.x() + st::historyAdminLogEmptyPadding.left(), rect.y() + st::historyAdminLogEmptyPadding.top(), innerWidth, style::al_top);
|
||||
}
|
||||
|
||||
TextWithEntities InnerWidget::getSelectedText() const {
|
||||
|
|
|
@ -152,6 +152,7 @@ private:
|
|||
void itemsAdded(Direction direction);
|
||||
void updateSize();
|
||||
void updateMinMaxIds();
|
||||
void updateEmptyText();
|
||||
void paintEmpty(Painter &p);
|
||||
|
||||
void toggleScrollDateShown();
|
||||
|
@ -218,6 +219,7 @@ private:
|
|||
// Don't load anything until the memento was read.
|
||||
bool _upLoaded = true;
|
||||
bool _downLoaded = true;
|
||||
Text _emptyText;
|
||||
|
||||
MouseAction _mouseAction = MouseAction::None;
|
||||
TextSelectType _mouseSelectType = TextSelectType::Letters;
|
||||
|
|
|
@ -73,6 +73,7 @@ FixedBar::FixedBar(QWidget *parent) : TWidget(parent)
|
|||
_backButton->moveToLeft(0, 0);
|
||||
_backButton->setClickedCallback([this] { goBack(); });
|
||||
_filter->setClickedCallback([this] {});
|
||||
_filter->hide();
|
||||
}
|
||||
|
||||
void FixedBar::applyFilter(MTPDchannelAdminLogEventsFilter::Flags flags, const std::vector<gsl::not_null<UserData*>> &admins) {
|
||||
|
@ -88,7 +89,7 @@ int FixedBar::resizeGetHeight(int newWidth) {
|
|||
auto newHeight = 0;
|
||||
|
||||
auto buttonLeft = newWidth;
|
||||
buttonLeft -= _filter->width(); _filter->moveToLeft(buttonLeft, 0);
|
||||
//buttonLeft -= _filter->width(); _filter->moveToLeft(buttonLeft, 0);
|
||||
_backButton->resizeToWidth(buttonLeft);
|
||||
_backButton->moveToLeft(0, 0);
|
||||
newHeight += _backButton->height();
|
||||
|
@ -106,6 +107,7 @@ void FixedBar::setAnimatingMode(bool enabled) {
|
|||
} else {
|
||||
setAttribute(Qt::WA_OpaquePaintEvent);
|
||||
showChildren();
|
||||
_filter->hide();
|
||||
}
|
||||
show();
|
||||
}
|
||||
|
|
|
@ -4458,7 +4458,7 @@ HistoryLocation::HistoryLocation(gsl::not_null<HistoryItem*> parent, const Locat
|
|||
, _data(App::location(coords))
|
||||
, _title(st::msgMinWidth)
|
||||
, _description(st::msgMinWidth)
|
||||
, _link(new LocationClickHandler(coords)) {
|
||||
, _link(MakeShared<LocationClickHandler>(coords)) {
|
||||
if (!title.isEmpty()) {
|
||||
_title.setText(st::webPageTitleStyle, textClean(title), _webpageTitleOptions);
|
||||
}
|
||||
|
@ -4474,7 +4474,7 @@ HistoryLocation::HistoryLocation(gsl::not_null<HistoryItem*> parent, const Histo
|
|||
, _data(other._data)
|
||||
, _title(other._title)
|
||||
, _description(other._description)
|
||||
, _link(new LocationClickHandler(_data->coords)) {
|
||||
, _link(MakeShared<LocationClickHandler>(_data->coords)) {
|
||||
}
|
||||
|
||||
void HistoryLocation::initDimensions() {
|
||||
|
|
|
@ -169,9 +169,9 @@ PluralResult Plural(ushort keyBase, float64 value) {
|
|||
auto shift = (useNonDefaultPlural ? ChoosePlural : ChoosePluralEn)((integer ? i : -1), i, v, w, f, t);
|
||||
auto string = langpack.getValue(LangKey(keyBase + shift));
|
||||
if (i == qCeil(n)) {
|
||||
return { string, QString::number(value) };
|
||||
return { string, QString::number(qRound(value)) };
|
||||
}
|
||||
return { string, QString::number(qRound(value)) };
|
||||
return { string, QString::number(value) };
|
||||
}
|
||||
|
||||
void UpdatePluralRules(const QString &languageId) {
|
||||
|
|
Loading…
Reference in New Issue