From 29493a0693a0aedcfa021835421f143af37e4aa7 Mon Sep 17 00:00:00 2001 From: John Preston Date: Thu, 27 Oct 2016 17:10:28 +0300 Subject: [PATCH] All emoji icons moved from sprite. --- Telegram/Resources/basic.style | 200 ------------ Telegram/Resources/basic_types.style | 14 - Telegram/Resources/icons/emoji_activity.png | Bin 0 -> 639 bytes .../Resources/icons/emoji_activity@2x.png | Bin 0 -> 1303 bytes Telegram/Resources/icons/emoji_food.png | Bin 0 -> 501 bytes Telegram/Resources/icons/emoji_food@2x.png | Bin 0 -> 777 bytes Telegram/Resources/icons/emoji_gif.png | Bin 0 -> 518 bytes Telegram/Resources/icons/emoji_gif@2x.png | Bin 0 -> 1033 bytes Telegram/Resources/icons/emoji_nature.png | Bin 0 -> 554 bytes Telegram/Resources/icons/emoji_nature@2x.png | Bin 0 -> 1100 bytes Telegram/Resources/icons/emoji_objects.png | Bin 0 -> 360 bytes Telegram/Resources/icons/emoji_objects@2x.png | Bin 0 -> 628 bytes Telegram/Resources/icons/emoji_people.png | Bin 0 -> 668 bytes Telegram/Resources/icons/emoji_people@2x.png | Bin 0 -> 1150 bytes Telegram/Resources/icons/emoji_recent.png | Bin 0 -> 546 bytes Telegram/Resources/icons/emoji_recent@2x.png | Bin 0 -> 968 bytes Telegram/Resources/icons/emoji_settings.png | Bin 0 -> 670 bytes .../Resources/icons/emoji_settings@2x.png | Bin 0 -> 1222 bytes Telegram/Resources/icons/emoji_symbols.png | Bin 0 -> 432 bytes Telegram/Resources/icons/emoji_symbols@2x.png | Bin 0 -> 859 bytes Telegram/Resources/icons/emoji_travel.png | Bin 0 -> 465 bytes Telegram/Resources/icons/emoji_travel@2x.png | Bin 0 -> 817 bytes Telegram/Resources/icons/emoji_trending.png | Bin 0 -> 546 bytes .../Resources/icons/emoji_trending@2x.png | Bin 0 -> 1189 bytes Telegram/SourceFiles/app.cpp | 1 + Telegram/SourceFiles/boxes/boxes.style | 3 + Telegram/SourceFiles/boxes/members_box.cpp | 6 +- .../history/field_autocomplete.cpp | 2 + Telegram/SourceFiles/history/history.style | 14 + .../inline_bot_layout_internal.cpp | 1 + Telegram/SourceFiles/intro/intro.style | 44 +++ Telegram/SourceFiles/intro/introphone.cpp | 1 + Telegram/SourceFiles/intro/introwidget.cpp | 1 + Telegram/SourceFiles/settings/settings.style | 1 + Telegram/SourceFiles/stickers/emoji_pan.cpp | 294 ++++++++---------- Telegram/SourceFiles/stickers/emoji_pan.h | 23 +- Telegram/SourceFiles/stickers/stickers.style | 126 +++++++- .../ui/buttons/history_down_button.h | 1 + Telegram/SourceFiles/ui/buttons/icon_button.h | 1 + Telegram/SourceFiles/ui/widgets/widgets.style | 22 +- .../SourceFiles/window/top_bar_widget.cpp | 1 + Telegram/SourceFiles/window/window.style | 1 + Telegram/gyp/Telegram.gyp | 1 + 43 files changed, 365 insertions(+), 393 deletions(-) create mode 100644 Telegram/Resources/icons/emoji_activity.png create mode 100644 Telegram/Resources/icons/emoji_activity@2x.png create mode 100644 Telegram/Resources/icons/emoji_food.png create mode 100644 Telegram/Resources/icons/emoji_food@2x.png create mode 100644 Telegram/Resources/icons/emoji_gif.png create mode 100644 Telegram/Resources/icons/emoji_gif@2x.png create mode 100644 Telegram/Resources/icons/emoji_nature.png create mode 100644 Telegram/Resources/icons/emoji_nature@2x.png create mode 100644 Telegram/Resources/icons/emoji_objects.png create mode 100644 Telegram/Resources/icons/emoji_objects@2x.png create mode 100644 Telegram/Resources/icons/emoji_people.png create mode 100644 Telegram/Resources/icons/emoji_people@2x.png create mode 100644 Telegram/Resources/icons/emoji_recent.png create mode 100644 Telegram/Resources/icons/emoji_recent@2x.png create mode 100644 Telegram/Resources/icons/emoji_settings.png create mode 100644 Telegram/Resources/icons/emoji_settings@2x.png create mode 100644 Telegram/Resources/icons/emoji_symbols.png create mode 100644 Telegram/Resources/icons/emoji_symbols@2x.png create mode 100644 Telegram/Resources/icons/emoji_travel.png create mode 100644 Telegram/Resources/icons/emoji_travel@2x.png create mode 100644 Telegram/Resources/icons/emoji_trending.png create mode 100644 Telegram/Resources/icons/emoji_trending@2x.png create mode 100644 Telegram/SourceFiles/intro/intro.style diff --git a/Telegram/Resources/basic.style b/Telegram/Resources/basic.style index 9b919578a..a3cda0de0 100644 --- a/Telegram/Resources/basic.style +++ b/Telegram/Resources/basic.style @@ -665,28 +665,6 @@ introErrTop: 15px; introErrHeight: 40px; introErrFont: font(16px); -introErrLabel: flatLabel(labelDefFlat) { - font: introErrFont; - align: align(center); -} -introBackButton: IconButton { - width: 40px; - height: 40px; - - opacity: 0.71; - overOpacity: 1.; - - icon: icon { - { size(40px, 40px), #eeeeee }, - { "title_previous", #969696, point(12px, 12px) }, - }; - iconPosition: point(0px, 0px); - downIconPosition: point(0px, 0px); - - duration: 150; -} -introBackPosition: point(32px, 32px); - setLittleSkip: 9px; setScroll: flatScroll(scrollDef) { bottomsh: 0px; @@ -725,19 +703,6 @@ topBarBackAlpha: 0.8; topBarBackColor: #005faf; topBarBackFont: font(16px); topBarArrowPadding: margins(39px, 8px, 17px, 8px); -topBarSearch: IconButton { - width: 44px; - height: topBarHeight; - - icon: icon {{ "title_search", #000000 }}; - iconPosition: point(13px, 18px); - downIconPosition: point(13px, 18px); - - opacity: 0.22; - overOpacity: 0.36; - - duration: 150; -} topBarMinPadding: 5px; topBarButton: RoundButton { textFg: #0084c4; @@ -1352,171 +1317,6 @@ dpiFont2: linkFont; dpiFont3: linkFont; dpiFont4: linkFont; -stickersMaxHeight: 440px; -stickersPadding: margins(19px, 17px, 19px, 17px); -stickersSize: size(64px, 64px); -stickersScroll: flatScroll(boxScroll) { - round: 2px; - deltax: 7px; - deltat: 23px; - deltab: 9px; -} -stickersReorderPadding: margins(0px, 12px, 0px, 12px); -stickersReorderFg: #777; -stickersRowDisabledOpacity: 0.4; -stickersRowDuration: 200; - -emojiScroll: flatScroll(solidScroll) { - deltat: 48px; -} -emojiRecentOver: sprite(0px, 196px, 21px, 22px); -emojiRecentActive: sprite(245px, 264px, 21px, 22px); -emojiPeopleOver: sprite(21px, 196px, 21px, 22px); -emojiPeopleActive: sprite(266px, 264px, 21px, 22px); -emojiNatureOver: sprite(42px, 196px, 21px, 22px); -emojiNatureActive: sprite(245px, 286px, 21px, 22px); -emojiFoodOver: sprite(63px, 196px, 21px, 22px); -emojiFoodActive: sprite(266px, 286px, 21px, 22px); -emojiActivityOver: sprite(126px, 196px, 21px, 22px); -emojiActivityActive: sprite(287px, 264px, 21px, 22px); -emojiTravelOver: sprite(105px, 196px, 21px, 22px); -emojiTravelActive: sprite(308px, 286px, 21px, 22px); -emojiObjectsOver: sprite(147px, 196px, 21px, 22px); -emojiObjectsActive: sprite(308px, 264px, 21px, 22px); -emojiSymbolsOver: sprite(84px, 196px, 21px, 22px); -emojiSymbolsActive: sprite(287px, 286px, 21px, 22px); -stickersSettings: sprite(140px, 124px, 21px, 22px); -savedGifsOver: sprite(329px, 286px, 21px, 22px); -savedGifsActive: sprite(350px, 286px, 21px, 22px); -featuredStickersOver: sprite(329px, 264px, 21px, 22px); -featuredStickersActive: sprite(350px, 264px, 21px, 22px); - -stickersSettingsUnreadSize: 17px; -stickersSettingsUnreadPosition: point(4px, 5px); - -emojiPanCategories: #f7f7f7; - -rbEmoji: flatCheckbox { - textColor: transparent; - bgColor: emojiPanCategories; - disColor: emojiPanCategories; - - width: 42px; - height: 46px; - - textTop: 0px; - textLeft: 0px; - font: font(fsize); - duration: 200; - bgFunc: transition(easeOutCirc); - cursor: cursor(pointer); - - disabledCursor: cursor(default); - imagePos: point(11px, 12px); -} -rbEmojiRecent: flatCheckbox(rbEmoji) { - imageRect: emojiRecentOver; - chkImageRect: emojiRecentActive; - overImageRect: emojiRecentOver; - chkOverImageRect: emojiRecentActive; - disImageRect: emojiRecentOver; - chkDisImageRect: emojiRecentActive; -} -rbEmojiPeople: flatCheckbox(rbEmoji) { - imageRect: emojiPeopleOver; - chkImageRect: emojiPeopleActive; - overImageRect: emojiPeopleOver; - chkOverImageRect: emojiPeopleActive; - disImageRect: emojiPeopleOver; - chkDisImageRect: emojiPeopleActive; -} -rbEmojiNature: flatCheckbox(rbEmoji) { - imageRect: emojiNatureOver; - chkImageRect: emojiNatureActive; - overImageRect: emojiNatureOver; - chkOverImageRect: emojiNatureActive; - disImageRect: emojiNatureOver; - chkDisImageRect: emojiNatureActive; -} -rbEmojiFood: flatCheckbox(rbEmoji) { - imageRect: emojiFoodOver; - chkImageRect: emojiFoodActive; - overImageRect: emojiFoodOver; - chkOverImageRect: emojiFoodActive; - disImageRect: emojiFoodOver; - chkDisImageRect: emojiFoodActive; -} -rbEmojiActivity: flatCheckbox(rbEmoji) { - imageRect: emojiActivityOver; - chkImageRect: emojiActivityActive; - overImageRect: emojiActivityOver; - chkOverImageRect: emojiActivityActive; - disImageRect: emojiActivityOver; - chkDisImageRect: emojiActivityActive; -} -rbEmojiTravel: flatCheckbox(rbEmoji) { - imageRect: emojiTravelOver; - chkImageRect: emojiTravelActive; - overImageRect: emojiTravelOver; - chkOverImageRect: emojiTravelActive; - disImageRect: emojiTravelOver; - chkDisImageRect: emojiTravelActive; -} -rbEmojiObjects: flatCheckbox(rbEmoji) { - imageRect: emojiObjectsOver; - chkImageRect: emojiObjectsActive; - overImageRect: emojiObjectsOver; - chkOverImageRect: emojiObjectsActive; - disImageRect: emojiObjectsOver; - chkDisImageRect: emojiObjectsActive; -} -rbEmojiSymbols: flatCheckbox(rbEmoji) { - imageRect: emojiSymbolsOver; - chkImageRect: emojiSymbolsActive; - overImageRect: emojiSymbolsOver; - chkOverImageRect: emojiSymbolsActive; - disImageRect: emojiSymbolsOver; - chkDisImageRect: emojiSymbolsActive; -} -emojiPanPadding: 12px; -emojiPanSize: size(45px, 41px); -emojiPanWidth: 345px; -emojiPanMaxHeight: 366px; -emojiPanDuration: 200; -emojiPanHover: #f0f4f7; - -emojiPanHeader: 42px; -emojiPanHeaderFont: semiboldFont; -emojiPanHeaderColor: #999; -emojiPanHeaderLeft: 22px; -emojiPanHeaderTop: 12px; -emojiPanHeaderBg: #fffffff2; - -emojiColorsPadding: 5px; -emojiColorsSep: 1px; -emojiColorsSepColor: #d5d5d5; - -emojiSwitchSkip: 27px; -emojiSwitchImgSkip: 21px; -emojiSwitchStickers: sprite(318px, 328px, 8px, 12px); -emojiSwitchEmoji: sprite(310px, 328px, 8px, 12px); -emojiSwitchColor: #42a8db; - -stickerPanSize: size(64px, 64px); -stickerPanPadding: 11px; -stickerPanDelete: sprite(128px, 132px, 12px, 12px); -stickerPanDeleteOpacity: 0.5; -stickerIconPadding: 5px; -stickerIconOpacity: 0.7; -stickerIconSel: 2px; -stickerIconSelColor: #58b2ed; -stickerIconLeft: sprite(342px, 72px, 40px, 1px); -stickerIconRight: sprite(342px, 73px, 40px, 1px); -stickerIconMove: 400; -stickerPreviewDuration: 150; -stickerPreviewBg: #FFFFFFB0; -stickerPreviewMin: 0.1; - botKbDuration: 200; botKbBg: #edf1f5; botKbOverBg: #d8e2ec; diff --git a/Telegram/Resources/basic_types.style b/Telegram/Resources/basic_types.style index 3ade742e2..78e722870 100644 --- a/Telegram/Resources/basic_types.style +++ b/Telegram/Resources/basic_types.style @@ -386,17 +386,3 @@ OutlineButton { font: font; padding: margins; } - -IconButton { - width: pixels; - height: pixels; - - opacity: double; - overOpacity: double; - - icon: icon; - iconPosition: point; - downIconPosition: point; - - duration: int; -} diff --git a/Telegram/Resources/icons/emoji_activity.png b/Telegram/Resources/icons/emoji_activity.png new file mode 100644 index 0000000000000000000000000000000000000000..055ff9f33c91d65a09eb946c04525dcdf7012fdb GIT binary patch literal 639 zcmV-_0)YLAP)u`w8A>t5+o@Sh0B8H==d59rm#=OR)`3n)bJtV08_uAiH-`WcR_#L~ty5hsb1Iy(y-EQ}0{P={r zu5&)0bBTODzZU<2JrF{`?RKyE7K_E&`t$R1>)cL8hGDSTY;rc6vDs|0P$)2+PE$(B zSS-dyqrpR3}%RdIKB2fyEsN~MCgw>Ml~UT)Pkolfu6Vz1ig=jVKXe_t`2OeVB#o3q)B zUaxm+zX0%S=XC%yO+&q2hsWbt`4Wi)Y}>}g#RWp45Q4!VEX#t==R>d8+t2j={(h~F zwOVb}tKDvwb?$u;%aedaH!f>6C_H{CTDjR1}3m2nrz%`%#*v(XuSQ zzP^$qKR!O#>2zqC<~|*q1A#z*kB^UxL?Sc{gVkzvjd3=crJ^W~XHW2ZIKZ+jNGYMJ zDx{P!O%uAVV>le*?CcDS#R4}sH^}93I6XZD07RovwA*dxma5fi+=X~N?)WjL(pG;AaJgKNQsVjf8Ld`pb-SvnNG6j2fMT(T;c&RK6_1*sBsm_B zscG8rLT#E5f}Ku>Bzb##`#tqH%`{Dt Z#21{=GQw=jr27B>002ovPDHLkV1htjKUV+% literal 0 HcmV?d00001 diff --git a/Telegram/Resources/icons/emoji_activity@2x.png b/Telegram/Resources/icons/emoji_activity@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..681df82ddcc473e589ecd7a9f7f50f94f89b5e47 GIT binary patch literal 1303 zcmV+y1?c*TP)4YHA7zA>I6cj%YHOY$J(? zD9bWB91cU@zq-cTB(N+CPN%cu7){gQcDoJze~f6YR)hEVcinMCQ4Ib2CQ4Bha2y9b z&x6fo1B#+_iJY9AbQ~)b3UG08(RHn!bB^OUOe7Nc^74X>Mgw!X97>Xep->2YJ|7MY z3?RcWsy)LnxVgEBZ*OmEeqLT)qSx!~y4Ek~QAfRAFDx%F8|K!-!voyh+(0&)g?Ky; zPft%k2m!y}4?NFeK3!W;6tP~f8xpP8>lg?G%qL0+L7wN)<#HL?@jQ>EQpu2H3#nAUp7#SIXVzCJ4=jULv*#H3G`S}^*@i<&vT|uo@gIcWyilV^l>njwC#kSg@?=3$# zI53Q6G#XXyB}p>0tyZg;&*yPxX9ro9HE-(!fj~!bZ{hm-TC<=a2w1IF4av432!iU@ z*Hwg~C>S3f2SP~4@%Q(4SXfwq=jUg&@8;$PCMG6ea&i(Z7K^&&wOS3D&8E8Tr>Cb- zC=@jF^&Cx}=P{qp>qca4ZB5sg5Yn;f+4mLEN~HpoN=0`(o6YKuedaRv5q;(8@87?5 zPojFgj?rio?RL8v68Lo|hG9??MfJQM9Ubj>yKEts%Y9Yc%^?~Jh4Ag|4d>?O)IN^m zaC380R{>;M#%MIEsrXGNN(e!UqL8L(92^|f$V(&=QRRmafSglsDTCKn^jQZ{Ic!1+L_!IN<^RTqEq<*t33*m4WL{S8qrr{&D zx3^(zY^<%n8xR067z`RpjUMjr?{%vxzu(_hY$GC`pP%=>^_?c{hDM`-q9__Ju(-I` z=C`=G*gMhT;bBat(^#!mv0kqm-hEmmW3iZ_NYgZp*Voq?zf!4$Hk+-#93_N+)oKNY z!vQSI0!`DvFbpsZqsdo`#R7+ihp@iBZut5!IywrwyStjc>FH@$Sy?ekMP2l(Z@TSc zRdsuN`>`T2SDt!lE|;tACfdV2>HCSsVlhpAXEK?7#QuAT+U@qXBek14{3k?%!Jwv4 zNu^Rq({x{Re#`r)+wE4LADhi4#N+X<@1LK6snKK@2Gi-Z8qL+!RkP+cm#82Jcz1V) zh=@l=M}2R3s}TVBr?-vhjMvv!pePC+A0J_Mb{5LzvMKYLa z|01n=w)O0JbT~IV=X}oB?|1eEfcWqz0e~b)sMqViI@oTvF`Z5kMG-vDgJoGS>+JXY zyj(6c41>5O&z+(uax$4PYnY~a-v>rfM3RNz@pzmGlBDN(5A=9ECJXOiUDtC#k_^L; z09XQm?RJ~gLKH=~t_#C3Qgt*<^KG5?`~9P)x~}tjy}sOjYd{e(_QX%y9|PWs;W|!99)QDm&wYg8%~ rEEWqamrIZY0DRr!esYvP4FbS_`2)bZOr&!&00000NkvXXu0mjfQZC}@ literal 0 HcmV?d00001 diff --git a/Telegram/Resources/icons/emoji_food@2x.png b/Telegram/Resources/icons/emoji_food@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..4f3d8cf7845b60c99d6ddc7ef3efa76917ef6912 GIT binary patch literal 777 zcmV+k1NQuhP)``T{~IA(Rr9R9HeH^aYe&^A18!t(-!0=}V}RYL#Bw zODd-vD)i7(iHYBHcx<2jGs({G&LmI1%psGR%qPDcvm4m~K-hx(+B85mzc;mTE|#|6bH;H6kM7oNK|_woNZDFH3>`aL(!Y_*e{meSHlKREaGXi!__fq>%o~?(Xge zp~YfR_^ni6ZQD+a^y0d15ZdWG-D*`}2$J5^49zcE-s`d%VKYCZZaV!lL;}#qEN#y==u3s z8e6Z|S3+-ZZ!pg1x-FOpP3kM*eC>p(?SC|l5R9(Ktk(9$ZE$||JXZ>IktTl4qL)pC{Zu-2M|5Nx#ofPLTRs;V9m z8e>&e?EC&rR0!b&+qPw;6iX?Gr;bue$x111+tvvSAsAX~CL(T{hCR=FNbH`T=W)|C zOhl};W*B3bh*&B0D?v-86cZ5}V;FtkGZ8%;@>i)KBJTU1pNNP7U^1D&A`C-FDFFaQ zQ2+pfAi!)kLs1mYwzyuesOuU;baUA1+1%W}g7f*z0C>G#yYH-RnddnJaO=100oZQ0 z2*VIbk|4`6NGaWoKf^G(cmClbj$;%>fz4(E0JvN(qk>=I`QBl3nCCf&=q*p5!0zXH zK7Lc+RwMvOk_1r{Ax+a!(Zyl`;8v(n(cNx`IF7Met&n9I>bf2k97c7Ici|^Vg1WAe zrYTOR(}%Dg#_&m5hGEE26mb+q&KCrMTMz9aoz`FdQPb(vwZrHAeh&bc&*#4j^%cwI z5&&>K9`Qe2>M#1K6+9dcb^`oE=eMWY8C90$k7iU^mLF!+3!5*v-bXpu<^TWy07*qo IM6N<$f)`2Rnm*AhG7`Ey}iX~G|K%AjSJ87RMRv%o6YEaJ}*UPvl-Pijq*I7 z;InjQL?O#EeS3Q=jbL1+(oB2c)MJd&bdEQl3HJxa)*-Rxl91f|fs#FjJ%Cc_v91c^-#ytBOlhf%mV)*|4PTTD^WfUmxw3_>vr zdVPHzG4MQ(HX4l|Cm5IA-Q5IPP18R6d7e*9xuPhglUz!>-A;r6&+`=BZZ{E=WlVQo z7{p_?+wIayqtQSZ{eB;d#R9*D#bSYezaP;x8Vz7P9!J;H#Rol`~G)3st{O~h39!e+xLB}&F6C(HdF8$+fE!N2qEBkKCnsCr@?hyn5LP@JQ5E`i5XQ@>C4MY=9c&P_(*HDT3~;6c9uF` zSf3`kt_Qa9zQ1}@*L6se6ww)mk?_uBGWpw3|Abtk7Z(=+N!NAJ>2z>)brtm2YBk8R z4A*sw|8c>!kZDZ_fubk@$(@~@MEp!9lL+yjL?x?3mgV5N*Xv~mc}d758jj0{hlf(g zj2WLbu3ns8kg9LGTv#j<$j z6E#f}+uPf?yu1unX&O1#b^p^gS_EG{j}k&4NmAq>^7QnC(P)&&pI4PDJ^eD|?CfEx>UcR4mJiDEIdE%H))a_!Zu=EK~-A zK}30YcnF4J%H$OR!!S5HI*RB9g8@JYNtATj?e?$T>C;L&gb)euQNCWtUCJtz#!pU8;x89{(^dG`&}y~PW+6E( ztN8h5ZOJwbKlwq-_kB2y1Iw~t7zXa{?(qEloN50DW4+sBo!|0e00000NkvXXu0mjf D84BsU literal 0 HcmV?d00001 diff --git a/Telegram/Resources/icons/emoji_nature.png b/Telegram/Resources/icons/emoji_nature.png new file mode 100644 index 0000000000000000000000000000000000000000..810cdf233e0ddcfce0ede1770d4f586db4265755 GIT binary patch literal 554 zcmV+_0@eMAP)5TEDW_fkquA%tE_D5W2ugk{MG=qCxG=h9=N*Rtf+Z;*QkIkoh-{L@ye z75Kgn)9Dl#V<3dk@Hmd)^?Jemeuw>j57+CpO`-2%+cqI$N8OMiB3YKDar|lTz&QuQ zFtoL@EFla-2*VJ{veYocFo1LZSt;jSQ&JQK*|x1^QWS;evtF;q4@ye;4mcbR9sGDa zzVXxP)WJLHGsb{1)=6i`hI~J^P&@tEY}QHNbzP0)Z+i#Jvb2BGG~sf&!1;Uz0D#SA z1Ey(eKDKRtR{Fm!RaF(4ra9jH%jFV+Ab`na0*o>6JWs>pIELr*36IAEcDo(iZnu7= zbzM`Q=M+T|2_Xhs>}L%bW8`@rMNvd~o)aSKEtTiF7MNujIgUdBKtT|^2a50e1OT*H zEGWw|Ek-G&lSWb0QB>D;=VTl8bzOJ-rIb2p-!y878^w*nK0+dGdi_(-PN%UnP2V*f z@=21U|C&0EGpIrcL7wOJVu(od`F!~9yRJJ}ufDn?;_n8E<2aP2sTQo1>U2nwByEM` s&xsI%q?DwTB19xaB&8HdDL+0b-)qiJN2TyqivR!s07*qoM6N<$f^$UxTL1t6 literal 0 HcmV?d00001 diff --git a/Telegram/Resources/icons/emoji_nature@2x.png b/Telegram/Resources/icons/emoji_nature@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..308965ef3a46f4bfdbf7b38b7cfeec2ab5be4b63 GIT binary patch literal 1100 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 ksf39{0tG>^91j5SU%C}O7*h^SSk z7OtyVV+zv*4jiFV>lcR34osG@q9i%^;l~;nM`=I0D#?YHx+z@ecz|n z`el!`mQu<)x>zhSoAcIsy(R#b05FOoG#ZV<13DZIXf~TD0iZDkLWsiX<#Iu_TD?yH zcsv#cADuD)?DzYRpf{%s0MqI8Bj|iS|G5(YSF2T_$#1t?3L);10>FB`&M1oh1fEVO zI*yYJ|E*lteH-w!#pv~Vk6;o7Kq+Nz*cijXVDKA!M)AG2aU5rYT5Ijs a=R04Ea+Xe@V|Td#0000=1?!3`6_O-D5CnXFexg>ZA)n9VvqePL)U`=<)H9Ow)9&^Ye3xMx%~B08k_np=>rwtyasmPovSG zt*x!TeH@{gOoj}@7>Kk=*LB+5-0bNi%QC&Zym;FH_cKBj3pouU69Zf|c#YHpe) zl}aVbX0s#rDVNI>3Wb<$#?nfX1WnUC{e!2K_4Re!+}r@L-A9wjWMH6vQ51!Z8B~_# zKrn8xn;29S#XvA_iAJMr%%D8a2ZC{n-Sn-Y_Au!C`+JZM$Jk8_TC3Fp!MNr5`I(Iw zG@s80f^o~;-5nb<=-Js>AQ-pUP3*}80EI#Uu~;k!Q%|bZDi#+P(QdZ^biLv4?(PPH za?1YxK0^XsGYSBgmzPK+64Q2dq*AG1X=w>xUtjFIo;6b{l^VDtm}J`RHnz97JCJ|_ zv|6nql}b$w)}4cc1NO$$9mh4wINmA!*8TlGg~MS-PtP@Kh2uEnayhK5tc-u!9P;}5 zisj|yj+=aU`mX#0L7<0+hl$VR$Hxc7<8ikYsPih+UXe(IN~O}okh-qZ>gwts%#Ns=F=KPUhS zhr@Jyd^|K#(=-xA(J#_J6aa-nAxfvyzBemQPfuxfc6J!#a8Rp~$)u;fCBrZ%lgV^! zC`=U!fEE@OTz6RN^}5&F&t#$2rLecR*K;XcU0snN2;)GG2Wpip%Ty>7=DFm-(V{%!AjUl2nbfG1S`QpEbIjzK=2I$LRv+zN-G2u z!AcMU{}p$Mmt>Qi;tx~J?6k8x3FVx_ zaU5jn@p!;>T}-D_j7Fn8;1e2#5CXg1E)$-V0+@yp5g23WcDwLA?;W5T8iuB6uq+F{ z?<=8)!y)Tzv285NQbL0ufUfJWLz7!hN(k{9RArmw1(V4nAIdpLtyatR;e0-iK^@1* zh6*7f$mw*-^r5cnvBll*_te9PncsEY)XY@2>GgWC8q+lMXWDMJaXcQQ1B1ap>ErEo z8`TVl!{S9%t5w`?HvmAt-&ZcN*=$B5TCdl!obo@tTrM=5%~YvK`~994iv-Bo!YcmWZ_4k%S@+b8T$(i~eEM~M-00000NkvXX Hu0mjf+Vs)U literal 0 HcmV?d00001 diff --git a/Telegram/Resources/icons/emoji_travel@2x.png b/Telegram/Resources/icons/emoji_travel@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..8958c7c62c0bf21e1ce2ebb2cf8f158b8f577b29 GIT binary patch literal 817 zcmV-11J3-3P)^yKaW8x^0C}N-60kgc8zK zWtB>05h10*5Qgt9-kWEdKX>k(Y5w$Zh{-)SznnYYz278zLJ~()RKjF3*(9VqsFR^k2$z?auq?|r=$z?T z52%yja2T~(&DWMzuh%yR>g3_!A@1((q(Fzmq450QW=h`Q-$_+fshV&&Op!=Lczob) zikvvB;_U2fGfN)?5&%roTt8?~NC4<|yXyrNffU&ZY}yKs8N6r_+IDS$KYahH09}<#LEdqrR+KwOZxYG@DI-p!Is4 zJFyHT(ci}#o|&;MOXQjC>xED#moii3lL?-7$bPft(L?RJq& vCVhj_KVc091JAv9&!OG*_%VOq{20(bu7gdULjWwx00000NkvXXu0mjfymo;h literal 0 HcmV?d00001 diff --git a/Telegram/Resources/icons/emoji_trending.png b/Telegram/Resources/icons/emoji_trending.png new file mode 100644 index 0000000000000000000000000000000000000000..4c76cf74a82879ab46541a1524e9ba43b08dfdf7 GIT binary patch literal 546 zcmV+-0^R+IP)St`XwBK`y=8(B@MS)fTwWFcjPoyAy;h1Dc0 zWxsS8C!tW+vLgQij`L*PTvX!J9v*=$Bx zmOp|jih?$q?eEZ1siX^OHk+s@3YBX#8pcq!+l{KK>O%c~KSm-EDtA7g(c|&xLkoq1 z;cijcb~Qnx-Kl;^}lkr_+f5fZ=eMs_XT7@1gm89vx>)W-FCP3ktA4Sm`0M}a^9tX3;LOArJom&*VEFqup!Z?RaA*z5ID z9)U6pLm9W*4J1hdM1)qW1)?ZY{%*G;vB_kjJVKIX8SeKxSS%I*0FWdJR8<84fLtyI z-}T(Y;c$50>3lwi)oMkI{eJ%fdKSlVB%aM?FFqM?EEXff=XqZDZQJd3JRXmTh* zteDLK!lv13O_YT(v+H;8Yku$E-Ouyv*~a^R>#lWQ*Y~Sr#(k&t;Q51#I(b3-vs?lgTgCZg>FE4)| zs7xjc2-2g`(b2C54G#~;)6>(SKoJp}nwq{Aw5_czXh@GF63N$qCMG7L$z%!{=+V&; z^7;JGgANW3h78i9p`oGBf{H{Ue0zKI8^G;$y1F`6&>z5}j*bqt6rvIm5&!@|CX=z|Ha9o> zRg?BA%FD|Gx|@iIy}iAkbvipcS@SC^D+7P@OG`@ugUaP{uUZEO2aNfXlaqmgW@l%k z)9DNtw5qDgt6o`I8DqZDXvCwbcKgg5jYhb-y7HMH85v=$mzS4E8zX`i6cjL;JfbKHT3T9s=9Nk%F<-4#gGQsF zt(TjdOB*AC=I7^wKp%?;e%-U0x??CdO~&t|j1!@~m^ z<_G;BC6Vay@sY8a(P;E}*T%=kfyd*)@$oUE*X44-%gYNf#`GkJpeB=vv6)h-^l3Ic zJk03%RbgRa#CeOwLhB*kYrS3%cDtR{#I#u06d4%_JRXl2)9G}yJ|d__qhT}!^9?jB zD+`1|Au+bUzfbEUf*K44n3|fRH9b8&am4#y5{ZPkShZR$Y;JDS`e>J#LZN_*iwk0m z&*uk#_@62&Dv0wF6BDdn+KoU>O$~AL(ACxD@A1KF6c!c|cVs&|JHa1CdU|?%3L6Xt zjEjro3`#nCy}rJpSS$`66acWlzu%|9z`y_}$ol$v;?t?Asqwdle~sjFIljKWdNpZm zZ1l@37K?q3+jhGhrBW%Ei}nAmR$M!{3h_zYnQYig$N+ULJ~~Fe@vI>#M_k zQIwRF;L6GhA|mSbdW?vOAm+uy#C(1Ra=Bc%ySt0k)zzH)0RXb^J_y>{+5)T93Uav| zY&ILbzrPdnoK7d`^?ERy&7fARVR?BOPEJk&X$k)VEPvLv*VrG600000NkvXXu0mjf D=;b#j literal 0 HcmV?d00001 diff --git a/Telegram/SourceFiles/app.cpp b/Telegram/SourceFiles/app.cpp index 6bfed1347..c44efaa90 100644 --- a/Telegram/SourceFiles/app.cpp +++ b/Telegram/SourceFiles/app.cpp @@ -27,6 +27,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #include "styles/style_overview.h" #include "styles/style_mediaview.h" +#include "styles/style_stickers.h" #include "lang.h" #include "data/data_abstract_structure.h" #include "history/history_service_layout.h" diff --git a/Telegram/SourceFiles/boxes/boxes.style b/Telegram/SourceFiles/boxes/boxes.style index 018503827..1d0266b4c 100644 --- a/Telegram/SourceFiles/boxes/boxes.style +++ b/Telegram/SourceFiles/boxes/boxes.style @@ -203,3 +203,6 @@ notificationSampleUserpicFg: #40ace3; notificationSampleCloseFg: #d7d7d7; notificationSampleTextFg: #d7d7d7; notificationSampleNameFg: #939393; + +membersAboutPadding: margins(0px, 12px, 0px, 12px); +membersAboutFg: #777; diff --git a/Telegram/SourceFiles/boxes/members_box.cpp b/Telegram/SourceFiles/boxes/members_box.cpp index c5647ef29..cacffc59c 100644 --- a/Telegram/SourceFiles/boxes/members_box.cpp +++ b/Telegram/SourceFiles/boxes/members_box.cpp @@ -170,8 +170,8 @@ void MembersBox::Inner::paintEvent(QPaintEvent *e) { p.translate(0, _rowHeight); } if (to == _rows.size() && _filter == MembersFilter::Recent && (_rows.size() < _channel->membersCount() || _rows.size() >= Global::ChatSizeMax())) { - p.setPen(st::stickersReorderFg); - _about.draw(p, st::contactsPadding.left(), st::stickersReorderPadding.top(), _aboutWidth, style::al_center); + p.setPen(st::membersAboutFg); + _about.draw(p, st::contactsPadding.left(), st::membersAboutPadding.top(), _aboutWidth, style::al_center); } } } @@ -348,7 +348,7 @@ void MembersBox::Inner::refresh() { _aboutHeight = 0; } else { _about.setText(st::boxTextFont, lng_channel_only_last_shown(lt_count, _rows.size())); - _aboutHeight = st::stickersReorderPadding.top() + _about.countHeight(_aboutWidth) + st::stickersReorderPadding.bottom(); + _aboutHeight = st::membersAboutPadding.top() + _about.countHeight(_aboutWidth) + st::membersAboutPadding.bottom(); if (_filter != MembersFilter::Recent || (_rows.size() >= _channel->membersCount() && _rows.size() < Global::ChatSizeMax())) { _aboutHeight = 0; } diff --git a/Telegram/SourceFiles/history/field_autocomplete.cpp b/Telegram/SourceFiles/history/field_autocomplete.cpp index bcae2de31..c217e8c70 100644 --- a/Telegram/SourceFiles/history/field_autocomplete.cpp +++ b/Telegram/SourceFiles/history/field_autocomplete.cpp @@ -25,6 +25,8 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #include "apiwrap.h" #include "localstorage.h" #include "styles/style_history.h" +#include "styles/style_widgets.h" +#include "styles/style_stickers.h" FieldAutocomplete::FieldAutocomplete(QWidget *parent) : TWidget(parent) , _scroll(this, st::mentionScroll) diff --git a/Telegram/SourceFiles/history/history.style b/Telegram/SourceFiles/history/history.style index 469119da6..7c1ff3156 100644 --- a/Telegram/SourceFiles/history/history.style +++ b/Telegram/SourceFiles/history/history.style @@ -210,3 +210,17 @@ historyAttachDropdownMenu: DropdownMenu(defaultDropdownMenu) { itemPadding: margins(48px, 11px, 48px, 11px); } } + +topBarSearch: IconButton { + width: 44px; + height: topBarHeight; + + icon: icon {{ "title_search", #000000 }}; + iconPosition: point(13px, 18px); + downIconPosition: point(13px, 18px); + + opacity: 0.22; + overOpacity: 0.36; + + duration: 150; +} diff --git a/Telegram/SourceFiles/inline_bots/inline_bot_layout_internal.cpp b/Telegram/SourceFiles/inline_bots/inline_bot_layout_internal.cpp index 09ffe49e9..3dd81b3df 100644 --- a/Telegram/SourceFiles/inline_bots/inline_bot_layout_internal.cpp +++ b/Telegram/SourceFiles/inline_bots/inline_bot_layout_internal.cpp @@ -23,6 +23,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #include "styles/style_overview.h" #include "styles/style_history.h" +#include "styles/style_stickers.h" #include "inline_bots/inline_bot_result.h" #include "media/media_audio.h" #include "media/media_clip_reader.h" diff --git a/Telegram/SourceFiles/intro/intro.style b/Telegram/SourceFiles/intro/intro.style new file mode 100644 index 000000000..e56d5f7b7 --- /dev/null +++ b/Telegram/SourceFiles/intro/intro.style @@ -0,0 +1,44 @@ +/* +This file is part of Telegram Desktop, +the official desktop version of Telegram messaging app, see https://telegram.org + +Telegram Desktop is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation, either version 3 of the License, or +(at your option) any later version. + +It is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +In addition, as a special exception, the copyright holders give permission +to link the code of portions of this program with the OpenSSL library. + +Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE +Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org +*/ +using "basic.style"; +using "ui/widgets/widgets.style"; + +introErrLabel: flatLabel(labelDefFlat) { + font: introErrFont; + align: align(center); +} +introBackButton: IconButton { + width: 40px; + height: 40px; + + opacity: 0.71; + overOpacity: 1.; + + icon: icon { + { size(40px, 40px), #eeeeee }, + { "title_previous", #969696, point(12px, 12px) }, + }; + iconPosition: point(0px, 0px); + downIconPosition: point(0px, 0px); + + duration: 150; +} +introBackPosition: point(32px, 32px); diff --git a/Telegram/SourceFiles/intro/introphone.cpp b/Telegram/SourceFiles/intro/introphone.cpp index 5f4e7c017..9bb01a378 100644 --- a/Telegram/SourceFiles/intro/introphone.cpp +++ b/Telegram/SourceFiles/intro/introphone.cpp @@ -24,6 +24,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #include "lang.h" #include "application.h" #include "intro/introcode.h" +#include "styles/style_intro.h" namespace { class SignUpClickHandler : public LeftButtonClickHandler { diff --git a/Telegram/SourceFiles/intro/introwidget.cpp b/Telegram/SourceFiles/intro/introwidget.cpp index dab521dd0..678a0e355 100644 --- a/Telegram/SourceFiles/intro/introwidget.cpp +++ b/Telegram/SourceFiles/intro/introwidget.cpp @@ -34,6 +34,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #include "ui/text/text.h" #include "ui/buttons/icon_button.h" #include "ui/effects/widget_fade_wrap.h" +#include "styles/style_intro.h" IntroWidget::IntroWidget(QWidget *parent) : TWidget(parent) , _a_stage(animation(this, &IntroWidget::step_stage)) diff --git a/Telegram/SourceFiles/settings/settings.style b/Telegram/SourceFiles/settings/settings.style index 0bb31a9a5..e7f9881cb 100644 --- a/Telegram/SourceFiles/settings/settings.style +++ b/Telegram/SourceFiles/settings/settings.style @@ -21,6 +21,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org using "basic.style"; using "basic_types.style"; using "dialogs/dialogs.style"; +using "ui/widgets/widgets.style"; settingsMaxWidth: 520px; settingsMaxPadding: 48px; diff --git a/Telegram/SourceFiles/stickers/emoji_pan.cpp b/Telegram/SourceFiles/stickers/emoji_pan.cpp index fc0dd4799..ffa997456 100644 --- a/Telegram/SourceFiles/stickers/emoji_pan.cpp +++ b/Telegram/SourceFiles/stickers/emoji_pan.cpp @@ -22,6 +22,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #include "stickers/emoji_pan.h" #include "styles/style_stickers.h" +#include "ui/buttons/icon_button.h" #include "boxes/confirmbox.h" #include "boxes/stickersetbox.h" #include "boxes/stickers_box.h" @@ -292,7 +293,7 @@ void EmojiColorPicker::drawVariant(Painter &p, int variant) { } EmojiPanInner::EmojiPanInner() : TWidget() -, _maxHeight(int(st::emojiPanMaxHeight) - st::rbEmoji.height) +, _maxHeight(int(st::emojiPanMaxHeight) - st::emojiCategory.height) , _a_selected(animation(this, &EmojiPanInner::step_selected)) { resize(st::emojiPanWidth - st::emojiScroll.width, countHeight()); @@ -797,9 +798,9 @@ StickerPanInner::StickerPanInner() : TWidget() , _a_selected(animation(this, &StickerPanInner::step_selected)) , _section(cShowingSavedGifs() ? Section::Gifs : Section::Stickers) , _addText(lang(lng_stickers_featured_add).toUpper()) -, _addWidth(st::featuredStickersAdd.font->width(_addText)) +, _addWidth(st::stickersTrendingAdd.font->width(_addText)) , _settings(this, lang(lng_stickers_you_have)) { - setMaxHeight(st::emojiPanMaxHeight - st::rbEmoji.height); + setMaxHeight(st::emojiPanMaxHeight - st::emojiCategory.height); setMouseTracking(true); setFocusPolicy(Qt::NoFocus); @@ -864,7 +865,7 @@ void StickerPanInner::readVisibleSets() { } int StickerPanInner::featuredRowHeight() const { - return st::featuredStickersHeader + st::stickerPanSize.height() + st::featuredStickersSkip; + return st::stickersTrendingHeader + st::stickerPanSize.height() + st::stickersTrendingSkip; } int StickerPanInner::countHeight(bool plain) { @@ -915,7 +916,7 @@ StickerPanInner::~StickerPanInner() { QRect StickerPanInner::stickerRect(int tab, int sel) { int x = 0, y = 0; if (_section == Section::Featured) { - y += st::emojiPanHeader + (tab * featuredRowHeight()) + st::featuredStickersHeader; + y += st::emojiPanHeader + (tab * featuredRowHeight()) + st::stickersTrendingHeader; x = st::stickerPanPadding + (sel * st::stickerPanSize.width()); } else { auto &sets = shownSets(); @@ -1018,15 +1019,15 @@ void StickerPanInner::paintStickers(Painter &p, const QRect &r) { if (featuredHasAddButton(c)) { auto add = featuredAddRect(c); auto selected = (_selectedFeaturedSetAdd == c); - auto textBg = selected ? st::featuredStickersAdd.textBgOver : st::featuredStickersAdd.textBg; - auto textTop = (selected && _selectedFeaturedSetAdd == _pressedFeaturedSetAdd) ? st::featuredStickersAdd.downTextTop : st::featuredStickersAdd.textTop; + auto textBg = selected ? st::stickersTrendingAdd.textBgOver : st::stickersTrendingAdd.textBg; + auto textTop = (selected && _selectedFeaturedSetAdd == _pressedFeaturedSetAdd) ? st::stickersTrendingAdd.downTextTop : st::stickersTrendingAdd.textTop; App::roundRect(p, myrtlrect(add), textBg, ImageRoundRadius::Small); - p.setFont(st::featuredStickersAdd.font); - p.setPen(selected ? st::featuredStickersAdd.textFgOver : st::featuredStickersAdd.textFg); - p.drawTextLeft(add.x() - (st::featuredStickersAdd.width / 2), add.y() + textTop, width(), _addText, _addWidth); + p.setFont(st::stickersTrendingAdd.font); + p.setPen(selected ? st::stickersTrendingAdd.textFgOver : st::stickersTrendingAdd.textFg); + p.drawTextLeft(add.x() - (st::stickersTrendingAdd.width / 2), add.y() + textTop, width(), _addText, _addWidth); - widthForTitle -= add.width() - (st::featuredStickersAdd.width / 2); + widthForTitle -= add.width() - (st::stickersTrendingAdd.width / 2); } else { auto add = featuredAddRect(c); int checkx = add.left() + (add.width() - st::stickersFeaturedInstalled.width()) / 2; @@ -1038,29 +1039,29 @@ void StickerPanInner::paintStickers(Painter &p, const QRect &r) { } auto titleText = set.title; - auto titleWidth = st::featuredStickersHeaderFont->width(titleText); + auto titleWidth = st::stickersTrendingHeaderFont->width(titleText); if (titleWidth > widthForTitle) { - titleText = st::featuredStickersHeaderFont->elided(titleText, widthForTitle); - titleWidth = st::featuredStickersHeaderFont->width(titleText); + titleText = st::stickersTrendingHeaderFont->elided(titleText, widthForTitle); + titleWidth = st::stickersTrendingHeaderFont->width(titleText); } - p.setFont(st::featuredStickersHeaderFont); - p.setPen(st::featuredStickersHeaderFg); - p.drawTextLeft(st::emojiPanHeaderLeft, y + st::featuredStickersHeaderTop, width(), titleText, titleWidth); + p.setFont(st::stickersTrendingHeaderFont); + p.setPen(st::stickersTrendingHeaderFg); + p.drawTextLeft(st::emojiPanHeaderLeft, y + st::stickersTrendingHeaderTop, width(), titleText, titleWidth); if (set.flags & MTPDstickerSet_ClientFlag::f_unread) { p.setPen(Qt::NoPen); p.setBrush(st::stickersFeaturedUnreadBg); p.setRenderHint(QPainter::HighQualityAntialiasing, true); - p.drawEllipse(rtlrect(st::emojiPanHeaderLeft + titleWidth + st::stickersFeaturedUnreadSkip, y + st::featuredStickersHeaderTop + st::stickersFeaturedUnreadTop, st::stickersFeaturedUnreadSize, st::stickersFeaturedUnreadSize, width())); + p.drawEllipse(rtlrect(st::emojiPanHeaderLeft + titleWidth + st::stickersFeaturedUnreadSkip, y + st::stickersTrendingHeaderTop + st::stickersFeaturedUnreadTop, st::stickersFeaturedUnreadSize, st::stickersFeaturedUnreadSize, width())); p.setRenderHint(QPainter::HighQualityAntialiasing, false); } - p.setFont(st::featuredStickersSubheaderFont); - p.setPen(st::featuredStickersSubheaderFg); - p.drawTextLeft(st::emojiPanHeaderLeft, y + st::featuredStickersSubheaderTop, width(), lng_stickers_count(lt_count, size)); + p.setFont(st::stickersTrendingSubheaderFont); + p.setPen(st::stickersTrendingSubheaderFg); + p.drawTextLeft(st::emojiPanHeaderLeft, y + st::stickersTrendingSubheaderTop, width(), lng_stickers_count(lt_count, size)); - y += st::featuredStickersHeader; + y += st::stickersTrendingHeader; if (y >= r.y() + r.height()) break; for (int j = fromcol; j < tocol; ++j) { @@ -1156,10 +1157,10 @@ int StickerPanInner::featuredContentWidth() const { } QRect StickerPanInner::featuredAddRect(int index) const { - int addw = _addWidth - st::featuredStickersAdd.width; - int addh = st::featuredStickersAdd.height; + int addw = _addWidth - st::stickersTrendingAdd.width; + int addh = st::stickersTrendingAdd.height; int addx = featuredContentWidth() - addw; - int addy = st::emojiPanHeader + index * featuredRowHeight() + st::featuredStickersAddTop; + int addy = st::emojiPanHeader + index * featuredRowHeight() + st::stickersTrendingAddTop; return QRect(addx, addy, addw, addh); } @@ -2002,7 +2003,7 @@ void StickerPanInner::fillIcons(QList &icons) { } for (int l = _mySets.size(); i < l; ++i) { auto s = _mySets[i].pack[0]; - int32 availw = st::rbEmoji.width - 2 * st::stickerIconPadding, availh = st::rbEmoji.height - 2 * st::stickerIconPadding; + int32 availw = st::emojiCategory.width - 2 * st::stickerIconPadding, availh = st::emojiCategory.height - 2 * st::stickerIconPadding; int32 thumbw = s->thumb->width(), thumbh = s->thumb->height(), pixw = 1, pixh = 1; if (availw * thumbh > availh * thumbw) { pixh = availh; @@ -2175,7 +2176,7 @@ void StickerPanInner::updateSelected() { } if (p.y() >= y && p.y() < ytill) { if (featured) { - if (p.y() < y + st::featuredStickersHeader) { + if (p.y() < y + st::stickersTrendingHeader) { if (featuredHasAddButton(c) && myrtlrect(featuredAddRect(c)).contains(p.x(), p.y())) { selectedFeaturedSetAdd = c; } else { @@ -2183,7 +2184,7 @@ void StickerPanInner::updateSelected() { } break; } - y += st::featuredStickersHeader; + y += st::stickersTrendingHeader; } else { y += st::emojiPanHeader; } @@ -2547,18 +2548,18 @@ EmojiPan::EmojiPan(QWidget *parent) : TWidget(parent) , _maxHeight(st::emojiPanMaxHeight) , _contentMaxHeight(st::emojiPanMaxHeight) , _contentHeight(_contentMaxHeight) -, _contentHeightEmoji(_contentHeight - st::rbEmoji.height) -, _contentHeightStickers(_contentHeight - st::rbEmoji.height) +, _contentHeightEmoji(_contentHeight - st::emojiCategory.height) +, _contentHeightStickers(_contentHeight - st::emojiCategory.height) , _a_appearance(animation(this, &EmojiPan::step_appearance)) , _shadow(st::defaultDropdownShadow) -, _recent(this , qsl("emoji_group"), dbietRecent , QString(), true , st::rbEmojiRecent) -, _people(this , qsl("emoji_group"), dbietPeople , QString(), false, st::rbEmojiPeople) -, _nature(this , qsl("emoji_group"), dbietNature , QString(), false, st::rbEmojiNature) -, _food(this , qsl("emoji_group"), dbietFood , QString(), false, st::rbEmojiFood) -, _activity(this, qsl("emoji_group"), dbietActivity, QString(), false, st::rbEmojiActivity) -, _travel(this , qsl("emoji_group"), dbietTravel , QString(), false, st::rbEmojiTravel) -, _objects(this , qsl("emoji_group"), dbietObjects , QString(), false, st::rbEmojiObjects) -, _symbols(this , qsl("emoji_group"), dbietSymbols , QString(), false, st::rbEmojiSymbols) +, _recent(this, st::emojiCategoryRecent) +, _people(this, st::emojiCategoryPeople) +, _nature(this, st::emojiCategoryNature) +, _food(this, st::emojiCategoryFood) +, _activity(this, st::emojiCategoryActivity) +, _travel(this, st::emojiCategoryTravel) +, _objects(this, st::emojiCategoryObjects) +, _symbols(this, st::emojiCategorySymbols) , _a_icons(animation(this, &EmojiPan::step_icons)) , _a_slide(animation(this, &EmojiPan::step_slide)) , e_scroll(this, st::emojiScroll) @@ -2589,19 +2590,21 @@ EmojiPan::EmojiPan(QWidget *parent) : TWidget(parent) e_inner.moveToLeft(0, 0, e_scroll.width()); s_inner.moveToLeft(0, 0, s_scroll.width()); - int32 left = _iconsLeft = st::defaultDropdownPadding.left() + (st::emojiPanWidth - 8 * st::rbEmoji.width) / 2; - int32 top = _iconsTop = st::defaultDropdownPadding.top() + _contentHeight - st::rbEmoji.height; - prepareTab(left, top, _width, _recent); - prepareTab(left, top, _width, _people); - prepareTab(left, top, _width, _nature); - prepareTab(left, top, _width, _food); - prepareTab(left, top, _width, _activity); - prepareTab(left, top, _width, _travel); - prepareTab(left, top, _width, _objects); - prepareTab(left, top, _width, _symbols); + int32 left = _iconsLeft = st::defaultDropdownPadding.left() + (st::emojiPanWidth - 8 * st::emojiCategory.width) / 2; + int32 top = _iconsTop = st::defaultDropdownPadding.top() + _contentHeight - st::emojiCategory.height; + prepareTab(left, top, _width, _recent, dbietRecent); + prepareTab(left, top, _width, _people, dbietPeople); + prepareTab(left, top, _width, _nature, dbietNature); + prepareTab(left, top, _width, _food, dbietFood); + prepareTab(left, top, _width, _activity, dbietActivity); + prepareTab(left, top, _width, _travel, dbietTravel); + prepareTab(left, top, _width, _objects, dbietObjects); + prepareTab(left, top, _width, _symbols, dbietSymbols); e_inner.fillPanels(e_panels); updatePanelsPositions(e_panels, 0); + setCurrentTabIcon(dbietRecent); + _hideTimer.setSingleShot(true); connect(&_hideTimer, SIGNAL(timeout()), this, SLOT(hideAnimated())); @@ -2657,8 +2660,8 @@ void EmojiPan::setMaxHeight(int32 h) { void EmojiPan::updateContentHeight() { int32 h = qMin(_contentMaxHeight, _maxHeight); - int32 he = h - st::rbEmoji.height; - int32 hs = h - (s_inner.showSectionIcons() ? st::rbEmoji.height : 0); + int32 he = h - st::emojiCategory.height; + int32 hs = h - (s_inner.showSectionIcons() ? st::emojiCategory.height : 0); if (h == _contentHeight && he == _contentHeightEmoji && hs == _contentHeightStickers) return; int32 was = _contentHeight, wase = _contentHeightEmoji, wass = _contentHeightStickers; @@ -2683,24 +2686,23 @@ void EmojiPan::updateContentHeight() { s_scroll.resize(st::emojiPanWidth, _contentHeightStickers); } - _iconsTop = st::defaultDropdownPadding.top() + _contentHeight - st::rbEmoji.height; - _recent.move(_recent.x(), _iconsTop); - _people.move(_people.x(), _iconsTop); - _nature.move(_nature.x(), _iconsTop); - _food.move(_food.x(), _iconsTop); - _activity.move(_activity.x(), _iconsTop); - _travel.move(_travel.x(), _iconsTop); - _objects.move(_objects.x(), _iconsTop); - _symbols.move(_symbols.x(), _iconsTop); + _iconsTop = st::defaultDropdownPadding.top() + _contentHeight - st::emojiCategory.height; + _recent->move(_recent->x(), _iconsTop); + _people->move(_people->x(), _iconsTop); + _nature->move(_nature->x(), _iconsTop); + _food->move(_food->x(), _iconsTop); + _activity->move(_activity->x(), _iconsTop); + _travel->move(_travel->x(), _iconsTop); + _objects->move(_objects->x(), _iconsTop); + _symbols->move(_symbols->x(), _iconsTop); update(); } -void EmojiPan::prepareTab(int32 &left, int32 top, int32 _width, FlatRadiobutton &tab) { - tab.moveToLeft(left, top, _width); - left += tab.width(); - tab.setAttribute(Qt::WA_OpaquePaintEvent); - connect(&tab, SIGNAL(changed()), this, SLOT(onTabChange())); +void EmojiPan::prepareTab(int &left, int top, int _width, Ui::IconButton *tab, DBIEmojiTab value) { + tab->moveToLeft(left, top, _width); + left += tab->width(); + tab->setClickedCallback([this, value] { setActiveTab(value); }); } void EmojiPan::onWndActiveChanged() { @@ -2718,8 +2720,8 @@ void EmojiPan::onSaveConfigDelayed(int32 delay) { } void EmojiPan::paintStickerSettingsIcon(Painter &p) const { - int settingsLeft = _iconsLeft + 7 * st::rbEmoji.width; - p.drawSpriteLeft(settingsLeft + st::rbEmojiRecent.imagePos.x(), _iconsTop + st::rbEmojiRecent.imagePos.y(), width(), st::stickersSettings); + int settingsLeft = _iconsLeft + 7 * st::emojiCategory.width; + st::stickersSettings.paint(p, settingsLeft + st::emojiCategory.iconPosition.x(), _iconsTop + st::emojiCategory.iconPosition.y(), width()); } void EmojiPan::paintFeaturedStickerSetsBadge(Painter &p, int iconLeft) const { @@ -2727,7 +2729,7 @@ void EmojiPan::paintFeaturedStickerSetsBadge(Painter &p, int iconLeft) const { Dialogs::Layout::UnreadBadgeStyle unreadSt; unreadSt.sizeId = Dialogs::Layout::UnreadBadgeInStickersPanel; unreadSt.size = st::stickersSettingsUnreadSize; - int unreadRight = iconLeft + st::rbEmoji.width - st::stickersSettingsUnreadPosition.x(); + int unreadRight = iconLeft + st::emojiCategory.width - st::stickersSettingsUnreadPosition.x(); if (rtl()) unreadRight = width() - unreadRight; int unreadTop = _iconsTop + st::stickersSettingsUnreadPosition.y(); Dialogs::Layout::paintUnreadCount(p, QString::number(unread), unreadRight, unreadTop, unreadSt); @@ -2750,28 +2752,28 @@ void EmojiPan::paintEvent(QPaintEvent *e) { if (_cache.isNull()) { p.fillRect(myrtlrect(r.x() + r.width() - st::emojiScroll.width, r.y(), st::emojiScroll.width, e_scroll.height()), st::white->b); if (_stickersShown && s_inner.showSectionIcons()) { - p.fillRect(r.left(), _iconsTop, r.width(), st::rbEmoji.height, st::emojiPanCategories); + p.fillRect(r.left(), _iconsTop, r.width(), st::emojiCategory.height, st::emojiPanCategories); paintStickerSettingsIcon(p); if (!_icons.isEmpty()) { int x = _iconsLeft, selxrel = _iconsLeft + _iconSelX.current(), selx = selxrel - _iconsX.current(); - QRect clip(x, _iconsTop, _iconsLeft + 7 * st::rbEmoji.width - x, st::rbEmoji.height); + QRect clip(x, _iconsTop, _iconsLeft + 7 * st::emojiCategory.width - x, st::emojiCategory.height); if (rtl()) clip.moveLeft(width() - x - clip.width()); p.setClipRect(clip); auto getSpecialSetIcon = [](uint64 setId, bool active) { if (setId == Stickers::NoneSetId) { - return active ? st::savedGifsActive : st::savedGifsOver; + return active ? &st::emojiSavedGifsActive : &st::emojiSavedGifs; } else if (setId == Stickers::FeaturedSetId) { - return active ? st::featuredStickersActive : st::featuredStickersOver; + return active ? &st::stickersTrendingActive : &st::stickersTrending; } - return active ? st::rbEmojiRecent.chkImageRect : st::rbEmojiRecent.imageRect; + return active ? &st::emojiRecentActive : &st::emojiRecent; }; int i = 0; - i += _iconsX.current() / int(st::rbEmoji.width); - x -= _iconsX.current() % int(st::rbEmoji.width); + i += _iconsX.current() / int(st::emojiCategory.width); + x -= _iconsX.current() % int(st::emojiCategory.width); selxrel -= _iconsX.current(); for (int l = qMin(_icons.size(), i + 8); i < l; ++i) { auto &s = _icons.at(i); @@ -2779,54 +2781,52 @@ void EmojiPan::paintEvent(QPaintEvent *e) { s.sticker->thumb->load(); QPixmap pix(s.sticker->thumb->pix(s.pixw, s.pixh)); - p.drawPixmapLeft(x + (st::rbEmoji.width - s.pixw) / 2, _iconsTop + (st::rbEmoji.height - s.pixh) / 2, width(), pix); - x += st::rbEmoji.width; + p.drawPixmapLeft(x + (st::emojiCategory.width - s.pixw) / 2, _iconsTop + (st::emojiCategory.height - s.pixh) / 2, width(), pix); + x += st::emojiCategory.width; } else { if (true || selxrel != x) { - p.drawSpriteLeft(x + st::rbEmojiRecent.imagePos.x(), _iconsTop + st::rbEmojiRecent.imagePos.y(), width(), getSpecialSetIcon(s.setId, false)); + getSpecialSetIcon(s.setId, false)->paint(p, x + st::emojiCategory.iconPosition.x(), _iconsTop + st::emojiCategory.iconPosition.y(), width()); } - //if (selxrel < x + st::rbEmoji.width && selxrel > x - st::rbEmoji.width) { - // p.setOpacity(1 - (qAbs(selxrel - x) / float64(st::rbEmoji.width))); + //if (selxrel < x + st::emojiCategory.width && selxrel > x - st::emojiCategory.width) { + // p.setOpacity(1 - (qAbs(selxrel - x) / float64(st::emojiCategory.width))); // p.drawSpriteLeft(x + st::rbEmojiRecent.imagePos.x(), _iconsTop + st::rbEmojiRecent.imagePos.y(), width(), getSpecialSetIcon(s.setId, true)); // p.setOpacity(1); //} if (s.setId == Stickers::FeaturedSetId) { paintFeaturedStickerSetsBadge(p, x); } - x += st::rbEmoji.width; + x += st::emojiCategory.width; } } - if (rtl()) selx = width() - selx - st::rbEmoji.width; + if (rtl()) selx = width() - selx - st::emojiCategory.width; p.setOpacity(1.); - p.fillRect(selx, _iconsTop + st::rbEmoji.height - st::stickerIconPadding, st::rbEmoji.width, st::stickerIconSel, st::stickerIconSelColor); + p.fillRect(selx, _iconsTop + st::emojiCategory.height - st::stickerIconPadding, st::emojiCategory.width, st::stickerIconSel, st::stickerIconSelColor); float64 o_left = snap(float64(_iconsX.current()) / st::stickerIconLeft.pxWidth(), 0., 1.); if (o_left > 0) { p.setOpacity(o_left); - p.drawSpriteLeft(QRect(_iconsLeft, _iconsTop, st::stickerIconLeft.pxWidth(), st::rbEmoji.height), width(), st::stickerIconLeft); + p.drawSpriteLeft(QRect(_iconsLeft, _iconsTop, st::stickerIconLeft.pxWidth(), st::emojiCategory.height), width(), st::stickerIconLeft); } float64 o_right = snap(float64(_iconsMax - _iconsX.current()) / st::stickerIconRight.pxWidth(), 0., 1.); if (o_right > 0) { p.setOpacity(o_right); - p.drawSpriteRight(QRect(width() - _iconsLeft - 7 * st::rbEmoji.width, _iconsTop, st::stickerIconRight.pxWidth(), st::rbEmoji.height), width(), st::stickerIconRight); + p.drawSpriteRight(QRect(width() - _iconsLeft - 7 * st::emojiCategory.width, _iconsTop, st::stickerIconRight.pxWidth(), st::emojiCategory.height), width(), st::stickerIconRight); } } } else if (_stickersShown) { - int32 x = rtl() ? (_recent.x() + _recent.width()) : (_objects.x() + _objects.width()); - p.fillRect(x, _recent.y(), r.left() + r.width() - x, st::rbEmoji.height, st::white); + int32 x = rtl() ? (_recent->x() + _recent->width()) : (_objects->x() + _objects->width()); + p.fillRect(x, _recent->y(), r.left() + r.width() - x, st::emojiCategory.height, st::white); } else { - p.fillRect(r.left(), _recent.y(), (rtl() ? _objects.x() : _recent.x() - r.left()), st::rbEmoji.height, st::emojiPanCategories); - int32 x = rtl() ? (_recent.x() + _recent.width()) : (_objects.x() + _objects.width()); - p.fillRect(x, _recent.y(), r.left() + r.width() - x, st::rbEmoji.height, st::emojiPanCategories); + p.fillRect(r.left(), _iconsTop, r.width(), st::emojiCategory.height, st::emojiPanCategories); } } else { p.fillRect(r, st::white); p.drawPixmap(r.left(), r.top(), _cache); } } else { - p.fillRect(QRect(r.left(), r.top(), r.width(), r.height() - st::rbEmoji.height), st::white->b); - p.fillRect(QRect(r.left(), _iconsTop, r.width(), st::rbEmoji.height), st::emojiPanCategories->b); + p.fillRect(QRect(r.left(), r.top(), r.width(), r.height() - st::emojiCategory.height), st::white->b); + p.fillRect(QRect(r.left(), _iconsTop, r.width(), st::emojiCategory.height), st::emojiPanCategories->b); p.setOpacity(o * a_fromAlpha.current()); QRect fromDst = QRect(r.left() + a_fromCoord.current(), r.top(), _fromCache.width() / cIntRetinaFactor(), _fromCache.height() / cIntRetinaFactor()); QRect fromSrc = QRect(0, 0, _fromCache.width(), _fromCache.height()); @@ -2957,7 +2957,7 @@ void EmojiPan::mouseReleaseEvent(QMouseEvent *e) { updateSelected(); if (wasDown == _iconOver && _iconOver >= 0 && _iconOver < _icons.size()) { - _iconSelX = anim::ivalue(_iconOver * st::rbEmoji.width, _iconOver * st::rbEmoji.width); + _iconSelX = anim::ivalue(_iconOver * st::emojiCategory.width, _iconOver * st::emojiCategory.width); s_inner.showStickerSet(_icons.at(_iconOver).setId); } } @@ -3031,7 +3031,7 @@ void EmojiPan::onRefreshIcons(bool scrollAnimation) { _iconsMax = 0; } else { _iconHovers = QVector(_icons.size(), 0); - _iconsMax = qMax(int((_icons.size() - 7) * st::rbEmoji.width), 0); + _iconsMax = qMax(int((_icons.size() - 7) * st::emojiCategory.width), 0); } if (_iconsX.current() > _iconsMax) { _iconsX = anim::ivalue(_iconsMax, _iconsMax); @@ -3070,12 +3070,12 @@ void EmojiPan::updateSelected() { int32 x = p.x(), y = p.y(), newOver = -1; if (rtl()) x = width() - x; x -= _iconsLeft; - if (x >= st::rbEmoji.width * 7 && x < st::rbEmoji.width * 8 && y >= _iconsTop && y < _iconsTop + st::rbEmoji.height) { + if (x >= st::emojiCategory.width * 7 && x < st::emojiCategory.width * 8 && y >= _iconsTop && y < _iconsTop + st::emojiCategory.height) { newOver = _icons.size(); } else if (!_icons.isEmpty()) { - if (y >= _iconsTop && y < _iconsTop + st::rbEmoji.height && x >= 0 && x < 7 * st::rbEmoji.width && x < _icons.size() * st::rbEmoji.width) { + if (y >= _iconsTop && y < _iconsTop + st::emojiCategory.height && x >= 0 && x < 7 * st::emojiCategory.width && x < _icons.size() * st::emojiCategory.width) { x += _iconsX.current(); - newOver = qFloor(x / st::rbEmoji.width); + newOver = qFloor(x / st::emojiCategory.width); } } if (newOver != _iconOver) { @@ -3108,7 +3108,7 @@ void EmojiPan::updateIcons() { if (!_stickersShown || !s_inner.showSectionIcons()) return; QRect r(st::defaultDropdownPadding.left(), st::defaultDropdownPadding.top(), _width - st::defaultDropdownPadding.left() - st::defaultDropdownPadding.right(), _height - st::defaultDropdownPadding.top() - st::defaultDropdownPadding.bottom()); - update(r.left(), _iconsTop, r.width(), st::rbEmoji.height); + update(r.left(), _iconsTop, r.width(), st::emojiCategory.height); } void EmojiPan::step_icons(uint64 ms, bool timer) { @@ -3229,11 +3229,7 @@ void EmojiPan::hideFinish() { _hiding = false; e_scroll.scrollToY(0); - if (!_recent.checked()) { - _noTabUpdate = true; - _recent.setChecked(true); - _noTabUpdate = false; - } + setCurrentTabIcon(dbietRecent); s_scroll.scrollToY(0); _iconOver = _iconDown = -1; _iconSel = 0; @@ -3349,55 +3345,46 @@ bool EmojiPan::ui_isInlineItemBeingChosen() { void EmojiPan::showAll() { if (_stickersShown) { s_scroll.show(); - _recent.hide(); - _people.hide(); - _nature.hide(); - _food.hide(); - _activity.hide(); - _travel.hide(); - _objects.hide(); - _symbols.hide(); + _recent->hide(); + _people->hide(); + _nature->hide(); + _food->hide(); + _activity->hide(); + _travel->hide(); + _objects->hide(); + _symbols->hide(); e_scroll.hide(); } else { s_scroll.hide(); - _recent.show(); - _people.show(); - _nature.show(); - _food.show(); - _activity.show(); - _travel.show(); - _objects.show(); - _symbols.show(); + _recent->show(); + _people->show(); + _nature->show(); + _food->show(); + _activity->show(); + _travel->show(); + _objects->show(); + _symbols->show(); e_scroll.show(); } } void EmojiPan::hideAll() { - _recent.hide(); - _people.hide(); - _nature.hide(); - _food.hide(); - _activity.hide(); - _travel.hide(); - _objects.hide(); - _symbols.hide(); + _recent->hide(); + _people->hide(); + _nature->hide(); + _food->hide(); + _activity->hide(); + _travel->hide(); + _objects->hide(); + _symbols->hide(); e_scroll.hide(); s_scroll.hide(); e_inner.clearSelection(true); s_inner.clearSelection(true); } -void EmojiPan::onTabChange() { - if (_noTabUpdate) return; - DBIEmojiTab newTab = dbietRecent; - if (_people.checked()) newTab = dbietPeople; - else if (_nature.checked()) newTab = dbietNature; - else if (_food.checked()) newTab = dbietFood; - else if (_activity.checked()) newTab = dbietActivity; - else if (_travel.checked()) newTab = dbietTravel; - else if (_objects.checked()) newTab = dbietObjects; - else if (_symbols.checked()) newTab = dbietSymbols; - e_inner.showEmojiPack(newTab); +void EmojiPan::setActiveTab(DBIEmojiTab tab) { + e_inner.showEmojiPack(tab); } void EmojiPan::updatePanelsPositions(const QVector &panels, int32 st) { @@ -3423,27 +3410,22 @@ void EmojiPan::onScrollEmoji() { updatePanelsPositions(e_panels, st); - auto tab = e_inner.currentTab(st); - FlatRadiobutton *check = nullptr; - switch (tab) { - case dbietRecent: check = &_recent; break; - case dbietPeople: check = &_people; break; - case dbietNature: check = &_nature; break; - case dbietFood: check = &_food; break; - case dbietActivity: check = &_activity; break; - case dbietTravel: check = &_travel; break; - case dbietObjects: check = &_objects; break; - case dbietSymbols: check = &_symbols; break; - } - if (check && !check->checked()) { - _noTabUpdate = true; - check->setChecked(true); - _noTabUpdate = false; - } + setCurrentTabIcon(e_inner.currentTab(st)); e_inner.setVisibleTopBottom(st, st + e_scroll.height()); } +void EmojiPan::setCurrentTabIcon(DBIEmojiTab tab) { + _recent->setIcon((tab == dbietRecent) ? &st::emojiRecentActive : nullptr); + _people->setIcon((tab == dbietPeople) ? &st::emojiPeopleActive : nullptr); + _nature->setIcon((tab == dbietNature) ? &st::emojiNatureActive : nullptr); + _food->setIcon((tab == dbietFood) ? &st::emojiFoodActive : nullptr); + _activity->setIcon((tab == dbietActivity) ? &st::emojiActivityActive : nullptr); + _travel->setIcon((tab == dbietTravel) ? &st::emojiTravelActive : nullptr); + _objects->setIcon((tab == dbietObjects) ? &st::emojiObjectsActive : nullptr); + _symbols->setIcon((tab == dbietSymbols) ? &st::emojiSymbolsActive : nullptr); +} + void EmojiPan::onScrollStickers() { auto st = s_scroll.scrollTop(); @@ -3468,13 +3450,13 @@ void EmojiPan::validateSelectedIcon(ValidateIconAnimations animations) { } if (newSel != _iconSel) { _iconSel = newSel; - auto iconSelXFinal = newSel * st::rbEmoji.width; + auto iconSelXFinal = newSel * st::emojiCategory.width; if (animations == ValidateIconAnimations::Full) { _iconSelX.start(iconSelXFinal); } else { _iconSelX = anim::ivalue(iconSelXFinal, iconSelXFinal); } - auto iconsXFinal = snap((2 * newSel - 7) * int(st::rbEmoji.width) / 2, 0, _iconsMax); + auto iconsXFinal = snap((2 * newSel - 7) * int(st::emojiCategory.width) / 2, 0, _iconsMax); if (animations == ValidateIconAnimations::None) { _iconsX = anim::ivalue(iconsXFinal, iconsXFinal); _a_icons.stop(); diff --git a/Telegram/SourceFiles/stickers/emoji_pan.h b/Telegram/SourceFiles/stickers/emoji_pan.h index a90ae4d1e..3beab8728 100644 --- a/Telegram/SourceFiles/stickers/emoji_pan.h +++ b/Telegram/SourceFiles/stickers/emoji_pan.h @@ -30,6 +30,10 @@ class ItemBase; class Result; } // namespace InlineBots +namespace Ui { +class IconButton; +} // namesapce Ui + namespace internal { constexpr int InlineItemsMaxPerRow = 5; @@ -545,7 +549,6 @@ private slots: void onWndActiveChanged(); - void onTabChange(); void onScrollEmoji(); void onScrollStickers(); void onSwitch(); @@ -577,6 +580,8 @@ private: bool preventAutoHide() const; void installSetDone(const MTPmessages_StickerSetInstallResult &result); bool installSetFail(uint64 setId, const RPCError &error); + void setActiveTab(DBIEmojiTab tab); + void setCurrentTabIcon(DBIEmojiTab tab); void paintStickerSettingsIcon(Painter &p) const; void paintFeaturedStickerSetsBadge(Painter &p, int iconLeft) const; @@ -596,8 +601,8 @@ private: void updateSelected(); void updateIcons(); - void prepareTab(int32 &left, int32 top, int32 _width, FlatRadiobutton &tab); - void updatePanelsPositions(const QVector &panels, int32 st); + void prepareTab(int &left, int top, int _width, Ui::IconButton *tab, DBIEmojiTab value); + void updatePanelsPositions(const QVector &panels, int st); void showAll(); void hideAll(); @@ -605,8 +610,6 @@ private: int32 _maxHeight, _contentMaxHeight, _contentHeight, _contentHeightEmoji, _contentHeightStickers; bool _horizontal = false; - bool _noTabUpdate = false; - int32 _width, _height, _bottom; bool _hiding = false; QPixmap _cache; @@ -618,7 +621,15 @@ private: Ui::RectShadow _shadow; - FlatRadiobutton _recent, _people, _nature, _food, _activity, _travel, _objects, _symbols; + ChildWidget _recent; + ChildWidget _people; + ChildWidget _nature; + ChildWidget _food; + ChildWidget _activity; + ChildWidget _travel; + ChildWidget _objects; + ChildWidget _symbols; + QList _icons; QVector _iconHovers; int _iconOver = -1; diff --git a/Telegram/SourceFiles/stickers/stickers.style b/Telegram/SourceFiles/stickers/stickers.style index c1a9168a1..4eea840ee 100644 --- a/Telegram/SourceFiles/stickers/stickers.style +++ b/Telegram/SourceFiles/stickers/stickers.style @@ -21,19 +21,20 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org using "basic.style"; using "boxes/boxes.style"; +using "ui/widgets/widgets.style"; -featuredStickersHeader: 45px; -featuredStickersSkip: 15px; +stickersTrendingHeader: 45px; +stickersTrendingSkip: 15px; -featuredStickersHeaderFont: semiboldFont; -featuredStickersHeaderFg: windowTextFg; -featuredStickersHeaderTop: 0px; -featuredStickersSubheaderFont: normalFont; -featuredStickersSubheaderFg: #777; -featuredStickersSubheaderTop: 20px; +stickersTrendingHeaderFont: semiboldFont; +stickersTrendingHeaderFg: windowTextFg; +stickersTrendingHeaderTop: 0px; +stickersTrendingSubheaderFont: normalFont; +stickersTrendingSubheaderFg: #777; +stickersTrendingSubheaderTop: 20px; -featuredStickersAddTop: 3px; -featuredStickersAdd: RoundButton(defaultActiveButton) { +stickersTrendingAddTop: 3px; +stickersTrendingAdd: RoundButton(defaultActiveButton) { width: -17px; height: 26px; textTop: 4px; @@ -56,3 +57,108 @@ stickersFeaturedUnreadSize: 5px; stickersFeaturedUnreadSkip: 5px; stickersFeaturedUnreadTop: 7px; stickersFeaturedInstalled: icon {{ "mediaview_save_check", #40ace3 }}; + +stickersMaxHeight: 440px; +stickersPadding: margins(19px, 17px, 19px, 17px); +stickersSize: size(64px, 64px); +stickersScroll: flatScroll(boxScroll) { + round: 2px; + deltax: 7px; + deltat: 23px; + deltab: 9px; +} +stickersReorderPadding: margins(0px, 12px, 0px, 12px); +stickersReorderFg: #777; +stickersRowDisabledOpacity: 0.4; +stickersRowDuration: 200; + +stickersSettings: icon {{ "emoji_settings", #b3b3b3 }}; +stickersTrending: icon {{ "emoji_trending", #b3b3b3 }}; +stickersTrendingActive: icon {{ "emoji_trending", #58b2ed }}; + +stickersSettingsUnreadSize: 17px; +stickersSettingsUnreadPosition: point(4px, 5px); + +emojiScroll: flatScroll(solidScroll) { + deltat: 48px; +} +emojiRecent: icon {{ "emoji_recent", #b3b3b3 }}; +emojiRecentActive: icon {{ "emoji_recent", #58b2ed }}; +emojiPeople: icon {{ "emoji_people", #b3b3b3 }}; +emojiPeopleActive: icon {{ "emoji_people", #58b2ed }}; +emojiNature: icon {{ "emoji_nature", #b3b3b3 }}; +emojiNatureActive: icon {{ "emoji_nature", #58b2ed }}; +emojiFood: icon {{ "emoji_food", #b3b3b3 }}; +emojiFoodActive: icon {{ "emoji_food", #58b2ed }}; +emojiActivity: icon {{ "emoji_activity", #b3b3b3 }}; +emojiActivityActive: icon {{ "emoji_activity", #58b2ed }}; +emojiTravel: icon {{ "emoji_travel", #b3b3b3 }}; +emojiTravelActive: icon {{ "emoji_travel", #58b2ed }}; +emojiObjects: icon {{ "emoji_objects", #b3b3b3 }}; +emojiObjectsActive: icon {{ "emoji_objects", #58b2ed }}; +emojiSymbols: icon {{ "emoji_symbols", #b3b3b3 }}; +emojiSymbolsActive: icon {{ "emoji_symbols", #58b2ed }}; +emojiSavedGifs: icon {{ "emoji_gif", #b3b3b3 }}; +emojiSavedGifsActive: icon {{ "emoji_gif", #58b2ed }}; + +emojiPanCategories: #f7f7f7; + +emojiCategory: IconButton { + width: 42px; + height: 46px; + + opacity: 1.; + overOpacity: 1.; + + iconPosition: point(11px, 12px); + downIconPosition: point(11px, 12px); + + duration: 0; +} +emojiCategoryRecent: IconButton(emojiCategory) { icon: emojiRecent; } +emojiCategoryPeople: IconButton(emojiCategory) { icon: emojiPeople; } +emojiCategoryNature: IconButton(emojiCategory) { icon: emojiNature; } +emojiCategoryFood: IconButton(emojiCategory) { icon: emojiFood; } +emojiCategoryActivity: IconButton(emojiCategory) { icon: emojiActivity; } +emojiCategoryTravel: IconButton(emojiCategory) { icon: emojiTravel; } +emojiCategoryObjects: IconButton(emojiCategory) { icon: emojiObjects; } +emojiCategorySymbols: IconButton(emojiCategory) { icon: emojiSymbols; } + +emojiPanPadding: 12px; +emojiPanSize: size(45px, 41px); +emojiPanWidth: 345px; +emojiPanMaxHeight: 366px; +emojiPanDuration: 200; +emojiPanHover: #f0f4f7; + +emojiPanHeader: 42px; +emojiPanHeaderFont: semiboldFont; +emojiPanHeaderColor: #999; +emojiPanHeaderLeft: 22px; +emojiPanHeaderTop: 12px; +emojiPanHeaderBg: #fffffff2; + +emojiColorsPadding: 5px; +emojiColorsSep: 1px; +emojiColorsSepColor: #d5d5d5; + +emojiSwitchSkip: 27px; +emojiSwitchImgSkip: 21px; +emojiSwitchStickers: sprite(318px, 328px, 8px, 12px); +emojiSwitchEmoji: sprite(310px, 328px, 8px, 12px); +emojiSwitchColor: #42a8db; + +stickerPanSize: size(64px, 64px); +stickerPanPadding: 11px; +stickerPanDelete: sprite(128px, 132px, 12px, 12px); +stickerPanDeleteOpacity: 0.5; +stickerIconPadding: 5px; +stickerIconOpacity: 0.7; +stickerIconSel: 2px; +stickerIconSelColor: #58b2ed; +stickerIconLeft: sprite(342px, 72px, 40px, 1px); +stickerIconRight: sprite(342px, 73px, 40px, 1px); +stickerIconMove: 400; +stickerPreviewDuration: 150; +stickerPreviewBg: #FFFFFFB0; +stickerPreviewMin: 0.1; diff --git a/Telegram/SourceFiles/ui/buttons/history_down_button.h b/Telegram/SourceFiles/ui/buttons/history_down_button.h index 0ab821ee5..03e2d7976 100644 --- a/Telegram/SourceFiles/ui/buttons/history_down_button.h +++ b/Telegram/SourceFiles/ui/buttons/history_down_button.h @@ -21,6 +21,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #pragma once #include "ui/button.h" +#include "styles/style_widgets.h" namespace Ui { diff --git a/Telegram/SourceFiles/ui/buttons/icon_button.h b/Telegram/SourceFiles/ui/buttons/icon_button.h index 488a49df1..104a5825a 100644 --- a/Telegram/SourceFiles/ui/buttons/icon_button.h +++ b/Telegram/SourceFiles/ui/buttons/icon_button.h @@ -21,6 +21,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #pragma once #include "ui/button.h" +#include "styles/style_widgets.h" namespace Ui { diff --git a/Telegram/SourceFiles/ui/widgets/widgets.style b/Telegram/SourceFiles/ui/widgets/widgets.style index 5eda18b3c..959c7cc75 100644 --- a/Telegram/SourceFiles/ui/widgets/widgets.style +++ b/Telegram/SourceFiles/ui/widgets/widgets.style @@ -27,10 +27,18 @@ LabelSimple { textFg: color; } -defaultLabelSimple: LabelSimple { - font: normalFont; - maxWidth: 0px; - textFg: windowTextFg; +IconButton { + width: pixels; + height: pixels; + + opacity: double; + overOpacity: double; + + icon: icon; + iconPosition: point; + downIconPosition: point; + + duration: int; } MediaSlider { @@ -153,6 +161,12 @@ DropdownMenu { menu: Menu; } +defaultLabelSimple: LabelSimple { + font: normalFont; + maxWidth: 0px; + textFg: windowTextFg; +} + widgetSlideDuration: 200; widgetFadeDuration: 200; diff --git a/Telegram/SourceFiles/window/top_bar_widget.cpp b/Telegram/SourceFiles/window/top_bar_widget.cpp index 703adf37a..6aa796332 100644 --- a/Telegram/SourceFiles/window/top_bar_widget.cpp +++ b/Telegram/SourceFiles/window/top_bar_widget.cpp @@ -21,6 +21,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org #include "stdafx.h" #include "window/top_bar_widget.h" +#include "styles/style_history.h" #include "boxes/addcontactbox.h" #include "boxes/confirmbox.h" #include "mainwidget.h" diff --git a/Telegram/SourceFiles/window/window.style b/Telegram/SourceFiles/window/window.style index 8722c4d3b..a7da80f3b 100644 --- a/Telegram/SourceFiles/window/window.style +++ b/Telegram/SourceFiles/window/window.style @@ -20,6 +20,7 @@ Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org */ using "basic.style"; +using "ui/widgets/widgets.style"; titleIconPosition: point(9px, 9px); titleIcon: icon { diff --git a/Telegram/gyp/Telegram.gyp b/Telegram/gyp/Telegram.gyp index 012edecf9..9ffc4d0f8 100644 --- a/Telegram/gyp/Telegram.gyp +++ b/Telegram/gyp/Telegram.gyp @@ -39,6 +39,7 @@ '<(src_loc)/boxes/boxes.style', '<(src_loc)/dialogs/dialogs.style', '<(src_loc)/history/history.style', + '<(src_loc)/intro/intro.style', '<(src_loc)/media/view/mediaview.style', '<(src_loc)/media/player/media_player.style', '<(src_loc)/overview/overview.style',