mirror of https://github.com/procxx/kepka.git
Selected messages actions (forward, delete, cancel) redesigned.
This commit is contained in:
parent
13b795d614
commit
701b8c87e6
|
@ -110,9 +110,11 @@ boxBlueCloseDuration: 150;
|
||||||
boxBlueShadow: sprite(132px, 108px, 1px, 4px);
|
boxBlueShadow: sprite(132px, 108px, 1px, 4px);
|
||||||
|
|
||||||
boxButtonFont: font(boxFontSize semibold);
|
boxButtonFont: font(boxFontSize semibold);
|
||||||
defaultBoxButton: BoxButton {
|
defaultBoxButton: RoundButton {
|
||||||
textFg: #2f9fea;
|
textFg: #2f9fea;
|
||||||
textFgOver: #2f9fea;
|
textFgOver: #2f9fea;
|
||||||
|
secondaryTextFg: #2f9fea;
|
||||||
|
secondaryTextFgOver: #2f9fea;
|
||||||
textBg: white;
|
textBg: white;
|
||||||
textBgOver: #edf7ff;
|
textBgOver: #edf7ff;
|
||||||
|
|
||||||
|
@ -125,10 +127,10 @@ defaultBoxButton: BoxButton {
|
||||||
font: boxButtonFont;
|
font: boxButtonFont;
|
||||||
duration: 200;
|
duration: 200;
|
||||||
}
|
}
|
||||||
cancelBoxButton: BoxButton(defaultBoxButton) {
|
cancelBoxButton: RoundButton(defaultBoxButton) {
|
||||||
textFg: #aeaeae;
|
textFg: #aeaeae;
|
||||||
}
|
}
|
||||||
attentionBoxButton: BoxButton(defaultBoxButton) {
|
attentionBoxButton: RoundButton(defaultBoxButton) {
|
||||||
textFg: #ea4b2f;
|
textFg: #ea4b2f;
|
||||||
textFgOver: #ea4b2f;
|
textFgOver: #ea4b2f;
|
||||||
textBgOver: #fff0ed;
|
textBgOver: #fff0ed;
|
||||||
|
@ -985,10 +987,12 @@ topBarSearch: iconedButton(btnDefIconed) {
|
||||||
height: topBarHeight;
|
height: topBarHeight;
|
||||||
}
|
}
|
||||||
topBarMinPadding: 5px;
|
topBarMinPadding: 5px;
|
||||||
topBarButton: BoxButton {
|
topBarButton: RoundButton {
|
||||||
textFg: #0084c4;
|
textFg: #0084c4;
|
||||||
textFgOver: #0084c4;
|
textFgOver: #0084c4;
|
||||||
textBg: white;
|
secondaryTextFg: #0084c4;
|
||||||
|
secondaryTextFgOver: #0084c4;
|
||||||
|
textBg: windowBg;
|
||||||
textBgOver: #edf4f7;
|
textBgOver: #edf4f7;
|
||||||
|
|
||||||
width: -22px;
|
width: -22px;
|
||||||
|
@ -1000,20 +1004,34 @@ topBarButton: BoxButton {
|
||||||
font: font(fsize);
|
font: font(fsize);
|
||||||
duration: 200;
|
duration: 200;
|
||||||
}
|
}
|
||||||
topBarClearButton: BoxButton(topBarButton) {
|
defaultActiveButton: RoundButton {
|
||||||
padding: margins(8px, 14px, 8px, 14px);
|
textFg: #ffffff;
|
||||||
}
|
textFgOver: #ffffff;
|
||||||
topBarActionButton: flatButton(btnDefNext, btnDefBig) {
|
secondaryTextFg: #cceeff;
|
||||||
textTop: 8px;
|
secondaryTextFgOver: #cceeff;
|
||||||
overTextTop: 8px;
|
textBg: windowActiveBg;
|
||||||
downTextTop: 9px;
|
textBgOver: windowActiveBg;
|
||||||
|
|
||||||
font: font(fsize);
|
secondarySkip: 7px;
|
||||||
overFont: font(fsize);
|
|
||||||
width: 101px;
|
width: -34px;
|
||||||
height: 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;
|
activeFadeInDuration: 500;
|
||||||
activeFadeOutDuration: 3000;
|
activeFadeOutDuration: 3000;
|
||||||
|
@ -1997,7 +2015,7 @@ botKbScroll: flatScroll(solidScroll) {
|
||||||
deltax: 3px;
|
deltax: 3px;
|
||||||
width: 10px;
|
width: 10px;
|
||||||
}
|
}
|
||||||
switchPmButton: BoxButton(defaultBoxButton) {
|
switchPmButton: RoundButton(defaultBoxButton) {
|
||||||
width: 320px;
|
width: 320px;
|
||||||
height: 34px;
|
height: 34px;
|
||||||
textTop: 7px;
|
textTop: 7px;
|
||||||
|
|
|
@ -309,12 +309,16 @@ botKeyboardButton {
|
||||||
downTextTop: pixels;
|
downTextTop: pixels;
|
||||||
}
|
}
|
||||||
|
|
||||||
BoxButton {
|
RoundButton {
|
||||||
textFg: color;
|
textFg: color;
|
||||||
textFgOver: color;
|
textFgOver: color;
|
||||||
textBg: color; // rect of textBg with rounded rect of textBgOver upon it
|
textBg: color; // rect of textBg with rounded rect of textBgOver upon it
|
||||||
textBgOver: color;
|
textBgOver: color;
|
||||||
|
|
||||||
|
secondaryTextFg: color;
|
||||||
|
secondaryTextFgOver: color;
|
||||||
|
secondarySkip: pixels;
|
||||||
|
|
||||||
width: pixels;
|
width: pixels;
|
||||||
height: pixels;
|
height: pixels;
|
||||||
padding: margins;
|
padding: margins;
|
||||||
|
|
|
@ -35,7 +35,7 @@ TextParseOptions _confirmBoxTextOptions = {
|
||||||
Qt::LayoutDirectionAuto, // dir
|
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)
|
, _informative(false)
|
||||||
, _text(100)
|
, _text(100)
|
||||||
, _confirm(this, doneText.isEmpty() ? lang(lng_box_ok) : doneText, doneStyle)
|
, _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);
|
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)
|
, _informative(true)
|
||||||
, _text(100)
|
, _text(100)
|
||||||
, _confirm(this, doneText.isEmpty() ? lang(lng_box_ok) : doneText, doneStyle)
|
, _confirm(this, doneText.isEmpty() ? lang(lng_box_ok) : doneText, doneStyle)
|
||||||
|
|
|
@ -29,7 +29,7 @@ class ConfirmBox : public AbstractBox, public ClickHandlerHost {
|
||||||
|
|
||||||
public:
|
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 keyPressEvent(QKeyEvent *e);
|
||||||
void paintEvent(QPaintEvent *e);
|
void paintEvent(QPaintEvent *e);
|
||||||
void resizeEvent(QResizeEvent *e);
|
void resizeEvent(QResizeEvent *e);
|
||||||
|
@ -61,7 +61,7 @@ protected:
|
||||||
|
|
||||||
private:
|
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;
|
friend class InformBox;
|
||||||
|
|
||||||
void init(const QString &text);
|
void init(const QString &text);
|
||||||
|
@ -80,7 +80,7 @@ private:
|
||||||
|
|
||||||
class InformBox : public ConfirmBox {
|
class InformBox : public ConfirmBox {
|
||||||
public:
|
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) {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -89,13 +89,15 @@ dialogsTextStyleActive: textStyle(dialogsTextStyle) {
|
||||||
dialogsNewChatIcon: icon {
|
dialogsNewChatIcon: icon {
|
||||||
{ "dialogs_new_chat", #b7b7b7, point(9px, 10px) }
|
{ "dialogs_new_chat", #b7b7b7, point(9px, 10px) }
|
||||||
};
|
};
|
||||||
dialogsNewChatButton: BoxButton {
|
dialogsNewChatButton: RoundButton {
|
||||||
width: 36px;
|
width: 36px;
|
||||||
height: 36px;
|
height: 36px;
|
||||||
icon: dialogsNewChatIcon;
|
icon: dialogsNewChatIcon;
|
||||||
|
|
||||||
textFg: transparent;
|
textFg: transparent;
|
||||||
textFgOver: transparent;
|
textFgOver: transparent;
|
||||||
|
secondaryTextFg: transparent;
|
||||||
|
secondaryTextFgOver: transparent;
|
||||||
textBg: transparent;
|
textBg: transparent;
|
||||||
textBgOver: transparent;
|
textBgOver: transparent;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,7 @@ profileTopBarBackIconPosition: point(15px, 20px);
|
||||||
profileTopBarBackFont: font(14px);
|
profileTopBarBackFont: font(14px);
|
||||||
profileTopBarBackFg: #1485c2;
|
profileTopBarBackFg: #1485c2;
|
||||||
profileTopBarBackPosition: point(32px, 17px);
|
profileTopBarBackPosition: point(32px, 17px);
|
||||||
profileFixedBarButton: BoxButton(topBarButton) {
|
profileFixedBarButton: RoundButton(topBarButton) {
|
||||||
}
|
}
|
||||||
|
|
||||||
profileMarginTop: 13px;
|
profileMarginTop: 13px;
|
||||||
|
@ -61,22 +61,9 @@ profileMarginBottom: 30px;
|
||||||
profileButtonLeft: 27px;
|
profileButtonLeft: 27px;
|
||||||
profileButtonTop: 88px;
|
profileButtonTop: 88px;
|
||||||
profileButtonSkip: 10px;
|
profileButtonSkip: 10px;
|
||||||
profilePrimaryButton: BoxButton {
|
profilePrimaryButton: RoundButton(defaultActiveButton) {
|
||||||
textFg: #ffffff;
|
|
||||||
textFgOver: #ffffff;
|
|
||||||
textBg: windowActiveBg;
|
|
||||||
textBgOver: windowActiveBg;
|
|
||||||
|
|
||||||
width: -34px;
|
|
||||||
height: 34px;
|
|
||||||
padding: margins(0px, 0px, 0px, 0px);
|
|
||||||
|
|
||||||
textTop: 8px;
|
|
||||||
|
|
||||||
font: semiboldFont;
|
|
||||||
duration: 200;
|
|
||||||
}
|
}
|
||||||
profileSecondaryButton: BoxButton(profilePrimaryButton) {
|
profileSecondaryButton: RoundButton(profilePrimaryButton) {
|
||||||
textFg: semiboldButtonBlueText;
|
textFg: semiboldButtonBlueText;
|
||||||
textFgOver: semiboldButtonBlueText;
|
textFgOver: semiboldButtonBlueText;
|
||||||
textBg: #ffffff;
|
textBg: #ffffff;
|
||||||
|
@ -85,7 +72,7 @@ profileSecondaryButton: BoxButton(profilePrimaryButton) {
|
||||||
profileAddMemberIcon: icon {
|
profileAddMemberIcon: icon {
|
||||||
{ "profile_add_member", windowActiveBg, point(20px, 10px) },
|
{ "profile_add_member", windowActiveBg, point(20px, 10px) },
|
||||||
};
|
};
|
||||||
profileAddMemberButton: BoxButton(profileSecondaryButton) {
|
profileAddMemberButton: RoundButton(profileSecondaryButton) {
|
||||||
width: 62px;
|
width: 62px;
|
||||||
icon: profileAddMemberIcon;
|
icon: profileAddMemberIcon;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 &buttonStyle = _buttons.isEmpty() ? st::profilePrimaryButton : st::profileSecondaryButton;
|
||||||
auto button = new Ui::RoundButton(this, text, buttonStyle);
|
auto button = new Ui::RoundButton(this, text, buttonStyle);
|
||||||
button->setTextTransform(Ui::RoundButton::TextTransform::ToUpper);
|
button->setTextTransform(Ui::RoundButton::TextTransform::ToUpper);
|
||||||
|
|
|
@ -95,7 +95,7 @@ private:
|
||||||
void setChannelButtons();
|
void setChannelButtons();
|
||||||
|
|
||||||
void clearButtons();
|
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);
|
void paintDivider(Painter &p);
|
||||||
|
|
||||||
|
|
|
@ -23,13 +23,14 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org
|
||||||
|
|
||||||
namespace Ui {
|
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)
|
, _text(text)
|
||||||
, _fullText(text)
|
, _fullText(text)
|
||||||
, _textWidth(st.font->width(_text))
|
, _textWidth(st.font->width(_text))
|
||||||
, _st(st)
|
, _st(st)
|
||||||
, a_textBgOverOpacity(0)
|
, a_textBgOverOpacity(0)
|
||||||
, a_textFg(st.textFg->c)
|
, a_textFg(st.textFg->c)
|
||||||
|
, a_secondaryTextFg(st.secondaryTextFg->c)
|
||||||
, _a_over(animation(this, &RoundButton::step_over)) {
|
, _a_over(animation(this, &RoundButton::step_over)) {
|
||||||
resizeToText();
|
resizeToText();
|
||||||
|
|
||||||
|
@ -46,6 +47,11 @@ void RoundButton::setText(const QString &text) {
|
||||||
updateText();
|
updateText();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RoundButton::setSecondaryText(const QString &secondaryText) {
|
||||||
|
_fullSecondaryText = secondaryText;
|
||||||
|
updateText();
|
||||||
|
}
|
||||||
|
|
||||||
void RoundButton::setFullWidth(int newFullWidth) {
|
void RoundButton::setFullWidth(int newFullWidth) {
|
||||||
_fullWidthOverride = newFullWidth;
|
_fullWidthOverride = newFullWidth;
|
||||||
resizeToText();
|
resizeToText();
|
||||||
|
@ -54,58 +60,79 @@ void RoundButton::setFullWidth(int newFullWidth) {
|
||||||
void RoundButton::updateText() {
|
void RoundButton::updateText() {
|
||||||
if (_transform == TextTransform::ToUpper) {
|
if (_transform == TextTransform::ToUpper) {
|
||||||
_text = _fullText.toUpper();
|
_text = _fullText.toUpper();
|
||||||
|
_secondaryText = _fullSecondaryText.toUpper();
|
||||||
} else {
|
} else {
|
||||||
_text = _fullText;
|
_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();
|
resizeToText();
|
||||||
}
|
}
|
||||||
|
|
||||||
int RoundButton::textWidth() const {
|
|
||||||
return _textWidth;
|
|
||||||
}
|
|
||||||
|
|
||||||
void RoundButton::resizeToText() {
|
void RoundButton::resizeToText() {
|
||||||
|
int innerWidth = contentWidth();
|
||||||
if (_fullWidthOverride < 0) {
|
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) {
|
} 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 {
|
} 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));
|
_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());
|
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) {
|
void RoundButton::paintEvent(QPaintEvent *e) {
|
||||||
Painter p(this);
|
Painter p(this);
|
||||||
|
|
||||||
|
int innerWidth = contentWidth();
|
||||||
auto rounded = rtlrect(rect().marginsRemoved(_st.padding), width());
|
auto rounded = rtlrect(rect().marginsRemoved(_st.padding), width());
|
||||||
if (_fullWidthOverride < 0) {
|
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);
|
App::roundRect(p, rounded, _st.textBg);
|
||||||
|
|
||||||
float64 o = a_textBgOverOpacity.current();
|
auto o = a_textBgOverOpacity.current();
|
||||||
if (o > 0) {
|
if (o > 0) {
|
||||||
p.setOpacity(o);
|
p.setOpacity(o);
|
||||||
App::roundRect(p, rounded, _st.textBgOver);
|
App::roundRect(p, rounded, _st.textBgOver);
|
||||||
p.setOpacity(1);
|
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 (!_text.isEmpty()) {
|
||||||
if (o > 0) {
|
if (o > 0) {
|
||||||
p.setPen(a_textFg.current());
|
p.setPen(a_textFg.current());
|
||||||
} else {
|
} else {
|
||||||
p.setPen(_st.textFg);
|
p.setPen(_st.textFg);
|
||||||
}
|
}
|
||||||
p.setFont(_st.font);
|
p.drawTextLeft(textLeft, textTop, width(), _text);
|
||||||
int textLeft = _st.padding.left() + ((width() - _textWidth - _st.padding.left() - _st.padding.right()) / 2);
|
}
|
||||||
if (_fullWidthOverride < 0) {
|
if (!_secondaryText.isEmpty()) {
|
||||||
textLeft = -_fullWidthOverride / 2;
|
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());
|
_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) {
|
if (dt >= 1) {
|
||||||
_a_over.stop();
|
_a_over.stop();
|
||||||
a_textFg.finish();
|
a_textFg.finish();
|
||||||
|
a_secondaryTextFg.finish();
|
||||||
a_textBgOverOpacity.finish();
|
a_textBgOverOpacity.finish();
|
||||||
} else {
|
} else {
|
||||||
a_textFg.update(dt, anim::linear);
|
a_textFg.update(dt, anim::linear);
|
||||||
|
a_secondaryTextFg.update(dt, anim::linear);
|
||||||
a_textBgOverOpacity.update(dt, anim::linear);
|
a_textBgOverOpacity.update(dt, anim::linear);
|
||||||
}
|
}
|
||||||
if (timer) update();
|
if (timer) update();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RoundButton::onStateChanged(int oldState, ButtonStateChangeSource source) {
|
void RoundButton::onStateChanged(int oldState, ButtonStateChangeSource source) {
|
||||||
float64 textBgOverOpacity = (_state & StateOver) ? 1 : 0;
|
auto textBgOverOpacity = (_state & StateOver) ? 1. : 0.;
|
||||||
style::color textFg = (_state & StateOver) ? (_st.textFgOver) : _st.textFg;
|
auto textFg = (_state & StateOver) ? (_st.textFgOver) : _st.textFg;
|
||||||
|
auto secondaryTextFg = (_state & StateOver) ? (_st.secondaryTextFgOver) : _st.secondaryTextFg;
|
||||||
|
|
||||||
a_textBgOverOpacity.start(textBgOverOpacity);
|
a_textBgOverOpacity.start(textBgOverOpacity);
|
||||||
a_textFg.start(textFg->c);
|
a_textFg.start(textFg->c);
|
||||||
|
a_secondaryTextFg.start(secondaryTextFg->c);
|
||||||
if (source == ButtonByUser || source == ButtonByPress || true) {
|
if (source == ButtonByUser || source == ButtonByPress || true) {
|
||||||
_a_over.stop();
|
_a_over.stop();
|
||||||
a_textBgOverOpacity.finish();
|
|
||||||
a_textFg.finish();
|
a_textFg.finish();
|
||||||
|
a_secondaryTextFg.finish();
|
||||||
|
a_textBgOverOpacity.finish();
|
||||||
update();
|
update();
|
||||||
} else {
|
} else {
|
||||||
_a_over.start();
|
_a_over.start();
|
||||||
|
|
|
@ -26,10 +26,12 @@ namespace Ui {
|
||||||
|
|
||||||
class RoundButton : public Button {
|
class RoundButton : public Button {
|
||||||
public:
|
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);
|
void setText(const QString &text);
|
||||||
int textWidth() const;
|
void setSecondaryText(const QString &secondaryText);
|
||||||
|
|
||||||
|
int contentWidth() const;
|
||||||
|
|
||||||
void setFullWidth(int newFullWidth);
|
void setFullWidth(int newFullWidth);
|
||||||
|
|
||||||
|
@ -52,12 +54,16 @@ private:
|
||||||
|
|
||||||
QString _text, _fullText;
|
QString _text, _fullText;
|
||||||
int _textWidth;
|
int _textWidth;
|
||||||
|
|
||||||
|
QString _secondaryText, _fullSecondaryText;
|
||||||
|
int _secondaryTextWidth = 0;
|
||||||
|
|
||||||
int _fullWidthOverride = 0;
|
int _fullWidthOverride = 0;
|
||||||
|
|
||||||
const style::BoxButton &_st;
|
const style::RoundButton &_st;
|
||||||
|
|
||||||
anim::fvalue a_textBgOverOpacity;
|
anim::fvalue a_textBgOverOpacity;
|
||||||
anim::cvalue a_textFg;
|
anim::cvalue a_textFg, a_secondaryTextFg;
|
||||||
Animation _a_over;
|
Animation _a_over;
|
||||||
|
|
||||||
TextTransform _transform = TextTransform::NoTransform;
|
TextTransform _transform = TextTransform::NoTransform;
|
||||||
|
|
|
@ -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())
|
, _text(text.toUpper())
|
||||||
, _fullText(text.toUpper())
|
, _fullText(text.toUpper())
|
||||||
, _textWidth(st.font->width(_text))
|
, _textWidth(st.font->width(_text))
|
||||||
|
|
|
@ -158,7 +158,7 @@ class BoxButton : public Button {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
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 setText(const QString &text);
|
||||||
void paintEvent(QPaintEvent *e) override;
|
void paintEvent(QPaintEvent *e) override;
|
||||||
|
@ -174,7 +174,7 @@ private:
|
||||||
QString _text, _fullText;
|
QString _text, _fullText;
|
||||||
int32 _textWidth;
|
int32 _textWidth;
|
||||||
|
|
||||||
const style::BoxButton &_st;
|
const style::RoundButton &_st;
|
||||||
|
|
||||||
anim::fvalue a_textBgOverOpacity;
|
anim::fvalue a_textBgOverOpacity;
|
||||||
anim::cvalue a_textFg;
|
anim::cvalue a_textFg;
|
||||||
|
|
|
@ -33,22 +33,16 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org
|
||||||
namespace Window {
|
namespace Window {
|
||||||
|
|
||||||
TopBarWidget::TopBarWidget(MainWidget *w) : TWidget(w)
|
TopBarWidget::TopBarWidget(MainWidget *w) : TWidget(w)
|
||||||
, a_over(0)
|
|
||||||
, _a_appearance(animation(this, &TopBarWidget::step_appearance))
|
, _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)
|
, _clearSelection(this, lang(lng_selected_clear), st::topBarClearButton)
|
||||||
, _forward(this, lang(lng_selected_forward), st::topBarActionButton)
|
, _forward(this, lang(lng_selected_forward), st::defaultActiveButton)
|
||||||
, _delete(this, lang(lng_selected_delete), st::topBarActionButton)
|
, _delete(this, lang(lng_selected_delete), st::defaultActiveButton)
|
||||||
, _selectionButtonsWidth(_clearSelection->width() + _forward->width() + _delete->width())
|
|
||||||
, _forwardDeleteWidth(qMax(_forward->textWidth(), _delete->textWidth()))
|
|
||||||
, _info(this, nullptr, st::infoButton)
|
, _info(this, nullptr, st::infoButton)
|
||||||
, _mediaType(this, lang(lng_media_type), st::topBarButton)
|
, _mediaType(this, lang(lng_media_type), st::topBarButton)
|
||||||
, _search(this, st::topBarSearch) {
|
, _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(_forward, SIGNAL(clicked()), this, SLOT(onForwardSelection()));
|
||||||
connect(_delete, SIGNAL(clicked()), this, SLOT(onDeleteSelection()));
|
connect(_delete, SIGNAL(clicked()), this, SLOT(onDeleteSelection()));
|
||||||
|
@ -151,10 +145,6 @@ void TopBarWidget::paintEvent(QPaintEvent *e) {
|
||||||
}
|
}
|
||||||
main()->paintTopBar(p, a_over.current(), decreaseWidth);
|
main()->paintTopBar(p, a_over.current(), decreaseWidth);
|
||||||
p.restore();
|
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) {
|
void TopBarWidget::resizeEvent(QResizeEvent *e) {
|
||||||
int32 r = width();
|
int 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;
|
|
||||||
|
|
||||||
if (forwardDeleteWidth > 2 * (st::topBarMinPadding + 1)) {
|
int buttonsLeft = st::topBarActionSkip + (Adaptive::OneColumn() ? 0 : st::lineWidth);
|
||||||
fullW += 4;
|
int buttonsWidth = _forward->contentWidth() + _delete->contentWidth() + _clearSelection->width();
|
||||||
forwardDeleteWidth -= 2;
|
buttonsWidth += buttonsLeft + st::topBarActionSkip * 3;
|
||||||
} else if (forwardDeleteWidth > 2 * st::topBarMinPadding) {
|
|
||||||
fullW += (forwardDeleteWidth - 2 * st::topBarMinPadding) * 2;
|
|
||||||
forwardDeleteWidth = 2 * st::topBarMinPadding;
|
|
||||||
} else {
|
|
||||||
++fit;
|
|
||||||
}
|
|
||||||
if (fullW >= 0) break;
|
|
||||||
|
|
||||||
if (skip > st::topBarMinPadding) {
|
int widthLeft = qMin(r - buttonsWidth, -2 * st::defaultActiveButton.width);
|
||||||
--skip;
|
_forward->setFullWidth(-(widthLeft / 2));
|
||||||
++fullW;
|
_delete->setFullWidth(-(widthLeft / 2));
|
||||||
} else {
|
|
||||||
++fit;
|
int buttonsTop = (height() - _forward->height()) / 2;
|
||||||
}
|
|
||||||
if (fullW >= 0 || fit >= 3) break;
|
_forward->moveToLeft(buttonsLeft, buttonsTop);
|
||||||
}
|
buttonsLeft += _forward->width() + st::topBarActionSkip;
|
||||||
_clearSelection->setFullWidth(selectedClearWidth);
|
|
||||||
_forward->setWidth(_forwardDeleteWidth + forwardDeleteWidth);
|
_delete->moveToLeft(buttonsLeft, buttonsTop);
|
||||||
_delete->setWidth(_forwardDeleteWidth + forwardDeleteWidth);
|
_clearSelection->moveToRight(st::topBarActionSkip, buttonsTop);
|
||||||
_selStrLeft = -selectedClearWidth / 2;
|
|
||||||
|
|
||||||
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 (!_info->isHidden()) _info->move(r -= _info->width(), 0);
|
||||||
if (!_mediaType->isHidden()) _mediaType->move(r -= _mediaType->width(), 0);
|
if (!_mediaType->isHidden()) _mediaType->move(r -= _mediaType->width(), 0);
|
||||||
_search->move(width() - (_info->isHidden() ? st::topBarForwardPadding.right() : _info->width()) - _search->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() {
|
void TopBarWidget::showAll() {
|
||||||
if (_animating) {
|
if (_animating) {
|
||||||
resizeEvent(0);
|
resizeEvent(nullptr);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
PeerData *h = App::main() ? App::main()->historyPeer() : 0, *o = App::main() ? App::main()->overviewPeer() : 0;
|
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) {
|
void TopBarWidget::showSelected(uint32 selCount, bool canDelete) {
|
||||||
_selPeer = App::main()->overviewPeer() ? App::main()->overviewPeer() : App::main()->peer();
|
_selPeer = App::main()->overviewPeer() ? App::main()->overviewPeer() : App::main()->peer();
|
||||||
_selCount = selCount;
|
_selCount = selCount;
|
||||||
_canDelete = canDelete;
|
if (_selCount > 0) {
|
||||||
_selStr = (_selCount > 0) ? lng_selected_count(lt_count, _selCount) : QString();
|
_canDelete = canDelete;
|
||||||
_selStrWidth = st::btnDefLink.font->width(_selStr);
|
_forward->setSecondaryText(QString::number(_selCount));
|
||||||
|
_delete->setSecondaryText(QString::number(_selCount));
|
||||||
|
}
|
||||||
setCursor(_selCount ? style::cur_default : style::cur_pointer);
|
setCursor(_selCount ? style::cur_default : style::cur_pointer);
|
||||||
|
|
||||||
updateMembersShowArea();
|
updateMembersShowArea();
|
||||||
|
|
|
@ -26,7 +26,6 @@ namespace Ui {
|
||||||
class PeerAvatarButton;
|
class PeerAvatarButton;
|
||||||
class RoundButton;
|
class RoundButton;
|
||||||
} // namespace Ui
|
} // namespace Ui
|
||||||
class FlatButton;
|
|
||||||
class IconedButton;
|
class IconedButton;
|
||||||
|
|
||||||
namespace Window {
|
namespace Window {
|
||||||
|
@ -73,20 +72,17 @@ signals:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
MainWidget *main();
|
MainWidget *main();
|
||||||
anim::fvalue a_over;
|
anim::fvalue a_over = { 0. };
|
||||||
Animation _a_appearance;
|
Animation _a_appearance;
|
||||||
|
|
||||||
PeerData *_selPeer = nullptr;
|
PeerData *_selPeer = nullptr;
|
||||||
uint32 _selCount;
|
int _selCount = 0;
|
||||||
bool _canDelete;
|
bool _canDelete = false;
|
||||||
QString _selStr;
|
|
||||||
int32 _selStrLeft, _selStrWidth;
|
|
||||||
|
|
||||||
bool _animating;
|
bool _animating = false;
|
||||||
|
|
||||||
ChildWidget<Ui::RoundButton> _clearSelection;
|
ChildWidget<Ui::RoundButton> _clearSelection;
|
||||||
ChildWidget<FlatButton> _forward, _delete;
|
ChildWidget<Ui::RoundButton> _forward, _delete;
|
||||||
int _selectionButtonsWidth, _forwardDeleteWidth;
|
|
||||||
|
|
||||||
ChildWidget<Ui::PeerAvatarButton> _info;
|
ChildWidget<Ui::PeerAvatarButton> _info;
|
||||||
ChildWidget<Ui::RoundButton> _mediaType;
|
ChildWidget<Ui::RoundButton> _mediaType;
|
||||||
|
|
Loading…
Reference in New Issue