Pārlūkot izejas kodu

LibGUI: Disable the ColumnsView subview in MultiView for now

This is causing FilePicker to log a bunch of debug noise due to the
missing support for tree models in SortingProxyModel and it's not
helping anyone so let's just disable it.

This needs fixing in SortingProxyModel.
Andreas Kling 5 gadi atpakaļ
vecāks
revīzija
3523071bb7

+ 2 - 1
Libraries/LibGUI/FilePicker.cpp

@@ -156,9 +156,10 @@ FilePicker::FilePicker(Mode mode, const StringView& file_name, const StringView&
     toolbar->add_action(m_view->view_as_icons_action());
     toolbar->add_action(m_view->view_as_icons_action());
     toolbar->add_action(m_view->view_as_table_action());
     toolbar->add_action(m_view->view_as_table_action());
 
 
-    // FIXME: Enable this once GUI::ColumnsView doesn't crash when used here.
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_view->view_as_columns_action().set_enabled(false);
     m_view->view_as_columns_action().set_enabled(false);
     toolbar->add_action(m_view->view_as_columns_action());
     toolbar->add_action(m_view->view_as_columns_action());
+#endif
 
 
     auto lower_container = vertical_container->add<Widget>();
     auto lower_container = vertical_container->add<Widget>();
     lower_container->set_layout(make<VerticalBoxLayout>());
     lower_container->set_layout(make<VerticalBoxLayout>());

+ 20 - 2
Libraries/LibGUI/MultiView.cpp

@@ -40,17 +40,22 @@ MultiView::MultiView()
 {
 {
     set_active_widget(nullptr);
     set_active_widget(nullptr);
     m_item_view = add<ItemView>();
     m_item_view = add<ItemView>();
-    m_columns_view = add<ColumnsView>();
     m_table_view = add<TableView>();
     m_table_view = add<TableView>();
 
 
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
+    m_columns_view = add<ColumnsView>();
+#endif
+
     m_item_view->on_activation = [&](auto& index) {
     m_item_view->on_activation = [&](auto& index) {
         if (on_activation)
         if (on_activation)
             on_activation(index);
             on_activation(index);
     };
     };
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_columns_view->on_activation = [&](auto& index) {
     m_columns_view->on_activation = [&](auto& index) {
         if (on_activation)
         if (on_activation)
             on_activation(index);
             on_activation(index);
     };
     };
+#endif
     m_table_view->on_activation = [&](auto& index) {
     m_table_view->on_activation = [&](auto& index) {
         if (on_activation)
         if (on_activation)
             on_activation(index);
             on_activation(index);
@@ -64,10 +69,12 @@ MultiView::MultiView()
         if (on_selection_change)
         if (on_selection_change)
             on_selection_change();
             on_selection_change();
     };
     };
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_columns_view->on_selection_change = [this] {
     m_columns_view->on_selection_change = [this] {
         if (on_selection_change)
         if (on_selection_change)
             on_selection_change();
             on_selection_change();
     };
     };
+#endif
 
 
     m_table_view->on_context_menu_request = [this](auto& index, auto& event) {
     m_table_view->on_context_menu_request = [this](auto& index, auto& event) {
         if (on_context_menu_request)
         if (on_context_menu_request)
@@ -77,10 +84,12 @@ MultiView::MultiView()
         if (on_context_menu_request)
         if (on_context_menu_request)
             on_context_menu_request(index, event);
             on_context_menu_request(index, event);
     };
     };
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_columns_view->on_context_menu_request = [this](auto& index, auto& event) {
     m_columns_view->on_context_menu_request = [this](auto& index, auto& event) {
         if (on_context_menu_request)
         if (on_context_menu_request)
             on_context_menu_request(index, event);
             on_context_menu_request(index, event);
     };
     };
+#endif
 
 
     m_table_view->on_drop = [this](auto& index, auto& event) {
     m_table_view->on_drop = [this](auto& index, auto& event) {
         if (on_drop)
         if (on_drop)
@@ -90,11 +99,12 @@ MultiView::MultiView()
         if (on_drop)
         if (on_drop)
             on_drop(index, event);
             on_drop(index, event);
     };
     };
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_columns_view->on_drop = [this](auto& index, auto& event) {
     m_columns_view->on_drop = [this](auto& index, auto& event) {
         if (on_drop)
         if (on_drop)
             on_drop(index, event);
             on_drop(index, event);
     };
     };
-
+#endif
     set_view_mode(ViewMode::Icon);
     set_view_mode(ViewMode::Icon);
 
 
     build_actions();
     build_actions();
@@ -114,10 +124,12 @@ void MultiView::set_view_mode(ViewMode mode)
         set_active_widget(m_table_view);
         set_active_widget(m_table_view);
         return;
         return;
     }
     }
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     if (mode == ViewMode::Columns) {
     if (mode == ViewMode::Columns) {
         set_active_widget(m_columns_view);
         set_active_widget(m_columns_view);
         return;
         return;
     }
     }
+#endif
     if (mode == ViewMode::Icon) {
     if (mode == ViewMode::Icon) {
         set_active_widget(m_item_view);
         set_active_widget(m_item_view);
         return;
         return;
@@ -141,7 +153,9 @@ void MultiView::set_model_column(int column)
         return;
         return;
     m_model_column = column;
     m_model_column = column;
     m_item_view->set_model_column(column);
     m_item_view->set_model_column(column);
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_columns_view->set_model_column(column);
     m_columns_view->set_model_column(column);
+#endif
 }
 }
 
 
 void MultiView::set_column_hidden(int column_index, bool hidden)
 void MultiView::set_column_hidden(int column_index, bool hidden)
@@ -165,18 +179,22 @@ void MultiView::build_actions()
         });
         });
     m_view_as_icons_action->set_checkable(true);
     m_view_as_icons_action->set_checkable(true);
 
 
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_view_as_columns_action = Action::create(
     m_view_as_columns_action = Action::create(
         "Columns view", Gfx::Bitmap::load_from_file("/res/icons/16x16/columns-view.png"), [this](auto&) {
         "Columns view", Gfx::Bitmap::load_from_file("/res/icons/16x16/columns-view.png"), [this](auto&) {
             set_view_mode(ViewMode::Columns);
             set_view_mode(ViewMode::Columns);
             m_view_as_columns_action->set_checked(true);
             m_view_as_columns_action->set_checked(true);
         });
         });
     m_view_as_columns_action->set_checkable(true);
     m_view_as_columns_action->set_checkable(true);
