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

refactor(Tooltip, Popover): refactor Tooltip and Popover logic #8040

Merged
merged 11 commits into from
Jan 13, 2025

Conversation

EldarMuhamethanov
Copy link
Contributor

@EldarMuhamethanov EldarMuhamethanov commented Dec 5, 2024

  • Unit-тесты
  • Документация фичи
  • Release notes

Описание

Сейчас Popover и Tooltip имеют очень похожие реализации, которые минимально отличаются друг от друга. Вообще если так подумать, то Tooltip - это частный случай Popover. Нужно придумать как объединить логику

Изменения

  • Добавил хук useTooltip по примеру usePopover. Добавил упоминание в документации, а также написал тест
  • Вынес общую логику хуков useTooltip и usePopover в useFloatingElement, который содержит всю логику позиционирования всплывающего элемента.
  • Вынес логику патча children в хук useAnchorElement.
  • Также добавил логику, которая позволяет в children Tooltip/Popover прокидывать обычный текст. В таком случае мы просто оборачиваем его в span

Release notes

Улучшения

  • Tooltip: добавлена возможность установки своего якорного элемента для Popover снаружи

Исправления

  • Tooltip: Теперь в качестве children можно прокинуть обычный текст

@EldarMuhamethanov EldarMuhamethanov added cmp:tooltip cmp:popover Бывший dropdown labels Dec 5, 2024
@EldarMuhamethanov EldarMuhamethanov added this to the v7.1.0 milestone Dec 5, 2024
@EldarMuhamethanov EldarMuhamethanov self-assigned this Dec 5, 2024
@EldarMuhamethanov EldarMuhamethanov requested a review from a team as a code owner December 5, 2024 11:14
Copy link
Contributor

github-actions bot commented Dec 5, 2024

size-limit report 📦

Path Size
JS 390.76 KB (+0.45% 🔺)
JS (gzip) 118.48 KB (+0.36% 🔺)
JS (brotli) 97.45 KB (+0.22% 🔺)
JS import Div (tree shaking) 1.56 KB (0%)
CSS 341.82 KB (0%)
CSS (gzip) 42.32 KB (0%)
CSS (brotli) 33.7 KB (0%)

Copy link

codesandbox-ci bot commented Dec 5, 2024

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 Dec 5, 2024

e2e tests

⚠️ Some screenshots were failed. See Playwright Report.

Playwright Report

Copy link
Contributor

github-actions bot commented Dec 5, 2024

👀 Docs deployed

Commit 2f953d1

Copy link

codecov bot commented Dec 5, 2024

Codecov Report

Attention: Patch coverage is 94.79167% with 5 lines in your changes missing coverage. Please review.

Project coverage is 95.52%. Comparing base (23acf45) to head (2f953d1).
Report is 17 commits behind head on master.

Files with missing lines Patch % Lines
packages/vkui/src/hooks/useFloatingElement.tsx 80.00% 4 Missing ⚠️
...ackages/vkui/src/components/Tooltip/useTooltip.tsx 97.36% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master    #8040      +/-   ##
==========================================
- Coverage   95.55%   95.52%   -0.03%     
==========================================
  Files         398      401       +3     
  Lines       11332    11364      +32     
  Branches     3733     3739       +6     
==========================================
+ Hits        10828    10856      +28     
- Misses        504      508       +4     
Flag Coverage Δ
unittests 95.52% <94.79%> (-0.03%) ⬇️

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.

Здорово 👍

@vkcom-publisher vkcom-publisher added the pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности label Dec 19, 2024
@inomdzhon inomdzhon modified the milestones: v7.1.0, v7.2.0 Dec 19, 2024
@vkcom-publisher vkcom-publisher removed the pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности label Dec 20, 2024
@vkcom-publisher vkcom-publisher added the pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности label Jan 6, 2025
@EldarMuhamethanov EldarMuhamethanov merged commit 44b3c5d into master Jan 13, 2025
27 of 29 checks passed
@EldarMuhamethanov EldarMuhamethanov deleted the e.muhamethanov/tooltip-popover-refactoring branch January 13, 2025 13:17
@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
Labels
cmp:popover Бывший dropdown cmp:tooltip pr-needs-work Автоматизация: PR автоматически закроется через 14 дней при отсутствии активности
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

4 participants