org.apache.wicket.event.Broadcast.java Source code

Java tutorial

Introduction

Here is the source code for org.apache.wicket.event.Broadcast.java

Source

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */
package org.apache.wicket.event;

import org.apache.wicket.Application;
import org.apache.wicket.Component;
import org.apache.wicket.Page;
import org.apache.wicket.Session;
import org.apache.wicket.request.cycle.RequestCycle;

/**
 * Defines the event broadcast type.
 * 
 * @author igor
 */
public enum Broadcast {
    /**
     * Breadth first traversal. Supported sinks in order of traversal:
     * 
     * <ol>
     * <li>{@link Application}</li>
     * <li>{@link Session}</li>
     * <li>{@link RequestCycle}</li>
     * <li>{@link Page}</li>
     * <li>{@link Component}s</li>
     * </ol>
     * 
     * Components receive the event with a preorder breadth-first traversal, eg: Apply recursively:
     * <ol>
     * <li>The component receives the event</li>
     * <li>The component's children receive the event</li>
     * </ol>
     * 
     * Any sink along the path can be specified and traversal will start with the specified sink as
     * root, eg:
     * 
     * <ul>
     * <li>If a component inside the page is specified then only the component and all its children
     * will receive the event</li>
     * <li>If Session is specified then the session, the request cycle, the page and all its
     * components will receive the event</li>
     * </ul>
     */
    BREADTH,
    /**
     * Depth first traversal. Supported sinks in order of traversal:
     * 
     * <ol>
     * <li>{@link Component}s</li>
     * <li>{@link Page}</li>
     * <li>{@link RequestCycle}</li>
     * <li>{@link Session}</li>
     * <li>{@link Application}</li>
     * </ol>
     * 
     * Components receive the event with a postorder depth-first traversal, eg: Apply recursively:
     * <ol>
     * <li>The component's children receive the event</li>
     * <li>The component receives the event</li>
     * </ol>
     * 
     * Any sink along the path can be specified and traversal will start with the specified sink as
     * root, eg:
     * 
     * <ul>
     * <li>If a component inside the page is specified then only the component and all its children
     * will receive the event</li>
     * <li>If Session is specified then the session, the request cycle, the page and all its
     * components will receive the event</li>
     * </ul>
     * 
     */
    DEPTH,
    /**
     * A bubble-up traversal. In a bubble-up traversal only the sink and its parents are notified.
     * 
     * Supported sinks in order of traversal are:
     * <ol>
     * <li>{@link Component}s</li>
     * <li>{@link Page}</li>
     * <li>{@link RequestCycle}</li>
     * <li>{@link Session}</li>
     * <li>{@link Application}</li>
     * </ol>
     * 
     * Any sink along the path can be specified and traversal will start at the specified sink and
     * work its way up to the {@link Application}, eg:
     * 
     * <ul>
     * <li>If a component inside the page is specified then only the component, its parents, the
     * request cycle, the session, and the application will be notified.
     * <li>If Session is specified then the session, the application will be notified</li>
     * </ul>
     */
    BUBBLE,
    /**
     * Only the specified sink receives the event
     */
    EXACT
}