IDEMPIERE-5529 StackOverflowError at Quick Entry using WDateEditor (#1940)

This commit is contained in:
hengsin 2023-07-16 21:24:43 +08:00 committed by GitHub
parent 65a69ee332
commit 8034113ccc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 61 additions and 18 deletions

View File

@ -18,8 +18,10 @@
package org.adempiere.webui.editor; package org.adempiere.webui.editor;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.time.LocalDateTime;
import java.time.ZoneId; import java.time.ZoneId;
import java.util.Date; import java.util.Date;
import java.util.Objects;
import org.adempiere.webui.ValuePreference; import org.adempiere.webui.ValuePreference;
import org.adempiere.webui.component.Datebox; import org.adempiere.webui.component.Datebox;
@ -171,30 +173,43 @@ public class WDateEditor extends WEditor implements ContextMenuListener
{ {
if (value == null || value.toString().trim().length() == 0) if (value == null || value.toString().trim().length() == 0)
{ {
Timestamp currentValue = oldValue;
oldValue = null; oldValue = null;
getComponent().setValue(null); getComponent().setValue(null);
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, value); if (currentValue != null)
super.fireValueChange(changeEvent); {
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, null);
super.fireValueChange(changeEvent);
}
} }
else if (value instanceof Timestamp) else if (value instanceof Timestamp)
{ {
getComponent().setValueInLocalDateTime(((Timestamp)value).toLocalDateTime()); Timestamp currentValue = oldValue;
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, value); LocalDateTime localDateTime = ((Timestamp)value).toLocalDateTime();
super.fireValueChange(changeEvent); getComponent().setValueInLocalDateTime(localDateTime);
oldValue = (Timestamp)value; oldValue = Timestamp.valueOf(localDateTime);
if (!Objects.equals(currentValue, oldValue))
{
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, oldValue);
super.fireValueChange(changeEvent);
}
} }
else else
{ {
try try
{ {
Timestamp currentValue = oldValue;
getComponent().setText(value.toString()); getComponent().setText(value.toString());
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, value); if (getComponent().getValue() != null)
super.fireValueChange(changeEvent); oldValue = Timestamp.valueOf(getComponent().getValue().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime());
else
oldValue = null;
if (!Objects.equals(currentValue, oldValue))
{
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, oldValue);
super.fireValueChange(changeEvent);
}
} catch (Exception e) {} } catch (Exception e) {}
if (getComponent().getValue() != null)
oldValue = Timestamp.valueOf(getComponent().getValue().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime());
else
oldValue = null;
} }
} }

View File

@ -36,6 +36,8 @@ import org.compiere.util.Util;
import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events; import org.zkoss.zk.ui.event.Events;
import com.google.common.base.Objects;
/** /**
* Default editor for {@link DisplayType#DateTime} and {@link DisplayType#TimestampWithTimeZone}. * Default editor for {@link DisplayType#DateTime} and {@link DisplayType#TimestampWithTimeZone}.
* Implemented with {@link DatetimeBox} component. * Implemented with {@link DatetimeBox} component.
@ -215,30 +217,46 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
{ {
if (value == null || value.toString().trim().length() == 0) if (value == null || value.toString().trim().length() == 0)
{ {
Timestamp currentValue = oldValue;
oldValue = null; oldValue = null;
getComponent().setValue(null); getComponent().setValue(null);
if (currentValue != null)
{
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, null);
super.fireValueChange(changeEvent);
}
} }
else if (value instanceof Timestamp) else if (value instanceof Timestamp)
{ {
Timestamp ts = (Timestamp) value; Timestamp ts = (Timestamp) value;
if (isTimestampWithTimeZone()) if (isTimestampWithTimeZone())
{ {
Timestamp currentValue = oldValue;
ZonedDateTime zdt = ts.toInstant().atZone(getComponent().getDatebox().getTimeZone().toZoneId()); ZonedDateTime zdt = ts.toInstant().atZone(getComponent().getDatebox().getTimeZone().toZoneId());
getComponent().setValueInZonedDateTime(zdt); getComponent().setValueInZonedDateTime(zdt);
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, value); oldValue = Timestamp.from(zdt.toInstant());
super.fireValueChange(changeEvent); if (!Objects.equal(currentValue, oldValue))
{
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, oldValue);
super.fireValueChange(changeEvent);
}
} }
else else
{ {
Timestamp currentValue = oldValue;
LocalDateTime localTime = ts.toLocalDateTime(); LocalDateTime localTime = ts.toLocalDateTime();
getComponent().setValueInLocalDateTime(localTime); getComponent().setValueInLocalDateTime(localTime);
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), oldValue, value); oldValue = Timestamp.valueOf(localTime);
super.fireValueChange(changeEvent); if (!Objects.equal(currentValue, oldValue))
{
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, oldValue);
super.fireValueChange(changeEvent);
}
} }
oldValue = ts;
} }
else else
{ {
Timestamp currentValue = oldValue;
try try
{ {
getComponent().setText(value.toString()); getComponent().setText(value.toString());
@ -249,10 +267,20 @@ public class WDatetimeEditor extends WEditor implements ContextMenuListener
oldValue = Timestamp.from(getComponent().getDatebox().getValue().toInstant()); oldValue = Timestamp.from(getComponent().getDatebox().getValue().toInstant());
else else
oldValue = Timestamp.valueOf(getComponent().getDatebox().getValue().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime()); oldValue = Timestamp.valueOf(getComponent().getDatebox().getValue().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime());
if (!Objects.equal(currentValue, oldValue))
{
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, oldValue);
super.fireValueChange(changeEvent);
}
} }
else else
{ {
oldValue = null; oldValue = null;
if (currentValue != null)
{
ValueChangeEvent changeEvent = new ValueChangeEvent(this, this.getColumnName(), currentValue, null);
super.fireValueChange(changeEvent);
}
} }
} }
} }