-
Notifications
You must be signed in to change notification settings - Fork 126
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
A preliminary PR for message persistence and notifications #342
base: message-history
Are you sure you want to change the base?
A preliminary PR for message persistence and notifications #342
Conversation
AndrewH seems not to be a GitHub user. You need a GitHub account to be able to sign the CLA. If you have already a GitHub account, please add the email address used for this commit to your account. You have signed the CLA already but the status is still pending? Let us recheck it. |
This is something I've been wanting for AGES! Thanks for kicking this off! I'm excited to see where you take it. I'll definitely be happy to test this out. The serialize/deserialize of the whole message history each time a new message is received or a new channel is loaded could get quite resource intensive. localStorage doesn't give us much in the way of fancy data structures, but it'd be possible to combine a few different localStorage items and encode useful data in the keyName. You could encode the device, channel, and array index of each message. Perhaps something like: // the array index of the most recent message
const channelCursor = localStorage.get(`device/${device_id}/channel/${channel_id}/cursor`);
// the most recent message for a channel
const message = localStorage.get(`device/${device_id}/channel/${channel_id}/message/${channelCursor}`); This would also make it possible to load pages of messages on scroll rather than the whole history at once. // the array index of the most recent message
const channelCursor = localStorage.get(`device/${device_id}/channel/${channel_id}/cursor`);
// the most recent "page" of messages
let messages = []
for (let i = channelCursor - 10; i < channelCursor; i++) {
messages.push(localStorage.get(`device/${device_id}/channel/${channel_id}/message/${i}`));
} As for deleting all history? Make life easy and clear the whole localStorage 😆 This is by no means definitive but I hope it gives you some motivation to continue 😊 |
Thanks for the feedback @blaknite, for the amount of effort required to implement paginated serialization for localStorage i'd probably just prefer to spend that time switching to IndexedDb. The message history is already broken up by channel and by node (for direct), even several hundred messages will serialize pretty easily. In fact as a quick and dirty solution I would probably just make the history truncate to the last 100 messages. That way speed never becomes an issue. I don't have a lot of free time to spend on this, so others are welcome to run with it :) |
I've taken a stab at building upon this in #346. Let me know if you have any suggestions :) |
Is there anything from this PR that didn't make it in #346 ? I made a branch called |
I don't think the unread message icons or the notification sound was in @blaknite PR. But I can tidy up the changes and make a new PR for that smaller change if you prefer. |
Yep, that's correct. I didn't copy over any of the notifications work. |
Can we work together to get this finished? I think this would be a really great feature. Ideally, I would like to have this PR be its own release. There is a decent amount of new features that I would like to release prior to this, then release this as a standalone release. |
Sounds good. I think this PR which is just message persistence be merged on its own whenever you think is best. |
@andrewheadricke Can you fix the conflicts? |
This PR implements message persistence/history using localStorage. It also displays an unread message icon when there are new messages. It also includes birdpumps #185 notification sound PR.
There are plenty of optimisations that can be done to this, here's some suggestions: