about summary refs log tree commit diff
path: root/LibMatrix/Helpers
diff options
context:
space:
mode:
authorRory& <root@rory.gay>2024-03-20 12:00:54 +0100
committerRory& <root@rory.gay>2024-03-20 12:00:54 +0100
commitb992d20da79b9de020d629bf9574abefff9c4b12 (patch)
treea5205343b6edbc8f627215efdd147d86a4a737c7 /LibMatrix/Helpers
parentBot related fixes, image size (diff)
downloadLibMatrix-b992d20da79b9de020d629bf9574abefff9c4b12.tar.xz
New messagebuilder stuff, table-based help command
Diffstat (limited to 'LibMatrix/Helpers')
-rw-r--r--LibMatrix/Helpers/MessageBuilder.cs37
-rw-r--r--LibMatrix/Helpers/SyncHelper.cs2
2 files changed, 32 insertions, 7 deletions
diff --git a/LibMatrix/Helpers/MessageBuilder.cs b/LibMatrix/Helpers/MessageBuilder.cs
index 0753aca..d897078 100644
--- a/LibMatrix/Helpers/MessageBuilder.cs
+++ b/LibMatrix/Helpers/MessageBuilder.cs
@@ -1,4 +1,3 @@
-using ArcaneLibs;
 using LibMatrix.EventTypes.Spec;
 
 namespace LibMatrix.Helpers;
@@ -50,7 +49,7 @@ public class MessageBuilder(string msgType = "m.text", string format = "org.matr
         Content.FormattedBody += "</font>";
         return this;
     }
-    
+
     public MessageBuilder WithCustomEmoji(string mxcUri, string name) {
         Content.Body += $"{{{name}}}";
         Content.FormattedBody += $"<img data-mx-emoticon height=\"32\" src=\"{mxcUri}\" alt=\"{name}\" title=\"{name}\" />";
@@ -72,23 +71,51 @@ public class MessageBuilder(string msgType = "m.text", string format = "org.matr
         // }
         return this;
     }
-    
+
     public MessageBuilder WithCodeBlock(string code, string language = "plaintext") {
         Content.Body += code;
         Content.FormattedBody += $"<pre><code class=\"language-{language}\">{code}</code></pre>";
         return this;
     }
-    
+
     public MessageBuilder WithCollapsibleSection(string title, string body) {
         Content.Body += body;
         Content.FormattedBody += $"<details><summary>{title}</summary>{body}</details>";
         return this;
     }
-    
+
     public MessageBuilder WithCollapsibleSection(string title, Action<MessageBuilder> bodyBuilder) {
         Content.FormattedBody += $"<details><summary>{title}</summary>";
         bodyBuilder(this);
         Content.FormattedBody += "</details>";
         return this;
     }
+
+    public MessageBuilder WithTable(Action<TableBuilder> tableBuilder) {
+        var tb = new TableBuilder(this);
+        this.WithHtmlTag("table", msb => tableBuilder(tb));
+        return this;
+    }
+
+    public class TableBuilder(MessageBuilder msb) {
+        public TableBuilder WithTitle(string title, int colspan) {
+            msb.Content.Body += title + "\n";
+            msb.Content.FormattedBody += $"<thead><tr><th colspan=\"{colspan}\">{title}</th></tr></thead>";
+            return this;
+        }
+
+        public TableBuilder WithRow(Action<RowBuilder> rowBuilder) {
+            var rb = new RowBuilder(msb);
+            msb.WithHtmlTag("tr", msb => rowBuilder(rb)).WithBody("\n");
+            return this;
+        }
+
+        public class RowBuilder(MessageBuilder msb) {
+            public RowBuilder WithCell(string content, Dictionary<string, string>? attributes = null) {
+                msb.Content.Body += content + "\n";
+                msb.Content.FormattedBody += $"<td>{content}</td>\t";
+                return this;
+            }
+        }
+    }
 }
\ No newline at end of file
diff --git a/LibMatrix/Helpers/SyncHelper.cs b/LibMatrix/Helpers/SyncHelper.cs
index e696b70..1833bd0 100644
--- a/LibMatrix/Helpers/SyncHelper.cs
+++ b/LibMatrix/Helpers/SyncHelper.cs
@@ -1,7 +1,5 @@
 using System.Diagnostics;
 using System.Net.Http.Json;
-using System.Text.Json;
-using System.Text.Json.Serialization;
 using ArcaneLibs.Extensions;
 using LibMatrix.Filters;
 using LibMatrix.Homeservers;