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

feature(Cell): Allow to handle onClick when mode="removable" #5745

Merged

Conversation

mendrew
Copy link
Contributor

@mendrew mendrew commented Sep 4, 2023

resolves: #5741

Описание

Добавляем возможность обработки клика на контент Cell в режиме removable.

Изменения

  • в режиме removable SimpleCell внутри Cell disabled, если нету обработчика onClick.
  • поддерживается только active состояние при нажании, hover не поддерживатеся.
  • в active состоянии подсвечивается вся область Сell, включая зоны Removable.
  • особо обрабатываем режим removable для iOS. onClick работает, но только до тех пор пока пользователь не кликнул на иконку удаления. После этого контент Cell сдвигается и появляется "настоящая" кнопка удаления. В этот момент onClick не работает, чтобы позволить пользователю отменить режим удаления кликом по контенту Cell.

Пытался добавить скриншотные тесты для активного состояния, хотя бы на mousedown, но в скриншот стабильно не попадает состояние при mousedown.

Видео

При клике на контент видно эффект компонента Tappable, но эффект отсутствует после клика на иконку удаления.

2023-09-07.12.18.49.mov

@codesandbox-ci
Copy link

codesandbox-ci bot commented Sep 4, 2023

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.

Latest deployment of this branch, based on commit af7b358:

Sandbox Source
VKUI TypeScript Configuration

@github-actions
Copy link
Contributor

github-actions bot commented Sep 4, 2023

size-limit report 📦

Path Size
JS 347.81 KB (+0.07% 🔺)
JS (gzip) 104.11 KB (+0.06% 🔺)
JS (brotli) 84.67 KB (-0.14% 🔽)
JS import Div (tree shaking) 3.04 KB (0%)
CSS 278.5 KB (+0.17% 🔺)
CSS (gzip) 36.29 KB (+0.13% 🔺)
CSS (brotli) 28.71 KB (+0.11% 🔺)

@github-actions
Copy link
Contributor

github-actions bot commented Sep 4, 2023

e2e tests

Playwright Report

@github-actions
Copy link
Contributor

github-actions bot commented Sep 4, 2023

👀 Docs deployed

Commit af7b358

@codecov
Copy link

codecov bot commented Sep 4, 2023

Codecov Report

Patch coverage: 100.00% and project coverage change: +0.07% 🎉

Comparison is base (0e15b3d) 81.96% compared to head (af7b358) 82.04%.
Report is 19 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff             @@
##           master    #5745      +/-   ##
==========================================
+ Coverage   81.96%   82.04%   +0.07%     
==========================================
  Files         296      296              
  Lines        9819     9839      +20     
  Branches     3107     3121      +14     
==========================================
+ Hits         8048     8072      +24     
+ Misses       1771     1767       -4     
Flag Coverage Δ
unittests 82.04% <100.00%> (+0.07%) ⬆️

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

Files Changed Coverage Δ
packages/vkui/src/components/Cell/Cell.tsx 97.01% <100.00%> (+3.36%) ⬆️
...ckages/vkui/src/components/Removable/Removable.tsx 91.52% <100.00%> (+5.56%) ⬆️

... and 5 files with indirect coverage changes

☔ View full report in Codecov by Sentry.

📢 Have feedback on the report? Share it here.

With exception for iOS platform.
onClick works only if content is not shifted, but if user clicks
on "remove" toggle button and content shifted - onClick is ignored
till user clicks outside.
@mendrew mendrew force-pushed the mendrew/feature/5741/Cell/handle-on-click-in-removable-mode branch from 000fc7e to 094b727 Compare September 5, 2023 07:25
@mendrew mendrew modified the milestone: v5.8.0 Sep 5, 2023
@mendrew mendrew marked this pull request as ready for review September 5, 2023 08:31
@mendrew mendrew requested a review from a team as a code owner September 5, 2023 08:31
@mendrew mendrew marked this pull request as draft September 5, 2023 12:54
@SevereCloud SevereCloud added the v5 Автоматизация: PR продублируется в ветку v5 label Sep 6, 2023
In Removable mode Cell consists of Removable component with
SimpleCell inside. So, SimpleCell hover/active effect doesn't
change background on the part that Removable elements occupy.
In order to make sure Removable delete button is on top of
SimpleCell we make Removable action button is absolutely positioned.
So, SimpleCell takes full Cell width and hightlight the whole cell
in active state.
As we alredy handle this space by padding on Cell content
@mendrew mendrew marked this pull request as ready for review September 7, 2023 15:19
@mendrew mendrew requested a review from Zaycevq September 7, 2023 15:19
Zaycevq
Zaycevq previously approved these changes Sep 8, 2023
Copy link

@Zaycevq Zaycevq 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

@Zaycevq Zaycevq 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

@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.

🤝

@mendrew mendrew merged commit 2f2137b into master Sep 15, 2023
@mendrew mendrew deleted the mendrew/feature/5741/Cell/handle-on-click-in-removable-mode branch September 15, 2023 09:00
vkcom-publisher pushed a commit that referenced this pull request Sep 15, 2023
* Описание
Добавляем возможность обработки клика на контент Cell в режиме `removable`.

* Изменения
- в режиме `removable` `SimpleCell` внутри `Cell` `disabled`, если нету обработчика `onClick`.
- поддерживается только `active` состояние при нажании, `hover` не поддерживатеся.
- в `active` состоянии подсвечивается вся область `Сell`, включая зоны `Removable`.
- особо обрабатываем режим `removable` для iOS. `onClick` работает, но только до тех пор пока пользователь не кликнул на иконку удаления. После этого контент `Cell` сдвигается и появляется "настоящая" кнопка удаления. В этот момент `onClick` не работает, чтобы позволить пользователю отменить режим удаления кликом по контенту Cell.

- В активном состоянии вся область Cell активная.
Дело в том, что реализации removable подразумевает то, что SimpleCell внутри Cell обернут в Removable компонент, который съедает часто пространства SimpleCell для расположения кнопок удаления.
Чтобы вся область Cell подсвечивалась в активном состоянии мы абсолютно позиционируем активные элементы Removable, такие как кнопка удаления, чтобы они были поверх SimpleCell, но не мешали активному состоянию, что в итоге позволяет SimpleCell занять всю ширину Cell.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
v5 Автоматизация: PR продублируется в ветку v5
Projects
None yet
4 participants