📄 loopsubcontenttransform.java
字号:
Locale locale = (Locale) templateCtx.get("locale");
if (locale == null) {
locale = Locale.getDefault();
templateCtx.put("locale", locale);
}
/*
final String editTemplate = getArg(args, "editTemplate", ctx);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, editTemplate:" + editTemplate, module);
final String wrapTemplateId = getArg(args, "wrapTemplateId", ctx);
final String mapKey = getArg(args, "mapKey", ctx);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, mapKey:" + mapKey, module);
final String templateContentId = getArg(args, "templateContentId", ctx);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, templateContentId:" + templateContentId, module);
final String subDataResourceTypeId = getArg(args, "subDataResourceTypeId", ctx);
final String contentId = getArg(args, "contentId", ctx);
final String rootDir = getArg(args, "rootDir", ctx);
final String webSiteId = getArg(args, "webSiteId", ctx);
final String https = getArg(args, "https", ctx);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, contentId:" + contentId, module);
final String viewSize = getArg(args, "viewSize", ctx);
final String viewIndex = getArg(args, "viewIndex", ctx);
final String listSize = getArg(args, "listSize", ctx);
final String highIndex = getArg(args, "highIndex", ctx);
final String lowIndex = getArg(args, "lowIndex", ctx);
final String queryString = getArg(args, "queryString", ctx);
final Locale locale = (Locale) FreeMarkerWorker.getWrappedObject("locale", env);
final String mimeTypeId = getArg(args, "mimeTypeId", ctx);
//final LocalDispatcher dispatcher = (LocalDispatcher) FreeMarkerWorker.getWrappedObject("dispatcher", env);
final GenericDelegator delegator = (GenericDelegator) FreeMarkerWorker.getWrappedObject("delegator", env);
//final GenericValue userLogin = (GenericValue) FreeMarkerWorker.getWrappedObject("userLogin", env);
ctx.put("mapKey", mapKey);
ctx.put("contentId", contentId);
ctx.put("templateContentId", templateContentId);
ctx.put("locale", locale);
//ctx.put("userLogin", userLogin);
String contentAssocTypeId = getArg(args, "contentAssocTypeId", ctx);
if (UtilValidate.isEmpty(contentAssocTypeId))
contentAssocTypeId = "SUB_CONTENT";
List assocTypes = UtilMisc.toList(contentAssocTypeId);
ctx.put("assocTypes", assocTypes);
*/
String fromDateStr = (String)templateCtx.get("fromDateStr");
Timestamp fromDate = null;
if (UtilValidate.isNotEmpty(fromDateStr)) {
fromDate = UtilDateTime.toTimestamp(fromDateStr);
}
if (fromDate == null)
fromDate = UtilDateTime.nowTimestamp();
String thisContentId = (String)templateCtx.get("contentId");
if (UtilValidate.isEmpty(thisContentId)) {
thisContentId = (String)templateCtx.get("subContentId");
}
String thisMapKey = (String)templateCtx.get("mapKey");
//GenericValue subContentDataResourceView = null;
Map results =
ContentServicesComplex.getAssocAndContentAndDataResourceMethod(delegator, thisContentId, thisMapKey, "From", fromDate, null, null, null, assocTypes, null);
List entityList = (List) results.get("entityList");
templateCtx.put("entityList", entityList);
return new LoopWriter(out) {
public void write(char cbuf[], int off, int len) {
buf.append(cbuf, off, len);
//StringBuffer ctxBuf = (StringBuffer) templateCtx.get("buf");
//ctxBuf.append(cbuf, off, len);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, buf:"+buf.toString(),module);
}
public void flush() throws IOException {
out.flush();
}
public int onStart() throws TemplateModelException, IOException {
templateCtx.put("entityIndex", new Integer(0));
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, onStart", module);
boolean inProgress = prepCtx(delegator, templateCtx);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, onStart, inProgress:" + inProgress, module);
if (inProgress) {
return TransformControl.EVALUATE_BODY;
} else {
return TransformControl.SKIP_BODY;
}
}
public int afterBody() throws TemplateModelException, IOException {
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, afterBody, start", module);
Integer idx = (Integer) templateCtx.get("entityIndex");
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, prepCtx, idx :" + idx, module);
int i = idx.intValue();
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, afterBody, i:" + i, module);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, afterBody, templateCtx.entityIndex:" + templateCtx.get("entityIndex"), module);
if (Debug.verboseOn()) Debug.logVerbose("buf:" + buf.toString(),module);
boolean inProgress = prepCtx(delegator, templateCtx);
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, afterBody, inProgress:" + inProgress + " inProgress:" + inProgress, module);
//out.write(buf.toString());
//buf.setLength(0);
if (inProgress)
return TransformControl.REPEAT_EVALUATION;
else
return TransformControl.END_EVALUATION;
}
public void close() throws IOException {
String wrappedFTL = buf.toString();
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, wrappedFTL:"+wrappedFTL,module);
String encloseWrappedText = (String)templateCtx.get("encloseWrappedText");
if (UtilValidate.isEmpty(encloseWrappedText) || encloseWrappedText.equalsIgnoreCase("false")) {
out.write(wrappedFTL);
wrappedFTL = ""; // So it won't get written again below.
}
String wrapTemplateId = (String)templateCtx.get("wrapTemplateId");
if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, wrapTemplateId:" + wrapTemplateId, module);
if (UtilValidate.isNotEmpty(wrapTemplateId)) {
templateCtx.put("wrappedFTL", wrappedFTL);
//if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, rootDir:" + rootDir, module);
Map templateRoot = FreeMarkerWorker.createEnvironmentMap(env);
/*
templateRoot.put("viewSize", viewSize);
templateRoot.put("viewIndex", viewIndex);
templateRoot.put("listSize", listSize);
templateRoot.put("highIndex", highIndex);
templateRoot.put("lowIndex", lowIndex);
templateRoot.put("queryString", queryString);
templateRoot.put("wrapMapKey", mapKey);
*/
templateRoot.put("wrapDataResourceTypeId", templateCtx.get("subDataResourceTypeId"));
templateRoot.put("wrapContentIdTo", templateCtx.get("contentId"));
templateRoot.put("wrapMimeTypeId", templateCtx.get("mimeTypeId"));
templateRoot.put("context", templateCtx);
//if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, wrapDataResourceTypeId:" + subDataResourceTypeId, module);
//if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, wrapContentIdTo:" + contentId, module);
//if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, wrapMimeTypeId:" + mimeTypeId, module);
//if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, wrapMapKey:" + mapKey,module);
//if (Debug.verboseOn()) Debug.logVerbose("in LoopSubContent, calling renderContentAsText, wrapTemplateId:" + wrapTemplateId, module);
Locale locale = (Locale) templateCtx.get("locale");
if (locale == null)
locale = Locale.getDefault();
String mimeTypeId = (String) templateCtx.get("mimeTypeId");
try {
ContentWorker.renderContentAsText(delegator, wrapTemplateId, out, templateRoot, null, locale, mimeTypeId);
} catch (GeneralException e) {
Debug.logError(e, "Error rendering content", module);
throw new IOException("Error rendering content" + e.toString());
}
} else {
if (UtilValidate.isNotEmpty(wrappedFTL))
out.write(wrappedFTL);
}
if (Debug.verboseOn()) Debug.logVerbose(FreeMarkerWorker.logMap("(L)before remove", templateCtx, 0),module);
FreeMarkerWorker.removeValues(templateCtx, removeKeyNames);
if (Debug.verboseOn()) Debug.logVerbose(FreeMarkerWorker.logMap("(L)after remove", templateCtx, 0),module);
FreeMarkerWorker.reloadValues(templateCtx, savedValues);
if (Debug.verboseOn()) Debug.logVerbose(FreeMarkerWorker.logMap("(L)after reload", templateCtx, 0),module);
}
};
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -