aboutsummaryrefslogtreecommitdiff
path: root/helix-term/src/ui
diff options
context:
space:
mode:
authorIvan Tham2021-06-19 15:54:37 +0000
committerBlaž Hrastnik2021-07-04 09:01:59 +0000
commit8985c58fd328cde512df0ac7bc577bd8a8c949a0 (patch)
tree09e82861faa30009a75859ed17746544af4eb5d7 /helix-term/src/ui
parent6ccfa229ed61552e243519534c8659c0974ef62e (diff)
Add infobox
Diffstat (limited to 'helix-term/src/ui')
-rw-r--r--helix-term/src/ui/editor.rs7
-rw-r--r--helix-term/src/ui/info.rs24
-rw-r--r--helix-term/src/ui/mod.rs1
3 files changed, 30 insertions, 2 deletions
diff --git a/helix-term/src/ui/editor.rs b/helix-term/src/ui/editor.rs
index 14c34493..8b7c92de 100644
--- a/helix-term/src/ui/editor.rs
+++ b/helix-term/src/ui/editor.rs
@@ -717,6 +717,10 @@ impl Component for EditorView {
self.render_view(doc, view, area, surface, &cx.editor.theme, is_focused);
}
+ if let Some(info) = std::mem::take(&mut cx.editor.autoinfo) {
+ info.render(area, surface, cx);
+ }
+
// render status msg
if let Some((status_msg, severity)) = &cx.editor.status_msg {
use helix_view::editor::Severity;
@@ -735,8 +739,7 @@ impl Component for EditorView {
}
if let Some(completion) = &self.completion {
- completion.render(area, surface, cx)
- // render completion here
+ completion.render(area, surface, cx);
}
}
diff --git a/helix-term/src/ui/info.rs b/helix-term/src/ui/info.rs
new file mode 100644
index 00000000..085a2d9b
--- /dev/null
+++ b/helix-term/src/ui/info.rs
@@ -0,0 +1,24 @@
+use crate::compositor::{Component, Context};
+use helix_view::graphics::{Margin, Rect, Style};
+use helix_view::info::Info;
+use tui::buffer::Buffer as Surface;
+use tui::widgets::{Block, Borders, Widget};
+
+impl Component for Info {
+ fn render(&self, viewport: Rect, surface: &mut Surface, cx: &mut Context) {
+ let block = Block::default().title(self.title).borders(Borders::ALL);
+ let Info { width, height, .. } = self;
+ let (w, h) = (*width + 2, *height + 2);
+ // -2 to subtract command line + statusline. a bit of a hack, because of splits.
+ let area = Rect::new(viewport.width - w, viewport.height - h - 2, w, h);
+ let margin = Margin {
+ vertical: 1,
+ horizontal: 1,
+ };
+ let Rect { x, y, .. } = area.inner(&margin);
+ for (y, line) in (y..).zip(self.text.lines()) {
+ surface.set_string(x, y, line, Style::default());
+ }
+ block.render(area, surface);
+ }
+}
diff --git a/helix-term/src/ui/mod.rs b/helix-term/src/ui/mod.rs
index 7111c968..288d3d2e 100644
--- a/helix-term/src/ui/mod.rs
+++ b/helix-term/src/ui/mod.rs
@@ -1,5 +1,6 @@
mod completion;
mod editor;
+mod info;
mod markdown;
mod menu;
mod picker;