diff options
| author | Owen Jacobson <owen@grimoire.ca> | 2025-05-16 20:33:05 -0400 |
|---|---|---|
| committer | Owen Jacobson <owen@grimoire.ca> | 2025-05-16 20:33:05 -0400 |
| commit | 4e8cfb5f37b607382fb80e012133dd372aa4ec36 (patch) | |
| tree | 47bd3baed1aa18d09b67dbdec846b66cab121c55 /ui/lib/state/remote | |
| parent | 96d363fd9290d43d2e6a11e2e5269fb8ccf6d65d (diff) | |
| parent | a38a449ab78a4e8ab56705922f5c13f9365a92a4 (diff) | |
Merge remote-tracking branch 'codeberg/prop/unread-channels'
Diffstat (limited to 'ui/lib/state/remote')
| -rw-r--r-- | ui/lib/state/remote/channels.svelte.js | 26 | ||||
| -rw-r--r-- | ui/lib/state/remote/messages.svelte.js | 7 |
2 files changed, 22 insertions, 11 deletions
diff --git a/ui/lib/state/remote/channels.svelte.js b/ui/lib/state/remote/channels.svelte.js index 64edb09..8b190dd 100644 --- a/ui/lib/state/remote/channels.svelte.js +++ b/ui/lib/state/remote/channels.svelte.js @@ -1,10 +1,26 @@ -import { SvelteMap } from 'svelte/reactivity'; +import { DateTime } from 'luxon'; + +class Channel { + static boot({ at, id, name }) { + return new Channel({ + at: DateTime.fromISO(at), + id, + name + }); + } + + constructor({ at, id, name }) { + this.at = at; + this.id = id; + this.name = name; + } +} export class Channels { - all = $state(); + all = $state([]); static boot(channels) { - const all = new SvelteMap(channels.map((channel) => [channel.id, channel])); + const all = channels.map((channel) => Channel.boot(channel)); return new Channels({ all }); } @@ -12,8 +28,8 @@ export class Channels { this.all = all; } - add({ id, name }) { - this.all.set(id, { id, name }); + add({ at, id, name }) { + this.all.set(id, Channel.boot({ at, id, name })); } remove(id) { diff --git a/ui/lib/state/remote/messages.svelte.js b/ui/lib/state/remote/messages.svelte.js index c6d31f0..0a081bb 100644 --- a/ui/lib/state/remote/messages.svelte.js +++ b/ui/lib/state/remote/messages.svelte.js @@ -1,7 +1,7 @@ import { DateTime } from 'luxon'; import { render } from '$lib/markdown.js'; -export class Message { +class Message { static boot({ id, at, channel, sender, body }) { return new Message({ id, @@ -21,11 +21,6 @@ export class Message { this.body = body; this.renderedBody = renderedBody; } - - resolve(get) { - const { sender, ...rest } = this; - return new Message({ sender: get.sender(sender), ...rest }); - } } export class Messages { |
