You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

BinderPropertySet.java 1.5KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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;
  17. import java.io.Serializable;
  18. import java.util.Optional;
  19. import java.util.stream.Stream;
  20. /**
  21. * Describes a set of properties that can be used with a {@link Binder}.
  22. *
  23. * @author Vaadin Ltd
  24. *
  25. * @since
  26. *
  27. * @param <T>
  28. * the type for which the properties are defined
  29. */
  30. public interface BinderPropertySet<T> extends Serializable {
  31. /**
  32. * Gets all known properties as a stream.
  33. *
  34. * @return a stream of property names, not <code>null</code>
  35. */
  36. public Stream<BinderPropertyDefinition<T, ?>> getProperties();
  37. /**
  38. * Gets the definition for the named property, or an empty optional if there
  39. * is no property with the given name.
  40. *
  41. * @param name
  42. * the property name to look for, not <code>null</code>
  43. * @return the property definition, or empty optional if property doesn't
  44. * exist
  45. */
  46. public Optional<BinderPropertyDefinition<T, ?>> getProperty(String name);
  47. }