+#endif
 
 
     m_view_type_action_group = make<ActionGroup>();
     m_view_type_action_group = make<ActionGroup>();
     m_view_type_action_group->set_exclusive(true);
     m_view_type_action_group->set_exclusive(true);
     m_view_type_action_group->add_action(*m_view_as_table_action);
     m_view_type_action_group->add_action(*m_view_as_table_action);
     m_view_type_action_group->add_action(*m_view_as_icons_action);
     m_view_type_action_group->add_action(*m_view_as_icons_action);
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     m_view_type_action_group->add_action(*m_view_as_columns_action);
     m_view_type_action_group->add_action(*m_view_as_columns_action);
+#endif
 }
 }
 
 
 }
 }

+ 12 - 0
Libraries/LibGUI/MultiView.h

@@ -32,6 +32,8 @@
 #include <LibGUI/StackWidget.h>
 #include <LibGUI/StackWidget.h>
 #include <LibGUI/TableView.h>
 #include <LibGUI/TableView.h>
 
 
+//#define MULTIVIEW_WITH_COLUMNSVIEW
+
 namespace GUI {
 namespace GUI {
 
 
 class MultiView final : public GUI::StackWidget {
 class MultiView final : public GUI::StackWidget {
@@ -65,8 +67,10 @@ public:
         switch (m_view_mode) {
         switch (m_view_mode) {
         case ViewMode::List:
         case ViewMode::List:
             return *m_table_view;
             return *m_table_view;
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
         case ViewMode::Columns:
         case ViewMode::Columns:
             return *m_columns_view;
             return *m_columns_view;
+#endif
         case ViewMode::Icon:
         case ViewMode::Icon:
             return *m_item_view;
             return *m_item_view;
         default:
         default:
@@ -82,7 +86,9 @@ public:
     {
     {
         callback(*m_table_view);
         callback(*m_table_view);
         callback(*m_item_view);
         callback(*m_item_view);
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
         callback(*m_columns_view);
         callback(*m_columns_view);
+#endif
     }
     }
 
 
     Model* model() { return m_model; }
     Model* model() { return m_model; }
@@ -92,7 +98,9 @@ public:
 
 
     Action& view_as_table_action() { return *m_view_as_table_action; }
     Action& view_as_table_action() { return *m_view_as_table_action; }
     Action& view_as_icons_action() { return *m_view_as_icons_action; }
     Action& view_as_icons_action() { return *m_view_as_icons_action; }
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     Action& view_as_columns_action() { return *m_view_as_columns_action; }
     Action& view_as_columns_action() { return *m_view_as_columns_action; }
+#endif
 
 
 private:
 private:
     MultiView();
     MultiView();
@@ -106,11 +114,15 @@ private:
 
 
     RefPtr<TableView> m_table_view;
     RefPtr<TableView> m_table_view;
     RefPtr<ItemView> m_item_view;
     RefPtr<ItemView> m_item_view;
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     RefPtr<ColumnsView> m_columns_view;
     RefPtr<ColumnsView> m_columns_view;
+#endif
 
 
     RefPtr<Action> m_view_as_table_action;
     RefPtr<Action> m_view_as_table_action;
     RefPtr<Action> m_view_as_icons_action;
     RefPtr<Action> m_view_as_icons_action;
+#ifdef MULTIVIEW_WITH_COLUMNSVIEW
     RefPtr<Action> m_view_as_columns_action;
     RefPtr<Action> m_view_as_columns_action;
+#endif
 
 
     OwnPtr<ActionGroup> m_view_type_action_group;
     OwnPtr<ActionGroup> m_view_type_action_group;
 };
 };