status-react/doc/decisions/UI-related/7-august-2023-paste-button-ux.md
Siddarth Kumar 7043e03dd4
Enter scan code tab in Syncing (#16852)
* feat: add enter scan code view

This commit adds the enter sync code UI.

Fixes : #16062

Design link : https://www.figma.com/file/V6nlpAWIf2e1XU8RJ9yQPe/Syncing-for-Mobile?node-id=675%3A179729&mode=dev

Review notes :
We do not make use of quo2/input here because currently that component does not allow stretching to fit in sync code which spans upto 3 lines.
2023-10-05 21:05:54 +05:30

1.5 KiB

How should the paste button behave when clipboard is empty?

This question first came up as a review comment to this PR
https://github.com/status-im/status-mobile/pull/16852

There were 2 considerations :

  • Either keep the paste button disabled when there is nothing in the clipboard OR
  • Always keep the paste button enabled

There were positives and negatives for both approaches.

Positives of keeping paste button disabled when there is nothing in clipboard would require us to check the value of clipboard as soon as the component is mounted (i.e when the user first sees the screen). In iOS this means a native permissions dialog would appear requesting for permissions to paste from the clipboard.

Negatives of this approach is that as soon as any user navigates to this screen they are greeted with this popup which can be annoying sometimes.

Positives of keeping paste button always enabled is that we can trigger a request to the clipboard on tap of the paste button which would trigger the native permissions dialog requesting for permissions to paste from the clipboard. In this case seeing this dialog is okay because the user has initiated a paste action.

Negatives of this approach is that in the event the clipboard is empty the user will still see the system dialog and on approving nothing will be pasted (because the clipboard was empty). This behaviour can be confusing.

On consulting the Design Team via discord it was concluded that out of the two approaches having the paste button always enabled is a better UX overall.