1b7c25ee4ad6c203cb396e8779fc5f62e723ecd9
[utils] / wicket / components / src / main / java / org / wamblee / wicket / behavior / 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.behavior;
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 without
25  * subclassing. 
26  * 
27  * @author Erik Brakkee
28  */
29 public interface PageBehavior extends Serializable {
30     
31     /**
32      * To be called as part of the Page's <code>onBeforeRender</code>
33      * @param aPage Page this is called for. 
34      */
35     void onBeforeRender(WebPage aPage);
36     
37     /**
38      * To be called as part of the Page's <code>setHeaders</code>
39      * @param aPage Page this is called for. 
40      * @param aResponse Response to set headers for. 
41      */
42     void setHeaders(WebPage aPage, WebResponse aResponse);
43    
44     /**
45      * To be called as part of the Page's <code>onAfterRender</code>
46      * @param aPage Page this is called for. 
47      */
48     void onAfterRender(WebPage aPage);
49 }