mirror of
https://github.com/AyuGram/AyuGramDesktop.git
synced 2025-06-05 06:33:57 +02:00
Added initial boosts list to boost info.
This commit is contained in:
parent
8041941565
commit
f61c22b065
4 changed files with 222 additions and 4 deletions
|
@ -10,6 +10,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "api/api_statistics.h"
|
#include "api/api_statistics.h"
|
||||||
#include "boxes/peers/edit_peer_invite_link.h"
|
#include "boxes/peers/edit_peer_invite_link.h"
|
||||||
#include "info/info_controller.h"
|
#include "info/info_controller.h"
|
||||||
|
#include "info/statistics/info_statistics_list_controllers.h"
|
||||||
#include "lang/lang_keys.h"
|
#include "lang/lang_keys.h"
|
||||||
#include "settings/settings_common.h"
|
#include "settings/settings_common.h"
|
||||||
#include "statistics/widgets/chart_header_widget.h"
|
#include "statistics/widgets/chart_header_widget.h"
|
||||||
|
@ -211,6 +212,35 @@ InnerWidget::InnerWidget(
|
||||||
|
|
||||||
FillOverview(inner, status);
|
FillOverview(inner, status);
|
||||||
|
|
||||||
|
::Settings::AddSkip(inner);
|
||||||
|
::Settings::AddDivider(inner);
|
||||||
|
::Settings::AddSkip(inner);
|
||||||
|
|
||||||
|
if (status.firstSlice.total > 0) {
|
||||||
|
::Settings::AddSkip(inner);
|
||||||
|
using PeerPtr = not_null<PeerData*>;
|
||||||
|
const auto header = inner->add(
|
||||||
|
object_ptr<Statistic::Header>(inner),
|
||||||
|
st::statisticsLayerMargins);
|
||||||
|
header->resizeToWidth(header->width());
|
||||||
|
header->setTitle(tr::lng_boosts_list_title(
|
||||||
|
tr::now,
|
||||||
|
lt_count,
|
||||||
|
status.firstSlice.total));
|
||||||
|
header->setSubTitle({});
|
||||||
|
Statistics::AddBoostsList(
|
||||||
|
status.firstSlice,
|
||||||
|
inner,
|
||||||
|
[=](PeerPtr p) { controller->showPeerInfo(p); },
|
||||||
|
peer,
|
||||||
|
tr::lng_boosts_title());
|
||||||
|
::Settings::AddSkip(inner);
|
||||||
|
::Settings::AddDividerText(
|
||||||
|
inner,
|
||||||
|
tr::lng_boosts_list_subtext());
|
||||||
|
::Settings::AddSkip(inner);
|
||||||
|
}
|
||||||
|
|
||||||
::Settings::AddSkip(inner);
|
::Settings::AddSkip(inner);
|
||||||
AddHeader(inner, tr::lng_boosts_link_title);
|
AddHeader(inner, tr::lng_boosts_link_title);
|
||||||
FillShareLink(inner, _show, status.link, peer);
|
FillShareLink(inner, _show, status.link, peer);
|
||||||
|
|
|
@ -9,6 +9,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
|
|
||||||
#include "api/api_statistics.h"
|
#include "api/api_statistics.h"
|
||||||
#include "boxes/peer_list_controllers.h"
|
#include "boxes/peer_list_controllers.h"
|
||||||
|
#include "data/data_boosts.h"
|
||||||
#include "data/data_channel.h"
|
#include "data/data_channel.h"
|
||||||
#include "data/data_session.h"
|
#include "data/data_session.h"
|
||||||
#include "data/data_user.h"
|
#include "data/data_user.h"
|
||||||
|
@ -16,14 +17,40 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "lang/lang_keys.h"
|
#include "lang/lang_keys.h"
|
||||||
#include "main/main_session.h"
|
#include "main/main_session.h"
|
||||||
#include "settings/settings_common.h"
|
#include "settings/settings_common.h"
|
||||||
|
#include "ui/effects/toggle_arrow.h"
|
||||||
|
#include "ui/painter.h"
|
||||||
|
#include "ui/rect.h"
|
||||||
#include "ui/widgets/buttons.h"
|
#include "ui/widgets/buttons.h"
|
||||||
#include "ui/wrap/slide_wrap.h"
|
#include "ui/wrap/slide_wrap.h"
|
||||||
#include "ui/wrap/vertical_layout.h"
|
#include "ui/wrap/vertical_layout.h"
|
||||||
#include "styles/style_settings.h"
|
#include "styles/style_settings.h"
|
||||||
|
#include "styles/style_statistics.h"
|
||||||
|
#include "styles/style_window.h"
|
||||||
|
|
||||||
namespace Info::Statistics {
|
namespace Info::Statistics {
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
void AddArrow(not_null<Ui::RpWidget*> parent) {
|
||||||
|
const auto arrow = Ui::CreateChild<Ui::RpWidget>(parent.get());
|
||||||
|
arrow->paintRequest(
|
||||||
|
) | rpl::start_with_next([=](const QRect &r) {
|
||||||
|
auto p = QPainter(arrow);
|
||||||
|
|
||||||
|
const auto path = Ui::ToggleUpDownArrowPath(
|
||||||
|
st::statisticsShowMoreButtonArrowSize,
|
||||||
|
st::statisticsShowMoreButtonArrowSize,
|
||||||
|
st::statisticsShowMoreButtonArrowSize,
|
||||||
|
st::mainMenuToggleFourStrokes,
|
||||||
|
0.);
|
||||||
|
|
||||||
|
auto hq = PainterHighQualityEnabler(p);
|
||||||
|
p.fillPath(path, st::lightButtonFg);
|
||||||
|
}, arrow->lifetime());
|
||||||
|
arrow->resize(Size(st::statisticsShowMoreButtonArrowSize * 2));
|
||||||
|
arrow->move(st::statisticsShowMoreButtonArrowPosition);
|
||||||
|
arrow->show();
|
||||||
|
}
|
||||||
|
|
||||||
void AddSubsectionTitle(
|
void AddSubsectionTitle(
|
||||||
not_null<Ui::VerticalLayout*> container,
|
not_null<Ui::VerticalLayout*> container,
|
||||||
rpl::producer<QString> title) {
|
rpl::producer<QString> title) {
|
||||||
|
@ -71,6 +98,12 @@ struct MembersDescriptor final {
|
||||||
Data::SupergroupStatistics data;
|
Data::SupergroupStatistics data;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct BoostsDescriptor final {
|
||||||
|
Data::BoostsListSlice firstSlice;
|
||||||
|
Fn<void(not_null<PeerData*>)> showPeerInfo;
|
||||||
|
not_null<PeerData*> peer;
|
||||||
|
};
|
||||||
|
|
||||||
class PeerListRowWithMsgId : public PeerListRow {
|
class PeerListRowWithMsgId : public PeerListRow {
|
||||||
public:
|
public:
|
||||||
using PeerListRow::PeerListRow;
|
using PeerListRow::PeerListRow;
|
||||||
|
@ -198,7 +231,7 @@ public:
|
||||||
void loadMoreRows() override;
|
void loadMoreRows() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool appendRow(not_null<PeerData*> peer, MsgId msgId);
|
void appendRow(not_null<PeerData*> peer, MsgId msgId);
|
||||||
void applySlice(const Data::PublicForwardsSlice &slice);
|
void applySlice(const Data::PublicForwardsSlice &slice);
|
||||||
|
|
||||||
const not_null<Main::Session*> _session;
|
const not_null<Main::Session*> _session;
|
||||||
|
@ -257,11 +290,11 @@ void PublicForwardsController::rowClicked(not_null<PeerListRow*> row) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PublicForwardsController::appendRow(
|
void PublicForwardsController::appendRow(
|
||||||
not_null<PeerData*> peer,
|
not_null<PeerData*> peer,
|
||||||
MsgId msgId) {
|
MsgId msgId) {
|
||||||
if (delegate()->peerListFindRow(peer->id.value)) {
|
if (delegate()->peerListFindRow(peer->id.value)) {
|
||||||
return false;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto row = std::make_unique<PeerListRowWithMsgId>(peer);
|
auto row = std::make_unique<PeerListRowWithMsgId>(peer);
|
||||||
|
@ -285,7 +318,94 @@ bool PublicForwardsController::appendRow(
|
||||||
row->setCustomStatus(resultText);
|
row->setCustomStatus(resultText);
|
||||||
|
|
||||||
delegate()->peerListAppendRow(std::move(row));
|
delegate()->peerListAppendRow(std::move(row));
|
||||||
return true;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
class BoostsController final : public PeerListController {
|
||||||
|
public:
|
||||||
|
explicit BoostsController(BoostsDescriptor d);
|
||||||
|
|
||||||
|
Main::Session &session() const override;
|
||||||
|
void prepare() override;
|
||||||
|
void rowClicked(not_null<PeerListRow*> row) override;
|
||||||
|
void loadMoreRows() override;
|
||||||
|
|
||||||
|
[[nodiscard]] bool skipRequest() const;
|
||||||
|
void setLimit(int limit);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void applySlice(const Data::BoostsListSlice &slice);
|
||||||
|
|
||||||
|
const not_null<Main::Session*> _session;
|
||||||
|
Fn<void(not_null<PeerData*>)> _showPeerInfo;
|
||||||
|
|
||||||
|
Api::Boosts _api;
|
||||||
|
Data::BoostsListSlice _firstSlice;
|
||||||
|
Data::BoostsListSlice::OffsetToken _apiToken;
|
||||||
|
|
||||||
|
int _limit = 0;
|
||||||
|
|
||||||
|
bool _allLoaded = false;
|
||||||
|
bool _requesting = false;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
BoostsController::BoostsController(BoostsDescriptor d)
|
||||||
|
: _session(&d.peer->session())
|
||||||
|
, _showPeerInfo(std::move(d.showPeerInfo))
|
||||||
|
, _api(d.peer)
|
||||||
|
, _firstSlice(std::move(d.firstSlice)) {
|
||||||
|
}
|
||||||
|
|
||||||
|
Main::Session &BoostsController::session() const {
|
||||||
|
return *_session;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool BoostsController::skipRequest() const {
|
||||||
|
return _requesting || _allLoaded;
|
||||||
|
}
|
||||||
|
|
||||||
|
void BoostsController::setLimit(int limit) {
|
||||||
|
_limit = limit;
|
||||||
|
_requesting = true;
|
||||||
|
_api.requestBoosts(_apiToken, [=](const Data::BoostsListSlice &slice) {
|
||||||
|
_requesting = false;
|
||||||
|
applySlice(slice);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
void BoostsController::prepare() {
|
||||||
|
applySlice(base::take(_firstSlice));
|
||||||
|
delegate()->peerListRefreshRows();
|
||||||
|
}
|
||||||
|
|
||||||
|
void BoostsController::loadMoreRows() {
|
||||||
|
}
|
||||||
|
|
||||||
|
void BoostsController::applySlice(const Data::BoostsListSlice &slice) {
|
||||||
|
_allLoaded = slice.allLoaded;
|
||||||
|
_apiToken = slice.token;
|
||||||
|
|
||||||
|
const auto formatter = u"MMM d, yyyy"_q;
|
||||||
|
for (const auto &item : slice.list) {
|
||||||
|
const auto user = session().data().user(item.userId);
|
||||||
|
if (delegate()->peerListFindRow(user->id.value)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
auto row = std::make_unique<PeerListRow>(user);
|
||||||
|
row->setCustomStatus(tr::lng_boosts_list_status(
|
||||||
|
tr::now,
|
||||||
|
lt_date,
|
||||||
|
QLocale().toString(item.expirationDate, formatter)));
|
||||||
|
delegate()->peerListAppendRow(std::move(row));
|
||||||
|
}
|
||||||
|
delegate()->peerListRefreshRows();
|
||||||
|
}
|
||||||
|
|
||||||
|
void BoostsController::rowClicked(not_null<PeerListRow*> row) {
|
||||||
|
crl::on_main([=, peer = row->peer()] {
|
||||||
|
_showPeerInfo(peer);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
@ -388,4 +508,53 @@ void AddMembersList(
|
||||||
showMore();
|
showMore();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AddBoostsList(
|
||||||
|
const Data::BoostsListSlice &firstSlice,
|
||||||
|
not_null<Ui::VerticalLayout*> container,
|
||||||
|
Fn<void(not_null<PeerData*>)> showPeerInfo,
|
||||||
|
not_null<PeerData*> peer,
|
||||||
|
rpl::producer<QString> title) {
|
||||||
|
const auto max = firstSlice.total;
|
||||||
|
struct State final {
|
||||||
|
State(BoostsDescriptor d) : controller(std::move(d)) {
|
||||||
|
}
|
||||||
|
PeerListContentDelegateSimple delegate;
|
||||||
|
BoostsController controller;
|
||||||
|
int limit = Api::Boosts::kFirstSlice;
|
||||||
|
};
|
||||||
|
auto d = BoostsDescriptor{ firstSlice, std::move(showPeerInfo), peer };
|
||||||
|
const auto state = container->lifetime().make_state<State>(std::move(d));
|
||||||
|
|
||||||
|
state->delegate.setContent(container->add(
|
||||||
|
object_ptr<PeerListContent>(container, &state->controller)));
|
||||||
|
state->controller.setDelegate(&state->delegate);
|
||||||
|
|
||||||
|
const auto wrap = container->add(
|
||||||
|
object_ptr<Ui::SlideWrap<Ui::SettingsButton>>(
|
||||||
|
container,
|
||||||
|
object_ptr<Ui::SettingsButton>(
|
||||||
|
container,
|
||||||
|
tr::lng_boosts_show_more(),
|
||||||
|
st::statisticsShowMoreButton)),
|
||||||
|
{ 0, -st::settingsButton.padding.top(), 0, 0 });
|
||||||
|
const auto button = wrap->entity();
|
||||||
|
AddArrow(button);
|
||||||
|
|
||||||
|
const auto showMore = [=] {
|
||||||
|
if (state->controller.skipRequest()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
state->limit = std::min(int(max), state->limit + Api::Boosts::kLimit);
|
||||||
|
state->controller.setLimit(state->limit);
|
||||||
|
if (state->limit == max) {
|
||||||
|
wrap->toggle(false, anim::type::instant);
|
||||||
|
}
|
||||||
|
container->resizeToWidth(container->width());
|
||||||
|
};
|
||||||
|
button->setClickedCallback(showMore);
|
||||||
|
if (state->limit == max) {
|
||||||
|
wrap->toggle(false, anim::type::instant);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Info::Statistics
|
} // namespace Info::Statistics
|
||||||
|
|
|
@ -14,6 +14,7 @@ class VerticalLayout;
|
||||||
} // namespace Ui
|
} // namespace Ui
|
||||||
|
|
||||||
namespace Data {
|
namespace Data {
|
||||||
|
struct BoostsListSlice;
|
||||||
struct PublicForwardsSlice;
|
struct PublicForwardsSlice;
|
||||||
struct SupergroupStatistics;
|
struct SupergroupStatistics;
|
||||||
} // namespace Data
|
} // namespace Data
|
||||||
|
@ -34,4 +35,11 @@ void AddMembersList(
|
||||||
not_null<PeerData*> peer,
|
not_null<PeerData*> peer,
|
||||||
rpl::producer<QString> title);
|
rpl::producer<QString> title);
|
||||||
|
|
||||||
|
void AddBoostsList(
|
||||||
|
const Data::BoostsListSlice &firstSlice,
|
||||||
|
not_null<Ui::VerticalLayout*> container,
|
||||||
|
Fn<void(not_null<PeerData*>)> showPeerInfo,
|
||||||
|
not_null<PeerData*> peer,
|
||||||
|
rpl::producer<QString> title);
|
||||||
|
|
||||||
} // namespace Info::Statistics
|
} // namespace Info::Statistics
|
||||||
|
|
|
@ -104,6 +104,17 @@ statisticsRecentPostButton: SettingsButton(defaultSettingsButton) {
|
||||||
height: 56px;
|
height: 56px;
|
||||||
padding: margins(7px, 0px, 24px, 0px);
|
padding: margins(7px, 0px, 24px, 0px);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
statisticsShowMoreButton: SettingsButton(defaultSettingsButton) {
|
||||||
|
textFg: lightButtonFg;
|
||||||
|
textFgOver: lightButtonFgOver;
|
||||||
|
|
||||||
|
padding: margins(73px, 10px, 22px, 8px);
|
||||||
|
}
|
||||||
|
|
||||||
|
statisticsShowMoreButtonArrowPosition: point(29px, 13px);
|
||||||
|
statisticsShowMoreButtonArrowSize: 7px;
|
||||||
|
|
||||||
boostsButton: SettingsButton(defaultSettingsButton) {
|
boostsButton: SettingsButton(defaultSettingsButton) {
|
||||||
textFg: lightButtonFg;
|
textFg: lightButtonFg;
|
||||||
textFgOver: lightButtonFgOver;
|
textFgOver: lightButtonFgOver;
|
||||||
|
|
Loading…
Add table
Reference in a new issue