-
Notifications
You must be signed in to change notification settings - Fork 4.9k
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
Add snaps notifications #13553
Comments
Curious to know what the user experience will be when the MetaMask popup / full UI is not in focus, whether using built-in or native browser notifications. Will the user see the notification or will they miss it? Also, if native browser notifications are used, will that require the user to make an extra step in order to give permissions in the native browser UI? |
Hey team! Please add your planning poker estimate with ZenHub @Gudahtt @hmalik88 @ritave |
@Montoya, we'd make the notifications persist in the MetaMask UI until dismissed by the user, or perhaps timed out if we can convince ourselves that the user saw them (perhaps by the page that they're displayed on in our UI being active). For the native browser notification, the extension already has that permission, so there will be no extra prompt. |
We will re-use existing MM components to allow developers to prompt notifications inside MM via Snaps. Ideally, developers should be able to define:
It will be the first batch of UI components we will expose to developers via Snaps! I expect that we can share feedback to the Design System team to help document their work on improving the consistency/flexibility of these components. Also, ideally, this implementation does not break (or can be easily fixed) after they re-shape this UI. What do y'all think? |
Do we want to make explicit/visible that the notification is triggered by a Snap and not MM itself? A helper tooltip can make the job. |
Tooltip sounds like a good approach. I do not want to over-optimize for Snaps. Ideally Snaps can behave like first-class functionality in MetaMask until we feel like we need to differentiate them from native MetaMask functionality for some reason. |
We already have the "home notification"/"system notification" system, which shows messages on the Home screen that can persist until dismissed, and can include custom content and actions. It also includes a system for stacking them, and hiding additional messages behind an expand/collapse button if there are too many. This is already the established place for showing messages that aren't tied to a specific UI context like a confirmation screen. This seems like a better place to start than designing a new notification system from scratch that would be in the same place and face many of the same challenges. If we're going to build a new system, then a lot of follow up questions come to mind. Are these blocking, or can they be ignored by the user? How can we ensure they don't obscure important parts of the Home screen? How do we handle showing multiple messages at once? Would we absorb the home notifications into this system, or somehow show both at once? |
Just to be clear, I'm not trying to create a new notification system. I'm just pointing on which components we could rely to make it more extensible and easy to maintain. If we want to attach this feature with our Home Notification System, we can do it! It will help also to iterate what we consider on the current implementation. Which component it is using @Gudahtt? Do we have documentation somewhere to understand which variables we can offer to developers? |
@holantonela regarding the notification components I think they need a bit of work before we can release them to the community. The api for the ActionableMessage component is quite messy. I'd like to clean it up or possibly deprecate it in favour of a new component. I think the Popover is in better shape but I would still like to have a look at the component api before giving it the green light. |
There is no documentation for system notifications because it's an internal system. We have only used it ourselves 7 times. The exact details of what it can do today don't really matter, are subject to change, and would not be directly exposed via the snaps API anyway. It is currently using its own component. It was built before the two components you referenced.
I did not think this issue involved custom UI. I had assumed that we would be treating this similarly to custom confirmations, i.e. it would be our UI, just with custom contents defined by the snap. And perhaps other configurable options like buttons, actions, styles, etc. The snap authors will not be directly building UI with our components. |
Yeah. That is the point. When I said "expose" I meant "allow developers to push content in the UI component". |
After our Design Sync, we refined some of the requirements for this feature on
|
Hi, the latest UI is here https://www.figma.com/file/2QWFaRYpa9SDZRCwFlW17j/Snap-Notifications?node-id=0%3A297 Update on design requirements:
|
Also, some thoughts about how notifications are marked as read
|
Closing via #14605 |
Once we added the ability for snaps to create notifications, we should implement these notifications in MetaMask.
We are likely to implement notifications that appear inside MetaMask itself, and for those we will need designs. These notifications should:
The other option for notifications is to give snaps access to native browser notifications, if in an attenuated way. It's unclear if this is something we should or will pursue at this time.
The text was updated successfully, but these errors were encountered: