(no commit message)
[utils] / wicket / components / src / main / java / org / wamblee / wicket / page / PageBehavior.java
1 /*
2  * Copyright 2005-2010 the original author or authors.
3  * 
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of 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,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package org.wamblee.wicket.page;
17
18 import java.io.Serializable;
19
20 import org.apache.wicket.markup.html.WebPage;
21 import org.apache.wicket.protocol.http.WebResponse;
22
23 /**
24  * Page behavior interface. This provides a mechanism to extend page behavior
25  * without subclassing. Implementations of this interface should be
26  * serializable.
27  * 
28  * @author Erik Brakkee
29  */
30 public interface PageBehavior extends Serializable {
31
32     /**
33      * To be called as part of the Page's <code>onBeforeRender</code>
34      * 
35      * @param aPage
36      *            Page this is called for.
37      */
38     void onBeforeRender(WebPage aPage);
39
40     /**
41      * To be called as part of the Page's <code>setHeaders</code>
42      * 
43      * @param aPage
44      *            Page this is called for.
45      * @param aResponse
46      *            Response to set headers for.
47      */
48     void setHeaders(WebPage aPage, WebResponse aResponse);
49
50     /**
51      * To be called as part of the Page's <code>onAfterRender</code>
52      * 
53      * @param aPage
54      *            Page this is called for.
55      */
56     void onAfterRender(WebPage aPage);
57
58     /**
59      * To be called in the {@link Page#onDetach
60
61      */
62     void onDetach(WebPage aPage);
63 }