summaryrefslogtreecommitdiff
path: root/ui/lib/store/channels.svelte.js
diff options
context:
space:
mode:
authorKit La Touche <kit@transneptune.net>2024-11-29 14:29:12 -0500
committerKit La Touche <kit@transneptune.net>2024-11-29 14:41:06 -0500
commitd36efbb1378ca1d6bf3b3c20391d711c00da4761 (patch)
tree3ddfeaaf68cf39c6fdcf07aa97957cb8ff348765 /ui/lib/store/channels.svelte.js
parent32a30bcf2140c8fbf1a739123d0378f17503efb0 (diff)
Rename and modify channels store
I tried to have a custom class for Channel objects, but Svelte's automatic proxy logic works only on bare objects, as far as I could tell. So that broke everything. I resorted to a function that would build the bare objects, but we still lack methods that I think would make life easier ("touch last read" etc).
Diffstat (limited to 'ui/lib/store/channels.svelte.js')
-rw-r--r--ui/lib/store/channels.svelte.js62
1 files changed, 62 insertions, 0 deletions
diff --git a/ui/lib/store/channels.svelte.js b/ui/lib/store/channels.svelte.js
new file mode 100644
index 0000000..8919be0
--- /dev/null
+++ b/ui/lib/store/channels.svelte.js
@@ -0,0 +1,62 @@
+import { DateTime } from 'luxon';
+const EPOCH_STRING = "1970-01-01T00:00:00Z";
+
+// For reasons unclear to me, a straight up class definition with a constructor
+// doesn't seem to work, reactively. So we resort to this.
+// Owen suggests that this sentence in the Svelte docs should make the reason
+// clear:
+// > If $state is used with an array or a simple object, the result is a deeply
+// > reactive state proxy.
+// Emphasis on "simple object".
+// --Kit
+function makeChannelObject({ id, name, draft = '', lastReadAt = null, scrollPosition = null }) {
+ return {
+ id,
+ name,
+ lastReadAt: lastReadAt || DateTime.fromISO(EPOCH_STRING),
+ draft,
+ scrollPosition,
+ };
+}
+
+export class Channels {
+ channels = $state([]);
+
+ getChannel(channelId) {
+ return this.channels.filter((ch) => ch.id === channelId)[0] || null;
+ }
+
+ setChannels(channels) {
+ this.channels = channels.map(makeChannelObject);
+ this.sort();
+ return this;
+ }
+
+ addChannel(id, name) {
+ this.channels = [
+ ...this.channels,
+ makeChannelObject({ id, name }),
+ ];
+ this.sort();
+ return this;
+ }
+
+ deleteChannel(id) {
+ const channelIndex = this.channels.map((e) => e.id).indexOf(id);
+ if (channelIndex !== -1) {
+ this.channels.splice(channelIndex, 1);
+ }
+ return this;
+ }
+
+ sort() {
+ this.channels.sort((a, b) => {
+ if (a.name < b.name) {
+ return -1;
+ } else if (a.name > b.name) {
+ return 1;
+ }
+ return 0;
+ });
+ }
+}