From 45f9925a990ed0fb4b842756f9482f2f5bf111d4 Mon Sep 17 00:00:00 2001 From: RadRussianRus Date: Thu, 15 Sep 2022 23:35:57 +0300 Subject: [PATCH] [Visual] Allow hiding shadow of modal window header This was needed for custom changelog box, which is currently not in main branch. --- ui/layers/box_content.cpp | 4 +++- ui/layers/box_content.h | 9 +++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/ui/layers/box_content.cpp b/ui/layers/box_content.cpp index 1dc17f4..5575885 100644 --- a/ui/layers/box_content.cpp +++ b/ui/layers/box_content.cpp @@ -343,10 +343,12 @@ void BoxContent::updateShadowsVisibility(anim::type animated) { _topShadow->toggle( ((top > 0) || (_innerTopSkip > 0 + && !_topShadowWithSkip && !getDelegate()->style().shadowIgnoreTopSkip)), animated); _bottomShadow->toggle( - (top < _scroll->scrollTopMax() || _innerBottomSkip > 0), + (top < _scroll->scrollTopMax() + || (_innerBottomSkip > 0 && !_bottomShadowWithSkip)), animated); } diff --git a/ui/layers/box_content.h b/ui/layers/box_content.h index ef94672..237d38c 100644 --- a/ui/layers/box_content.h +++ b/ui/layers/box_content.h @@ -240,6 +240,13 @@ protected: getDelegate()->setLayerType(layerType); } + void setTopShadowWithSkip(bool enabled) { + _topShadowWithSkip = enabled; + } + void setBottomShadowWithSkip(bool enabled) { + _bottomShadowWithSkip = enabled; + } + void setDimensions( int newWidth, int maxHeight, @@ -307,6 +314,8 @@ private: bool _preparing = false; bool _noContentMargin = false; bool _closeByEscape = true; + bool _topShadowWithSkip = false; + bool _bottomShadowWithSkip = false; int _innerTopSkip = 0; int _innerBottomSkip = 0; object_ptr _scroll = { nullptr };