FilteringProxyModel.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /*
  2. * Copyright (c) 2020, the SerenityOS developers.
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/NonnullRefPtr.h>
  8. #include <AK/Optional.h>
  9. #include <AK/String.h>
  10. #include <LibGUI/Model.h>
  11. #include <LibGUI/TextBox.h>
  12. namespace GUI {
  13. class FilteringProxyModel final : public Model {
  14. public:
  15. static NonnullRefPtr<FilteringProxyModel> construct(Model& model)
  16. {
  17. return adopt_ref(*new FilteringProxyModel(model));
  18. }
  19. virtual ~FilteringProxyModel() override {};
  20. virtual int row_count(ModelIndex const& = ModelIndex()) const override;
  21. virtual int column_count(ModelIndex const& = ModelIndex()) const override;
  22. virtual Variant data(ModelIndex const&, ModelRole = ModelRole::Display) const override;
  23. virtual void invalidate() override;
  24. virtual ModelIndex index(int row, int column = 0, ModelIndex const& parent = ModelIndex()) const override;
  25. virtual bool is_searchable() const override;
  26. virtual Vector<ModelIndex> matches(StringView const&, unsigned = MatchesFlag::AllMatching, ModelIndex const& = ModelIndex()) override;
  27. void set_filter_term(StringView const& term);
  28. ModelIndex map(ModelIndex const&) const;
  29. private:
  30. void filter();
  31. explicit FilteringProxyModel(Model& model)
  32. : m_model(model)
  33. {
  34. }
  35. Model& m_model;
  36. // Maps row to actual model index.
  37. Vector<ModelIndex> m_matching_indices;
  38. String m_filter_term;
  39. };
  40. }