You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@isis.apache.org by "ASF subversion and git services (JIRA)" <ji...@apache.org> on 2014/10/09 19:50:34 UTC
[jira] [Commented] (ISIS-852) Derived property cannot be written
properly
[ https://issues.apache.org/jira/browse/ISIS-852?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14165427#comment-14165427 ]
ASF subversion and git services commented on ISIS-852:
------------------------------------------------------
Commit 1b10065e7fefc591e7e510ecb7a5ea6dba17f485 in isis's branch refs/heads/master from [~danhaywood]
[ https://git-wip-us.apache.org/repos/asf?p=isis.git;h=1b10065 ]
ISIS-852: updateable derived properties that have just a getter and a modifyXxx() method.
> Derived property cannot be written properly
> -------------------------------------------
>
> Key: ISIS-852
> URL: https://issues.apache.org/jira/browse/ISIS-852
> Project: Isis
> Issue Type: Bug
> Components: Viewer: Wicket
> Affects Versions: viewer-wicket-1.6.0
> Reporter: Thomas Koren
> Assignee: Dan Haywood
> Fix For: core-1.7.0
>
>
> when using the proposed modifyXxx syntax to make a derived property writable, it is rendered as "disabled" in wicket viewer.
> {code:title=demo|borderStyle=solid}
> public LocalDate getDerivedDate() { ... }
> public void modifyDerivedDate(final LocalDate date) { ... }
> {code}
> when using the alternative setXxx syntax, the UI component is writable. but in this case, the value of the derived property is not written to the persisted property.
> {code:title=demo|borderStyle=solid}
> // {{ BeginAt (property)
> @javax.jdo.annotations.Persistent
> private DateTime beginAt;
> @Disabled
> @javax.jdo.annotations.Column(allowsNull = "false")
> public DateTime getBeginAt() {
> return beginAt;
> }
> public void setBeginAt(final DateTime beginAt) {
> this.beginAt = beginAt;
> }
> // }}
> // {{ DerivedDate (property)
> @NotPersisted
> @NotPersistent
> public LocalDate getDerivedDate() {
> return getBeginAt().toLocalDate();
> }
> public void setDerivedDate(final LocalDate beginDate) {
> setBeginAt(getBeginAt().withDate(beginDate.getYear(), beginDate.getMonthOfYear(), beginDate.getDayOfMonth()));
> }
> // }}
> {code}
> it seems like the value set by the derived property gets overwritten by the original/old value of the persisted property that is displayed in the wicket component.
> therefore it might only be an issue, if original and derived properties are members of the same entity and displayed via wicket viewer.
> some background:
> i try to use 3 ui components (= derived properties: date, hour, minute) to set a single persisted DateTime property.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)