a lodda changes my guy

This commit is contained in:
2026-01-30 15:56:58 +00:00
parent d82dc87af1
commit 63ad9247bc
10 changed files with 101 additions and 82 deletions

View File

@@ -8,11 +8,11 @@ import (
"fmt"
"github.com/diamondburned/gotk4/pkg/gdk/v4"
"github.com/diamondburned/gotk4/pkg/gtk/v4"
"github.com/kirsle/configdir"
"io"
"net/http"
"os"
"path/filepath"
"github.com/kirsle/configdir"
)
// global or app-level map/cache
@@ -105,7 +105,6 @@ func newImageFromWeb(url string) *gtk.Image {
return nil
}
fullpath := filepath.Join(pa, sum)
// step 3: save it

View File

@@ -1,11 +1,11 @@
package main
import (
"fmt"
"github.com/diamondburned/gotk4/pkg/glib/v2"
"github.com/diamondburned/gotk4/pkg/gtk/v4"
"gosrc.io/xmpp/stanza"
Jid "mellium.im/xmpp/jid"
"fmt"
)
func scrollToBottomAfterUpdate(scrolledWindow *gtk.ScrolledWindow) {
@@ -39,8 +39,22 @@ func switchToTab(jid string) {
gen := gtk.NewBox(gtk.OrientationVertical, 0)
mm.Range(func(k, v any) bool {
userbox := gtk.NewBox(gtk.OrientationHorizontal, 0)
u := v.(stanza.Presence)
gen.Append(gtk.NewLabel(Jid.MustParse(u.From).Resourcepart()))
var mu MucUser
u.Get(&mu)
nick_label := gtk.NewLabel(Jid.MustParse(u.From).Resourcepart())
affil_label := gtk.NewLabel(mu.MucUserItem.Affiliation)
// nick_label.SetHAlign(gtk.AlignStart)
// affil_label.SetHAlign(gtk.AlignEnd)
userbox.Append(nick_label)
userbox.Append(affil_label)
gen.Append(userbox)
return true
})

View File

@@ -3,16 +3,17 @@ package main
// This file contains the function that generates message widgets depending on message stanza
import (
"os"
"context"
"encoding/base64"
"fmt"
"github.com/diamondburned/gotk4/pkg/gtk/v4"
"github.com/google/uuid"
"github.com/jacoblockett/sanitizefilename"
"github.com/jasonlovesdoggo/gopen"
"gosrc.io/xmpp/stanza"
"mellium.im/xmpp/jid"
"github.com/google/uuid"
"github.com/jasonlovesdoggo/gopen"
"encoding/base64"
"github.com/jacoblockett/sanitizefilename"
"os"
"path/filepath"
)
func generateMessageWidget(p stanza.Packet) gtk.Widgetter {
@@ -31,7 +32,7 @@ func generateMessageWidget(p stanza.Packet) gtk.Widgetter {
reactions := gtk.NewBox(gtk.OrientationHorizontal, 0)
reactions.SetVisible(false)
reaction := []string{"👍", "👎", "♥️", "🤣", "😭",}
reaction := []string{"👍", "👎", "♥️", "🤣", "😭"}
for _, v := range reaction {
like := gtk.NewButton()
like.SetLabel(v)
@@ -72,7 +73,6 @@ func generateMessageWidget(p stanza.Packet) gtk.Widgetter {
ocu := OccupantID{}
m.Get(&ocu)
authorBox := gtk.NewBox(gtk.OrientationHorizontal, 10)
contentBox := gtk.NewBox(gtk.OrientationHorizontal, 0)
// im := newImageFromPath("debug.png")
@@ -80,6 +80,7 @@ func generateMessageWidget(p stanza.Packet) gtk.Widgetter {
// authorBox.Append(im)
im := getAvatar(m.From, ocu.ID)
im.SetPixelSize(40)
im.AddCSSClass("author_img")
authorBox.Append(im)
al := gtk.NewLabel(jid.MustParse(m.From).Resourcepart())
al.AddCSSClass("author")
@@ -107,14 +108,12 @@ func generateMessageWidget(p stanza.Packet) gtk.Widgetter {
// media.AddCSSClass("chat_image")
mbtn := gtk.NewButtonWithLabel("🖼️")
// mbtn.SetChild(newImageFromWeb(oob.URL))
mbtn.ConnectClicked(func(){
mbtn.ConnectClicked(func() {
gopen.Open(oob.URL)
})
authorBox.Append(mbtn)
}
return mainBox
}
@@ -123,10 +122,15 @@ func getVAdjustment(scrolledWindow *gtk.ScrolledWindow) *gtk.Adjustment {
return val
}
func getAvatar(j, hash string) *gtk.Image {
hash = sanitizefilename.Sanitize(hash)
func getAvatar(j, hash string) *gtk.Image { // TODO: This function probably shouldn't be here, and should probably be in xmpp-helpers or somewhere similar.
p, err := ensureCache()
if err != nil {
return newImageFromPath("debug.png")
}
_, err := os.ReadFile(hash)
hash = filepath.Join(p, sanitizefilename.Sanitize(hash))
_, err = os.ReadFile(hash)
if err == nil {
return newImageFromPath(hash)
}
@@ -134,9 +138,9 @@ func getAvatar(j, hash string) *gtk.Image {
iqResp, err := stanza.NewIQ(stanza.Attrs{
Type: "get",
From: clientroot.Session.BindJid,
To: j,
Id: "vc2",
Lang: "e",
To: j,
Id: "vc2",
Lang: "en",
})
if err != nil {
@@ -150,7 +154,7 @@ func getAvatar(j, hash string) *gtk.Image {
if err != nil {
panic(err)
}
result := <- mychan
result := <-mychan
card, ok := result.Payload.(*VCard)
if !ok {
return newImageFromPath("debug.png")
@@ -166,12 +170,10 @@ func getAvatar(j, hash string) *gtk.Image {
panic(err)
}
err = os.WriteFile(hash, data, 0644)
if err != nil {
panic(err)
}
// TODO: Implement caching!
return newImageFromPath(hash)
}

View File

@@ -7,7 +7,6 @@ import (
// This file implements XEP-0393 partially by providing a function to get a Pango string.
// https://xmpp.org/extensions/xep-0393.html
func convertXEPToPango(text string) string {
/* FIXME this RegEx causes certain strings to appear invisible
text = regexp.MustCompile(`\*([^*]+)\*`).ReplaceAllString(text, "<b>$1</b>")

14
main.go
View File

@@ -19,6 +19,7 @@ import (
_ "embed"
"encoding/xml"
"runtime"
)
var loadedConfig lambdaConfig
@@ -70,10 +71,10 @@ func main() {
TransportConfiguration: xmpp.TransportConfiguration{
Address: loadedConfig.Server,
},
Jid: loadedConfig.Username,
Credential: xmpp.Password(loadedConfig.Password),
Insecure: loadedConfig.Insecure,
// StreamLogger: os.Stdout,
Jid: loadedConfig.Username,
Credential: xmpp.Password(loadedConfig.Password),
Insecure: loadedConfig.Insecure,
StreamLogger: os.Stdout,
}
router := xmpp.NewRouter()
@@ -125,13 +126,12 @@ func main() {
}
v := &stanza.Version{}
v = v.SetInfo("Lambda", "1.0", "Windows") // TODO: Allow spoofing and report correct information
v = v.SetInfo("Lambda", lambda_version, runtime.GOOS) // TODO: Allow spoofing on user request
iqResp.Payload = v
s.Send(iqResp)
})
router.HandleFunc("message", func(s xmpp.Sender, p stanza.Packet) {
m, ok := p.(stanza.Message)
if !ok {
@@ -155,7 +155,6 @@ func main() {
_, ok = tabs[originator]
if ok {
fmt.Println("valid")
tabs[originator].msgs.Append(b)
scrollToBottomAfterUpdate(scroller)
} else {
@@ -253,6 +252,7 @@ func activate(app *gtk.Application) {
app.SetMenubar(gio.NewMenu())
window.SetTitle("Lambda")
window.AddCSSClass("ssd")
menu := gtk.NewBox(gtk.OrientationHorizontal, 0)
/*
f_menu := gtk.NewMenuButton()

View File

@@ -6,3 +6,7 @@
max-width: 50px;
max-height: 50px;
}
.author_img {
border-radius 100%;
}

View File

@@ -1,24 +1,23 @@
package main
import (
"sync"
"github.com/diamondburned/gotk4/pkg/gtk/v4"
"sync"
)
type chatTab struct {
isMuc bool
msgs *gtk.ListBox
msgs *gtk.ListBox
}
type lambdaConfig struct {
Server string
Server string
Username string
Password string
Insecure bool
Nick string
Nick string
}
type mucUnit struct {
// key: OccupantID
// value: last user presence

3
version.go Normal file
View File

@@ -0,0 +1,3 @@
package main
var lambda_version string = "0.1.0"

View File

@@ -27,7 +27,7 @@ func sendMessage(c xmpp.Sender, sendTo string, msgType stanza.StanzaType, body s
}
// Joins a MUC
func joinMuc(c xmpp.Sender, jid string, muc string, nick string) error{
func joinMuc(c xmpp.Sender, jid string, muc string, nick string) error {
addr := muc + "/" + nick
fmt.Println(addr)
joinPresence := stanza.Presence{
@@ -36,8 +36,7 @@ func joinMuc(c xmpp.Sender, jid string, muc string, nick string) error{
To: addr,
},
Extensions: []stanza.PresExtension{
&stanza.MucPresence{
},
&stanza.MucPresence{},
},
}

View File

@@ -9,8 +9,8 @@ import (
)
type VCard struct {
XMLName xml.Name `xml:"vcard-temp vCard"`
Photo Photo `xml:"PHOTO"`
XMLName xml.Name `xml:"vcard-temp vCard"`
Photo Photo `xml:"PHOTO"`
ResultSet *stanza.ResultSet `xml:"set,omitempty"`
}