Skip to content

Package: DetailPanelRenderingFinishedCallback

DetailPanelRenderingFinishedCallback

nameinstructionbranchcomplexitylinemethod
adapt(BiConsumer)
M: 0 C: 5
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
renderingFinished(ViewModelContext, Object)
M: 0 C: 4
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 2
100%
M: 0 C: 1
100%

Coverage

1: /*******************************************************************************
2: * Copyright (c) 2011-2020 EclipseSource Muenchen GmbH and others.
3: *
4: * All rights reserved. This program and the accompanying materials
5: * are made available under the terms of the Eclipse Public License 2.0
6: * which accompanies this distribution, and is available at
7: * https://www.eclipse.org/legal/epl-2.0/
8: *
9: * SPDX-License-Identifier: EPL-2.0
10: *
11: * Contributors:
12: * Lucas Koehler - initial API and implementation
13: * Christian W. Damus - bug 559116
14: ******************************************************************************/
15: package org.eclipse.emfforms.spi.swt.treemasterdetail.util;
16:
17: import java.util.function.BiConsumer;
18:
19: import org.eclipse.emf.ecp.view.spi.context.ViewModelContext;
20:
21: /**
22: * This interface allows to be notified when the
23: * {@link org.eclipse.emfforms.spi.swt.treemasterdetail.TreeMasterDetailComposite TreeMasterDetailComposite} finished
24: * rendering a detail pane.
25: *
26: * @author Lucas Koehler
27: * @since 1.13
28: *
29: */
30: public interface DetailPanelRenderingFinishedCallback {
31:
32:         /**
33:          * This method is called after the renderedObject has been rendered.
34:          * If access to the {@link ViewModelContext} of the rendering is required, then
35:          * override the {@link #renderingFinished(ViewModelContext, Object)} method also.
36:          *
37:          * @param renderedObject The rendered Object
38:          *
39:          * @see #renderingFinished(ViewModelContext, Object)
40:          */
41:         void renderingFinished(Object renderedObject);
42:
43:         /**
44:          * Notify me that an object's detail view has been rendered. The default implementation
45:          * just delegates to the {@link #renderingFinished(Object)} call-back.
46:          *
47:          * @param context the view-model context of the rendering
48:          * @param renderedObject the object that was rendered
49:          *
50:          * @since 1.24
51:          * @see #renderingFinished(Object)
52:          */
53:         default void renderingFinished(ViewModelContext context, Object renderedObject) {
54:                 renderingFinished(renderedObject);
55:         }
56:
57:         /**
58:          * Adapt the two-argument version of the callback alone. A functional alternative that
59:          * does not require implementing the single-argument call-back.
60:          *
61:          * @param renderingFinished the rendering-finished call-back to adapt
62:          * @return the call-back adapter
63:          *
64:          * @since 1.24
65:          * @see #renderingFinished(ViewModelContext, Object)
66:          */
67:         static DetailPanelRenderingFinishedCallback adapt(
68:                 BiConsumer<? super ViewModelContext, ? super Object> renderingFinished) {
69:
70:                 return new DetailPanelRenderingFinishedCallback() {
71:
72:                         @Override
73:                         public void renderingFinished(ViewModelContext context, Object renderedObject) {
74:                                 renderingFinished.accept(context, renderedObject);
75:                         }
76:
77:                         @Override
78:                         public void renderingFinished(Object renderedObject) {
79:                                 // Not needed
80:                         }
81:                 };
82:         }
83:
84: }