📄 rendersubcontenttransform.java
字号:
/*
* $Id: RenderSubContentTransform.java,v 1.5 2003/12/23 07:24:05 jonesde Exp $
*
* Copyright (c) 2001-2003 The Open For Business Project - www.ofbiz.org
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
*/
package org.ofbiz.content.webapp.ftl;
import java.io.IOException;
import java.io.Writer;
import java.sql.Timestamp;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import org.ofbiz.base.util.Debug;
import org.ofbiz.base.util.GeneralException;
import org.ofbiz.base.util.UtilDateTime;
import org.ofbiz.base.util.UtilMisc;
import org.ofbiz.content.content.ContentWorker;
import org.ofbiz.entity.GenericDelegator;
import org.ofbiz.entity.GenericValue;
import freemarker.template.Environment;
import freemarker.template.SimpleHash;
import freemarker.template.TemplateHashModel;
import freemarker.template.TemplateTransformModel;
/**
* RenderSubContentTransform - Freemarker Transform for Content rendering
*
* @author <a href="mailto:byersa@automationgroups.com">Al Byers</a>
* @version $Revision: 1.5 $
* @since 3.0
*
* This transform cannot be called recursively (at this time).
*/
public class RenderSubContentTransform implements TemplateTransformModel {
public static final String module = RenderSubContentTransform.class.getName();
/**
* Does a conditional search to return a value for a parameter with the passed name. Looks first to see if it was passed as an argument to the transform.
* Secondly, it looks to see if it is passed as a parameter in the template context object.
* <p>
* Note that this is different from the getArg method of EditRenderDataResourceTransform, which checks the request object instead of the template context
* object.
*/
public static String getArg(Map args, String key, Environment env) {
return FreeMarkerWorker.getArg(args, key, env);
}
public static String getArg(Map args, String key, Map ctx) {
return FreeMarkerWorker.getArg(args, key, ctx);
}
public Writer getWriter(final Writer out, Map args) {
//final StringBuffer buf = new StringBuffer();
final Environment env = Environment.getCurrentEnvironment();
Map ctx = (Map) FreeMarkerWorker.getWrappedObject("context", env);
if (ctx == null) {
ctx = new HashMap();
}
final String mapKey = getArg(args, "mapKey", ctx);
final String subContentId = getArg(args, "subContentId", ctx);
final String subDataResourceTypeId = getArg(args, "subDataResourceTypeId", ctx);
final String contentId = getArg(args, "contentId", ctx);
final String mimeTypeId = getArg(args, "mimeTypeId", ctx);
final Locale locale = (Locale) FreeMarkerWorker.getWrappedObject("locale", env);
final HttpServletRequest request = (HttpServletRequest) FreeMarkerWorker.getWrappedObject("request", env);
final GenericDelegator delegator = (GenericDelegator) FreeMarkerWorker.getWrappedObject("delegator", env);
final GenericValue userLogin = (GenericValue) FreeMarkerWorker.getWrappedObject("userLogin", env);
GenericValue subContentDataResourceViewTemp = (GenericValue) FreeMarkerWorker.getWrappedObject("subContentDataResourceView", env);
if (subContentDataResourceViewTemp == null) {
List assocTypes = UtilMisc.toList("SUB_CONTENT");
Timestamp fromDate = UtilDateTime.nowTimestamp();
try {
subContentDataResourceViewTemp = ContentWorker.getSubContent(delegator, contentId, mapKey, subContentId, userLogin, assocTypes, fromDate);
} catch (IOException e) {
throw new RuntimeException(e.getMessage());
}
}
final GenericValue subContentDataResourceView = subContentDataResourceViewTemp;
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, start.", module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, mapKey:" + mapKey, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, subContentId:" + subContentId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, subDataResourceTypeId:" + subDataResourceTypeId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, contentId:" + contentId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, mimeTypeId:" + mimeTypeId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, locale:" + locale, module);
final Map templateContext = ctx;
return new Writer(out) {
public void write(char cbuf[], int off, int len) {
}
public void flush() throws IOException {
out.flush();
}
public void close() throws IOException {
try {
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, close:", module);
renderSubContent();
} catch (IOException e) {
throw new IOException(e.getMessage());
}
}
public void renderSubContent() throws IOException {
//TemplateHashModel dataRoot = env.getDataModel();
Timestamp fromDate = UtilDateTime.nowTimestamp();
ServletContext servletContext = request.getSession().getServletContext();
String rootDir = servletContext.getRealPath("/");
String webSiteId = (String) servletContext.getAttribute("webSiteId");
String https = (String) servletContext.getAttribute("https");
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, rootDir:" + rootDir, module);
templateContext.put("webSiteId", webSiteId);
templateContext.put("https", https);
templateContext.put("rootDir", rootDir);
Map templateRoot = FreeMarkerWorker.createEnvironmentMap(env);
templateRoot.put("context", templateContext);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, calling renderSubCasT:" + " contentId:" + contentId + " mapKey:" + mapKey + " subContentId:" + subContentId, module);
if (subContentDataResourceView != null) {
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, " + " subContentDataResourceView:" + subContentDataResourceView.get("contentId")
+ " / " + subContentDataResourceView.get("drDataResourceId"), module);
}
try {
Map results = ContentWorker.renderSubContentAsText(delegator, contentId, out, mapKey, subContentId, subContentDataResourceView, templateRoot, locale, mimeTypeId, userLogin, fromDate);
} catch (GeneralException e) {
Debug.logError(e, "Error rendering content", module);
throw new IOException("Error rendering content" + e.toString());
}
Map resultCtx = (Map) FreeMarkerWorker.getWrappedObject("context", env);
templateContext.put("mapKey", null);
templateContext.put("subContentId", null);
templateContext.put("subDataResourceTypeId", null);
templateContext.put("contentId", contentId);
templateContext.put("mimeTypeId", null);
templateContext.put("locale", locale);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, contentId." + resultCtx.get("contentId"), module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, after.", module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, mapKey:" + mapKey, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, subContentId:" + subContentId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, subDataResourceTypeId:" + subDataResourceTypeId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, contentId:" + contentId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, mimeTypeId:" + mimeTypeId, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, locale:" + locale, module);
if (Debug.verboseOn()) Debug.logVerbose("in RenderSubContent, contentId2." + resultCtx.get("contentId"), module);
return;
}
};
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -