GSortingProxyModel.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #pragma once
  2. #include <LibGUI/GModel.h>
  3. class GSortingProxyModel final : public GModel {
  4. public:
  5. static NonnullRefPtr<GSortingProxyModel> create(NonnullRefPtr<GModel>&& model) { return adopt(*new GSortingProxyModel(move(model))); }
  6. virtual ~GSortingProxyModel() override;
  7. virtual int row_count(const GModelIndex& = GModelIndex()) const override;
  8. virtual int column_count(const GModelIndex& = GModelIndex()) const override;
  9. virtual String row_name(int) const override;
  10. virtual String column_name(int) const override;
  11. virtual ColumnMetadata column_metadata(int) const override;
  12. virtual GVariant data(const GModelIndex&, Role = Role::Display) const override;
  13. virtual void update() override;
  14. virtual int key_column() const override { return m_key_column; }
  15. virtual GSortOrder sort_order() const override { return m_sort_order; }
  16. virtual void set_key_column_and_sort_order(int, GSortOrder) override;
  17. GModelIndex map_to_target(const GModelIndex&) const;
  18. private:
  19. explicit GSortingProxyModel(NonnullRefPtr<GModel>&&);
  20. GModel& target() { return *m_target; }
  21. const GModel& target() const { return *m_target; }
  22. void resort();
  23. void set_sorting_case_sensitive(bool b) { m_sorting_case_sensitive = b; }
  24. bool is_sorting_case_sensitive() { return m_sorting_case_sensitive; }
  25. NonnullRefPtr<GModel> m_target;
  26. Vector<int> m_row_mappings;
  27. int m_key_column { -1 };
  28. GSortOrder m_sort_order { GSortOrder::Ascending };
  29. bool m_sorting_case_sensitive { false };
  30. };