mirror of
https://github.com/telegramdesktop/tdesktop
synced 2025-01-11 01:10:13 +00:00
470 lines
14 KiB
Plaintext
470 lines
14 KiB
Plaintext
/*
|
|
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-2017 John Preston, https://desktop.telegram.org
|
|
*/
|
|
|
|
// basic
|
|
windowBg: #ffffff; // white: fallback for background
|
|
windowFg: #000000; // black: fallback for text color
|
|
windowBgOver: #f1f1f1; // light gray: fallback for over background
|
|
windowBgRipple: #e5e5e5; // darker gray: fallback for ripple effect
|
|
windowFgOver: windowFg; // black: fallback for over text color
|
|
windowSubTextFg: #999999; // gray: fallback for subtext color
|
|
windowSubTextFgOver: #919191; // gray over light blue: fallback for subtext over color
|
|
windowBoldFg: #222222; // dark gray: fallback for bold text color
|
|
windowBoldFgOver: #222222; // dark gray: fallback for over bold text color
|
|
windowBgActive: #40a7e3; // bright blue: fallback for blue filled active areas
|
|
windowFgActive: #ffffff; // text on bright blue: fallback for text on active areas
|
|
windowActiveTextFg: #168acd; // online blue: fallback for active color
|
|
windowShadowFg: #000000; // black: fallback for shadow color
|
|
windowShadowFgFallback: #f1f1f1; // gray: fallback for shadow without opacity
|
|
|
|
shadowFg: #00000018;
|
|
slideFadeOutBg: #0000003c;
|
|
slideFadeOutShadowFg: windowShadowFg;
|
|
|
|
imageBg: #000000;
|
|
imageBgTransparent: #ffffff;
|
|
|
|
// widgets
|
|
activeButtonBg: windowBgActive;
|
|
activeButtonBgOver: #39a5db;
|
|
activeButtonBgRipple: #2095d0;
|
|
activeButtonFg: windowFgActive;
|
|
activeButtonFgOver: activeButtonFg;
|
|
activeButtonSecondaryFg: #cceeff;
|
|
activeButtonSecondaryFgOver: activeButtonSecondaryFg;
|
|
activeLineFg: #37a1de;
|
|
activeLineFgError: #e48383;
|
|
|
|
lightButtonBg: windowBg;
|
|
lightButtonBgOver: #e3f1fa;
|
|
lightButtonBgRipple: #c9e4f6;
|
|
lightButtonFg: windowActiveTextFg;
|
|
lightButtonFgOver: lightButtonFg;
|
|
|
|
attentionButtonFg: #d14e4e;
|
|
attentionButtonFgOver: #d14e4e;
|
|
attentionButtonBgOver: #fcdfde;
|
|
attentionButtonBgRipple: #f4c3c2;
|
|
|
|
outlineButtonBg: windowBg;
|
|
outlineButtonBgOver: lightButtonBgOver;
|
|
outlineButtonOutlineFg: windowBgActive;
|
|
outlineButtonBgRipple: lightButtonBgRipple;
|
|
|
|
menuBg: windowBg;
|
|
menuBgOver: windowBgOver;
|
|
menuBgRipple: windowBgRipple;
|
|
menuIconFg: #a8a8a8;
|
|
menuIconFgOver: #999999;
|
|
menuSubmenuArrowFg: #373737;
|
|
menuFgDisabled: #cccccc;
|
|
menuSeparatorFg: #f1f1f1;
|
|
|
|
scrollBarBg: #00000053;
|
|
scrollBarBgOver: #0000007a;
|
|
scrollBg: #0000001a;
|
|
scrollBgOver: #0000002c;
|
|
|
|
smallCloseIconFg: #c7c7c7;
|
|
smallCloseIconFgOver: #a3a3a3;
|
|
|
|
radialFg: windowFgActive;
|
|
radialBg: #00000056;
|
|
|
|
placeholderFg: windowSubTextFg;
|
|
placeholderFgActive: #aaaaaa;
|
|
inputBorderFg: #e0e0e0;
|
|
filterInputBorderFg: #54c3f3;
|
|
filterInputInactiveBg: windowBgOver;
|
|
checkboxFg: #b3b3b3;
|
|
|
|
sliderBgInactive: #e1eaef;
|
|
sliderBgActive: windowBgActive;
|
|
|
|
tooltipBg: #eef2f5;
|
|
tooltipFg: #5d6c80;
|
|
tooltipBorderFg: #c9d1db;
|
|
|
|
// custom title bar for Windows and macOS
|
|
titleBg: windowBgOver;
|
|
titleShadow: #00000003;
|
|
titleButtonFg: #ababab;
|
|
titleButtonBgOver: #e5e5e5;
|
|
titleButtonFgOver: #9a9a9a;
|
|
titleButtonCloseBgOver: #e81123;
|
|
titleButtonCloseFgOver: windowFgActive;
|
|
titleFgActive: #3e3c3e;
|
|
titleFg: #acacac;
|
|
|
|
// tray icon
|
|
trayCounterBg: #f23c34;
|
|
trayCounterBgMute: #888888;
|
|
trayCounterFg: #ffffff;
|
|
trayCounterBgMacInvert: #ffffff;
|
|
trayCounterFgMacInvert: #ffffff01;
|
|
|
|
// layers
|
|
layerBg: #0000007f;
|
|
|
|
cancelIconFg: menuIconFg;
|
|
cancelIconFgOver: menuIconFgOver;
|
|
|
|
// boxes
|
|
boxBg: windowBg;
|
|
boxTextFg: windowFg;
|
|
boxTextFgGood: #4ab44a;
|
|
boxTextFgError: #d84d4d;
|
|
boxTitleFg: #404040;
|
|
boxSearchBg: boxBg;
|
|
boxSearchCancelIconFg: cancelIconFg;
|
|
boxSearchCancelIconFgOver: cancelIconFgOver;
|
|
|
|
boxTitleAdditionalFg: #808080;
|
|
boxTitleCloseFg: cancelIconFg;
|
|
boxTitleCloseFgOver: cancelIconFgOver;
|
|
|
|
membersAboutLimitFg: windowSubTextFgOver;
|
|
|
|
contactsBg: windowBg;
|
|
contactsBgOver: windowBgOver;
|
|
contactsNameFg: boxTextFg;
|
|
contactsStatusFg: windowSubTextFg;
|
|
contactsStatusFgOver: windowSubTextFgOver;
|
|
contactsStatusFgOnline: windowActiveTextFg;
|
|
|
|
photoCropFadeBg: layerBg;
|
|
photoCropPointFg: #ffffff7f;
|
|
|
|
// intro
|
|
introBg: windowBg;
|
|
introTitleFg: windowBoldFg;
|
|
introDescriptionFg: windowSubTextFg;
|
|
introErrorFg: windowSubTextFg;
|
|
|
|
introCoverTopBg: #0f89d0;
|
|
introCoverBottomBg: #39b0f0;
|
|
introCoverIconsFg: #5ec6ff;
|
|
introCoverPlaneTrace: #5ec6ff69;
|
|
introCoverPlaneInner: #c6d8e8;
|
|
introCoverPlaneOuter: #a1bed4;
|
|
introCoverPlaneTop: #ffffff;
|
|
|
|
// dialogs
|
|
dialogsMenuIconFg: menuIconFg;
|
|
dialogsMenuIconFgOver: menuIconFgOver;
|
|
|
|
dialogsBg: windowBg;
|
|
dialogsNameFg: windowBoldFg;
|
|
dialogsChatIconFg: dialogsNameFg;
|
|
dialogsDateFg: windowSubTextFg;
|
|
dialogsTextFg: windowSubTextFg;
|
|
dialogsTextFgService: windowActiveTextFg;
|
|
dialogsDraftFg: #dd4b39;
|
|
dialogsVerifiedIconBg: windowBgActive;
|
|
dialogsVerifiedIconFg: windowFgActive;
|
|
dialogsSendingIconFg: #c1c1c1;
|
|
dialogsSentIconFg: #5dc452;
|
|
dialogsUnreadBg: windowBgActive;
|
|
dialogsUnreadBgMuted: #bbbbbb;
|
|
dialogsUnreadFg: windowFgActive;
|
|
|
|
dialogsBgOver: windowBgOver;
|
|
dialogsNameFgOver: windowBoldFgOver;
|
|
dialogsChatIconFgOver: dialogsNameFgOver;
|
|
dialogsDateFgOver: windowSubTextFgOver;
|
|
dialogsTextFgOver: windowSubTextFgOver;
|
|
dialogsTextFgServiceOver: dialogsTextFgService;
|
|
dialogsDraftFgOver: dialogsDraftFg;
|
|
dialogsVerifiedIconBgOver: dialogsVerifiedIconBg;
|
|
dialogsVerifiedIconFgOver: dialogsVerifiedIconFg;
|
|
dialogsSendingIconFgOver: dialogsSendingIconFg;
|
|
dialogsSentIconFgOver: dialogsSentIconFg;
|
|
dialogsUnreadBgOver: dialogsUnreadBg;
|
|
dialogsUnreadBgMutedOver: dialogsUnreadBgMuted;
|
|
dialogsUnreadFgOver: dialogsUnreadFg;
|
|
|
|
dialogsBgActive: #419fd9;
|
|
dialogsNameFgActive: windowFgActive;
|
|
dialogsChatIconFgActive: dialogsNameFgActive;
|
|
dialogsDateFgActive: windowFgActive;
|
|
dialogsTextFgActive: windowFgActive;
|
|
dialogsTextFgServiceActive: dialogsTextFgActive;
|
|
dialogsDraftFgActive: #c6e1f7;
|
|
dialogsVerifiedIconBgActive: dialogsTextFgActive;
|
|
dialogsVerifiedIconFgActive: dialogsBgActive;
|
|
dialogsSendingIconFgActive: #ffffff99;
|
|
dialogsSentIconFgActive: dialogsTextFgActive;
|
|
dialogsUnreadBgActive: dialogsTextFgActive;
|
|
dialogsUnreadBgMutedActive: dialogsDraftFgActive;
|
|
dialogsUnreadFgActive: dialogsBgActive;
|
|
|
|
dialogsForwardBg: dialogsBgActive;
|
|
dialogsForwardFg: dialogsNameFgActive;
|
|
|
|
searchedBarBg: windowBgOver;
|
|
searchedBarBorder: shadowFg;
|
|
searchedBarFg: windowSubTextFgOver;
|
|
|
|
// history
|
|
topBarBg: windowBg;
|
|
|
|
emojiPanBg: windowBg;
|
|
emojiPanCategories: #f7f7f7 | windowBg;
|
|
emojiPanHeaderFg: windowSubTextFg;
|
|
emojiPanHeaderBg: #fffffff2 | emojiPanBg;
|
|
stickerPanDeleteBg: #000000cc;
|
|
stickerPanDeleteFg: windowFgActive;
|
|
stickerPreviewBg: #ffffffb0;
|
|
|
|
historyTextInFg: windowFg;
|
|
historyTextOutFg: windowFg;
|
|
historyCaptionInFg: historyTextInFg;
|
|
historyCaptionOutFg: historyTextOutFg;
|
|
historyFileNameInFg: historyTextInFg;
|
|
historyFileNameOutFg: historyTextOutFg;
|
|
historyOutIconFg: dialogsSentIconFg;
|
|
historyOutIconFgSelected: #4da79f;
|
|
historyIconFgInverted: windowFgActive;
|
|
historySendingOutIconFg: #98d292;
|
|
historySendingInIconFg: #a0adb5;
|
|
historySendingInvertedIconFg: #ffffffc8;
|
|
|
|
historySystemBg: #89a0b47f;
|
|
historySystemBgSelected: #bbc8d4a2;
|
|
historySystemFg: windowFgActive;
|
|
|
|
historyUnreadBarBg: #fcfbfa;
|
|
historyUnreadBarBorder: shadowFg;
|
|
historyUnreadBarFg: #538bb4;
|
|
|
|
historyForwardChooseBg: #0000004c;
|
|
historyForwardChooseFg: windowFgActive;
|
|
|
|
historyPeer1NameFg: #c03d33; // red
|
|
historyPeer1UserpicBg: #e17076;
|
|
historyPeer2NameFg: #4fad2d; // green
|
|
historyPeer2UserpicBg: #7bc862;
|
|
historyPeer3NameFg: #d09306; // yellow
|
|
historyPeer3UserpicBg: #e5ca77;
|
|
historyPeer4NameFg: windowActiveTextFg; // blue
|
|
historyPeer4UserpicBg: #65aadd;
|
|
historyPeer5NameFg: #8544d6; // purple
|
|
historyPeer5UserpicBg: #a695e7;
|
|
historyPeer6NameFg: #cd4073; // pink
|
|
historyPeer6UserpicBg: #ee7aae;
|
|
historyPeer7NameFg: #2996ad; // sea
|
|
historyPeer7UserpicBg: #6ec9cb;
|
|
historyPeer8NameFg: #ce671b; // orange
|
|
historyPeer8UserpicBg: #faa774;
|
|
historyPeerUserpicFg: windowFgActive;
|
|
|
|
historyScrollBarBg: #517c417a;
|
|
historyScrollBarBgOver: #517c41bc;
|
|
historyScrollBg: #517c414c;
|
|
historyScrollBgOver: #517c416b;
|
|
|
|
msgInBg: windowBg;
|
|
msgInBgSelected: #c2dcf2; // #358cd4 with 30% opacity
|
|
msgOutBg: #effdde;
|
|
msgOutBgSelected: #b7dbdb;
|
|
msgSelectOverlay: #358cd44c;
|
|
msgStickerOverlay: #358cd47f;
|
|
msgInServiceFg: windowActiveTextFg;
|
|
msgInServiceFgSelected: windowActiveTextFg;
|
|
msgOutServiceFg: #3a8e26;
|
|
msgOutServiceFgSelected: #367570;
|
|
msgInShadow: #748ea229;
|
|
msgInShadowSelected: #548dbb29;
|
|
msgOutShadow: #3ac34740;
|
|
msgOutShadowSelected: #37a78e40;
|
|
msgInDateFg: #a0acb6;
|
|
msgInDateFgSelected: #6a9cc5;
|
|
msgOutDateFg: #6cc264;
|
|
msgOutDateFgSelected: #50a79c;
|
|
msgServiceFg: windowFgActive;
|
|
msgServiceBg: #517c417f;
|
|
msgServiceBgSelected: #96b38ba2;
|
|
msgInReplyBarColor: activeLineFg;
|
|
msgInReplyBarSelColor: activeLineFg;
|
|
msgOutReplyBarColor: historyOutIconFg;
|
|
msgOutReplyBarSelColor: historyOutIconFgSelected;
|
|
msgImgReplyBarColor: msgServiceFg;
|
|
msgInMonoFg: #4e7391;
|
|
msgOutMonoFg: #469165;
|
|
msgDateImgFg: msgServiceFg;
|
|
msgDateImgBg: #00000054;
|
|
msgDateImgBgOver: #00000074;
|
|
msgDateImgBgSelected: #1c4a7187;
|
|
|
|
msgFileThumbLinkInFg: lightButtonFg;
|
|
msgFileThumbLinkInFgSelected: lightButtonFgOver;
|
|
msgFileThumbLinkOutFg: #5eba5b;
|
|
msgFileThumbLinkOutFgSelected: #31a298;
|
|
msgFileInBg: windowBgActive;
|
|
msgFileInBgOver: #4eade3;
|
|
msgFileInBgSelected: #51a3d3;
|
|
msgFileOutBg: #78c67f;
|
|
msgFileOutBgOver: #6bc272;
|
|
msgFileOutBgSelected: #5fb389;
|
|
|
|
msgFile1Bg: #72b1df; // blue
|
|
msgFile1BgDark: #5c9ece;
|
|
msgFile1BgOver: #5294c4;
|
|
msgFile1BgSelected: #5099d0;
|
|
msgFile2Bg: #61b96e; // green
|
|
msgFile2BgDark: #4da859;
|
|
msgFile2BgOver: #44a050;
|
|
msgFile2BgSelected: #46a07e;
|
|
msgFile3Bg: #e47272; // red
|
|
msgFile3BgDark: #cd5b5e;
|
|
msgFile3BgOver: #c35154;
|
|
msgFile3BgSelected: #9f6a82;
|
|
msgFile4Bg: #efc274; // yellow
|
|
msgFile4BgDark: #e6a561;
|
|
msgFile4BgOver: #dc9c5a;
|
|
msgFile4BgSelected: #b19d84;
|
|
|
|
historyFileInIconFg: msgInBg;
|
|
historyFileInIconFgSelected: msgInBgSelected;
|
|
historyFileInRadialFg: historyFileInIconFg;
|
|
historyFileInRadialFgSelected: historyFileInIconFgSelected;
|
|
historyFileOutIconFg: msgOutBg;
|
|
historyFileOutIconFgSelected: msgOutBgSelected;
|
|
historyFileOutRadialFg: historyFileOutIconFg;
|
|
historyFileOutRadialFgSelected: historyFileOutIconFgSelected;
|
|
historyFileThumbIconFg: msgInBg;
|
|
historyFileThumbIconFgSelected: msgInBgSelected;
|
|
historyFileThumbRadialFg: historyFileThumbIconFg;
|
|
historyFileThumbRadialFgSelected: historyFileThumbIconFgSelected;
|
|
|
|
msgWaveformInActive: windowBgActive;
|
|
msgWaveformInActiveSelected: #51a3d3;
|
|
msgWaveformInInactive: #d4dee6;
|
|
msgWaveformInInactiveSelected: #9cc1e1;
|
|
msgWaveformOutActive: #78c67f;
|
|
msgWaveformOutActiveSelected: #6badad;
|
|
msgWaveformOutInactive: #b3e2b4;
|
|
msgWaveformOutInactiveSelected: #91c3c3;
|
|
|
|
msgBotKbOverBgAdd: #ffffff20;
|
|
msgBotKbIconFg: msgServiceFg;
|
|
msgBotKbRippleBg: #00000020;
|
|
|
|
mediaInFg: msgInDateFg;
|
|
mediaInFgSelected: msgInDateFgSelected;
|
|
mediaOutFg: msgOutDateFg;
|
|
mediaOutFgSelected: msgOutDateFgSelected;
|
|
|
|
youtubePlayIconBg: #e83131c8;
|
|
youtubePlayIconFg: windowFgActive;
|
|
videoPlayIconBg: #0000007f;
|
|
videoPlayIconFg: #ffffff;
|
|
toastBg: #000000b2;
|
|
toastFg: windowFgActive;
|
|
|
|
reportSpamBg: emojiPanHeaderBg;
|
|
reportSpamFg: windowFg;
|
|
|
|
historyToDownShadow: #00000040;
|
|
historyComposeAreaBg: msgInBg;
|
|
historyComposeAreaFg: historyTextInFg;
|
|
historyComposeAreaFgService: msgInDateFg;
|
|
historyComposeIconFg: menuIconFg;
|
|
historyComposeIconFgOver: menuIconFgOver;
|
|
historySendIconFg: windowBgActive;
|
|
historySendIconFgOver: windowBgActive;
|
|
historyPinnedBg: historyComposeAreaBg;
|
|
historyReplyBg: historyComposeAreaBg;
|
|
historyReplyIconFg: windowBgActive;
|
|
historyReplyCancelFg: cancelIconFg;
|
|
historyReplyCancelFgOver: cancelIconFgOver;
|
|
|
|
historyComposeButtonBg: historyComposeAreaBg;
|
|
historyComposeButtonBgOver: windowBgOver;
|
|
historyComposeButtonBgRipple: windowBgRipple;
|
|
|
|
// overview
|
|
overviewCheckBg: #00000040;
|
|
overviewCheckFg: windowBg;
|
|
overviewCheckFgActive: windowBg;
|
|
overviewPhotoSelectOverlay: #40ace333;
|
|
|
|
// profile
|
|
profileStatusFgOver: #7c99b2;
|
|
profileVerifiedCheckBg: windowBgActive;
|
|
profileVerifiedCheckFg: windowFgActive;
|
|
|
|
// settings
|
|
notificationsBoxMonitorFg: windowFg;
|
|
notificationsBoxScreenBg: dialogsBgActive; // #6389a8;
|
|
|
|
notificationSampleUserpicFg: windowBgActive;
|
|
notificationSampleCloseFg: #d7d7d7 | windowSubTextFg;
|
|
notificationSampleTextFg: #d7d7d7 | windowSubTextFg;
|
|
notificationSampleNameFg: #939393 | windowSubTextFg;
|
|
|
|
mainMenuBg: windowBg;
|
|
mainMenuCoverBg: dialogsBgActive;
|
|
mainMenuCoverFg: windowFgActive;
|
|
|
|
mediaPlayerBg: windowBg;
|
|
mediaPlayerActiveFg: windowBgActive;
|
|
mediaPlayerInactiveFg: sliderBgInactive;
|
|
mediaPlayerDisabledFg: #9dd1ef;
|
|
|
|
// mediaview
|
|
mediaviewFileBg: windowBg;
|
|
mediaviewFileNameFg: windowFg;
|
|
mediaviewFileSizeFg: windowSubTextFg;
|
|
mediaviewFileRedCornerFg: #d55959;
|
|
mediaviewFileYellowCornerFg: #e8a659;
|
|
mediaviewFileGreenCornerFg: #49a957;
|
|
mediaviewFileBlueCornerFg: #599dcf;
|
|
mediaviewFileExtFg: activeButtonFg;
|
|
|
|
mediaviewMenuBg: #383838;
|
|
mediaviewMenuBgOver: #505050;
|
|
mediaviewMenuBgRipple: #676767;
|
|
mediaviewMenuFg: windowFgActive;
|
|
|
|
mediaviewBg: #222222eb;
|
|
mediaviewVideoBg: imageBg;
|
|
mediaviewControlBg: #0000003c;
|
|
mediaviewControlFg: windowFgActive;
|
|
mediaviewCaptionBg: #11111180;
|
|
mediaviewCaptionFg: mediaviewControlFg;
|
|
mediaviewTextLinkFg: #91d9ff;
|
|
mediaviewSaveMsgBg: toastBg;
|
|
mediaviewSaveMsgFg: toastFg;
|
|
|
|
mediaviewPlaybackActive: #c7c7c7;
|
|
mediaviewPlaybackInactive: #252525;
|
|
mediaviewPlaybackActiveOver: #ffffff;
|
|
mediaviewPlaybackInactiveOver: #474747;
|
|
mediaviewPlaybackProgressFg: #ffffffc7;
|
|
mediaviewPlaybackIconFg: mediaviewPlaybackActive;
|
|
mediaviewPlaybackIconFgOver: mediaviewPlaybackActiveOver;
|
|
mediaviewTransparentBg: #ffffff;
|
|
mediaviewTransparentFg: #cccccc;
|
|
|
|
// notification
|
|
notificationBg: windowBg;
|