From 377ae37de7ebcd4fcb639fd25a8463495fb02043 Mon Sep 17 00:00:00 2001 From: yellowsink Date: Wed, 27 Nov 2024 22:04:30 +0000 Subject: [PATCH] deploy: bf09523aba843b5e8718662a4195263364a39f15 --- pronoundb/plugin.js | 42 ++++++++++++++++++++++++++---------------- pronoundb/plugin.json | 2 +- 2 files changed, 27 insertions(+), 17 deletions(-) diff --git a/pronoundb/plugin.js b/pronoundb/plugin.js index 3ede257..d63fb90 100644 --- a/pronoundb/plugin.js +++ b/pronoundb/plugin.js @@ -66,16 +66,17 @@ } // plugins/pronoundb/db.ts - var UserProfileStore = shelter.flux.stores.UserProfileStore; + var UserProfileStore = shelter.flux.storesFlat.UserProfileStore; + var SelectedGuildStore = shelter.flux.storesFlat.SelectedGuildStore; var pronouns = { he: "he/him", it: "it/its", she: "she/her", they: "they/them", - any: "Any pronouns", - other: "Other pronouns", - ask: "Ask me my pronouns", - avoid: "Avoid pronouns, use my name" + any: "Any", + other: "Other", + ask: "Ask me", + avoid: "Use name" }; var additionalPronouns = [ "he/it", @@ -94,10 +95,14 @@ var pronounsToSearch = Object.values(pronouns).concat(additionalPronouns).filter((p) => p.includes("/")).sort((a, b) => b.length - a.length); var fromStore = (id) => { const profile = UserProfileStore.getUserProfile(id); + const scoped = UserProfileStore.getGuildMemberProfile( + id, + SelectedGuildStore.getGuildId() + ); if (!profile) return; - const pronounSource = (profile.pronouns + profile.bio).toLowerCase(); - return pronounsToSearch.find((p) => pronounSource.includes(p)); + const search = (s) => s && pronounsToSearch.find((p) => s.includes(p)); + return search(scoped?.pronouns) ?? search(scoped?.bio) ?? search(profile.pronouns) ?? search(profile.bio); }; var endpoint = "https://pronoundb.org/api/v2/lookup?platform=discord&ids="; var options = { @@ -147,6 +152,9 @@ } }); + // plugins/pronoundb/compactMode.scss + shelter.plugin.scoped.ui.injectCss(`[class*=latin12CompactTimeStamp]{width:6.25rem !important;--timestamp-width: 6.25rem !important}[class*=latin12CompactTimeStamp]::before{--avatar-size: 2.25rem !important}:root{--custom-message-margin-compact-indent: 9rem}`); + // plugins/pronoundb/index.tsx var _tmpl$ = /* @__PURE__ */ (0, import_web.template)(` \u2022`, 2); var { @@ -160,6 +168,9 @@ }, ui: { Space + }, + solid: { + Show } } = shelter; var patchedEls = /* @__PURE__ */ new WeakSet(); @@ -175,15 +186,14 @@ await forceBioFetch(el.parentElement.parentElement.querySelector("[id^=message-username]").firstElementChild, authorId); pronouns2 = fromStore(authorId); } - if (!pronouns2) - pronouns2 = "Unspecified"; - el.insertAdjacentElement("beforebegin", (() => { - const _el$ = _tmpl$.cloneNode(true), _el$2 = _el$.firstChild; - (0, import_web2.insert)(_el$, (0, import_web3.createComponent)(Space, {}), _el$2); - (0, import_web2.insert)(_el$, pronouns2, _el$2); - (0, import_web2.insert)(_el$, (0, import_web3.createComponent)(Space, {}), null); - return _el$; - })()); + if (pronouns2) + el.insertAdjacentElement("beforebegin", (() => { + const _el$ = _tmpl$.cloneNode(true), _el$2 = _el$.firstChild; + (0, import_web2.insert)(_el$, (0, import_web3.createComponent)(Space, {}), _el$2); + (0, import_web2.insert)(_el$, pronouns2, _el$2); + (0, import_web2.insert)(_el$, (0, import_web3.createComponent)(Space, {}), null); + return _el$; + })()); } function onDispatch() { const unObserve = observeDom("h3 time[id^=message-timestamp]", (el) => { diff --git a/pronoundb/plugin.json b/pronoundb/plugin.json index 8565833..5b0c15c 100644 --- a/pronoundb/plugin.json +++ b/pronoundb/plugin.json @@ -1 +1 @@ -{"name":"pronoundb","author":"Yellowsink","description":"Shows users' pronouns","hash":"687bc218d70ebba7aba7874fda7e7583"} \ No newline at end of file +{"name":"pronoundb","author":"Yellowsink","description":"Shows users' pronouns","hash":"c212b007590e5b553f0f3c901f68a39a"} \ No newline at end of file