summaryrefslogtreecommitdiff
path: root/client/src/interfaces
diff options
context:
space:
mode:
Diffstat (limited to 'client/src/interfaces')
-rw-r--r--client/src/interfaces/chat.rs44
-rw-r--r--client/src/interfaces/mod.rs21
2 files changed, 60 insertions, 5 deletions
diff --git a/client/src/interfaces/chat.rs b/client/src/interfaces/chat.rs
new file mode 100644
index 0000000..04b1f2c
--- /dev/null
+++ b/client/src/interfaces/chat.rs
@@ -0,0 +1,44 @@
+/*
+ wearechat - generic multiplayer game with voip
+ Copyright (C) 2025 metamuffin
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero General Public License as published by
+ the Free Software Foundation, version 3 of the License only.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with this program. If not, see <https://www.gnu.org/licenses/>.
+*/
+use super::InterfaceData;
+use egui::{TextEdit, Widget};
+use std::sync::Arc;
+
+pub struct ChatInterface {
+ pub idata: Arc<InterfaceData>,
+ pub edit: String,
+}
+
+impl Widget for &mut ChatInterface {
+ fn ui(self, ui: &mut egui::Ui) -> egui::Response {
+ let mut chat = self.idata.chat.lock().unwrap();
+
+ ui.add(TextEdit::singleline(&mut self.edit));
+ if ui.button("Send").clicked() {
+ chat.send_queue.push_back(self.edit.clone());
+ self.edit.clear();
+ }
+
+ ui.group(|ui| {
+ for m in &chat.history {
+ ui.label(m);
+ }
+ });
+
+ ui.response()
+ }
+}
diff --git a/client/src/interfaces/mod.rs b/client/src/interfaces/mod.rs
index 9cbfbe3..0e419bc 100644
--- a/client/src/interfaces/mod.rs
+++ b/client/src/interfaces/mod.rs
@@ -14,15 +14,18 @@
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
+pub mod chat;
pub mod graphicsconfig;
pub mod prefabindex;
pub mod profiler;
use crate::{
+ chat::Chat,
download::Downloader,
network::Network,
render::{GraphicsConfig, scene::ScenePreparer, ui::UI_POSITION_OFFSET},
};
+use chat::ChatInterface;
use egui::{Pos2, Widget};
use graphicsconfig::GraphicsConfigInterface;
use prefabindex::PrefabIndexInterface;
@@ -36,6 +39,7 @@ enum Interface {
Profiler(Profiler),
PrefabIndex(PrefabIndexInterface),
GraphicsConfig(GraphicsConfigInterface),
+ Chat(ChatInterface),
}
pub struct InterfaceData {
@@ -46,6 +50,7 @@ pub struct InterfaceData {
pub render_timing: Arc<Mutex<TimingProfiler>>,
pub adapter_info: Arc<AdapterInfo>,
pub graphics_config: Arc<Mutex<(bool, GraphicsConfig)>>,
+ pub chat: Arc<Mutex<Chat>>,
}
pub fn ui_selector(idata: Arc<InterfaceData>) -> impl Fn(&egui::Context) -> bool {
@@ -58,6 +63,7 @@ pub fn ui_selector(idata: Arc<InterfaceData>) -> impl Fn(&egui::Context) -> bool
Interface::Profiler(_) => "Profiler",
Interface::PrefabIndex(_) => "Prefab Index",
Interface::GraphicsConfig(_) => "Graphics Configuration",
+ Interface::Chat(_) => "Chat",
})
.open(&mut open)
.default_pos(Pos2::new(UI_POSITION_OFFSET, UI_POSITION_OFFSET))
@@ -78,13 +84,18 @@ pub fn ui_selector(idata: Arc<InterfaceData>) -> impl Fn(&egui::Context) -> bool
idata: idata.clone(),
})
}
+ if ui.button("Chat").clicked() {
+ *state = Interface::Chat(ChatInterface {
+ idata: idata.clone(),
+ edit: Default::default(),
+ })
+ }
ui.response()
}
- Interface::Profiler(profiler) => profiler.ui(ui),
- Interface::PrefabIndex(prefab_index_interface) => prefab_index_interface.ui(ui),
- Interface::GraphicsConfig(graphics_config_interface) => {
- graphics_config_interface.ui(ui)
- }
+ Interface::Profiler(i) => i.ui(ui),
+ Interface::PrefabIndex(i) => i.ui(ui),
+ Interface::GraphicsConfig(i) => i.ui(ui),
+ Interface::Chat(i) => i.ui(ui),
});
open
}