Selected messages actions (forward, delete, cancel) redesigned.

This commit is contained in:
John Preston 2016-06-22 20:11:35 +03:00
parent 13b795d614
commit 701b8c87e6
14 changed files with 150 additions and 149 deletions

View File

@ -110,9 +110,11 @@ boxBlueCloseDuration: 150;
boxBlueShadow: sprite(132px, 108px, 1px, 4px);
boxButtonFont: font(boxFontSize semibold);
defaultBoxButton: BoxButton {
defaultBoxButton: RoundButton {
textFg: #2f9fea;
textFgOver: #2f9fea;
secondaryTextFg: #2f9fea;
secondaryTextFgOver: #2f9fea;
textBg: white;
textBgOver: #edf7ff;
@ -125,10 +127,10 @@ defaultBoxButton: BoxButton {
font: boxButtonFont;
duration: 200;
}
cancelBoxButton: BoxButton(defaultBoxButton) {
cancelBoxButton: RoundButton(defaultBoxButton) {
textFg: #aeaeae;
}
attentionBoxButton: BoxButton(defaultBoxButton) {
attentionBoxButton: RoundButton(defaultBoxButton) {
textFg: #ea4b2f;
textFgOver: #ea4b2f;
textBgOver: #fff0ed;
@ -985,10 +987,12 @@ topBarSearch: iconedButton(btnDefIconed) {
height: topBarHeight;
}
topBarMinPadding: 5px;
topBarButton: BoxButton {
topBarButton: RoundButton {
textFg: #0084c4;
textFgOver: #0084c4;
textBg: white;
secondaryTextFg: #0084c4;
secondaryTextFgOver: #0084c4;
textBg: windowBg;
textBgOver: #edf4f7;
width: -22px;
@ -1000,20 +1004,34 @@ topBarButton: BoxButton {
font: font(fsize);
duration: 200;
}
topBarClearButton: BoxButton(topBarButton) {
padding: margins(8px, 14px, 8px, 14px);
}
topBarActionButton: flatButton(btnDefNext, btnDefBig) {
textTop: 8px;
overTextTop: 8px;
downTextTop: 9px;
defaultActiveButton: RoundButton {
textFg: #ffffff;
textFgOver: #ffffff;
secondaryTextFg: #cceeff;
secondaryTextFgOver: #cceeff;
textBg: windowActiveBg;
textBgOver: windowActiveBg;
font: font(fsize);
overFont: font(fsize);
width: 101px;
secondarySkip: 7px;
width: -34px;
height: 34px;
padding: margins(0px, 0px, 0px, 0px);
textTop: 8px;
font: semiboldFont;
duration: 200;
}
topBarActionSkip: 13px;
topBarClearButton: RoundButton(defaultActiveButton) {
textFg: semiboldButtonBlueText;
textFgOver: semiboldButtonBlueText;
textBg: #ffffff;
textBgOver: #f2f7fa;
width: -18px;
}
topBarActionSkip: 10px;
activeFadeInDuration: 500;
activeFadeOutDuration: 3000;
@ -1997,7 +2015,7 @@ botKbScroll: flatScroll(solidScroll) {
deltax: 3px;
width: 10px;
}
switchPmButton: BoxButton(defaultBoxButton) {
switchPmButton: RoundButton(defaultBoxButton) {
width: 320px;
height: 34px;
textTop: 7px;

View File

@ -309,12 +309,16 @@ botKeyboardButton {
downTextTop: pixels;
}
BoxButton {
RoundButton {
textFg: color;
textFgOver: color;
textBg: color; // rect of textBg with rounded rect of textBgOver upon it
textBgOver: color;
secondaryTextFg: color;
secondaryTextFgOver: color;
secondarySkip: pixels;
width: pixels;
height: pixels;
padding: margins;

View File

@ -35,7 +35,7 @@ TextParseOptions _confirmBoxTextOptions = {
Qt::LayoutDirectionAuto, // dir
};
ConfirmBox::ConfirmBox(const QString &text, const QString &doneText, const style::BoxButton &doneStyle, const QString &cancelText, const style::BoxButton &cancelStyle) : AbstractBox(st::boxWidth)
ConfirmBox::ConfirmBox(const QString &text, const QString &doneText, const style::RoundButton &doneStyle, const QString &cancelText, const style::RoundButton &cancelStyle) : AbstractBox(st::boxWidth)
, _informative(false)
, _text(100)
, _confirm(this, doneText.isEmpty() ? lang(lng_box_ok) : doneText, doneStyle)
@ -43,7 +43,7 @@ ConfirmBox::ConfirmBox(const QString &text, const QString &doneText, const style
init(text);
}
ConfirmBox::ConfirmBox(const QString &text, const QString &doneText, const style::BoxButton &doneStyle, bool informative) : AbstractBox(st::boxWidth)
ConfirmBox::ConfirmBox(const QString &text, const QString &doneText, const style::RoundButton &doneStyle, bool informative) : AbstractBox(st::boxWidth)
, _informative(true)
, _text(100)
, _confirm(this, doneText.isEmpty() ? lang(lng_box_ok) : doneText, doneStyle)

View File

@ -29,7 +29,7 @@ class ConfirmBox : public AbstractBox, public ClickHandlerHost {
public:
ConfirmBox(const QString &text, const QString &doneText = QString(), const style::BoxButton &doneStyle = st::defaultBoxButton, const QString &cancelText = QString(), const style::BoxButton &cancelStyle = st::cancelBoxButton);
ConfirmBox(const QString &text, const QString &doneText = QString(), const style::RoundButton &doneStyle = st::defaultBoxButton, const QString &cancelText = QString(), const style::RoundButton &cancelStyle = st::cancelBoxButton);
void keyPressEvent(QKeyEvent *e);
void paintEvent(QPaintEvent *e);
void resizeEvent(QResizeEvent *e);
@ -61,7 +61,7 @@ protected:
private:
ConfirmBox(const QString &text, const QString &doneText, const style::BoxButton &doneStyle, bool informative);
ConfirmBox(const QString &text, const QString &doneText, const style::RoundButton &doneStyle, bool informative);
friend class InformBox;
void init(const QString &text);
@ -80,7 +80,7 @@ private:
class InformBox : public ConfirmBox {
public:
InformBox(const QString &text, const QString &doneText = QString(), const style::BoxButton &doneStyle = st::defaultBoxButton) : ConfirmBox(text, doneText, doneStyle, true) {
InformBox(const QString &text, const QString &doneText = QString(), const style::RoundButton &doneStyle = st::defaultBoxButton) : ConfirmBox(text, doneText, doneStyle, true) {
}
};

View File

@ -89,13 +89,15 @@ dialogsTextStyleActive: textStyle(dialogsTextStyle) {
dialogsNewChatIcon: icon {
{ "dialogs_new_chat", #b7b7b7, point(9px, 10px) }
};
dialogsNewChatButton: BoxButton {
dialogsNewChatButton: RoundButton {
width: 36px;
height: 36px;
icon: dialogsNewChatIcon;
textFg: transparent;
textFgOver: transparent;
secondaryTextFg: transparent;
secondaryTextFgOver: transparent;
textBg: transparent;
textBgOver: transparent;
}

View File

@ -32,7 +32,7 @@ profileTopBarBackIconPosition: point(15px, 20px);
profileTopBarBackFont: font(14px);
profileTopBarBackFg: #1485c2;
profileTopBarBackPosition: point(32px, 17px);
profileFixedBarButton: BoxButton(topBarButton) {
profileFixedBarButton: RoundButton(topBarButton) {
}
profileMarginTop: 13px;
@ -61,22 +61,9 @@ profileMarginBottom: 30px;
profileButtonLeft: 27px;
profileButtonTop: 88px;
profileButtonSkip: 10px;
profilePrimaryButton: BoxButton {
textFg: #ffffff;
textFgOver: #ffffff;
textBg: windowActiveBg;
textBgOver: windowActiveBg;
width: -34px;
height: 34px;
padding: margins(0px, 0px, 0px, 0px);
textTop: 8px;
font: semiboldFont;
duration: 200;
profilePrimaryButton: RoundButton(defaultActiveButton) {
}
profileSecondaryButton: BoxButton(profilePrimaryButton) {
profileSecondaryButton: RoundButton(profilePrimaryButton) {
textFg: semiboldButtonBlueText;
textFgOver: semiboldButtonBlueText;
textBg: #ffffff;
@ -85,7 +72,7 @@ profileSecondaryButton: BoxButton(profilePrimaryButton) {
profileAddMemberIcon: icon {
{ "profile_add_member", windowActiveBg, point(20px, 10px) },
};
profileAddMemberButton: BoxButton(profileSecondaryButton) {
profileAddMemberButton: RoundButton(profileSecondaryButton) {
width: 62px;
icon: profileAddMemberIcon;
}

View File

@ -414,7 +414,7 @@ void CoverWidget::clearButtons() {
}
}
void CoverWidget::addButton(const QString &text, const char *slot, const style::BoxButton *replacementStyle) {
void CoverWidget::addButton(const QString &text, const char *slot, const style::RoundButton *replacementStyle) {
auto &buttonStyle = _buttons.isEmpty() ? st::profilePrimaryButton : st::profileSecondaryButton;
auto button = new Ui::RoundButton(this, text, buttonStyle);
button->setTextTransform(Ui::RoundButton::TextTransform::ToUpper);

View File

@ -95,7 +95,7 @@ private:
void setChannelButtons();
void clearButtons();
void addButton(const QString &text, const char *slot, const style::BoxButton *replacementStyle = nullptr);
void addButton(const QString &text, const char *slot, const style::RoundButton *replacementStyle = nullptr);
void paintDivider(Painter &p);

View File

@ -23,13 +23,14 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org
namespace Ui {
RoundButton::RoundButton(QWidget *parent, const QString &text, const style::BoxButton &st) : Button(parent)
RoundButton::RoundButton(QWidget *parent, const QString &text, const style::RoundButton &st) : Button(parent)
, _text(text)
, _fullText(text)
, _textWidth(st.font->width(_text))
, _st(st)
, a_textBgOverOpacity(0)
, a_textFg(st.textFg->c)
, a_secondaryTextFg(st.secondaryTextFg->c)
, _a_over(animation(this, &RoundButton::step_over)) {
resizeToText();
@ -46,6 +47,11 @@ void RoundButton::setText(const QString &text) {
updateText();
}
void RoundButton::setSecondaryText(const QString &secondaryText) {
_fullSecondaryText = secondaryText;
updateText();
}
void RoundButton::setFullWidth(int newFullWidth) {
_fullWidthOverride = newFullWidth;
resizeToText();
@ -54,58 +60,79 @@ void RoundButton::setFullWidth(int newFullWidth) {
void RoundButton::updateText() {
if (_transform == TextTransform::ToUpper) {
_text = _fullText.toUpper();
_secondaryText = _fullSecondaryText.toUpper();
} else {
_text = _fullText;
_secondaryText = _fullSecondaryText;
}
_textWidth = _st.font->width(_text);
_textWidth = _text.isEmpty() ? 0 : _st.font->width(_text);
_secondaryTextWidth = _secondaryText.isEmpty() ? 0 : _st.font->width(_secondaryText);
resizeToText();
}
int RoundButton::textWidth() const {
return _textWidth;
}
void RoundButton::resizeToText() {
int innerWidth = contentWidth();
if (_fullWidthOverride < 0) {
resize(_textWidth - _fullWidthOverride, _st.height + _st.padding.top() + _st.padding.bottom());
resize(innerWidth - _fullWidthOverride, _st.height + _st.padding.top() + _st.padding.bottom());
} else if (_st.width <= 0) {
resize(_textWidth - _st.width + _st.padding.left() + _st.padding.right(), _st.height + _st.padding.top() + _st.padding.bottom());
resize(innerWidth - _st.width + _st.padding.left() + _st.padding.right(), _st.height + _st.padding.top() + _st.padding.bottom());
} else {
if (_st.width < _textWidth + (_st.height - _st.font->height)) {
if (_st.width < innerWidth + (_st.height - _st.font->height)) {
_text = _st.font->elided(_fullText, qMax(_st.width - (_st.height - _st.font->height), 1));
_textWidth = _st.font->width(_text);
innerWidth = _st.font->width(_text);
}
resize(_st.width + _st.padding.left() + _st.padding.right(), _st.height + _st.padding.top() + _st.padding.bottom());
}
}
int RoundButton::contentWidth() const {
int result = _textWidth + _secondaryTextWidth;
if (_textWidth > 0 && _secondaryTextWidth > 0) {
result += _st.secondarySkip;
}
return result;
}
void RoundButton::paintEvent(QPaintEvent *e) {
Painter p(this);
int innerWidth = contentWidth();
auto rounded = rtlrect(rect().marginsRemoved(_st.padding), width());
if (_fullWidthOverride < 0) {
rounded = QRect(-_fullWidthOverride / 4, rounded.top(), _textWidth - _fullWidthOverride / 2, rounded.height());
rounded = QRect(0, rounded.top(), innerWidth - _fullWidthOverride, rounded.height());
}
App::roundRect(p, rounded, _st.textBg);
float64 o = a_textBgOverOpacity.current();
auto o = a_textBgOverOpacity.current();
if (o > 0) {
p.setOpacity(o);
App::roundRect(p, rounded, _st.textBgOver);
p.setOpacity(1);
}
p.setFont(_st.font);
int textLeft = _st.padding.left() + ((width() - innerWidth - _st.padding.left() - _st.padding.right()) / 2);
if (_fullWidthOverride < 0) {
textLeft = -_fullWidthOverride / 2;
}
int textTop = _st.padding.top() + _st.textTop;
if (!_text.isEmpty()) {
if (o > 0) {
p.setPen(a_textFg.current());
} else {
p.setPen(_st.textFg);
}
p.setFont(_st.font);
int textLeft = _st.padding.left() + ((width() - _textWidth - _st.padding.left() - _st.padding.right()) / 2);
if (_fullWidthOverride < 0) {
textLeft = -_fullWidthOverride / 2;
p.drawTextLeft(textLeft, textTop, width(), _text);
}
if (!_secondaryText.isEmpty()) {
textLeft += _textWidth + (_textWidth ? _st.secondarySkip : 0);
if (o > 0) {
p.setPen(a_secondaryTextFg.current());
} else {
p.setPen(_st.secondaryTextFg);
}
p.drawTextLeft(textLeft, _st.padding.top() + _st.textTop, width(), _text);
p.drawTextLeft(textLeft, textTop, width(), _secondaryText);
}
_st.icon.paint(p, QPoint(_st.padding.left(), _st.padding.right()), width());
}
@ -115,24 +142,29 @@ void RoundButton::step_over(float64 ms, bool timer) {
if (dt >= 1) {
_a_over.stop();
a_textFg.finish();
a_secondaryTextFg.finish();
a_textBgOverOpacity.finish();
} else {
a_textFg.update(dt, anim::linear);
a_secondaryTextFg.update(dt, anim::linear);
a_textBgOverOpacity.update(dt, anim::linear);
}
if (timer) update();
}
void RoundButton::onStateChanged(int oldState, ButtonStateChangeSource source) {
float64 textBgOverOpacity = (_state & StateOver) ? 1 : 0;
style::color textFg = (_state & StateOver) ? (_st.textFgOver) : _st.textFg;
auto textBgOverOpacity = (_state & StateOver) ? 1. : 0.;
auto textFg = (_state & StateOver) ? (_st.textFgOver) : _st.textFg;
auto secondaryTextFg = (_state & StateOver) ? (_st.secondaryTextFgOver) : _st.secondaryTextFg;
a_textBgOverOpacity.start(textBgOverOpacity);
a_textFg.start(textFg->c);
a_secondaryTextFg.start(secondaryTextFg->c);
if (source == ButtonByUser || source == ButtonByPress || true) {
_a_over.stop();
a_textBgOverOpacity.finish();
a_textFg.finish();
a_secondaryTextFg.finish();
a_textBgOverOpacity.finish();
update();
} else {
_a_over.start();

View File

@ -26,10 +26,12 @@ namespace Ui {
class RoundButton : public Button {
public:
RoundButton(QWidget *parent, const QString &text, const style::BoxButton &st);
RoundButton(QWidget *parent, const QString &text, const style::RoundButton &st);
void setText(const QString &text);
int textWidth() const;
void setSecondaryText(const QString &secondaryText);
int contentWidth() const;
void setFullWidth(int newFullWidth);
@ -52,12 +54,16 @@ private:
QString _text, _fullText;
int _textWidth;
QString _secondaryText, _fullSecondaryText;
int _secondaryTextWidth = 0;
int _fullWidthOverride = 0;
const style::BoxButton &_st;
const style::RoundButton &_st;
anim::fvalue a_textBgOverOpacity;
anim::cvalue a_textFg;
anim::cvalue a_textFg, a_secondaryTextFg;
Animation _a_over;
TextTransform _transform = TextTransform::NoTransform;

View File

@ -319,7 +319,7 @@ void EmojiButton::setLoading(bool loading) {
}
}
BoxButton::BoxButton(QWidget *parent, const QString &text, const style::BoxButton &st) : Button(parent)
BoxButton::BoxButton(QWidget *parent, const QString &text, const style::RoundButton &st) : Button(parent)
, _text(text.toUpper())
, _fullText(text.toUpper())
, _textWidth(st.font->width(_text))

View File

@ -158,7 +158,7 @@ class BoxButton : public Button {
Q_OBJECT
public:
BoxButton(QWidget *parent, const QString &text, const style::BoxButton &st);
BoxButton(QWidget *parent, const QString &text, const style::RoundButton &st);
void setText(const QString &text);
void paintEvent(QPaintEvent *e) override;
@ -174,7 +174,7 @@ private:
QString _text, _fullText;
int32 _textWidth;
const style::BoxButton &_st;
const style::RoundButton &_st;
anim::fvalue a_textBgOverOpacity;
anim::cvalue a_textFg;

View File

@ -33,22 +33,16 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org
namespace Window {
TopBarWidget::TopBarWidget(MainWidget *w) : TWidget(w)
, a_over(0)
, _a_appearance(animation(this, &TopBarWidget::step_appearance))
, _selPeer(0)
, _selCount(0)
, _canDelete(false)
, _selStrLeft((-st::topBarClearButton.width + st::topBarClearButton.padding.left() + st::topBarClearButton.padding.right()) / 2)
, _selStrWidth(0)
, _animating(false)
, _clearSelection(this, lang(lng_selected_clear), st::topBarClearButton)
, _forward(this, lang(lng_selected_forward), st::topBarActionButton)
, _delete(this, lang(lng_selected_delete), st::topBarActionButton)
, _selectionButtonsWidth(_clearSelection->width() + _forward->width() + _delete->width())
, _forwardDeleteWidth(qMax(_forward->textWidth(), _delete->textWidth()))
, _forward(this, lang(lng_selected_forward), st::defaultActiveButton)
, _delete(this, lang(lng_selected_delete), st::defaultActiveButton)
, _info(this, nullptr, st::infoButton)
, _mediaType(this, lang(lng_media_type), st::topBarButton)
, _search(this, st::topBarSearch) {
_clearSelection->setTextTransform(Ui::RoundButton::TextTransform::ToUpper);
_forward->setTextTransform(Ui::RoundButton::TextTransform::ToUpper);
_delete->setTextTransform(Ui::RoundButton::TextTransform::ToUpper);
connect(_forward, SIGNAL(clicked()), this, SLOT(onForwardSelection()));
connect(_delete, SIGNAL(clicked()), this, SLOT(onDeleteSelection()));
@ -151,10 +145,6 @@ void TopBarWidget::paintEvent(QPaintEvent *e) {
}
main()->paintTopBar(p, a_over.current(), decreaseWidth);
p.restore();
} else {
p.setFont(st::linkFont);
p.setPen(st::btnDefLink.color);
p.drawText(_selStrLeft, st::topBarClearButton.padding.top() + st::topBarClearButton.textTop + st::linkFont->ascent, _selStr);
}
}
@ -165,60 +155,24 @@ void TopBarWidget::mousePressEvent(QMouseEvent *e) {
}
void TopBarWidget::resizeEvent(QResizeEvent *e) {
int32 r = width();
if (!_forward->isHidden() || !_delete->isHidden()) {
int fullW = r - (_selectionButtonsWidth + (_selStrWidth - st::topBarClearButton.width + st::topBarClearButton.padding.left() + st::topBarClearButton.padding.right()) + st::topBarActionSkip);
int selectedClearWidth = st::topBarClearButton.width - st::topBarClearButton.padding.left() - st::topBarClearButton.padding.right();
int forwardDeleteWidth = st::topBarActionButton.width - _forwardDeleteWidth;
int skip = st::topBarActionSkip;
while (fullW < 0) {
int fit = 0;
if (selectedClearWidth < -2 * (st::topBarMinPadding + 1)) {
fullW += 4;
selectedClearWidth += 2;
} else if (selectedClearWidth < -2 * st::topBarMinPadding) {
fullW += (-2 * st::topBarMinPadding - selectedClearWidth) * 2;
selectedClearWidth = -2 * st::topBarMinPadding;
} else {
++fit;
}
if (fullW >= 0) break;
int r = width();
if (forwardDeleteWidth > 2 * (st::topBarMinPadding + 1)) {
fullW += 4;
forwardDeleteWidth -= 2;
} else if (forwardDeleteWidth > 2 * st::topBarMinPadding) {
fullW += (forwardDeleteWidth - 2 * st::topBarMinPadding) * 2;
forwardDeleteWidth = 2 * st::topBarMinPadding;
} else {
++fit;
}
if (fullW >= 0) break;
int buttonsLeft = st::topBarActionSkip + (Adaptive::OneColumn() ? 0 : st::lineWidth);
int buttonsWidth = _forward->contentWidth() + _delete->contentWidth() + _clearSelection->width();
buttonsWidth += buttonsLeft + st::topBarActionSkip * 3;
if (skip > st::topBarMinPadding) {
--skip;
++fullW;
} else {
++fit;
}
if (fullW >= 0 || fit >= 3) break;
}
_clearSelection->setFullWidth(selectedClearWidth);
_forward->setWidth(_forwardDeleteWidth + forwardDeleteWidth);
_delete->setWidth(_forwardDeleteWidth + forwardDeleteWidth);
_selStrLeft = -selectedClearWidth / 2;
int widthLeft = qMin(r - buttonsWidth, -2 * st::defaultActiveButton.width);
_forward->setFullWidth(-(widthLeft / 2));
_delete->setFullWidth(-(widthLeft / 2));
int buttonsTop = (height() - _forward->height()) / 2;
_forward->moveToLeft(buttonsLeft, buttonsTop);
buttonsLeft += _forward->width() + st::topBarActionSkip;
_delete->moveToLeft(buttonsLeft, buttonsTop);
_clearSelection->moveToRight(st::topBarActionSkip, buttonsTop);
int32 availX = _selStrLeft + _selStrWidth, availW = r - (_clearSelection->width() + selectedClearWidth / 2) - availX;
if (_forward->isHidden()) {
_delete->move(availX + (availW - _delete->width()) / 2, (st::topBarHeight - _forward->height()) / 2);
} else if (_delete->isHidden()) {
_forward->move(availX + (availW - _forward->width()) / 2, (st::topBarHeight - _forward->height()) / 2);
} else {
_forward->move(availX + (availW - _forward->width() - _delete->width() - skip) / 2, (st::topBarHeight - _forward->height()) / 2);
_delete->move(availX + (availW + _forward->width() - _delete->width() + skip) / 2, (st::topBarHeight - _forward->height()) / 2);
}
_clearSelection->move(r -= _clearSelection->width(), 0);
}
if (!_info->isHidden()) _info->move(r -= _info->width(), 0);
if (!_mediaType->isHidden()) _mediaType->move(r -= _mediaType->width(), 0);
_search->move(width() - (_info->isHidden() ? st::topBarForwardPadding.right() : _info->width()) - _search->width(), 0);
@ -246,7 +200,7 @@ void TopBarWidget::stopAnim() {
void TopBarWidget::showAll() {
if (_animating) {
resizeEvent(0);
resizeEvent(nullptr);
return;
}
PeerData *h = App::main() ? App::main()->historyPeer() : 0, *o = App::main() ? App::main()->overviewPeer() : 0;
@ -317,9 +271,11 @@ void TopBarWidget::updateMembersShowArea() {
void TopBarWidget::showSelected(uint32 selCount, bool canDelete) {
_selPeer = App::main()->overviewPeer() ? App::main()->overviewPeer() : App::main()->peer();
_selCount = selCount;
_canDelete = canDelete;
_selStr = (_selCount > 0) ? lng_selected_count(lt_count, _selCount) : QString();
_selStrWidth = st::btnDefLink.font->width(_selStr);
if (_selCount > 0) {
_canDelete = canDelete;
_forward->setSecondaryText(QString::number(_selCount));
_delete->setSecondaryText(QString::number(_selCount));
}
setCursor(_selCount ? style::cur_default : style::cur_pointer);
updateMembersShowArea();

View File

@ -26,7 +26,6 @@ namespace Ui {
class PeerAvatarButton;
class RoundButton;
} // namespace Ui
class FlatButton;
class IconedButton;
namespace Window {
@ -73,20 +72,17 @@ signals:
private:
MainWidget *main();
anim::fvalue a_over;
anim::fvalue a_over = { 0. };
Animation _a_appearance;
PeerData *_selPeer = nullptr;
uint32 _selCount;
bool _canDelete;
QString _selStr;
int32 _selStrLeft, _selStrWidth;
int _selCount = 0;
bool _canDelete = false;
bool _animating;
bool _animating = false;
ChildWidget<Ui::RoundButton> _clearSelection;
ChildWidget<FlatButton> _forward, _delete;
int _selectionButtonsWidth, _forwardDeleteWidth;
ChildWidget<Ui::RoundButton> _forward, _delete;
ChildWidget<Ui::PeerAvatarButton> _info;
ChildWidget<Ui::RoundButton> _mediaType;