Subversion Repository Public Repository

litesoft

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// This Source Code is Copyright & Licenced as indicated below
package org.litesoft.GWT.client.widgets.nonpublic.external;
/*
 * Copyright 2006 Mat Gessel <mat.gessel@gmail.com>
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */

import com.google.gwt.user.client.EventListener;
import com.google.gwt.user.client.ui.*;

import java.util.*;

/**
 * An interface implemented by widgets which support event handling via
 * controllers.
 */
public interface ControllerSupport extends EventListener {
    /**
     * Sets the controllers which will process events on this widget. Clears out
     * the current controllers, if any. When the widget is added to the DOM,
     * received events will be delegated to each controller which declares the
     * event's type via
     * {@link asquare.gwt.tk.client.ui.behavior.EventDelegate#getEventBits() getEventBits()}.
     *
     * @param controllers a list of 0 or more controllers, or <code>null</code>
     */
    void setControllers( List controllers );

    /**
     * Gets a controller with the specified id. The id is often an interface or
     * base class, as controllers can have multiple implementations. Used to
     * modify the behavior of existing widgets.
     *
     * @param id a Class identifying the type of controller to get
     *
     * @return the first controller matching the id, or <code>null</code>
     */
    Controller getController( Class id );

    /**
     * Adds a controller to process events on this widget. Multiple controllers
     * may be added.
     *
     * @param controller a controller to add
     *
     * @return the widget this call was made on (for convenience)
     */
    Widget addController( Controller controller );

    /**
     * Removes a controller
     *
     * @param controller a controller to remove
     *
     * @return the widget this call was made on (for convenience)
     *
     * @throws IllegalArgumentException if <code>controller</code> is not present
     */
    Widget removeController( Controller controller );
}

Commits for litesoft/trunk/Java/GWT/Client/src/org/litesoft/GWT/client/widgets/nonpublic/external/ControllerSupport.java

Diff revisions: vs.
Revision Author Commited Message
950 Diff Diff GeorgeS picture GeorgeS Thu 19 Jun, 2014 17:57:04 +0000

New Lines

948 Diff Diff GeorgeS picture GeorgeS Sat 07 Jun, 2014 23:42:39 +0000

Jusefuls Formatter Updated to New Code Format

49 Diff Diff GeorgeS picture GeorgeS Mon 12 Apr, 2010 02:59:10 +0000

License Text

2 GeorgeS picture GeorgeS Sun 07 Feb, 2010 12:50:58 +0000