org.apache.wicket.core.request.handler.IPartialPageRequestHandler.java Source code

Java tutorial

Introduction

Here is the source code for org.apache.wicket.core.request.handler.IPartialPageRequestHandler.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.core.request.handler;

import java.util.Collection;

import org.apache.wicket.Component;
import org.apache.wicket.MarkupContainer;
import org.apache.wicket.markup.head.IHeaderResponse;

/**
 * Request handler that allows partial updates of the current page instance.
 */
public interface IPartialPageRequestHandler extends IPageRequestHandler {

    /**
     * Adds a component to the list of components to be rendered
     *
     * @param markupId
     *            id of client-side dom element that will be updated
     * @param component
     *            component to be rendered
     * @throws IllegalArgumentException
     *             if the component is a {@link org.apache.wicket.Page} or an {@link org.apache.wicket.markup.repeater.AbstractRepeater}
     * @throws IllegalStateException
     *             if the components are currently being rendered, or have already been rendered
     */
    void add(final Component component, final String markupId);

    /**
     * Adds components to the list of components to be rendered.
     *
     * @param components
     *            components to be rendered
     */
    void add(Component... components);

    /**
     * Visits all children of the specified parent container and adds them to the target if they are
     * of same type as <code>childCriteria</code>
     *
     * @param parent
     *            Must not be null.
     * @param childCriteria
     *            Must not be null. If you want to traverse all components use ` Component.class as
     *            the value for this argument.
     */
    void addChildren(MarkupContainer parent, Class<?> childCriteria);

    /**
     * Adds javascript that will be evaluated on the client side after components are replaced
     *
     * <p>If the javascript needs to do something asynchronously (i.e. needs to use window.setTimeout(), for example
     * to do animations) then the following special syntax may be used: <code>someFunctionName|myJsLogic(someFunctionName);</code>.
     * Wicket will transform it to: <code>function(someFunctionName){myJsLogic(someFunctionName);}</code> and your code
     * is responsible to execute <em>someFunctionName()</em> when the asynchronous task is finished. Once <em>someFunctionName</em>
     * is executed the next appended script will be executed. <strong>Important</strong>: it is highly recommended to
     * execute your code in try/finally to make sure <em>someFunctionName</em> is executed even an error happens in
     * your code, otherwise all following scripts wont be executed.</p>
     *
     * @param javascript
     */
    void appendJavaScript(CharSequence javascript);

    /**
     * Adds javascript that will be evaluated on the client side before components are replaced.
     *
     * <p>If the javascript needs to do something asynchronously (i.e. needs to use window.setTimeout(), for example
     * to do animations) then the following special syntax may be used: <code>someFunctionName|myJsLogic(someFunctionName);</code>.
     * Wicket will transform it to: <code>function(someFunctionName){myJsLogic(someFunctionName);}</code> and your code
     * is responsible to execute <em>someFunctionName()</em> when the asynchronous task is finished. Once <em>someFunctionName</em>
     * is executed the next prepended script will be executed. <strong>Important</strong>: it is highly recommended to
     * execute your code in try/finally to make sure <em>someFunctionName</em> is executed even an error happens in
     * your code, otherwise all following scripts and component replacements wont be made.</p>
     *
     * @param javascript
     */
    void prependJavaScript(CharSequence javascript);

    /**
     * Sets the focus in the browser to the given component. The markup id must be set. If the
     * component is null the focus will not be set to any component.
     *
     * @param component
     *            The component to get the focus or null.
     */
    void focusComponent(Component component);

    /**
     * Returns an unmodifiable collection of all components added to this target
     *
     * @return unmodifiable collection of all components added to this target
     */
    Collection<? extends Component> getComponents();

    /**
     * Returns the header response associated with current handler.
     *
     * Beware that only renderOnDomReadyJavaScript and renderOnLoadJavaScript can be called outside
     * the renderHeader(IHeaderResponse response) method. Calls to other render** methods will
     * result in the call failing with a debug-level log statement to help you see why it failed.
     *
     * @return header response
     */
    IHeaderResponse getHeaderResponse();
}