Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(ScrollLock): export useScroll to scroll locked layout #8137

Merged

Conversation

EldarMuhamethanov
Copy link
Contributor

@EldarMuhamethanov EldarMuhamethanov commented Jan 9, 2025


  • Unit-тесты
  • Release notes

Описание

В issue #8069 был приложен пример, где нужно было реализовать скролл фона при открытии ModalCard. Это было сделано не самым удобным способом - убиранием блокировки, изменение скролла window, и возвратом блокировки. У данного подхода есть еще проблема в том, что при изменении скролла, скроллбар справа появляется и потом пропадает. Выглядит не очень

Сейчас в контексте ScrollContext уже есть методы scrollTo и getScroll, которые позволяют скроллить, но только, когда скролл не заблочен. Нужно доработать эти функции, чтобы они работали корректно и при заблокированном скролле. Также надо подумать как из отдать пользователю наружу

Изменения

  • Доработал логику функций из контекста scrollTo и getScroll, так чтобы они корректно работали при заблокированном скролле. Для этого добавил правильный расчет x и y на основании стилей у body
  • Добавил тест, проверяющий новый функционал со скроллом при заблокированном контенте.
  • Добавил хук useScrollingLockedScroll, который возвращает только scrollTo и getScroll из контекста ScrollContext, чтобы не экспортировать больше чем нужно

Release notes

Улучшения

  • Добавлен хук useScroll, который позволяет скролить ScrollContext из AppRoot вручную.

Copy link
Contributor

github-actions bot commented Jan 9, 2025

size-limit report 📦

Path Size
JS 394.58 KB (+0.18% 🔺)
JS (gzip) 119.63 KB (+0.18% 🔺)
JS (brotli) 98.52 KB (+0.23% 🔺)
JS import Div (tree shaking) 1.56 KB (0%)
CSS 346.91 KB (0%)
CSS (gzip) 42.96 KB (0%)
CSS (brotli) 34.3 KB (0%)

Copy link

codesandbox-ci bot commented Jan 9, 2025

This pull request is automatically built and testable in CodeSandbox.

To see build info of the built libraries, click here or the icon next to each commit SHA.

Copy link
Contributor

github-actions bot commented Jan 9, 2025

e2e tests

Playwright Report

Copy link
Contributor

github-actions bot commented Jan 9, 2025

👀 Docs deployed

Commit 6731074

Copy link

codecov bot commented Jan 9, 2025

Codecov Report

Attention: Patch coverage is 89.09091% with 6 lines in your changes missing coverage. Please review.

Project coverage is 95.46%. Comparing base (0e0e2a7) to head (6731074).
Report is 37 commits behind head on master.

Files with missing lines Patch % Lines
...ages/vkui/src/components/AppRoot/ScrollContext.tsx 89.09% 6 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master    #8137      +/-   ##
==========================================
- Coverage   95.50%   95.46%   -0.05%     
==========================================
  Files         403      403              
  Lines       11525    11554      +29     
  Branches     3827     3829       +2     
==========================================
+ Hits        11007    11030      +23     
- Misses        518      524       +6     
Flag Coverage Δ
unittests 95.46% <89.09%> (-0.05%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Contributor

@andrey-medvedev-vk andrey-medvedev-vk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🔥

Copy link
Contributor

@andrey-medvedev-vk andrey-medvedev-vk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

💯

@vkcom-publisher vkcom-publisher added the pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности label Jan 18, 2025
@EldarMuhamethanov EldarMuhamethanov removed the pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности label Jan 21, 2025
@inomdzhon inomdzhon added this to the v7.2.0 milestone Jan 27, 2025
# Conflicts:
#	packages/vkui/src/components/AppRoot/ScrollContext.test.tsx
@vkcom-publisher vkcom-publisher added the pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности label Feb 7, 2025
@inomdzhon inomdzhon changed the title feat(ScrollLock): add useScrollingLockedScroll to scroll locked layout feat(ScrollLock): export useScroll to scroll locked layout Feb 11, 2025
Copy link
Contributor

@inomdzhon inomdzhon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🔥

@inomdzhon
Copy link
Contributor

inomdzhon commented Feb 11, 2025

В Release notes скорей нужно написать, что даём API для скролла ScrollContext из AppRoot

Скролл при заблокированном скролле это лишь кейс исползования

@vkcom-publisher vkcom-publisher removed the pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности label Feb 12, 2025
@EldarMuhamethanov EldarMuhamethanov merged commit aed03e0 into master Feb 12, 2025
27 of 29 checks passed
@EldarMuhamethanov EldarMuhamethanov deleted the e.muhamethanov/manual-scroll-with-scroll-lock branch February 12, 2025 10:36
@vkcom-publisher
Copy link
Contributor

v7.2.0 🎉

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

4 participants