-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
TW-692: Add ADR for send/listen event
- Loading branch information
Showing
1 changed file
with
67 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
# 7. Instructions for naming twake events | ||
|
||
Date: 2023-10-03 | ||
|
||
## Status | ||
|
||
Accepted | ||
|
||
## Docs | ||
|
||
- [Spec](https://spec.matrix.org/v1.6/#events) | ||
|
||
## Context | ||
|
||
- All data exchanged through Matrix is represented as an “event”. In addition, we have local support events. | ||
- We can use local events to handle logic and behavior by injecting events into a defined stream. | ||
|
||
## How to name events | ||
- Below are the naming rules for events. | ||
- App.twake is the name of the application. | ||
- Inapp is event use for local support. | ||
- Profile is the name of the feature. | ||
- Avatar is the name of the event. | ||
ex: 'app.twake.inapp.profile.avatar' | ||
|
||
## How to use events. | ||
- Send event | ||
|
||
``` | ||
class TwakeEventDispatcher { | ||
static final TwakeEventDispatcher _twakeEventDispatcher = | ||
TwakeEventDispatcher._instance(); | ||
factory TwakeEventDispatcher() { | ||
return _twakeEventDispatcher; | ||
} | ||
TwakeEventDispatcher._instance(); | ||
void sendAccountDataEvent({ | ||
required Client client, | ||
required BasicEvent basicEvent, | ||
}) { | ||
client.onAccountData.add(basicEvent); | ||
} | ||
} | ||
twakeEventDispatcher.sendAccountDataEvent( | ||
client: client, | ||
basicEvent: BasicEvent( | ||
type: TwakeInappEventTypes.uploadAvatarEvent, | ||
content: profile.toJson(), | ||
), | ||
); | ||
``` | ||
- Listen event and handle it | ||
|
||
``` | ||
client.onAccountData.stream.listen((event) { | ||
Logs().d( | ||
'FetchProfileMixin::onAccountData() - EventType: ${event.type} - EventContent: ${event.content}', | ||
); | ||
if (event.type == TwakeInappEventTypes.uploadAvatarEvent) { | ||
profileNotifier.value = Profile.fromJson(event.content); | ||
} | ||
}); | ||
``` |