X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=server%2Fruntime%2Forg.argeo.server.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fserver%2Fmvc%2FSerializingView.java;fp=server%2Fruntime%2Forg.argeo.server.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fserver%2Fmvc%2FSerializingView.java;h=74a3ec3469368355b6901dbbd01cd4d2be83b5df;hb=c69f105ffc363f6e425567fb705003408577162c;hp=05befd68d6d3a6919e604ce6d91e390b992bf172;hpb=bc3dd777a21dbf4d6522c46de12064f2254dfa2b;p=lgpl%2Fargeo-commons.git diff --git a/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/mvc/SerializingView.java b/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/mvc/SerializingView.java index 05befd68d..74a3ec346 100644 --- a/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/mvc/SerializingView.java +++ b/server/runtime/org.argeo.server.core/src/main/java/org/argeo/server/mvc/SerializingView.java @@ -10,13 +10,23 @@ import org.argeo.ArgeoException; import org.argeo.server.ServerAnswer; import org.argeo.server.ServerSerializer; import org.springframework.validation.BindingResult; +import org.springframework.web.servlet.View; import org.springframework.web.servlet.view.AbstractView; +/** + * Can be used as a standalone {@link View} or using + * {@link SerializingViewResolver} + */ public class SerializingView extends AbstractView implements MvcConstants { private final String viewName; private final Locale locale; - private final ServerSerializer serializer; + private ServerSerializer serializer; + + public SerializingView() { + this.viewName = null; + this.locale = Locale.getDefault(); + } public SerializingView(String viewName, Locale locale, ServerSerializer serializer) { @@ -25,7 +35,7 @@ public class SerializingView extends AbstractView implements MvcConstants { this.serializer = serializer; } - @SuppressWarnings({ "unchecked", "restriction" }) + @SuppressWarnings( { "unchecked", "restriction" }) @Override protected void renderMergedOutputModel(Map model, HttpServletRequest request, HttpServletResponse response) @@ -68,7 +78,7 @@ public class SerializingView extends AbstractView implements MvcConstants { return model.get(ANSWER_MODEL_KEY); } else if (model.containsKey(ANSWER_MODEL_KEY_AS_HTML)) { return model.get(ANSWER_MODEL_KEY_AS_HTML); - } else if (model.containsKey(viewName)) { + } else if (viewName != null && model.containsKey(viewName)) { return model.get(viewName); } else { if (model.size() == 0) @@ -87,4 +97,8 @@ public class SerializingView extends AbstractView implements MvcConstants { return locale; } + public void setSerializer(ServerSerializer serializer) { + this.serializer = serializer; + } + }