diff --git a/Userland/Applications/SystemMonitor/main.cpp b/Userland/Applications/SystemMonitor/main.cpp index 8f37cee457..11838a2c60 100644 --- a/Userland/Applications/SystemMonitor/main.cpp +++ b/Userland/Applications/SystemMonitor/main.cpp @@ -41,6 +41,7 @@ #include #include #include +#include #include #include #include @@ -58,6 +59,7 @@ #include #include #include +#include #include #include #include @@ -433,6 +435,39 @@ NonnullRefPtr build_process_window(pid_t pid) main_widget.set_fill_with_background_color(true); main_widget.set_layout(); + auto& hero_container = main_widget.add(); + hero_container.set_shrink_to_fit(true); + hero_container.set_layout(); + hero_container.layout()->set_margins({ 4, 4, 4, 4 }); + hero_container.layout()->set_spacing(8); + + auto& icon_label = hero_container.add(); + icon_label.set_fixed_size(32, 32); + + GUI::ModelIndex process_index; + for (int row = 0; row < ProcessModel::the().row_count({}); ++row) { + auto index = ProcessModel::the().index(row, ProcessModel::Column::PID); + if (index.data().to_i32() == pid) { + process_index = index; + break; + } + } + + VERIFY(process_index.is_valid()); + if (auto icon_data = process_index.sibling_at_column(ProcessModel::Column::Icon).data(); icon_data.is_icon()) { + icon_label.set_icon(icon_data.as_icon().bitmap_for_size(32)); + } + + auto& process_name_label = hero_container.add(); + process_name_label.set_font(Gfx::FontDatabase::default_bold_font()); + process_name_label.set_text_alignment(Gfx::TextAlignment::CenterLeft); + process_name_label.set_text(String::formatted("{} (PID {})", + process_index.sibling_at_column(ProcessModel::Column::Name).data().to_string(), + pid)); + + auto& separator = main_widget.add(); + separator.set_fixed_height(2); + auto& widget_stack = main_widget.add(); auto& unavailable_process_widget = widget_stack.add(String::formatted("Unable to access PID {}", pid));