needs bug fixing
This commit is contained in:
@@ -26,41 +26,51 @@ pub fn calculate_sidebar_layout(show_sidebar: bool, main_content_area: Rect) ->
|
||||
}
|
||||
}
|
||||
|
||||
pub fn render_sidebar(f: &mut Frame, area: Rect, theme: &Theme, profile_tree: &ProfileTreeResponse) {
|
||||
let sidebar_block = Block::default()
|
||||
.style(Style::default().bg(theme.bg));
|
||||
|
||||
pub fn render_sidebar(
|
||||
f: &mut Frame,
|
||||
area: Rect,
|
||||
theme: &Theme,
|
||||
profile_tree: &ProfileTreeResponse,
|
||||
selected_profile: &Option<String>,
|
||||
) {
|
||||
let sidebar_block = Block::default().style(Style::default().bg(theme.bg));
|
||||
let mut items = Vec::new();
|
||||
|
||||
for profile in &profile_tree.profiles {
|
||||
// Profile header
|
||||
items.push(ListItem::new(Line::from(vec![
|
||||
Span::styled("📁 ", Style::default().fg(theme.accent)),
|
||||
Span::styled(&profile.name, Style::default().fg(theme.highlight)),
|
||||
])));
|
||||
|
||||
// Profile tables
|
||||
for (table_idx, table) in profile.tables.iter().enumerate() {
|
||||
let is_last_table = table_idx == profile.tables.len() - 1;
|
||||
let tree_prefix = if is_last_table { "└─ " } else { "├─ " };
|
||||
|
||||
// Table name
|
||||
if let Some(profile_name) = selected_profile {
|
||||
if let Some(profile) = profile_tree.profiles.iter()
|
||||
.find(|p| &p.name == profile_name)
|
||||
{
|
||||
// Profile header
|
||||
items.push(ListItem::new(Line::from(vec![
|
||||
Span::styled(format!(" {}", tree_prefix), Style::default().fg(theme.fg)),
|
||||
Span::styled(&table.name, Style::default().fg(theme.fg)),
|
||||
Span::styled("📁 ", Style::default().fg(theme.accent)),
|
||||
Span::styled(&profile.name, Style::default().fg(theme.highlight)),
|
||||
])));
|
||||
|
||||
// Dependencies
|
||||
if !table.depends_on.is_empty() {
|
||||
let dep_prefix = if is_last_table { " " } else { "│ " };
|
||||
let deps = table.depends_on.join(", ");
|
||||
// Tables
|
||||
for (table_idx, table) in profile.tables.iter().enumerate() {
|
||||
let is_last = table_idx == profile.tables.len() - 1;
|
||||
let prefix = if is_last { "└─ " } else { "├─ " };
|
||||
|
||||
items.push(ListItem::new(Line::from(vec![
|
||||
Span::styled(format!(" {} └─ ", dep_prefix), Style::default().fg(theme.secondary)),
|
||||
Span::styled(format!("→ {}", deps), Style::default().fg(theme.secondary)),
|
||||
])));
|
||||
let mut line = vec![
|
||||
Span::styled(format!(" {}", prefix), Style::default().fg(theme.fg)),
|
||||
Span::styled(&table.name, Style::default().fg(theme.fg)),
|
||||
];
|
||||
|
||||
if !table.depends_on.is_empty() {
|
||||
line.push(Span::styled(
|
||||
format!(" → {}", table.depends_on.join(", ")),
|
||||
Style::default().fg(theme.secondary)
|
||||
));
|
||||
}
|
||||
|
||||
items.push(ListItem::new(Line::from(line)));
|
||||
}
|
||||
}
|
||||
} else {
|
||||
items.push(ListItem::new(Span::styled(
|
||||
"No profile selected",
|
||||
Style::default().fg(theme.secondary)
|
||||
)));
|
||||
}
|
||||
|
||||
let list = List::new(items)
|
||||
|
||||
Reference in New Issue
Block a user