Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

DataProviderWrapper.java 2.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * Copyright 2000-2016 Vaadin Ltd.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License"); you may not
  5. * use this file except in compliance with the License. You may obtain a copy of
  6. * the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  12. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  13. * License for the specific language governing permissions and limitations under
  14. * the License.
  15. */
  16. package com.vaadin.data.provider;
  17. import java.util.Objects;
  18. import java.util.stream.Stream;
  19. import com.vaadin.shared.Registration;
  20. /**
  21. * Wrapper class for modifying, chaining and replacing filters and sorting in a
  22. * query. Used to create a suitable {@link Query} for the underlying data
  23. * provider with correct filters and sorting.
  24. *
  25. * @author Vaadin Ltd.
  26. * @since 8.0
  27. *
  28. * @param <T>
  29. * data provider data type
  30. * @param <F>
  31. * wrapper query filter type
  32. * @param <M>
  33. * underlying data provider filter type
  34. */
  35. public abstract class DataProviderWrapper<T, F, M>
  36. implements DataProvider<T, F> {
  37. /**
  38. * The actual data provider behind this wrapper.
  39. */
  40. protected DataProvider<T, M> dataProvider;
  41. /**
  42. * Constructs a filtering wrapper for a data provider.
  43. *
  44. * @param dataProvider
  45. * the wrapped data provider, not <code>null</code>
  46. */
  47. protected DataProviderWrapper(DataProvider<T, M> dataProvider) {
  48. this.dataProvider = Objects.requireNonNull(dataProvider,
  49. "The wrapped data provider cannot be null.");
  50. }
  51. @Override
  52. public boolean isInMemory() {
  53. return dataProvider.isInMemory();
  54. }
  55. @Override
  56. public void refreshAll() {
  57. dataProvider.refreshAll();
  58. }
  59. @Override
  60. public void refreshItem(T item) {
  61. dataProvider.refreshItem(item);
  62. }
  63. @Override
  64. public Object getId(T item) {
  65. return dataProvider.getId(item);
  66. }
  67. @Override
  68. public Registration addDataProviderListener(
  69. DataProviderListener<T> listener) {
  70. return dataProvider.addDataProviderListener(listener);
  71. }
  72. @Override
  73. public int size(Query<T, F> t) {
  74. return dataProvider.size(new Query<>(t.getOffset(), t.getLimit(),
  75. t.getSortOrders(), t.getInMemorySorting(), getFilter(t)));
  76. }
  77. @Override
  78. public Stream<T> fetch(Query<T, F> t) {
  79. return dataProvider.fetch(new Query<>(t.getOffset(), t.getLimit(),
  80. t.getSortOrders(), t.getInMemorySorting(), getFilter(t)));
  81. }
  82. /**
  83. * Gets the filter that should be used in the modified Query.
  84. *
  85. * @param query
  86. * the current query
  87. * @return filter for the modified Query
  88. */
  89. protected abstract M getFilter(Query<T, F> query);
  90. }