X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=wicket%2Fcomponents%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fwicket%2Fbehavior%2FPageBehavior.java;fp=wicket%2Fcomponents%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fwicket%2Fbehavior%2FPageBehavior.java;h=4d9d3b3a82ce975de55100024b0254bf3f0d56ee;hb=e8442732ed5dd8c0e2c2bc02d7d1d5fce0ba1af5;hp=0000000000000000000000000000000000000000;hpb=ce31b728553829347e87373b85192cadbcbc99a7;p=utils
diff --git a/wicket/components/src/main/java/org/wamblee/wicket/behavior/PageBehavior.java b/wicket/components/src/main/java/org/wamblee/wicket/behavior/PageBehavior.java
new file mode 100644
index 00000000..4d9d3b3a
--- /dev/null
+++ b/wicket/components/src/main/java/org/wamblee/wicket/behavior/PageBehavior.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2005-2010 the original author or authors.
+ *
+ * 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.
+ */
+package org.wamblee.wicket.behavior;
+
+import org.apache.wicket.markup.html.WebPage;
+import org.apache.wicket.protocol.http.WebResponse;
+
+/**
+ * Page behavior interface. This provides a mechanism to extend page behavior without
+ * subclassing.
+ *
+ * @author Erik Brakkee
+ */
+public interface PageBehavior {
+
+ /**
+ * To be called as part of the Page's onBeforeRender
+ * @param aPage Page this is called for.
+ */
+ void onBeforeRender(WebPage aPage);
+
+ /**
+ * To be called as part of the Page's setHeaders
+ * @param aPage Page this is called for.
+ * @param aResponse Response to set headers for.
+ */
+ void setHeaders(WebPage aPage, WebResponse aResponse);
+
+ /**
+ * To be called as part of the Page's onAfterRender
+ * @param aPage Page this is called for.
+ */
+ void onAfterRender(WebPage aPage);
+}