form field fixed
This commit is contained in:
@@ -1,7 +1,7 @@
|
|||||||
// src/client/components/form.rs
|
// src/client/components/form.rs
|
||||||
use ratatui::{
|
use ratatui::{
|
||||||
widgets::{Paragraph, Block, Borders},
|
widgets::{Paragraph, Block, Borders},
|
||||||
layout::{Layout, Constraint, Direction, Rect, Margin, Position},
|
layout::{Layout, Constraint, Direction, Rect, Margin, Alignment},
|
||||||
style::Style,
|
style::Style,
|
||||||
text::{Line, Span},
|
text::{Line, Span},
|
||||||
Frame,
|
Frame,
|
||||||
@@ -16,14 +16,13 @@ pub fn render_form(
|
|||||||
inputs: &[&String],
|
inputs: &[&String],
|
||||||
theme: &Theme,
|
theme: &Theme,
|
||||||
) {
|
) {
|
||||||
// Create a block for the Adresar card
|
// Create Adresar card
|
||||||
let adresar_card = Block::default()
|
let adresar_card = Block::default()
|
||||||
.borders(Borders::ALL)
|
.borders(Borders::ALL)
|
||||||
.border_style(Style::default().fg(theme.border))
|
.border_style(Style::default().fg(theme.border))
|
||||||
.title(" Adresar ")
|
.title(" Adresar ")
|
||||||
.style(Style::default().bg(theme.bg).fg(theme.fg));
|
.style(Style::default().bg(theme.bg).fg(theme.fg));
|
||||||
|
|
||||||
// Render the card first
|
|
||||||
f.render_widget(adresar_card, area);
|
f.render_widget(adresar_card, area);
|
||||||
|
|
||||||
// Define the inner area for the form (inside the card)
|
// Define the inner area for the form (inside the card)
|
||||||
@@ -32,56 +31,71 @@ pub fn render_form(
|
|||||||
vertical: 1,
|
vertical: 1,
|
||||||
});
|
});
|
||||||
|
|
||||||
// Split the inner area into two columns: labels and inputs
|
// Split into label column and input column
|
||||||
let columns = Layout::default()
|
let columns = Layout::default()
|
||||||
.direction(Direction::Horizontal)
|
.direction(Direction::Horizontal)
|
||||||
.constraints([Constraint::Percentage(30), Constraint::Percentage(70)])
|
.constraints([Constraint::Percentage(30), Constraint::Percentage(70)])
|
||||||
.split(inner_area);
|
.split(inner_area);
|
||||||
|
|
||||||
// Create a bordered block for the input area
|
// Create compact input container
|
||||||
let input_block = Block::default()
|
let input_container = Block::default()
|
||||||
.borders(Borders::ALL)
|
.borders(Borders::ALL)
|
||||||
.border_style(Style::default().fg(theme.accent));
|
.border_style(Style::default().fg(theme.accent))
|
||||||
|
.style(Style::default().bg(theme.bg));
|
||||||
|
|
||||||
// Render the labels on the left
|
// Center the input box vertically
|
||||||
let label_area = columns[0];
|
let vertical_center = Layout::default()
|
||||||
|
.direction(Direction::Vertical)
|
||||||
|
.constraints([
|
||||||
|
Constraint::Min(1),
|
||||||
|
Constraint::Length(fields.len() as u16 + 2), // +2 for borders
|
||||||
|
Constraint::Min(1),
|
||||||
|
])
|
||||||
|
.split(columns[1]);
|
||||||
|
|
||||||
|
// Render the input container
|
||||||
|
f.render_widget(&input_container, vertical_center[1]);
|
||||||
|
|
||||||
|
// Input area inside borders
|
||||||
|
let input_area = input_container.inner(vertical_center[1]);
|
||||||
|
let input_rows = Layout::default()
|
||||||
|
.direction(Direction::Vertical)
|
||||||
|
.constraints(vec![Constraint::Length(1); fields.len()])
|
||||||
|
.split(input_area);
|
||||||
|
|
||||||
|
// Render labels close to the border
|
||||||
for (i, field) in fields.iter().enumerate() {
|
for (i, field) in fields.iter().enumerate() {
|
||||||
let label = Paragraph::new(Line::from(Span::styled(
|
let label = Paragraph::new(Line::from(Span::styled(
|
||||||
field.to_string(),
|
format!("{}:", field),
|
||||||
Style::default().fg(theme.fg),
|
Style::default().fg(theme.fg),
|
||||||
)));
|
)));
|
||||||
f.render_widget(label, Rect {
|
f.render_widget(label, Rect {
|
||||||
x: label_area.x,
|
x: columns[0].x,
|
||||||
y: label_area.y + i as u16,
|
y: vertical_center[1].y + 1 + i as u16, // Align with input rows
|
||||||
width: label_area.width,
|
width: columns[0].width,
|
||||||
height: 1,
|
height: 1,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Render the inputs inside the bordered block
|
// Render inputs with left-aligned text and free cursor movement
|
||||||
let input_area = input_block.inner(columns[1]);
|
|
||||||
f.render_widget(input_block, columns[1]);
|
|
||||||
|
|
||||||
for (i, input) in inputs.iter().enumerate() {
|
for (i, input) in inputs.iter().enumerate() {
|
||||||
let input_paragraph = Paragraph::new(input.as_str())
|
let is_active = i == *current_field;
|
||||||
.style(if i == *current_field {
|
|
||||||
|
let input_display = Paragraph::new(input.as_str())
|
||||||
|
.alignment(Alignment::Left)
|
||||||
|
.style(if is_active {
|
||||||
Style::default().fg(theme.highlight)
|
Style::default().fg(theme.highlight)
|
||||||
} else {
|
} else {
|
||||||
Style::default().fg(theme.fg)
|
Style::default().fg(theme.fg)
|
||||||
});
|
});
|
||||||
|
|
||||||
f.render_widget(input_paragraph, Rect {
|
f.render_widget(input_display, input_rows[i]);
|
||||||
x: input_area.x,
|
|
||||||
y: input_area.y + i as u16,
|
|
||||||
width: input_area.width,
|
|
||||||
height: 1,
|
|
||||||
});
|
|
||||||
|
|
||||||
// Render the cursor in the active field
|
// Position cursor at the correct position in the active field
|
||||||
if i == *current_field {
|
if is_active {
|
||||||
let cursor_x = input_area.x + input.len() as u16;
|
let cursor_x = input_rows[i].x + input.len() as u16;
|
||||||
let cursor_y = input_area.y + i as u16;
|
let cursor_y = input_rows[i].y;
|
||||||
f.set_cursor_position(Position::new(cursor_x, cursor_y));
|
f.set_cursor(cursor_x, cursor_y);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user