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.

EditorComponentGenerator.java 1.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  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.ui.components.grid;
  17. import com.vaadin.server.SerializableFunction;
  18. import com.vaadin.ui.Component;
  19. /**
  20. * A callback interface for generating an editor component corresponding to an
  21. * editable column of a grid. The generated component will be used in the grid
  22. * editor to edit the value of the column for the selected grid row.
  23. *
  24. * @author Vaadin Ltd.
  25. * @since 8.0
  26. *
  27. * @param <BEAN>
  28. * the bean type this generator is compatible with
  29. */
  30. @FunctionalInterface
  31. public interface EditorComponentGenerator<BEAN>
  32. extends SerializableFunction<BEAN, Component> {
  33. /**
  34. * Gets a component for a given {@code bean}.
  35. *
  36. * @param bean
  37. * the bean this component will be used to edit
  38. * @return the generated component
  39. */
  40. @Override
  41. public Component apply(BEAN bean);
  42. }