ui: Refactor styling a bit, ensure infobox is stylable
This commit is contained in:
parent
cbd39d67a4
commit
68626b8f78
3 changed files with 13 additions and 11 deletions
|
@ -6,7 +6,8 @@ use tui::widgets::{Block, Borders, Paragraph, Widget};
|
|||
|
||||
impl Component for Info {
|
||||
fn render(&mut self, viewport: Rect, surface: &mut Surface, cx: &mut Context) {
|
||||
let style = cx.editor.theme.get("ui.popup");
|
||||
let text_style = cx.editor.theme.get("ui.text.focus");
|
||||
let popup_style = text_style.patch(cx.editor.theme.get("ui.popup"));
|
||||
|
||||
// Calculate the area of the terminal to modify. Because we want to
|
||||
// render at the bottom right, we use the viewport's width and height
|
||||
|
@ -19,12 +20,12 @@ impl Component for Info {
|
|||
width,
|
||||
height,
|
||||
));
|
||||
surface.clear_with(area, style);
|
||||
surface.clear_with(area, popup_style);
|
||||
|
||||
let block = Block::default()
|
||||
.title(self.title.as_str())
|
||||
.borders(Borders::ALL)
|
||||
.border_style(style);
|
||||
.border_style(popup_style);
|
||||
|
||||
let margin = Margin {
|
||||
vertical: 0,
|
||||
|
@ -33,6 +34,8 @@ impl Component for Info {
|
|||
let inner = block.inner(area).inner(&margin);
|
||||
block.render(area, surface);
|
||||
|
||||
Paragraph::new(self.text.as_str()).render(inner, surface);
|
||||
Paragraph::new(self.text.as_str())
|
||||
.style(text_style)
|
||||
.render(inner, surface);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -284,7 +284,8 @@ const BASE_WIDTH: u16 = 30;
|
|||
impl Prompt {
|
||||
pub fn render_prompt(&self, area: Rect, surface: &mut Surface, cx: &mut Context) {
|
||||
let theme = &cx.editor.theme;
|
||||
let text_color = theme.get("ui.text.focus");
|
||||
let prompt_color = theme.get("ui.text");
|
||||
let completion_color = theme.get("ui.statusline");
|
||||
let selected_color = theme.get("ui.menu.selected");
|
||||
// completion
|
||||
|
||||
|
@ -326,15 +327,13 @@ impl Prompt {
|
|||
let mut row = 0;
|
||||
let mut col = 0;
|
||||
|
||||
// TODO: paginate
|
||||
for (i, (_range, completion)) in
|
||||
self.completion.iter().enumerate().skip(offset).take(items)
|
||||
{
|
||||
let color = if Some(i) == self.selection {
|
||||
// Style::default().bg(Color::Rgb(104, 60, 232))
|
||||
selected_color // TODO: just invert bg
|
||||
} else {
|
||||
text_color
|
||||
completion_color
|
||||
};
|
||||
surface.set_stringn(
|
||||
area.x + col * (1 + col_width),
|
||||
|
@ -377,12 +376,12 @@ impl Prompt {
|
|||
|
||||
let line = area.height - 1;
|
||||
// render buffer text
|
||||
surface.set_string(area.x, area.y + line, &self.prompt, text_color);
|
||||
surface.set_string(area.x, area.y + line, &self.prompt, prompt_color);
|
||||
surface.set_string(
|
||||
area.x + self.prompt.len() as u16,
|
||||
area.y + line,
|
||||
&self.line,
|
||||
text_color,
|
||||
prompt_color,
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -42,7 +42,7 @@ module = "#ff0000"
|
|||
"ui.help" = { bg = "#7958DC", fg = "#171452" }
|
||||
|
||||
"ui.text" = { fg = "lavender" }
|
||||
"ui.text.focus" = { fg = "lilac" }
|
||||
"ui.text.focus" = { fg = "white" }
|
||||
|
||||
"ui.selection" = { bg = "#540099" }
|
||||
"ui.selection.primary" = { bg = "#540099" }
|
||||
|
|
Loading…
Add table
Reference in a new issue