#include "Actions/ActionRouting.h" #include "Actions/EditorActions.h" #include "ConsolePanel.h" #include "Core/EditorConsoleSink.h" #include "UI/UI.h" #include #include #include namespace XCEngine { namespace Editor { ConsolePanel::ConsolePanel() : Panel("Console") { } void ConsolePanel::Render() { UI::PanelWindowScope panel(m_name.c_str()); if (!panel.IsOpen()) { return; } Actions::ObserveInactiveActionRoute(*m_context); auto* sink = Debug::EditorConsoleSink::GetInstance(); { UI::PanelToolbarScope toolbar("ConsoleToolbar", UI::StandardPanelToolbarHeight()); if (toolbar.IsOpen()) { if (Actions::DrawToolbarAction(Actions::MakeClearConsoleAction())) { sink->Clear(); } ImGui::SameLine(); UI::DrawToolbarLabel("Filter"); ImGui::SameLine(); Actions::DrawToolbarToggleAction(Actions::MakeConsoleInfoFilterAction(m_filterState.ShowInfo()), m_filterState.ShowInfo()); ImGui::SameLine(); Actions::DrawToolbarToggleAction(Actions::MakeConsoleWarningFilterAction(m_filterState.ShowWarning()), m_filterState.ShowWarning()); ImGui::SameLine(); Actions::DrawToolbarToggleAction(Actions::MakeConsoleErrorFilterAction(m_filterState.ShowError()), m_filterState.ShowError()); } } UI::PanelContentScope content("LogScroll", UI::DefaultPanelContentPadding(), ImGuiWindowFlags_HorizontalScrollbar); if (!content.IsOpen()) { return; } const auto logs = sink->GetLogs(); size_t logIndex = 0; for (const auto& log : logs) { if (!m_filterState.Allows(log.level)) { continue; } const char* prefix; switch (log.level) { case ::XCEngine::Debug::LogLevel::Verbose: case ::XCEngine::Debug::LogLevel::Debug: case ::XCEngine::Debug::LogLevel::Info: prefix = "[INFO] "; break; case ::XCEngine::Debug::LogLevel::Warning: prefix = "[WARN] "; break; case ::XCEngine::Debug::LogLevel::Error: case ::XCEngine::Debug::LogLevel::Fatal: prefix = "[ERROR] "; break; } ImGui::PushID(static_cast(logIndex)); const char* category = ::XCEngine::Debug::LogCategoryToString(log.category); std::string fullMessage = std::string(prefix) + "[" + category + "] " + log.message.CStr(); if (UI::DrawConsoleLogRow(fullMessage.c_str())) { ImGui::SetClipboardText(fullMessage.c_str()); } ImGui::PopID(); logIndex++; } } } }