X-Git-Url: https://git.argeo.org/?p=gpl%2Fargeo-suite.git;a=blobdiff_plain;f=core%2Forg.argeo.entity.ui%2Fsrc%2Forg%2Fargeo%2Fentity%2Fui%2Fforms%2FSingleTermPart.java;h=0dcf13d128c5e43659ceeff3950336d126dc500a;hp=e9fad048f5aeabf7962c37d109b191fd3acdfda6;hb=d583547f3046d1e0d9a1dc689abe71dcd1decfb7;hpb=475324c72691c723253f2f0edd7a411a101c04ae diff --git a/core/org.argeo.entity.ui/src/org/argeo/entity/ui/forms/SingleTermPart.java b/core/org.argeo.entity.ui/src/org/argeo/entity/ui/forms/SingleTermPart.java index e9fad04..0dcf13d 100644 --- a/core/org.argeo.entity.ui/src/org/argeo/entity/ui/forms/SingleTermPart.java +++ b/core/org.argeo.entity.ui/src/org/argeo/entity/ui/forms/SingleTermPart.java @@ -11,6 +11,7 @@ import org.argeo.cms.ui.widgets.ContextOverlay; import org.argeo.eclipse.ui.MouseDoubleClick; import org.argeo.eclipse.ui.MouseDown; import org.argeo.eclipse.ui.Selected; +import org.argeo.entity.Term; import org.argeo.entity.TermsManager; import org.argeo.jcr.Jcr; import org.eclipse.swt.SWT; @@ -47,8 +48,7 @@ public class SingleTermPart extends AbstractTermsPart { ToolItem deleteItem = new ToolItem(toolBar, SWT.PUSH); styleDelete(deleteItem); deleteItem.addSelectionListener((Selected) (e) -> { - Jcr.set(getNode(), typology, null); - Jcr.save(getNode()); + setValue(null); stopEditing(); }); ToolItem cancelItem = new ToolItem(toolBar, SWT.PUSH); @@ -95,7 +95,7 @@ public class SingleTermPart extends AbstractTermsPart { } else { Composite block = new Composite(box, SWT.NONE); block.setLayout(CmsUiUtils.noSpaceGridLayout(2)); - String currentValue = Jcr.get(getNode(), typology); + Term currentValue = getValue(); if (currentValue != null) { Label lbl = new Label(block, SWT.SINGLE); String display = getTermLabel(currentValue); @@ -120,8 +120,8 @@ public class SingleTermPart extends AbstractTermsPart { @Override protected void refresh(ContextOverlay contextArea, String filter, Text txt) { CmsUiUtils.clear(contextArea); - List terms = termsManager.listAllTerms(typology); - terms: for (String term : terms) { + List terms = termsManager.listAllTerms(typology.getId()); + terms: for (Term term : terms) { String display = getTermLabel(term); if (filter != null && !display.toLowerCase().contains(filter)) continue terms; @@ -130,8 +130,7 @@ public class SingleTermPart extends AbstractTermsPart { processTermListLabel(term, termL); if (isTermSelectable(term)) termL.addMouseListener((MouseDown) (e) -> { - Jcr.set(getNode(), typology, term); - Jcr.save(getNode()); + setValue(term); contextArea.hide(); stopEditing(); }); @@ -140,4 +139,17 @@ public class SingleTermPart extends AbstractTermsPart { // txt.setFocus(); } + protected Term getValue() { + String property = typology.getId(); + String id = Jcr.get(getNode(), property); + Term term = termsManager.getTerm(id); + + return term; + } + + protected void setValue(Term value) { + String property = typology.getId(); + Jcr.set(getNode(), property, value != null ? value.getId() : null); + Jcr.save(getNode()); + } }