Start work on allowing mentions for all users in call

This commit is contained in:
Max Brunsfeld 2024-01-24 09:45:26 -08:00
parent 68260a48bb
commit c81d318098
2 changed files with 28 additions and 10 deletions

View File

@ -118,6 +118,7 @@ pub struct MembershipSortKey<'a> {
pub enum ChannelEvent { pub enum ChannelEvent {
ChannelCreated(ChannelId), ChannelCreated(ChannelId),
ChannelRenamed(ChannelId), ChannelRenamed(ChannelId),
ChannelParticipantsChanged(ChannelId),
} }
impl EventEmitter<ChannelEvent> for ChannelStore {} impl EventEmitter<ChannelEvent> for ChannelStore {}

View File

@ -1,7 +1,7 @@
use anyhow::Result; use anyhow::Result;
use channel::{ChannelId, ChannelMembership, ChannelStore, MessageParams}; use channel::{ChannelId, ChannelMembership, ChannelStore, MessageParams};
use client::UserId; use client::{User, UserId};
use collections::HashMap; use collections::{HashMap, HashSet};
use editor::{AnchorRangeExt, CompletionProvider, Editor, EditorElement, EditorStyle}; use editor::{AnchorRangeExt, CompletionProvider, Editor, EditorElement, EditorStyle};
use fuzzy::StringMatchCandidate; use fuzzy::StringMatchCandidate;
use gpui::{ use gpui::{
@ -30,7 +30,7 @@ lazy_static! {
pub struct MessageEditor { pub struct MessageEditor {
pub editor: View<Editor>, pub editor: View<Editor>,
channel_store: Model<ChannelStore>, channel_store: Model<ChannelStore>,
users: HashMap<String, UserId>, channel_members: HashMap<String, UserId>,
mentions: Vec<UserId>, mentions: Vec<UserId>,
mentions_task: Option<Task<()>>, mentions_task: Option<Task<()>>,
channel_id: Option<ChannelId>, channel_id: Option<ChannelId>,
@ -108,7 +108,7 @@ impl MessageEditor {
Self { Self {
editor, editor,
channel_store, channel_store,
users: HashMap::default(), channel_members: HashMap::default(),
channel_id: None, channel_id: None,
mentions: Vec::new(), mentions: Vec::new(),
mentions_task: None, mentions_task: None,
@ -147,14 +147,22 @@ impl MessageEditor {
} }
pub fn set_members(&mut self, members: Vec<ChannelMembership>, _: &mut ViewContext<Self>) { pub fn set_members(&mut self, members: Vec<ChannelMembership>, _: &mut ViewContext<Self>) {
self.users.clear(); self.channel_members.clear();
self.users.extend( self.channel_members.extend(
members members
.into_iter() .into_iter()
.map(|member| (member.user.github_login.clone(), member.user.id)), .map(|member| (member.user.github_login.clone(), member.user.id)),
); );
} }
pub fn update_users(&mut self, users: &Vec<Arc<User>>, cx: &mut ViewContext<Self>) {
self.channel_members.extend(
users
.into_iter()
.map(|user| (user.github_login.clone(), user.id)),
);
}
pub fn take_message(&mut self, cx: &mut ViewContext<Self>) -> MessageParams { pub fn take_message(&mut self, cx: &mut ViewContext<Self>) -> MessageParams {
self.editor.update(cx, |editor, cx| { self.editor.update(cx, |editor, cx| {
let highlights = editor.text_highlights::<Self>(cx); let highlights = editor.text_highlights::<Self>(cx);
@ -221,9 +229,18 @@ impl MessageEditor {
let start_offset = end_offset - query.len(); let start_offset = end_offset - query.len();
let start_anchor = buffer.read(cx).anchor_before(start_offset); let start_anchor = buffer.read(cx).anchor_before(start_offset);
let candidates = self let names = HashSet::new();
.users for (github_login, _) in self.channel_members {
.keys() names.insert(github_login.clone());
}
if let Some(channel_id) = channel_id {
for participant in self.channel_store.read(cx).channel_participants(channel_id) {
names.insert(participant.github_login.clone());
}
}
let candidates = names
.into_iter()
.map(|user| StringMatchCandidate { .map(|user| StringMatchCandidate {
id: 0, id: 0,
string: user.clone(), string: user.clone(),
@ -283,7 +300,7 @@ impl MessageEditor {
text.clear(); text.clear();
text.extend(buffer.text_for_range(range.clone())); text.extend(buffer.text_for_range(range.clone()));
if let Some(username) = text.strip_prefix("@") { if let Some(username) = text.strip_prefix("@") {
if let Some(user_id) = this.users.get(username) { if let Some(user_id) = this.channel_members.get(username) {
let start = multi_buffer.anchor_after(range.start); let start = multi_buffer.anchor_after(range.start);
let end = multi_buffer.anchor_after(range.end); let end = multi_buffer.anchor_after(range.end);