IDEMPIERE-2317 Translation in AlertProcessor

This commit is contained in:
Nicolas Micoud 2014-12-17 08:50:58 -05:00
parent 4e2e14b825
commit fdc99703c0
1 changed files with 17 additions and 10 deletions

View File

@ -41,6 +41,7 @@ import org.compiere.util.CLogger;
import org.compiere.util.DB; import org.compiere.util.DB;
import org.compiere.util.DisplayType; import org.compiere.util.DisplayType;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Language;
import org.compiere.util.Msg; import org.compiere.util.Msg;
import org.compiere.util.TimeUtil; import org.compiere.util.TimeUtil;
import org.compiere.util.Trx; import org.compiere.util.Trx;
@ -93,7 +94,13 @@ public class AlertProcessor extends AdempiereServer
MAlert[] alerts = m_model.getAlerts(false); MAlert[] alerts = m_model.getAlerts(false);
for (int i = 0; i < alerts.length; i++) for (int i = 0; i < alerts.length; i++)
{ {
if (!processAlert(alerts[i])) Language language = Env.getLanguage(getCtx());
// Try to get the language of the client's alert
MClient client = MClient.get(getCtx(), alerts[i].getAD_Client_ID());
if (client.getLanguage() != null)
language = client.getLanguage();
if (!processAlert(alerts[i], language))
countError++; countError++;
count++; count++;
} }
@ -119,7 +126,7 @@ public class AlertProcessor extends AdempiereServer
* @param alert alert * @param alert alert
* @return true if processed * @return true if processed
*/ */
protected boolean processAlert (MAlert alert) protected boolean processAlert (MAlert alert, Language language)
{ {
if (!alert.isValid()) if (!alert.isValid())
return false; return false;
@ -164,8 +171,8 @@ public class AlertProcessor extends AdempiereServer
try try
{ {
String text = null; String text = null;
if (MSysConfig.getBooleanValue(MSysConfig.ALERT_SEND_ATTACHMENT_AS_XLS, true, Env.getAD_Client_ID(getCtx()))) if (MSysConfig.getBooleanValue(MSysConfig.ALERT_SEND_ATTACHMENT_AS_XLS, true, alert.getAD_Client_ID()))
text = getExcelReport(rule, sql, null, attachments); text = getExcelReport(rule, sql, language, null, attachments);
else else
text = getPlainTextReport(rule, sql, null, attachments); text = getPlainTextReport(rule, sql, null, attachments);
if (text != null && text.length() > 0) if (text != null && text.length() > 0)
@ -220,9 +227,9 @@ public class AlertProcessor extends AdempiereServer
// //
// Report footer - Date Generated // Report footer - Date Generated
DateFormat df = DisplayType.getDateFormat(DisplayType.DateTime); DateFormat df = DisplayType.getDateFormat(DisplayType.DateTime, language);
message.append("\n\n"); message.append("\n\n");
message.append(Msg.translate(getCtx(), "Date")).append(" : ") message.append(Msg.translate(language, "Date")).append(" : ")
.append(df.format(new Timestamp(System.currentTimeMillis()))); .append(df.format(new Timestamp(System.currentTimeMillis())));
Collection<Integer> users = alert.getRecipientUsers(); Collection<Integer> users = alert.getRecipientUsers();
@ -408,7 +415,7 @@ public class AlertProcessor extends AdempiereServer
* @return summary message to be added into mail content * @return summary message to be added into mail content
* @throws Exception * @throws Exception
*/ */
protected String getExcelReport(MAlertRule rule, String sql, String trxName, Collection<File> attachments) protected String getExcelReport(MAlertRule rule, String sql, Language language, String trxName, Collection<File> attachments)
throws Exception throws Exception
{ {
ArrayList<ArrayList<Object>> data = getData(sql, trxName); ArrayList<ArrayList<Object>> data = getData(sql, trxName);
@ -418,10 +425,10 @@ public class AlertProcessor extends AdempiereServer
File file = rule.createReportFile("xls"); File file = rule.createReportFile("xls");
// //
ArrayExcelExporter exporter = new ArrayExcelExporter(getCtx(), data); ArrayExcelExporter exporter = new ArrayExcelExporter(getCtx(), data);
exporter.export(file, null, false); exporter.export(file, language, false);
attachments.add(file); attachments.add(file);
String msg = rule.getName() + " (@SeeAttachment@ "+file.getName()+")"+Env.NL; String msg = rule.getName() + " (" + Msg.translate(language, "SeeAttachment") + " " + file.getName() + ")" + Env.NL;
return Msg.parseTranslation(Env.getCtx(), msg); return msg;
} }
/** /**