Tutti-commits
Threads by month
- ----- 2026 -----
- June
- May
- April
- March
- February
- January
- ----- 2025 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2024 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2023 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2022 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2021 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2020 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2019 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2018 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2017 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2016 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2015 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2014 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2013 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2012 -----
- December
- November
- 4058 discussions
r79 - trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence
by tchemit@users.forge.codelutin.com 17 Dec '12
by tchemit@users.forge.codelutin.com 17 Dec '12
17 Dec '12
Author: tchemit
Date: 2012-12-17 08:32:05 +0100 (Mon, 17 Dec 2012)
New Revision: 79
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/79
Log:
remove too hard test for the moment on entity removal
Modified:
trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java
Modified: trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java
===================================================================
--- trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java 2012-12-15 16:15:44 UTC (rev 78)
+++ trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java 2012-12-17 07:32:05 UTC (rev 79)
@@ -769,7 +769,13 @@
protected <B extends IdAware> void remove(Class<B> type, String id) {
Preconditions.checkNotNull(id, "Can't delete a null id");
B bean = getBean(type, id);
- Preconditions.checkNotNull(bean, "Can't delete a null bean");
+ //FIXME tchemit Should never happen!
+ if (bean == null) {
+ if (log.isWarnEnabled()) {
+ log.warn("No bean with id: " + id);
+ }
+ }
+// Preconditions.checkNotNull(bean, "Can't delete a null bean");
cache.remove(type, bean);
persistToFile(type);
}
1
0
15 Dec '12
Author: tchemit
Date: 2012-12-15 17:15:44 +0100 (Sat, 15 Dec 2012)
New Revision: 78
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/78
Log:
optimize i18n
Modified:
trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
Modified: trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
===================================================================
--- trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-15 16:05:45 UTC (rev 77)
+++ trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-15 16:15:44 UTC (rev 78)
@@ -163,8 +163,6 @@
tutti.table.macrowaste.batch.header.comment=Commentaire
tutti.table.macrowaste.batch.header.file=Pièces jointes
tutti.table.macrowaste.batch.header.macroWasteCategory=Catégorie
-tutti.table.macrowaste.batch.header.speciesByCode=Espèce
-tutti.table.macrowaste.batch.header.speciesByGenusCode=Espèce
tutti.table.macrowaste.batch.header.weight=Poids
tutti.table.plankton.batch.header.comment=Commentaire
tutti.table.plankton.batch.header.elevationRate=Fraction d'élévation
@@ -207,7 +205,6 @@
tutti.title.selectedCruise=Campagne %s
tutti.title.selectedProgram=Série de campagne %s
tutti.to.be.done=< A FAIRE >
-tutti.tooltip.=
tutti.tooltip.attachment.none=Pas de pièce-jointes
tutti.tooltip.comment.none=Pas de commentaire
tutti.validator.error.cruise.beginDate.required=La date de début est obligatoire
1
0
15 Dec '12
Author: tchemit
Date: 2012-12-15 17:05:45 +0100 (Sat, 15 Dec 2012)
New Revision: 77
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/77
Log:
add new entities (macroWasteCategory, SortedUnsortedCategory)
improve batch handler design
add filter on batch tables
improve longtext editor
improve attachment editor
Added:
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/AbstractTuttiBatchTableUIHandler.java
trunk/tutti-ui-swing/src/main/resources/icons/action-edit-attachment.png
trunk/tutti-ui-swing/src/main/resources/icons/action-edit-comment.png
Modified:
trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java
trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevFixtures.java
trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java
trunk/tutti-persistence/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistence.java
trunk/tutti-persistence/src/main/resources/META-INF/services/fr.ifremer.tutti.persistence.entities.IdAware
trunk/tutti-persistence/src/main/xmi/tutti-persistence.zargo
trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/DecoratorService.java
trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/PersistenceService.java
trunk/tutti-service/src/main/resources/i18n/tutti-service_fr_FR.properties
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/AbstractTuttiUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchRowModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchTableModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUI.jaxx
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchRowModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchTableModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUI.jaxx
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchRowModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchTableModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUI.jaxx
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchRowModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchTableModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUI.jaxx
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchRowModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTableModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTreeModel.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUI.jaxx
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.jaxx
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/table/AbstractTuttiTableUIHandler.java
trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
Modified: trunk/tutti-persistence/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistence.java
===================================================================
--- trunk/tutti-persistence/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistence.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-persistence/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistence.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -36,9 +36,11 @@
import fr.ifremer.tutti.persistence.entities.referential.BeaufortScale;
import fr.ifremer.tutti.persistence.entities.referential.Country;
import fr.ifremer.tutti.persistence.entities.referential.Gear;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
import fr.ifremer.tutti.persistence.entities.referential.Person;
import fr.ifremer.tutti.persistence.entities.referential.SeaState;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.referential.Vessel;
@@ -72,6 +74,8 @@
//-- Referential methods --//
//------------------------------------------------------------------------//
+ List<SortedUnsortedCategory> getAllSortedUnsortedCategory();
+
List<WeightCategory> getAllWeightCategory();
List<Sex> getAllSex();
@@ -94,6 +98,8 @@
List<Person> getAllPerson();
+ List<MacroWasteCategory> getAllMacroWasteCategory();
+
//------------------------------------------------------------------------//
//-- Program methods --//
//------------------------------------------------------------------------//
Modified: trunk/tutti-persistence/src/main/resources/META-INF/services/fr.ifremer.tutti.persistence.entities.IdAware
===================================================================
--- trunk/tutti-persistence/src/main/resources/META-INF/services/fr.ifremer.tutti.persistence.entities.IdAware 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-persistence/src/main/resources/META-INF/services/fr.ifremer.tutti.persistence.entities.IdAware 2012-12-15 16:05:45 UTC (rev 77)
@@ -1,3 +1,4 @@
+fr.ifremer.tutti.persistence.entities.data.Attachment
fr.ifremer.tutti.persistence.entities.data.AccidentalBatch
fr.ifremer.tutti.persistence.entities.data.BenthosBatch
fr.ifremer.tutti.persistence.entities.data.FishingOperation
@@ -10,9 +11,11 @@
fr.ifremer.tutti.persistence.entities.referential.BeaufortScale
fr.ifremer.tutti.persistence.entities.referential.Country
fr.ifremer.tutti.persistence.entities.referential.Gear
+fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory
fr.ifremer.tutti.persistence.entities.referential.Person
fr.ifremer.tutti.persistence.entities.referential.SeaState
fr.ifremer.tutti.persistence.entities.referential.Sex
+fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory
fr.ifremer.tutti.persistence.entities.referential.Species
fr.ifremer.tutti.persistence.entities.referential.Strata
fr.ifremer.tutti.persistence.entities.referential.Vessel
Modified: trunk/tutti-persistence/src/main/xmi/tutti-persistence.zargo
===================================================================
(Binary files differ)
Modified: trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java
===================================================================
--- trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -36,9 +36,11 @@
import fr.ifremer.tutti.persistence.entities.referential.BeaufortScale;
import fr.ifremer.tutti.persistence.entities.referential.Country;
import fr.ifremer.tutti.persistence.entities.referential.Gear;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
import fr.ifremer.tutti.persistence.entities.referential.Person;
import fr.ifremer.tutti.persistence.entities.referential.SeaState;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.referential.Vessel;
@@ -69,6 +71,11 @@
}
@Override
+ public List<SortedUnsortedCategory> getAllSortedUnsortedCategory() {
+ return null;
+ }
+
+ @Override
public List<WeightCategory> getAllWeightCategory() {
return null;
}
@@ -124,6 +131,11 @@
}
@Override
+ public List<MacroWasteCategory> getAllMacroWasteCategory() {
+ return null;
+ }
+
+ @Override
public List<Program> getAllProgram() {
return null;
}
Modified: trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevFixtures.java
===================================================================
--- trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevFixtures.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevFixtures.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -26,14 +26,16 @@
import com.google.common.collect.ArrayListMultimap;
import fr.ifremer.tutti.persistence.entities.IdAware;
-import fr.ifremer.tutti.persistence.entities.referential.Person;
-import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.referential.BeaufortScale;
import fr.ifremer.tutti.persistence.entities.referential.Country;
import fr.ifremer.tutti.persistence.entities.referential.Gear;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
+import fr.ifremer.tutti.persistence.entities.referential.Person;
import fr.ifremer.tutti.persistence.entities.referential.SeaState;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
+import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.referential.Vessel;
import fr.ifremer.tutti.persistence.entities.referential.WeightCategory;
import fr.ifremer.tutti.persistence.entities.referential.Zone;
@@ -257,6 +259,39 @@
wc.setName("Gros");
cache.put(WeightCategory.class, wc);
+ SortedUnsortedCategory suc;
+
+ suc = new SortedUnsortedCategory();
+ suc.setId(UUID.randomUUID().toString());
+ suc.setName("Vrac");
+ cache.put(SortedUnsortedCategory.class, suc);
+
+ suc = new SortedUnsortedCategory();
+ suc.setId(UUID.randomUUID().toString());
+ suc.setName("Hors Vrac");
+ cache.put(SortedUnsortedCategory.class, suc);
+
+ MacroWasteCategory mwc;
+
+ mwc = new MacroWasteCategory();
+ mwc.setId(UUID.randomUUID().toString());
+ mwc.setName("Pneu");
+ cache.put(MacroWasteCategory.class, mwc);
+
+ mwc = new MacroWasteCategory();
+ mwc.setId(UUID.randomUUID().toString());
+ mwc.setName("Plastique");
+ cache.put(MacroWasteCategory.class, mwc);
+
+ mwc = new MacroWasteCategory();
+ mwc.setId(UUID.randomUUID().toString());
+ mwc.setName("Machine à laver");
+ cache.put(MacroWasteCategory.class, mwc);
+
+ mwc = new MacroWasteCategory();
+ mwc.setId(UUID.randomUUID().toString());
+ mwc.setName("Métal");
+ cache.put(MacroWasteCategory.class, mwc);
}
public List<Zone> zone() {
@@ -304,7 +339,15 @@
return getData(WeightCategory.class);
}
- protected <B extends IdAware> List<B> getData(Class<B> entityType) {
+ public List<SortedUnsortedCategory> sortedUnsortedCategory() {
+ return getData(SortedUnsortedCategory.class);
+ }
+
+ public List<MacroWasteCategory> macroWasteCategory() {
+ return getData(MacroWasteCategory.class);
+ }
+
+ public <B extends IdAware> List<B> getData(Class<B> entityType) {
List<B> result = (List<B>) cache.get(entityType);
return result;
}
Modified: trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java
===================================================================
--- trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-persistence-dev/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceDevImpl.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -48,9 +48,11 @@
import fr.ifremer.tutti.persistence.entities.referential.BeaufortScale;
import fr.ifremer.tutti.persistence.entities.referential.Country;
import fr.ifremer.tutti.persistence.entities.referential.Gear;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
import fr.ifremer.tutti.persistence.entities.referential.Person;
import fr.ifremer.tutti.persistence.entities.referential.SeaState;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.referential.Vessel;
@@ -171,6 +173,13 @@
//------------------------------------------------------------------------//
@Override
+ public List<SortedUnsortedCategory> getAllSortedUnsortedCategory() {
+ List<SortedUnsortedCategory> result =
+ getDataInNewList(SortedUnsortedCategory.class);
+ return result;
+ }
+
+ @Override
public List<WeightCategory> getAllWeightCategory() {
List<WeightCategory> result =
getDataInNewList(WeightCategory.class);
@@ -220,6 +229,13 @@
}
@Override
+ public List<MacroWasteCategory> getAllMacroWasteCategory() {
+ List<MacroWasteCategory> result =
+ getDataInNewList(MacroWasteCategory.class);
+ return result;
+ }
+
+ @Override
public List<SeaState> getAllSeaState() {
List<SeaState> result = getDataInNewList(SeaState.class);
return result;
Modified: trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/DecoratorService.java
===================================================================
--- trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/DecoratorService.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/DecoratorService.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -24,17 +24,20 @@
* #L%
*/
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.Cruise;
import fr.ifremer.tutti.persistence.entities.data.FishingOperation;
-import fr.ifremer.tutti.persistence.entities.referential.Person;
-import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.data.Program;
import fr.ifremer.tutti.persistence.entities.referential.BeaufortScale;
import fr.ifremer.tutti.persistence.entities.referential.Country;
import fr.ifremer.tutti.persistence.entities.referential.Gear;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
+import fr.ifremer.tutti.persistence.entities.referential.Person;
import fr.ifremer.tutti.persistence.entities.referential.SeaState;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
+import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.referential.Vessel;
import fr.ifremer.tutti.persistence.entities.referential.WeightCategory;
import fr.ifremer.tutti.persistence.entities.referential.Zone;
@@ -57,6 +60,8 @@
public static final String BY_NAME = "byName";
+ public static final String SEPARATOR = "#";
+
/** Delegate decorator provider. */
protected DecoratorProvider decoratorProvider;
@@ -84,23 +89,26 @@
@Override
protected void loadDecorators() {
- registerMultiJXPathDecorator(Program.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(Cruise.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(FishingOperation.class, "${stationNumber}$s#${fishingOperationNumber}$s#${date}$td/%3$tm/%3$tY", "#", " - ");
- registerMultiJXPathDecorator(Zone.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(Vessel.class, "${name}$s#", "#", " - ");
- registerMultiJXPathDecorator(Country.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(Gear.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(Person.class, "${firstName}$s#${lastName}$s", "#", " ");
- registerMultiJXPathDecorator(BeaufortScale.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(SeaState.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(Strata.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(Sex.class, "${name}$s", "#", " - ");
- registerMultiJXPathDecorator(Species.class, "${codeMemo}#${genusSpecies}$s", "#", " - ");
- registerJXPathDecorator(Species.class, SPECIES_BY_CODE, "${codeMemo}$s");
- registerJXPathDecorator(Species.class, SPECIES_BY_GENUS, "${genusSpecies}$s");
- registerJXPathDecorator(WeightCategory.class, BY_NAME, "${name}$s");
- registerJXPathDecorator(Sex.class, BY_NAME, "${name}$s");
+ registerMultiJXPathDecorator(Program.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Cruise.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(FishingOperation.class, "${stationNumber}$s#${fishingOperationNumber}$s#${date}$td/%3$tm/%3$tY", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Zone.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Vessel.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Country.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Gear.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Person.class, "${firstName}$s#${lastName}$s", SEPARATOR, " ");
+ registerMultiJXPathDecorator(BeaufortScale.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(SeaState.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Strata.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Sex.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(SortedUnsortedCategory.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(MacroWasteCategory.class, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Species.class, "${codeMemo}$s#${genusSpecies}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Species.class, SPECIES_BY_CODE, "${codeMemo}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Species.class, SPECIES_BY_GENUS, "${genusSpecies}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(WeightCategory.class, BY_NAME, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Sex.class, BY_NAME, "${name}$s", SEPARATOR, " - ");
+ registerMultiJXPathDecorator(Attachment.class, "${name}$s", SEPARATOR, " - ");
}
};
}
@@ -124,6 +132,9 @@
n_("tutti.property.strata");
n_("tutti.property.codeMemo");
n_("tutti.property.genusSpecies");
+ n_("tutti.property.sortedUnsortedCategory");
+ n_("tutti.property.macroWasteCategory");
+ n_("tutti.property.attachment");
}
}
Modified: trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/PersistenceService.java
===================================================================
--- trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/PersistenceService.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-service/src/main/java/fr/ifremer/tutti/service/PersistenceService.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -38,9 +38,11 @@
import fr.ifremer.tutti.persistence.entities.referential.BeaufortScale;
import fr.ifremer.tutti.persistence.entities.referential.Country;
import fr.ifremer.tutti.persistence.entities.referential.Gear;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
import fr.ifremer.tutti.persistence.entities.referential.Person;
import fr.ifremer.tutti.persistence.entities.referential.SeaState;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.persistence.entities.referential.Strata;
import fr.ifremer.tutti.persistence.entities.referential.Vessel;
@@ -133,6 +135,12 @@
//------------------------------------------------------------------------//
@Override
+ public List<SortedUnsortedCategory> getAllSortedUnsortedCategory() {
+ checkDriverExists();
+ return driver.getAllSortedUnsortedCategory();
+ }
+
+ @Override
public List<WeightCategory> getAllWeightCategory() {
checkDriverExists();
return driver.getAllWeightCategory();
@@ -181,6 +189,12 @@
}
@Override
+ public List<MacroWasteCategory> getAllMacroWasteCategory() {
+ checkDriverExists();
+ return driver.getAllMacroWasteCategory();
+ }
+
+ @Override
public List<SeaState> getAllSeaState() {
checkDriverExists();
return driver.getAllSeaState();
Modified: trunk/tutti-service/src/main/resources/i18n/tutti-service_fr_FR.properties
===================================================================
--- trunk/tutti-service/src/main/resources/i18n/tutti-service_fr_FR.properties 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-service/src/main/resources/i18n/tutti-service_fr_FR.properties 2012-12-15 16:05:45 UTC (rev 77)
@@ -3,6 +3,7 @@
tutti.config.data.directory=Répertoire de données de l'application. Vous pouvez utiliser l'expression ${tutti.data.directory} pour le référence dans d'autres propriétés de configuration (ex\: ${tutti.data.directory}/tmp).
tutti.config.license.organizationName=Nom de l'organisation dans la licence
tutti.config.tmp.directory=Répertoire temporaire utilisée par l'application (est nettoyé à chaque démarrage de l'application)
+tutti.property.attachment=Pièce jointe
tutti.property.beaufortScale=Vent beaufort
tutti.property.codeMemo=Code Memo
tutti.property.country=Pays
@@ -13,9 +14,11 @@
tutti.property.gear=Engin
tutti.property.genusSpecies=Nom scientifique
tutti.property.lastName=Nom de Famille
+tutti.property.macroWasteCategory=Type de macro déchet
tutti.property.name=Nom
tutti.property.program=Série de campagne
tutti.property.seaState=État de la mer
+tutti.property.sortedUnsortedCategory=Vrac / Hors Vrac
tutti.property.stationNumber=Numéro de station
tutti.property.strata=Strate d'association
tutti.property.user=Utilisateur
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/AbstractTuttiUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/AbstractTuttiUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/AbstractTuttiUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -33,10 +33,9 @@
import fr.ifremer.tutti.ui.swing.config.TuttiConfig;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import fr.ifremer.tutti.ui.swing.util.editor.SimpleTimeEditor;
-import jaxx.runtime.swing.OneClicListSelectionModel;
import jaxx.runtime.swing.editor.NumberEditor;
import jaxx.runtime.swing.editor.bean.BeanComboBox;
-import jaxx.runtime.swing.editor.bean.BeanListHeader;
+import jaxx.runtime.swing.editor.bean.BeanDoubleList;
import jaxx.runtime.swing.renderer.DecoratorListCellRenderer;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
@@ -62,7 +61,6 @@
import java.util.List;
import java.util.Map;
import java.util.Set;
-import jaxx.runtime.swing.editor.bean.BeanDoubleList;
/**
* Contract of any UI handler.
@@ -186,7 +184,9 @@
* Prépare un component de choix d'entités pour un type d'entité donné et
* pour un service de persistance donné.
*
- * @param listHeader le component graphique à initialiser
+ * @param list le component graphique à initialiser
+ * @param data
+ * @param selectedData
*/
protected <E extends IdAware> void initBeanList(
BeanDoubleList<E> list,
@@ -206,7 +206,7 @@
// add data list to combo box
list.init((JXPathDecorator<E>) decorator, data, selectedData);
-
+
// OneClicListSelectionModel.installModel(listHeader.getList());
// updateIndices(listHeader.getList(), selectedData);
Added: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/AbstractTuttiBatchTableUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/AbstractTuttiBatchTableUIHandler.java (rev 0)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/AbstractTuttiBatchTableUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -0,0 +1,197 @@
+package fr.ifremer.tutti.ui.swing.content.operation;
+
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
+import com.ezware.oxbow.swingbits.table.filter.DistinctColumnItem;
+import com.ezware.oxbow.swingbits.table.filter.IFilterChangeListener;
+import com.ezware.oxbow.swingbits.table.filter.ITableFilter;
+import com.ezware.oxbow.swingbits.table.filter.JTableFilter;
+import com.ezware.oxbow.swingbits.table.filter.TableRowFilterSupport;
+import fr.ifremer.tutti.persistence.entities.data.FishingOperation;
+import fr.ifremer.tutti.service.PersistenceService;
+import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
+import fr.ifremer.tutti.ui.swing.util.TuttiBeanMonitor;
+import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
+import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableModel;
+import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableUIHandler;
+import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableUIModel;
+import fr.ifremer.tutti.ui.swing.util.table.TableRowModificationListener;
+import jaxx.runtime.SwingUtil;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.jdesktop.swingx.JXTable;
+import org.jdesktop.swingx.decorator.ComponentAdapter;
+import org.jdesktop.swingx.decorator.HighlightPredicate;
+import org.jdesktop.swingx.decorator.Highlighter;
+import org.jdesktop.swingx.sort.TableSortController;
+
+import javax.swing.event.ListSelectionListener;
+import javax.swing.table.TableColumnModel;
+import javax.swing.table.TableModel;
+import java.awt.Color;
+import java.awt.Component;
+import java.awt.event.FocusEvent;
+import java.util.Collection;
+
+/**
+ * Abstract ui handler forbatch ui.
+ *
+ * @author tchemit <chemit(a)codelutin.com>
+ * @since 0.2
+ */
+public abstract class AbstractTuttiBatchTableUIHandler<R extends AbstractTuttiBeanUIModel, M extends AbstractTuttiTableUIModel<?, R, M>> extends AbstractTuttiTableUIHandler<R, M> {
+
+
+ /** Logger. */
+ private static final Log log =
+ LogFactory.getLog(AbstractTuttiBatchTableUIHandler.class);
+
+ protected abstract void saveSelectedRowIfRequired();
+
+ protected abstract boolean isRowValid(R row);
+
+ protected abstract void saveRow(R row);
+
+ protected abstract FishingOperation getFishingOperation();
+
+ public abstract void selectFishingOperation(FishingOperation bean);
+
+ /**
+ * Persistence service.
+ *
+ * @since 0.2
+ */
+ protected final PersistenceService persistenceService;
+
+ /**
+ * To monitor changes on the fishing operation.
+ *
+ * @since 0.2
+ */
+ protected final TuttiBeanMonitor<M> fishingOperationMonitor;
+
+ protected AbstractTuttiBatchTableUIHandler(FishingOperationsUI parentUi,
+ String[] fishingProperties,
+ String... properties) {
+ super(parentUi.getHandler().getContext(), properties);
+ this.persistenceService = context.getService(PersistenceService.class);
+ this.fishingOperationMonitor = new TuttiBeanMonitor<M>(
+ fishingProperties);
+ }
+
+ public final void saveSelectedRowIfRequired(FocusEvent event) {
+
+ Component oppositeComponent = event.getOppositeComponent();
+
+ JXTable parentContainer = null;
+
+ if (oppositeComponent != null) {
+
+ // check out if still on table
+ parentContainer = SwingUtil.getParentContainer(
+ oppositeComponent, JXTable.class);
+ }
+
+ if (parentContainer == null) {
+
+ // out of the table can save
+ if (getFishingOperation() != null) {
+ saveSelectedRowIfRequired();
+ }
+ }
+ }
+
+ protected void initBatchTable(JXTable table,
+ TableColumnModel columnModel,
+ AbstractTuttiTableModel<R> tableModel) {
+
+ installTableKeyListener(columnModel, table);
+ table.getTableHeader().setReorderingAllowed(false);
+
+ JTableFilter tableFilter = new JTableFilter(table);
+ TableRowFilterSupport.forFilter(tableFilter).searchable(true).useTableRenderers(true).actions(true).apply();
+
+ tableFilter.addChangeListener(new IFilterChangeListener() {
+ @Override
+ public void filterChanged(ITableFilter<?> filter) {
+ if (log.isInfoEnabled()) {
+ log.info("Filter changed " + filter);
+ }
+ TableModel model = filter.getTable().getModel();
+ int columnCount = model.getColumnCount();
+ for (int i = 0; i < columnCount; i++) {
+ if (filter.isFiltered(i)) {
+ Collection<DistinctColumnItem> filterState = filter.getFilterState(i);
+ if (log.isInfoEnabled()) {
+ log.info("Column " + i + " is filtered: " + filterState);
+ }
+ }
+ }
+ }
+ });
+
+ TableSortController<TableModel> sorter = new TableSortController<TableModel>(tableModel);
+ sorter.setSortable(false);
+
+ table.setRowSorter(sorter);
+
+ Highlighter readOnlyHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
+ HighlightPredicate.READ_ONLY, Color.LIGHT_GRAY);
+
+ table.addHighlighter(readOnlyHighlighter);
+ Highlighter validHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
+ new HighlightPredicate.AndHighlightPredicate(HighlightPredicate.EDITABLE, new HighlightPredicate() {
+ @Override
+ public boolean isHighlighted(Component renderer, ComponentAdapter adapter) {
+
+ boolean result = false;
+ if (adapter.isEditable()) {
+ int rowIndex = adapter.convertRowIndexToModel(adapter.row);
+ R row = getTableModel().getEntry(rowIndex);
+ result = !row.isValid();
+ }
+ return result;
+ }
+ }), Color.RED);
+ table.addHighlighter(validHighlighter);
+
+ // when model datas change let's propagate it table model
+ listenRowsFromModel();
+
+ // save when row chaged and was modified
+ ListSelectionListener listener = new TableRowModificationListener<R>(
+ tableModel, getRowMonitor()) {
+ @Override
+ protected void saveSelectedRow() {
+ saveSelectedRowIfRequired();
+ }
+ };
+ table.getSelectionModel().addListSelectionListener(listener);
+
+ // always scroll to selected row
+ SwingUtil.scrollToTableSelection(table);
+ }
+
+}
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/AbstractTuttiBatchTableUIHandler.java
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchRowModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchRowModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchRowModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -25,11 +25,14 @@
*/
import fr.ifremer.tutti.persistence.entities.data.AccidentalBatch;
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import org.nuiton.util.beans.Binder;
import org.nuiton.util.beans.BinderFactory;
+import java.util.List;
+
/**
* Define a benthos batch row.
*
@@ -46,6 +49,8 @@
public static final String PROPERTY_COMMENT = "comment";
+ public static final String PROPERTY_ATTACHMENTS = "attachments";
+
/**
* Species observed.
*
@@ -67,6 +72,13 @@
*/
protected String comment;
+ /**
+ * Attachments
+ *
+ * @since 0.2
+ */
+ protected List<Attachment> attachments;
+
protected static final Binder<AccidentalBatch, AccidentalBatchRowModel> fromBeanBinder =
BinderFactory.newBinder(AccidentalBatch.class,
AccidentalBatchRowModel.class);
@@ -113,4 +125,14 @@
this.comment = comment;
firePropertyChange(PROPERTY_COMMENT, oldValue, comment);
}
+
+ public List<Attachment> getAttachments() {
+ return attachments;
+ }
+
+ public void setAttachments(List<Attachment> attachments) {
+ Object oldValue = getAttachments();
+ this.attachments = attachments;
+ firePropertyChange(PROPERTY_ATTACHMENTS, oldValue, attachments);
+ }
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchTableModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchTableModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchTableModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -42,36 +42,34 @@
public static final ColumnIdentifier<AccidentalBatchRowModel> SPECIES_BY_CODE = ColumnIdentifier.newId(
BenthosBatchRowModel.PROPERTY_SPECIES,
- n_("tutti.table.benthos.batch.header.speciesByCode"),
- n_("tutti.table.benthos.batch.header.speciesByCode"));
+ n_("tutti.table.accidental.batch.header.speciesByCode"),
+ n_("tutti.table.accidental.batch.header.speciesByCode"));
public static final ColumnIdentifier<AccidentalBatchRowModel> SPECIES_BY_GENUS_CODE = ColumnIdentifier.newId(
BenthosBatchRowModel.PROPERTY_SPECIES,
- n_("tutti.table.benthos.batch.header.speciesByGenusCode"),
- n_("tutti.table.benthos.batch.header.speciesByGenusCode"));
+ n_("tutti.table.accidental.batch.header.speciesByGenusCode"),
+ n_("tutti.table.accidental.batch.header.speciesByGenusCode"));
public static final ColumnIdentifier<AccidentalBatchRowModel> WEIGHT = ColumnIdentifier.newId(
BenthosBatchRowModel.PROPERTY_WEIGHT,
- n_("tutti.table.benthos.batch.header.weight"),
- n_("tutti.table.benthos.batch.header.weight"));
+ n_("tutti.table.accidental.batch.header.weight"),
+ n_("tutti.table.accidental.batch.header.weight"));
public static final ColumnIdentifier<AccidentalBatchRowModel> COMMENT = ColumnIdentifier.newId(
BenthosBatchRowModel.PROPERTY_COMMENT,
- n_("tutti.table.benthos.batch.header.comment"),
- n_("tutti.table.benthos.batch.header.comment"));
+ n_("tutti.table.accidental.batch.header.comment"),
+ n_("tutti.table.accidental.batch.header.comment"));
- public static final ColumnIdentifier<AccidentalBatchRowModel> FILE = ColumnIdentifier.newId(
- null,
- n_("tutti.table.benthos.batch.header.file"),
- n_("tutti.table.benthos.batch.header.file"));
+ public static final ColumnIdentifier<AccidentalBatchRowModel> ATTACHMENTS = ColumnIdentifier.newId(
+ AccidentalBatchRowModel.PROPERTY_ATTACHMENTS,
+ n_("tutti.table.accidental.batch.header.file"),
+ n_("tutti.table.accidental.batch.header.file"));
public AccidentalBatchTableModel(TableColumnModel columnModel) {
super(columnModel);
- setNoneEditableCols(
- FILE
- );
+ setNoneEditableCols();
}
@Override
@@ -94,14 +92,12 @@
if (propertyName == SPECIES_BY_CODE) {
// update also other columns
- fireTableCellUpdated(rowIndex,
- SPECIES_BY_GENUS_CODE);
+ fireTableCellUpdated(rowIndex, SPECIES_BY_GENUS_CODE);
} else if (propertyName == SPECIES_BY_GENUS_CODE) {
// update also other columns
- fireTableCellUpdated(rowIndex,
- SPECIES_BY_CODE);
+ fireTableCellUpdated(rowIndex, SPECIES_BY_CODE);
}
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUI.jaxx
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUI.jaxx 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUI.jaxx 2012-12-15 16:05:45 UTC (rev 77)
@@ -30,6 +30,7 @@
fr.ifremer.tutti.ui.swing.TuttiUIContext
fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI
fr.ifremer.tutti.ui.swing.util.editor.LongTextEditorUI
+ fr.ifremer.tutti.ui.swing.util.editor.AttachmentEditorUI
jaxx.runtime.swing.editor.NumberEditor
@@ -61,10 +62,12 @@
<AccidentalBatchUIModel id='model'
initializer='getContextValue(AccidentalBatchUIModel.class)'/>
- <LongTextEditorUI id='longTextEditorUI'/>
+ <LongTextEditorUI id='longTextEditor'/>
+
+ <AttachmentEditorUI id='attachmentEditor'/>
<JScrollPane id='tableScrollPane' constraints='BorderLayout.CENTER'>
- <JXTable id='table' onFocusLost='handler.saveSelectedRowIfRequired(event);'/>
+ <JXTable id='table' onFocusLost='handler.saveSelectedRowIfRequired(event)'/>
</JScrollPane>
</JPanel>
\ No newline at end of file
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/accidental/AccidentalBatchUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -27,42 +27,37 @@
import com.google.common.collect.Lists;
import fr.ifremer.tutti.persistence.entities.TuttiEntities;
import fr.ifremer.tutti.persistence.entities.data.AccidentalBatch;
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.FishingOperation;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.service.DecoratorService;
-import fr.ifremer.tutti.service.PersistenceService;
import fr.ifremer.tutti.ui.swing.TuttiUI;
+import fr.ifremer.tutti.ui.swing.content.operation.AbstractTuttiBatchTableUIHandler;
import fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI;
import fr.ifremer.tutti.ui.swing.util.TuttiBeanMonitor;
-import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
+import fr.ifremer.tutti.ui.swing.util.editor.AttachmentCellComponent;
import fr.ifremer.tutti.ui.swing.util.editor.LongTextCellComponent;
-import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableUIHandler;
-import fr.ifremer.tutti.ui.swing.util.table.TableRowModificationListener;
-import jaxx.runtime.SwingUtil;
+import org.apache.commons.lang3.ArrayUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.jdesktop.swingx.JXTable;
-import org.jdesktop.swingx.decorator.ComponentAdapter;
-import org.jdesktop.swingx.decorator.HighlightPredicate;
-import org.jdesktop.swingx.decorator.Highlighter;
import org.jdesktop.swingx.table.DefaultTableColumnModelExt;
import org.nuiton.util.decorator.Decorator;
-import javax.swing.event.ListSelectionListener;
import javax.swing.table.TableColumnModel;
-import java.awt.Color;
-import java.awt.Component;
-import java.awt.event.FocusEvent;
import java.util.List;
+import static org.nuiton.i18n.I18n.n_;
+
/**
* @author tchemit <chemit(a)codelutin.com>
* @since 0.2
*/
-public class AccidentalBatchUIHandler extends AbstractTuttiTableUIHandler<AccidentalBatchRowModel, AccidentalBatchUIModel> {
+public class AccidentalBatchUIHandler extends AbstractTuttiBatchTableUIHandler<AccidentalBatchRowModel, AccidentalBatchUIModel> {
/** Logger. */
- private static final Log log = LogFactory.getLog(AccidentalBatchUIHandler.class);
+ private static final Log log =
+ LogFactory.getLog(AccidentalBatchUIHandler.class);
/**
* UI.
@@ -71,28 +66,13 @@
*/
private final AccidentalBatchUI ui;
- /**
- * Persistence service.
- *
- * @since 0.2
- */
- private final PersistenceService persistenceService;
-
- /**
- * To monitor changes on the fishing operation.
- *
- * @since 0.2
- */
- private final TuttiBeanMonitor<AccidentalBatchUIModel> fishingOperationMonitor;
-
- public AccidentalBatchUIHandler(FishingOperationsUI parentUi, AccidentalBatchUI ui) {
- super(parentUi.getHandler().getContext(),
+ public AccidentalBatchUIHandler(FishingOperationsUI parentUi,
+ AccidentalBatchUI ui) {
+ super(parentUi, ArrayUtils.EMPTY_STRING_ARRAY,
AccidentalBatchRowModel.PROPERTY_SPECIES,
AccidentalBatchRowModel.PROPERTY_WEIGHT,
AccidentalBatchRowModel.PROPERTY_COMMENT);
this.ui = ui;
- this.persistenceService = context.getService(PersistenceService.class);
- this.fishingOperationMonitor = new TuttiBeanMonitor<AccidentalBatchUIModel>();
}
//------------------------------------------------------------------------//
@@ -115,6 +95,11 @@
}
@Override
+ protected FishingOperation getFishingOperation() {
+ return getModel().getFishingOperation();
+ }
+
+ @Override
protected TableColumnModel createTableColumnModel() {
DefaultTableColumnModelExt columnModel =
@@ -155,15 +140,19 @@
{ // Comment column
addColumnToModel(columnModel,
- LongTextCellComponent.newEditor(ui.getLongTextEditorUI()),
- LongTextCellComponent.newRender(),
+ LongTextCellComponent.newEditor(ui.getLongTextEditor()),
+ LongTextCellComponent.newRender(n_("tutti.tooltip.comment.none")),
AccidentalBatchTableModel.COMMENT);
}
{ // File column
addColumnToModel(columnModel,
- AccidentalBatchTableModel.FILE);
+ AttachmentCellComponent.newEditor(ui.getAttachmentEditor()),
+ AttachmentCellComponent.newRender(
+ getDecorator(Attachment.class, null),
+ n_("tutti.tooltip.attachment.none")),
+ AccidentalBatchTableModel.ATTACHMENTS);
}
return columnModel;
}
@@ -212,118 +201,71 @@
}
}
- //------------------------------------------------------------------------//
- //-- AbstractTuttiUIHandler methods --//
- //------------------------------------------------------------------------//
-
@Override
- public void beforeInitUI() {
+ protected void saveSelectedRowIfRequired() {
- if (log.isInfoEnabled()) {
- log.info("beforeInit: " + ui);
- }
+ TuttiBeanMonitor<AccidentalBatchRowModel> rowMonitor = getRowMonitor();
- AccidentalBatchUIModel model = new AccidentalBatchUIModel();
- ui.setContextValue(model);
+ AccidentalBatchRowModel bean = rowMonitor.getBean();
+ if (bean != null) {
- fishingOperationMonitor.setBean(model);
- }
+ if (bean.isValid()) {
+ // there is a valid bean attached to the monitor
- @Override
- public void afterInitUI() {
+ if (rowMonitor.wasModified()) {
- if (log.isInfoEnabled()) {
- log.info("afterInit: " + ui);
- }
+ // monitored bean was modified, save it
+ if (log.isInfoEnabled()) {
+ log.info("Row " + bean + " was modified, will save it");
+ }
- initUI(ui);
+ saveRow(bean);
- JXTable table = getTable();
+ // clear modified flag on the monitor
+ rowMonitor.clearModified();
+ }
+ } else {
- // create table column model
- TableColumnModel columnModel = createTableColumnModel();
+ // row is not valid can not save it
- // create table model
- AccidentalBatchTableModel tableModel =
- new AccidentalBatchTableModel(columnModel);
+ AccidentalBatch catchBean = bean.toBean();
- table.setModel(tableModel);
- table.setColumnModel(columnModel);
- installTableKeyListener(columnModel, table);
+ if (!TuttiEntities.isNew(catchBean)) {
- table.getTableHeader().setReorderingAllowed(false);
-
-
- Highlighter readOnlyHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- HighlightPredicate.READ_ONLY, Color.LIGHT_GRAY);
-
- table.addHighlighter(readOnlyHighlighter);
- Highlighter validHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- new HighlightPredicate.AndHighlightPredicate(HighlightPredicate.EDITABLE, new HighlightPredicate() {
- @Override
- public boolean isHighlighted(Component renderer, ComponentAdapter adapter) {
-
- boolean result = false;
- if (adapter.isEditable()) {
- int rowIndex = adapter.convertRowIndexToModel(adapter.row);
- AccidentalBatchRowModel row = getTableModel().getEntry(rowIndex);
- result = !row.isValid();
- }
- return result;
- }
- }), Color.RED);
- table.addHighlighter(validHighlighter);
-
- // when model datas change let's propagate it table model
- listenRowsFromModel();
-
- // save when row chaged and was modified
- ListSelectionListener listener = new TableRowModificationListener<AccidentalBatchRowModel>(
- getTableModel(), getRowMonitor()) {
- @Override
- protected void saveSelectedRow() {
- saveSelectedRowIfRequired();
+ // remove this
+ persistenceService.deleteAccidentalBatch(catchBean.getId());
+ }
}
- };
- table.getSelectionModel().addListSelectionListener(listener);
-
- // always scroll to selected row
- SwingUtil.scrollToTableSelection(getTable());
+ }
}
@Override
- public void onCloseUI() {
- if (log.isInfoEnabled()) {
- log.info("closing: " + ui);
- }
+ protected boolean isRowValid(AccidentalBatchRowModel row) {
+ boolean result = row.getSpecies() != null && row.getWeight() != null;
+ return result;
}
- //------------------------------------------------------------------------//
- //-- Public methods --//
- //------------------------------------------------------------------------//
+ @Override
+ protected void saveRow(AccidentalBatchRowModel row) {
- public void saveSelectedRowIfRequired(FocusEvent event) {
+ AccidentalBatch catchBean = row.toBean();
- Component oppositeComponent = event.getOppositeComponent();
-
- JXTable parentContainer = null;
-
- if (oppositeComponent != null) {
-
- // check out if still on table
- parentContainer = SwingUtil.getParentContainer(
- oppositeComponent, JXTable.class);
+ FishingOperation fishingOperation = getModel().getFishingOperation();
+ catchBean.setFishingOperation(fishingOperation);
+ if (log.isInfoEnabled()) {
+ log.info("Selected fishingOperation: " + fishingOperation.getId());
}
- if (parentContainer == null) {
+ if (TuttiEntities.isNew(catchBean)) {
- // out of the table can save
- if (getModel().getFishingOperation() != null) {
- saveSelectedRowIfRequired();
- }
+ catchBean = persistenceService.createAccidentalBatch(catchBean);
+ row.setId(catchBean.getId());
+ } else {
+ persistenceService.saveAccidentalBatch(catchBean);
}
}
+ @Override
public void selectFishingOperation(FishingOperation bean) {
JXTable table = getTable();
@@ -387,81 +329,60 @@
fishingOperationMonitor.clearModified();
}
- public void cancel() {
+ //------------------------------------------------------------------------//
+ //-- AbstractTuttiUIHandler methods --//
+ //------------------------------------------------------------------------//
- if (log.isInfoEnabled()) {
- log.info("Cancel edition");
- }
- }
+ @Override
+ public void beforeInitUI() {
- public void save() {
if (log.isInfoEnabled()) {
- log.info("Will save");
+ log.info("beforeInit: " + ui);
}
- }
- //------------------------------------------------------------------------//
- //-- Internal methods --//
- //------------------------------------------------------------------------//
+ AccidentalBatchUIModel model = new AccidentalBatchUIModel();
+ ui.setContextValue(model);
- protected boolean isRowValid(AccidentalBatchRowModel row) {
- boolean result = row.getSpecies() != null && row.getWeight() != null;
- return result;
+ fishingOperationMonitor.setBean(model);
}
- protected void saveSelectedRowIfRequired() {
+ @Override
+ public void afterInitUI() {
- TuttiBeanMonitor<AccidentalBatchRowModel> rowMonitor = getRowMonitor();
+ if (log.isInfoEnabled()) {
+ log.info("afterInit: " + ui);
+ }
- AccidentalBatchRowModel bean = rowMonitor.getBean();
- if (bean != null) {
+ initUI(ui);
- if (bean.isValid()) {
- // there is a valid bean attached to the monitor
+ JXTable table = getTable();
- if (rowMonitor.wasModified()) {
+ // create table column model
+ TableColumnModel columnModel = createTableColumnModel();
- // monitored bean was modified, save it
- if (log.isInfoEnabled()) {
- log.info("Row " + bean + " was modified, will save it");
- }
+ // create table model
+ AccidentalBatchTableModel tableModel =
+ new AccidentalBatchTableModel(columnModel);
- saveRow(bean);
+ table.setModel(tableModel);
+ table.setColumnModel(columnModel);
- // clear modified flag on the monitor
- rowMonitor.clearModified();
- }
- } else {
-
- // row is not valid can not save it
-
- AccidentalBatch catchBean = bean.toBean();
-
- if (!TuttiEntities.isNew(catchBean)) {
-
- // remove this
- persistenceService.deleteAccidentalBatch(catchBean.getId());
- }
- }
- }
+ initBatchTable(table, columnModel, tableModel);
}
- protected void saveRow(AccidentalBatchRowModel row) {
-
- AccidentalBatch catchBean = row.toBean();
-
- FishingOperation fishingOperation = getModel().getFishingOperation();
- catchBean.setFishingOperation(fishingOperation);
+ @Override
+ public void onCloseUI() {
if (log.isInfoEnabled()) {
- log.info("Selected fishingOperation: " + fishingOperation.getId());
+ log.info("closing: " + ui);
}
+ }
- if (TuttiEntities.isNew(catchBean)) {
+ //------------------------------------------------------------------------//
+ //-- Public methods --//
+ //------------------------------------------------------------------------//
- catchBean = persistenceService.createAccidentalBatch(catchBean);
- row.setId(catchBean.getId());
- } else {
- persistenceService.saveAccidentalBatch(catchBean);
- }
- }
+ //------------------------------------------------------------------------//
+ //-- Internal methods --//
+ //------------------------------------------------------------------------//
+
}
\ No newline at end of file
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchRowModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchRowModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchRowModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -24,12 +24,15 @@
* #L%
*/
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.BenthosBatch;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import org.nuiton.util.beans.Binder;
import org.nuiton.util.beans.BinderFactory;
+import java.util.List;
+
/**
* Define a benthos batch row.
*
@@ -52,6 +55,8 @@
public static final String PROPERTY_COMMENT = "comment";
+ public static final String PROPERTY_ATTACHMENTS = "attachments";
+
/**
* Species observed.
*
@@ -94,6 +99,13 @@
*/
protected String comment;
+ /**
+ * Attachments
+ *
+ * @since 0.2
+ */
+ protected List<Attachment> attachments;
+
protected static final Binder<BenthosBatch, BenthosBatchRowModel> fromBeanBinder =
BinderFactory.newBinder(BenthosBatch.class,
BenthosBatchRowModel.class);
@@ -170,4 +182,15 @@
this.comment = comment;
firePropertyChange(PROPERTY_COMMENT, oldValue, comment);
}
+
+ public List<Attachment> getAttachments() {
+ return attachments;
+ }
+
+ public void setAttachments(List<Attachment> attachments) {
+ Object oldValue = getAttachments();
+ this.attachments = attachments;
+ firePropertyChange(PROPERTY_ATTACHMENTS, oldValue, attachments);
+ }
+
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchTableModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchTableModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchTableModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -24,6 +24,7 @@
* #L%
*/
+import fr.ifremer.tutti.ui.swing.content.operation.species.SpeciesBatchRowModel;
import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableModel;
import fr.ifremer.tutti.ui.swing.util.table.ColumnIdentifier;
@@ -75,8 +76,8 @@
n_("tutti.table.benthos.batch.header.comment"),
n_("tutti.table.benthos.batch.header.comment"));
- public static final ColumnIdentifier<BenthosBatchRowModel> FILE = ColumnIdentifier.newId(
- null,
+ public static final ColumnIdentifier<BenthosBatchRowModel> ATTACHMENTS = ColumnIdentifier.newId(
+ SpeciesBatchRowModel.PROPERTY_ATTACHMENTS,
n_("tutti.table.benthos.batch.header.file"),
n_("tutti.table.benthos.batch.header.file"));
@@ -84,11 +85,7 @@
public BenthosBatchTableModel(TableColumnModel columnModel) {
super(columnModel);
- setNoneEditableCols(
- SAMPLE_WEIGHT,
- SAMPLING_RATIO,
- FILE
- );
+ setNoneEditableCols(SAMPLE_WEIGHT, SAMPLING_RATIO);
}
@Override
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUI.jaxx
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUI.jaxx 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUI.jaxx 2012-12-15 16:05:45 UTC (rev 77)
@@ -30,6 +30,7 @@
fr.ifremer.tutti.ui.swing.TuttiUIContext
fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI
fr.ifremer.tutti.ui.swing.util.editor.LongTextEditorUI
+ fr.ifremer.tutti.ui.swing.util.editor.AttachmentEditorUI
jaxx.runtime.swing.editor.NumberEditor
@@ -72,8 +73,10 @@
<field name='sampleTotalWeight' component='sampleTotalWeightField'/>
</BeanValidator>
- <LongTextEditorUI id='longTextEditorUI'/>
+ <LongTextEditorUI id='longTextEditor'/>
+ <AttachmentEditorUI id='attachmentEditor'/>
+
<Table id='form' fill='both' constraints='BorderLayout.NORTH'>
<!-- Poids total -->
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/benthos/BenthosBatchUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -26,43 +26,37 @@
import com.google.common.collect.Lists;
import fr.ifremer.tutti.persistence.entities.TuttiEntities;
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.BenthosBatch;
import fr.ifremer.tutti.persistence.entities.data.FishingOperation;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.service.DecoratorService;
-import fr.ifremer.tutti.service.PersistenceService;
import fr.ifremer.tutti.ui.swing.TuttiUI;
+import fr.ifremer.tutti.ui.swing.content.operation.AbstractTuttiBatchTableUIHandler;
import fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI;
import fr.ifremer.tutti.ui.swing.util.TuttiBeanMonitor;
-import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
+import fr.ifremer.tutti.ui.swing.util.editor.AttachmentCellComponent;
import fr.ifremer.tutti.ui.swing.util.editor.LongTextCellComponent;
-import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableUIHandler;
-import fr.ifremer.tutti.ui.swing.util.table.TableRowModificationListener;
-import jaxx.runtime.SwingUtil;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.jdesktop.swingx.JXTable;
-import org.jdesktop.swingx.decorator.ComponentAdapter;
-import org.jdesktop.swingx.decorator.HighlightPredicate;
-import org.jdesktop.swingx.decorator.Highlighter;
import org.jdesktop.swingx.table.DefaultTableColumnModelExt;
import org.nuiton.util.decorator.Decorator;
-import javax.swing.event.ListSelectionListener;
import javax.swing.table.TableColumnModel;
-import java.awt.Color;
-import java.awt.Component;
-import java.awt.event.FocusEvent;
import java.util.List;
+import static org.nuiton.i18n.I18n.n_;
+
/**
* @author tchemit <chemit(a)codelutin.com>
* @since 0.1
*/
-public class BenthosBatchUIHandler extends AbstractTuttiTableUIHandler<BenthosBatchRowModel, BenthosBatchUIModel> {
+public class BenthosBatchUIHandler extends AbstractTuttiBatchTableUIHandler<BenthosBatchRowModel, BenthosBatchUIModel> {
/** Logger. */
- private static final Log log = LogFactory.getLog(BenthosBatchUIHandler.class);
+ private static final Log log =
+ LogFactory.getLog(BenthosBatchUIHandler.class);
/**
* UI.
@@ -71,32 +65,17 @@
*/
private final BenthosBatchUI ui;
- /**
- * Persistence service.
- *
- * @since 0.2
- */
- private final PersistenceService persistenceService;
-
- /**
- * To monitor changes on the fishing operation.
- *
- * @since 0.2
- */
- private final TuttiBeanMonitor<BenthosBatchUIModel> fishingOperationMonitor;
-
- public BenthosBatchUIHandler(FishingOperationsUI parentUi, BenthosBatchUI ui) {
- super(parentUi.getHandler().getContext(),
+ public BenthosBatchUIHandler(FishingOperationsUI parentUi,
+ BenthosBatchUI ui) {
+ super(parentUi,
+ new String[]{BenthosBatchUIModel.PROPERTY_TOTAL_WEIGHT,
+ BenthosBatchUIModel.PROPERTY_SAMPLE_TOTAL_WEIGHT},
BenthosBatchRowModel.PROPERTY_SPECIES_TO_CONFIRM,
BenthosBatchRowModel.PROPERTY_SPECIES,
BenthosBatchRowModel.PROPERTY_WEIGHT,
BenthosBatchRowModel.PROPERTY_COMMENT);
this.ui = ui;
- this.persistenceService = context.getService(PersistenceService.class);
- this.fishingOperationMonitor = new TuttiBeanMonitor<BenthosBatchUIModel>(
- BenthosBatchUIModel.PROPERTY_TOTAL_WEIGHT,
- BenthosBatchUIModel.PROPERTY_SAMPLE_TOTAL_WEIGHT
- );
+
}
//------------------------------------------------------------------------//
@@ -119,6 +98,11 @@
}
@Override
+ protected FishingOperation getFishingOperation() {
+ return getModel().getFishingOperation();
+ }
+
+ @Override
protected String[] getRowPropertiesToIgnore() {
return new String[]{
BenthosBatchRowModel.PROPERTY_SAMPLE_WEIGHT,
@@ -187,15 +171,19 @@
{ // Comment column
addColumnToModel(columnModel,
- LongTextCellComponent.newEditor(ui.getLongTextEditorUI()),
- LongTextCellComponent.newRender(),
+ LongTextCellComponent.newEditor(ui.getLongTextEditor()),
+ LongTextCellComponent.newRender(n_("tutti.tooltip.comment.none")),
BenthosBatchTableModel.COMMENT);
}
{ // File column
addColumnToModel(columnModel,
- BenthosBatchTableModel.FILE);
+ AttachmentCellComponent.newEditor(ui.getAttachmentEditor()),
+ AttachmentCellComponent.newRender(
+ getDecorator(Attachment.class, null),
+ n_("tutti.tooltip.attachment.none")),
+ BenthosBatchTableModel.ATTACHMENTS);
}
return columnModel;
}
@@ -244,118 +232,71 @@
}
}
- //------------------------------------------------------------------------//
- //-- AbstractTuttiUIHandler methods --//
- //------------------------------------------------------------------------//
-
@Override
- public void beforeInitUI() {
+ protected void saveSelectedRowIfRequired() {
- if (log.isInfoEnabled()) {
- log.info("beforeInit: " + ui);
- }
+ TuttiBeanMonitor<BenthosBatchRowModel> rowMonitor = getRowMonitor();
- BenthosBatchUIModel model = new BenthosBatchUIModel();
- ui.setContextValue(model);
+ BenthosBatchRowModel bean = rowMonitor.getBean();
+ if (bean != null) {
- fishingOperationMonitor.setBean(model);
- }
+ if (bean.isValid()) {
+ // there is a valid bean attached to the monitor
- @Override
- public void afterInitUI() {
+ if (rowMonitor.wasModified()) {
- if (log.isInfoEnabled()) {
- log.info("afterInit: " + ui);
- }
+ // monitored bean was modified, save it
+ if (log.isInfoEnabled()) {
+ log.info("Row " + bean + " was modified, will save it");
+ }
- initUI(ui);
+ saveRow(bean);
- JXTable table = getTable();
+ // clear modified flag on the monitor
+ rowMonitor.clearModified();
+ }
+ } else {
- // create table column model
- TableColumnModel columnModel = createTableColumnModel();
+ // row is not valid can not save it
- // create table model
- BenthosBatchTableModel tableModel =
- new BenthosBatchTableModel(columnModel);
+ BenthosBatch catchBean = bean.toBean();
- table.setModel(tableModel);
- table.setColumnModel(columnModel);
- installTableKeyListener(columnModel, table);
+ if (!TuttiEntities.isNew(catchBean)) {
- table.getTableHeader().setReorderingAllowed(false);
-
-
- Highlighter readOnlyHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- HighlightPredicate.READ_ONLY, Color.LIGHT_GRAY);
-
- table.addHighlighter(readOnlyHighlighter);
- Highlighter validHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- new HighlightPredicate.AndHighlightPredicate(HighlightPredicate.EDITABLE, new HighlightPredicate() {
- @Override
- public boolean isHighlighted(Component renderer, ComponentAdapter adapter) {
-
- boolean result = false;
- if (adapter.isEditable()) {
- int rowIndex = adapter.convertRowIndexToModel(adapter.row);
- BenthosBatchRowModel row = getTableModel().getEntry(rowIndex);
- result = !row.isValid();
- }
- return result;
- }
- }), Color.RED);
- table.addHighlighter(validHighlighter);
-
- // when model datas change let's propagate it table model
- listenRowsFromModel();
-
- // save when row chaged and was modified
- ListSelectionListener listener = new TableRowModificationListener<BenthosBatchRowModel>(
- getTableModel(), getRowMonitor()) {
- @Override
- protected void saveSelectedRow() {
- saveSelectedRowIfRequired();
+ // remove this
+ persistenceService.deleteBenthosBatch(catchBean.getId());
+ }
}
- };
- table.getSelectionModel().addListSelectionListener(listener);
-
- // always scroll to selected row
- SwingUtil.scrollToTableSelection(getTable());
+ }
}
@Override
- public void onCloseUI() {
- if (log.isInfoEnabled()) {
- log.info("closing: " + ui);
- }
+ protected boolean isRowValid(BenthosBatchRowModel row) {
+ boolean result = row.getSpecies() != null && row.getWeight() != null;
+ return result;
}
- //------------------------------------------------------------------------//
- //-- Public methods --//
- //------------------------------------------------------------------------//
+ @Override
+ protected void saveRow(BenthosBatchRowModel row) {
- public void saveSelectedRowIfRequired(FocusEvent event) {
+ BenthosBatch catchBean = row.toBean();
- Component oppositeComponent = event.getOppositeComponent();
-
- JXTable parentContainer = null;
-
- if (oppositeComponent != null) {
-
- // check out if still on table
- parentContainer = SwingUtil.getParentContainer(
- oppositeComponent, JXTable.class);
+ FishingOperation fishingOperation = getModel().getFishingOperation();
+ catchBean.setFishingOperation(fishingOperation);
+ if (log.isInfoEnabled()) {
+ log.info("Selected fishingOperation: " + fishingOperation.getId());
}
- if (parentContainer == null) {
+ if (TuttiEntities.isNew(catchBean)) {
- // out of the table can save
- if (getModel().getFishingOperation() != null) {
- saveSelectedRowIfRequired();
- }
+ catchBean = persistenceService.createBenthosBatch(catchBean);
+ row.setId(catchBean.getId());
+ } else {
+ persistenceService.saveBenthosBatch(catchBean);
}
}
+ @Override
public void selectFishingOperation(FishingOperation bean) {
JXTable table = getTable();
@@ -419,81 +360,61 @@
fishingOperationMonitor.clearModified();
}
- public void cancel() {
- if (log.isInfoEnabled()) {
- log.info("Cancel edition");
- }
- }
+ //------------------------------------------------------------------------//
+ //-- AbstractTuttiUIHandler methods --//
+ //------------------------------------------------------------------------//
- public void save() {
+ @Override
+ public void beforeInitUI() {
+
if (log.isInfoEnabled()) {
- log.info("Will save");
+ log.info("beforeInit: " + ui);
}
- }
- //------------------------------------------------------------------------//
- //-- Internal methods --//
- //------------------------------------------------------------------------//
+ BenthosBatchUIModel model = new BenthosBatchUIModel();
+ ui.setContextValue(model);
- protected boolean isRowValid(BenthosBatchRowModel row) {
- boolean result = row.getSpecies() != null && row.getWeight() != null;
- return result;
+ fishingOperationMonitor.setBean(model);
}
- protected void saveSelectedRowIfRequired() {
+ @Override
+ public void afterInitUI() {
- TuttiBeanMonitor<BenthosBatchRowModel> rowMonitor = getRowMonitor();
+ if (log.isInfoEnabled()) {
+ log.info("afterInit: " + ui);
+ }
- BenthosBatchRowModel bean = rowMonitor.getBean();
- if (bean != null) {
+ initUI(ui);
- if (bean.isValid()) {
- // there is a valid bean attached to the monitor
+ JXTable table = getTable();
- if (rowMonitor.wasModified()) {
+ // create table column model
+ TableColumnModel columnModel = createTableColumnModel();
- // monitored bean was modified, save it
- if (log.isInfoEnabled()) {
- log.info("Row " + bean + " was modified, will save it");
- }
+ // create table model
+ BenthosBatchTableModel tableModel =
+ new BenthosBatchTableModel(columnModel);
- saveRow(bean);
+ table.setModel(tableModel);
+ table.setColumnModel(columnModel);
- // clear modified flag on the monitor
- rowMonitor.clearModified();
- }
- } else {
-
- // row is not valid can not save it
-
- BenthosBatch catchBean = bean.toBean();
-
- if (!TuttiEntities.isNew(catchBean)) {
-
- // remove this
- persistenceService.deleteBenthosBatch(catchBean.getId());
- }
- }
- }
+ initBatchTable(table, columnModel, tableModel);
}
- protected void saveRow(BenthosBatchRowModel row) {
-
- BenthosBatch catchBean = row.toBean();
-
- FishingOperation fishingOperation = getModel().getFishingOperation();
- catchBean.setFishingOperation(fishingOperation);
+ @Override
+ public void onCloseUI() {
if (log.isInfoEnabled()) {
- log.info("Selected fishingOperation: " + fishingOperation.getId());
+ log.info("closing: " + ui);
}
+ }
- if (TuttiEntities.isNew(catchBean)) {
+ //------------------------------------------------------------------------//
+ //-- Public methods --//
+ //------------------------------------------------------------------------//
- catchBean = persistenceService.createBenthosBatch(catchBean);
- row.setId(catchBean.getId());
- } else {
- persistenceService.saveBenthosBatch(catchBean);
- }
- }
+ //------------------------------------------------------------------------//
+ //-- Internal methods --//
+ //------------------------------------------------------------------------//
+
}
\ No newline at end of file
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchRowModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchRowModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchRowModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -24,12 +24,15 @@
* #L%
*/
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.MacroWasteBatch;
-import fr.ifremer.tutti.persistence.entities.referential.Species;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import org.nuiton.util.beans.Binder;
import org.nuiton.util.beans.BinderFactory;
+import java.util.List;
+
/**
* Define a benthos batch row.
*
@@ -40,18 +43,20 @@
private static final long serialVersionUID = 1L;
- public static final String PROPERTY_SPECIES = "species";
+ public static final String PROPERTY_MACRO_WASTE_CATEGORY = "macroWasteCategory";
public static final String PROPERTY_WEIGHT = "weight";
public static final String PROPERTY_COMMENT = "comment";
+ public static final String PROPERTY_ATTACHMENTS = "attachments";
+
/**
- * Species observed.
+ * macroWaste category.
*
* @since 0.2
*/
- protected Species species;
+ protected MacroWasteCategory macroWasteCategory;
/**
* Observed weight.
@@ -61,12 +66,19 @@
protected Float weight;
/**
- * Comment on this catches.
+ * Comment on this batch.
*
* @since 0.2
*/
protected String comment;
+ /**
+ * Attachments.
+ *
+ * @since 0.2
+ */
+ protected List<Attachment> attachments;
+
protected static final Binder<MacroWasteBatch, MacroWasteBatchRowModel> fromBeanBinder =
BinderFactory.newBinder(MacroWasteBatch.class,
MacroWasteBatchRowModel.class);
@@ -84,14 +96,14 @@
fromBean(aBatch);
}
- public Species getSpecies() {
- return species;
+ public MacroWasteCategory getMacroWasteCategory() {
+ return macroWasteCategory;
}
- public void setSpecies(Species species) {
- Object oldValue = getSpecies();
- this.species = species;
- firePropertyChange(PROPERTY_SPECIES, oldValue, species);
+ public void setMacroWasteCategory(MacroWasteCategory macroWasteCategory) {
+ Object oldValue = getMacroWasteCategory();
+ this.macroWasteCategory = macroWasteCategory;
+ firePropertyChange(PROPERTY_MACRO_WASTE_CATEGORY, oldValue, macroWasteCategory);
}
public Float getWeight() {
@@ -113,4 +125,14 @@
this.comment = comment;
firePropertyChange(PROPERTY_COMMENT, oldValue, comment);
}
+
+ public List<Attachment> getAttachments() {
+ return attachments;
+ }
+
+ public void setAttachments(List<Attachment> attachments) {
+ Object oldValue = getAttachments();
+ this.attachments = attachments;
+ firePropertyChange(PROPERTY_ATTACHMENTS, oldValue, attachments);
+ }
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchTableModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchTableModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchTableModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -39,16 +39,11 @@
private static final long serialVersionUID = 1L;
- public static final ColumnIdentifier<MacroWasteBatchRowModel> SPECIES_BY_CODE = ColumnIdentifier.newId(
- MacroWasteBatchRowModel.PROPERTY_SPECIES,
- n_("tutti.table.macrowaste.batch.header.speciesByCode"),
- n_("tutti.table.macrowaste.batch.header.speciesByCode"));
+ public static final ColumnIdentifier<MacroWasteBatchRowModel> MACRO_WASTE_CATEGORY = ColumnIdentifier.newId(
+ MacroWasteBatchRowModel.PROPERTY_MACRO_WASTE_CATEGORY,
+ n_("tutti.table.macrowaste.batch.header.macroWasteCategory"),
+ n_("tutti.table.macrowaste.batch.header.macroWasteCategory"));
- public static final ColumnIdentifier<MacroWasteBatchRowModel> SPECIES_BY_GENUS_CODE = ColumnIdentifier.newId(
- MacroWasteBatchRowModel.PROPERTY_SPECIES,
- n_("tutti.table.macrowaste.batch.header.speciesByGenusCode"),
- n_("tutti.table.macrowaste.batch.header.speciesByGenusCode"));
-
public static final ColumnIdentifier<MacroWasteBatchRowModel> WEIGHT = ColumnIdentifier.newId(
MacroWasteBatchRowModel.PROPERTY_WEIGHT,
n_("tutti.table.macrowaste.batch.header.weight"),
@@ -59,16 +54,15 @@
n_("tutti.table.macrowaste.batch.header.comment"),
n_("tutti.table.macrowaste.batch.header.comment"));
- public static final ColumnIdentifier<MacroWasteBatchRowModel> FILE = ColumnIdentifier.newId(
- null,
+ public static final ColumnIdentifier<MacroWasteBatchRowModel> ATTACHMENTS = ColumnIdentifier.newId(
+ MacroWasteBatchRowModel.PROPERTY_ATTACHMENTS,
n_("tutti.table.macrowaste.batch.header.file"),
n_("tutti.table.macrowaste.batch.header.file"));
-
public MacroWasteBatchTableModel(TableColumnModel columnModel) {
super(columnModel);
- setNoneEditableCols(FILE);
+ setNoneEditableCols();
}
@Override
@@ -80,25 +74,4 @@
return result;
}
- @Override
- public void setValueAt(Object aValue,
- int rowIndex,
- int columnIndex,
- ColumnIdentifier<MacroWasteBatchRowModel> propertyName,
- MacroWasteBatchRowModel entry) {
- super.setValueAt(aValue, rowIndex, columnIndex, propertyName, entry);
-
- if (propertyName == SPECIES_BY_CODE) {
-
- // update also other columns
- fireTableCellUpdated(rowIndex,
- SPECIES_BY_GENUS_CODE);
-
- } else if (propertyName == SPECIES_BY_GENUS_CODE) {
-
- // update also other columns
- fireTableCellUpdated(rowIndex,
- SPECIES_BY_CODE);
- }
- }
}
\ No newline at end of file
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUI.jaxx
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUI.jaxx 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUI.jaxx 2012-12-15 16:05:45 UTC (rev 77)
@@ -30,6 +30,7 @@
fr.ifremer.tutti.ui.swing.TuttiUIContext
fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI
fr.ifremer.tutti.ui.swing.util.editor.LongTextEditorUI
+ fr.ifremer.tutti.ui.swing.util.editor.AttachmentEditorUI
jaxx.runtime.swing.editor.NumberEditor
@@ -71,8 +72,10 @@
<field name='totalWeight' component='totalWeightField'/>
</BeanValidator>
- <LongTextEditorUI id='longTextEditorUI'/>
+ <LongTextEditorUI id='longTextEditor'/>
+ <AttachmentEditorUI id='attachmentEditor'/>
+
<Table id='form' fill='both' constraints='BorderLayout.NORTH'>
<!-- Poids total -->
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/macrowaste/MacroWasteBatchUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -26,43 +26,36 @@
import com.google.common.collect.Lists;
import fr.ifremer.tutti.persistence.entities.TuttiEntities;
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.FishingOperation;
import fr.ifremer.tutti.persistence.entities.data.MacroWasteBatch;
-import fr.ifremer.tutti.persistence.entities.referential.Species;
-import fr.ifremer.tutti.service.DecoratorService;
-import fr.ifremer.tutti.service.PersistenceService;
+import fr.ifremer.tutti.persistence.entities.referential.MacroWasteCategory;
import fr.ifremer.tutti.ui.swing.TuttiUI;
+import fr.ifremer.tutti.ui.swing.content.operation.AbstractTuttiBatchTableUIHandler;
import fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI;
import fr.ifremer.tutti.ui.swing.util.TuttiBeanMonitor;
-import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
+import fr.ifremer.tutti.ui.swing.util.editor.AttachmentCellComponent;
import fr.ifremer.tutti.ui.swing.util.editor.LongTextCellComponent;
-import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableUIHandler;
-import fr.ifremer.tutti.ui.swing.util.table.TableRowModificationListener;
-import jaxx.runtime.SwingUtil;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.jdesktop.swingx.JXTable;
-import org.jdesktop.swingx.decorator.ComponentAdapter;
-import org.jdesktop.swingx.decorator.HighlightPredicate;
-import org.jdesktop.swingx.decorator.Highlighter;
import org.jdesktop.swingx.table.DefaultTableColumnModelExt;
import org.nuiton.util.decorator.Decorator;
-import javax.swing.event.ListSelectionListener;
import javax.swing.table.TableColumnModel;
-import java.awt.Color;
-import java.awt.Component;
-import java.awt.event.FocusEvent;
import java.util.List;
+import static org.nuiton.i18n.I18n.n_;
+
/**
* @author tchemit <chemit(a)codelutin.com>
* @since 0.2
*/
-public class MacroWasteBatchUIHandler extends AbstractTuttiTableUIHandler<MacroWasteBatchRowModel, MacroWasteBatchUIModel> {
+public class MacroWasteBatchUIHandler extends AbstractTuttiBatchTableUIHandler<MacroWasteBatchRowModel, MacroWasteBatchUIModel> {
/** Logger. */
- private static final Log log = LogFactory.getLog(MacroWasteBatchUIHandler.class);
+ private static final Log log =
+ LogFactory.getLog(MacroWasteBatchUIHandler.class);
/**
* UI.
@@ -71,31 +64,13 @@
*/
private final MacroWasteBatchUI ui;
- /**
- * Persistence service.
- *
- * @since 0.2
- */
- private final PersistenceService persistenceService;
-
- /**
- * To monitor changes on the fishing operation.
- *
- * @since 0.2
- */
- private final TuttiBeanMonitor<MacroWasteBatchUIModel> fishingOperationMonitor;
-
-
public MacroWasteBatchUIHandler(FishingOperationsUI parentUi, MacroWasteBatchUI ui) {
- super(parentUi.getHandler().getContext(),
- MacroWasteBatchRowModel.PROPERTY_SPECIES,
+ super(parentUi,
+ new String[]{MacroWasteBatchUIModel.PROPERTY_TOTAL_WEIGHT},
+ MacroWasteBatchRowModel.PROPERTY_MACRO_WASTE_CATEGORY,
MacroWasteBatchRowModel.PROPERTY_WEIGHT,
MacroWasteBatchRowModel.PROPERTY_COMMENT);
this.ui = ui;
- this.persistenceService = context.getService(PersistenceService.class);
- this.fishingOperationMonitor = new TuttiBeanMonitor<MacroWasteBatchUIModel>(
- MacroWasteBatchUIModel.PROPERTY_TOTAL_WEIGHT
- );
}
//------------------------------------------------------------------------//
@@ -118,36 +93,27 @@
}
@Override
+ protected FishingOperation getFishingOperation() {
+ return getModel().getFishingOperation();
+ }
+
+ @Override
protected TableColumnModel createTableColumnModel() {
DefaultTableColumnModelExt columnModel =
new DefaultTableColumnModelExt();
- List<Species> allSpecies = persistenceService.getAllSpecies();
-
{
- // Species (by code) column
+ // MacroWaste Category column
- Decorator<Species> decorator = getDecorator(
- Species.class, DecoratorService.SPECIES_BY_CODE);
+ Decorator<MacroWasteCategory> decorator = getDecorator(
+ MacroWasteCategory.class, null);
addComboDataColumnToModel(columnModel,
- MacroWasteBatchTableModel.SPECIES_BY_CODE,
- decorator, allSpecies);
+ MacroWasteBatchTableModel.MACRO_WASTE_CATEGORY,
+ decorator, persistenceService.getAllMacroWasteCategory());
}
- {
- // Species (by genusCode) column
-
- Decorator<Species> decorator = getDecorator(
- Species.class, DecoratorService.SPECIES_BY_GENUS);
-
- addComboDataColumnToModel(columnModel,
- MacroWasteBatchTableModel.SPECIES_BY_GENUS_CODE,
- decorator, allSpecies);
-
- }
-
{ // Weight column
addFloatColumnToModel(columnModel,
@@ -158,15 +124,19 @@
{ // Comment column
addColumnToModel(columnModel,
- LongTextCellComponent.newEditor(ui.getLongTextEditorUI()),
- LongTextCellComponent.newRender(),
+ LongTextCellComponent.newEditor(ui.getLongTextEditor()),
+ LongTextCellComponent.newRender(n_("tutti.tooltip.comment.none")),
MacroWasteBatchTableModel.COMMENT);
}
{ // File column
addColumnToModel(columnModel,
- MacroWasteBatchTableModel.FILE);
+ AttachmentCellComponent.newEditor(ui.getAttachmentEditor()),
+ AttachmentCellComponent.newRender(
+ getDecorator(Attachment.class, null),
+ n_("tutti.tooltip.attachment.none")),
+ MacroWasteBatchTableModel.ATTACHMENTS);
}
return columnModel;
}
@@ -215,118 +185,72 @@
}
}
- //------------------------------------------------------------------------//
- //-- AbstractTuttiUIHandler methods --//
- //------------------------------------------------------------------------//
-
@Override
- public void beforeInitUI() {
+ protected void saveSelectedRowIfRequired() {
- if (log.isInfoEnabled()) {
- log.info("beforeInit: " + ui);
- }
+ TuttiBeanMonitor<MacroWasteBatchRowModel> rowMonitor = getRowMonitor();
- MacroWasteBatchUIModel model = new MacroWasteBatchUIModel();
- ui.setContextValue(model);
+ MacroWasteBatchRowModel bean = rowMonitor.getBean();
+ if (bean != null) {
- fishingOperationMonitor.setBean(model);
- }
+ if (bean.isValid()) {
+ // there is a valid bean attached to the monitor
- @Override
- public void afterInitUI() {
+ if (rowMonitor.wasModified()) {
- if (log.isInfoEnabled()) {
- log.info("afterInit: " + ui);
- }
+ // monitored bean was modified, save it
+ if (log.isInfoEnabled()) {
+ log.info("Row " + bean + " was modified, will save it");
+ }
- initUI(ui);
+ saveRow(bean);
- JXTable table = getTable();
+ // clear modified flag on the monitor
+ rowMonitor.clearModified();
+ }
+ } else {
- // create table column model
- TableColumnModel columnModel = createTableColumnModel();
+ // row is not valid can not save it
- // create table model
- MacroWasteBatchTableModel tableModel =
- new MacroWasteBatchTableModel(columnModel);
+ MacroWasteBatch catchBean = bean.toBean();
- table.setModel(tableModel);
- table.setColumnModel(columnModel);
- installTableKeyListener(columnModel, table);
+ if (!TuttiEntities.isNew(catchBean)) {
- table.getTableHeader().setReorderingAllowed(false);
-
-
- Highlighter readOnlyHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- HighlightPredicate.READ_ONLY, Color.LIGHT_GRAY);
-
- table.addHighlighter(readOnlyHighlighter);
- Highlighter validHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- new HighlightPredicate.AndHighlightPredicate(HighlightPredicate.EDITABLE, new HighlightPredicate() {
- @Override
- public boolean isHighlighted(Component renderer, ComponentAdapter adapter) {
-
- boolean result = false;
- if (adapter.isEditable()) {
- int rowIndex = adapter.convertRowIndexToModel(adapter.row);
- MacroWasteBatchRowModel row = getTableModel().getEntry(rowIndex);
- result = !row.isValid();
- }
- return result;
- }
- }), Color.RED);
- table.addHighlighter(validHighlighter);
-
- // when model datas change let's propagate it table model
- listenRowsFromModel();
-
- // save when row chaged and was modified
- ListSelectionListener listener = new TableRowModificationListener<MacroWasteBatchRowModel>(
- getTableModel(), getRowMonitor()) {
- @Override
- protected void saveSelectedRow() {
- saveSelectedRowIfRequired();
+ // remove this
+ persistenceService.deleteMacroWasteBatch(catchBean.getId());
+ }
}
- };
- table.getSelectionModel().addListSelectionListener(listener);
-
- // always scroll to selected row
- SwingUtil.scrollToTableSelection(getTable());
+ }
}
@Override
- public void onCloseUI() {
- if (log.isInfoEnabled()) {
- log.info("closing: " + ui);
- }
+ protected boolean isRowValid(MacroWasteBatchRowModel row) {
+ boolean result = row.getMacroWasteCategory() != null &&
+ row.getWeight() != null;
+ return result;
}
- //------------------------------------------------------------------------//
- //-- Public methods --//
- //------------------------------------------------------------------------//
+ @Override
+ protected void saveRow(MacroWasteBatchRowModel row) {
- public void saveSelectedRowIfRequired(FocusEvent event) {
+ MacroWasteBatch catchBean = row.toBean();
- Component oppositeComponent = event.getOppositeComponent();
-
- JXTable parentContainer = null;
-
- if (oppositeComponent != null) {
-
- // check out if still on table
- parentContainer = SwingUtil.getParentContainer(
- oppositeComponent, JXTable.class);
+ FishingOperation fishingOperation = getModel().getFishingOperation();
+ catchBean.setFishingOperation(fishingOperation);
+ if (log.isInfoEnabled()) {
+ log.info("Selected fishingOperation: " + fishingOperation.getId());
}
- if (parentContainer == null) {
+ if (TuttiEntities.isNew(catchBean)) {
- // out of the table can save
- if (getModel().getFishingOperation() != null) {
- saveSelectedRowIfRequired();
- }
+ catchBean = persistenceService.createMacroWasteBatch(catchBean);
+ row.setId(catchBean.getId());
+ } else {
+ persistenceService.saveMacroWasteBatch(catchBean);
}
}
+ @Override
public void selectFishingOperation(FishingOperation bean) {
JXTable table = getTable();
@@ -390,81 +314,60 @@
fishingOperationMonitor.clearModified();
}
- public void cancel() {
+ //------------------------------------------------------------------------//
+ //-- AbstractTuttiUIHandler methods --//
+ //------------------------------------------------------------------------//
- if (log.isInfoEnabled()) {
- log.info("Cancel edition");
- }
- }
+ @Override
+ public void beforeInitUI() {
- public void save() {
if (log.isInfoEnabled()) {
- log.info("Will save");
+ log.info("beforeInit: " + ui);
}
- }
- //------------------------------------------------------------------------//
- //-- Internal methods --//
- //------------------------------------------------------------------------//
+ MacroWasteBatchUIModel model = new MacroWasteBatchUIModel();
+ ui.setContextValue(model);
- protected boolean isRowValid(MacroWasteBatchRowModel row) {
- boolean result = row.getSpecies() != null && row.getWeight() != null;
- return result;
+ fishingOperationMonitor.setBean(model);
}
- protected void saveSelectedRowIfRequired() {
+ @Override
+ public void afterInitUI() {
- TuttiBeanMonitor<MacroWasteBatchRowModel> rowMonitor = getRowMonitor();
+ if (log.isInfoEnabled()) {
+ log.info("afterInit: " + ui);
+ }
- MacroWasteBatchRowModel bean = rowMonitor.getBean();
- if (bean != null) {
+ initUI(ui);
- if (bean.isValid()) {
- // there is a valid bean attached to the monitor
+ JXTable table = getTable();
- if (rowMonitor.wasModified()) {
+ // create table column model
+ TableColumnModel columnModel = createTableColumnModel();
- // monitored bean was modified, save it
- if (log.isInfoEnabled()) {
- log.info("Row " + bean + " was modified, will save it");
- }
+ // create table model
+ MacroWasteBatchTableModel tableModel =
+ new MacroWasteBatchTableModel(columnModel);
- saveRow(bean);
+ table.setModel(tableModel);
+ table.setColumnModel(columnModel);
- // clear modified flag on the monitor
- rowMonitor.clearModified();
- }
- } else {
-
- // row is not valid can not save it
-
- MacroWasteBatch catchBean = bean.toBean();
-
- if (!TuttiEntities.isNew(catchBean)) {
-
- // remove this
- persistenceService.deleteMacroWasteBatch(catchBean.getId());
- }
- }
- }
+ initBatchTable(table, columnModel, tableModel);
}
- protected void saveRow(MacroWasteBatchRowModel row) {
-
- MacroWasteBatch catchBean = row.toBean();
-
- FishingOperation fishingOperation = getModel().getFishingOperation();
- catchBean.setFishingOperation(fishingOperation);
+ @Override
+ public void onCloseUI() {
if (log.isInfoEnabled()) {
- log.info("Selected fishingOperation: " + fishingOperation.getId());
+ log.info("closing: " + ui);
}
+ }
- if (TuttiEntities.isNew(catchBean)) {
+ //------------------------------------------------------------------------//
+ //-- Public methods --//
+ //------------------------------------------------------------------------//
- catchBean = persistenceService.createMacroWasteBatch(catchBean);
- row.setId(catchBean.getId());
- } else {
- persistenceService.saveMacroWasteBatch(catchBean);
- }
- }
+ //------------------------------------------------------------------------//
+ //-- Internal methods --//
+ //------------------------------------------------------------------------//
+
}
\ No newline at end of file
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchRowModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchRowModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchRowModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -24,12 +24,15 @@
* #L%
*/
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.PlanktonBatch;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import org.nuiton.util.beans.Binder;
import org.nuiton.util.beans.BinderFactory;
+import java.util.List;
+
/**
* Define a benthos batch row.
*
@@ -52,6 +55,8 @@
public static final String PROPERTY_COMMENT = "comment";
+ public static final String PROPERTY_ATTACHMENTS = "attachments";
+
/**
* Species observed.
*
@@ -94,6 +99,13 @@
*/
protected String comment;
+ /**
+ * Attachments
+ *
+ * @since 0.2
+ */
+ protected List<Attachment> attachments;
+
protected static final Binder<PlanktonBatch, PlanktonBatchRowModel> fromBeanBinder =
BinderFactory.newBinder(PlanktonBatch.class,
PlanktonBatchRowModel.class);
@@ -170,4 +182,14 @@
this.comment = comment;
firePropertyChange(PROPERTY_COMMENT, oldValue, comment);
}
+
+ public List<Attachment> getAttachments() {
+ return attachments;
+ }
+
+ public void setAttachments(List<Attachment> attachments) {
+ Object oldValue = getAttachments();
+ this.attachments = attachments;
+ firePropertyChange(PROPERTY_ATTACHMENTS, oldValue, attachments);
+ }
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchTableModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchTableModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchTableModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -74,20 +74,15 @@
n_("tutti.table.plankton.batch.header.comment"),
n_("tutti.table.plankton.batch.header.comment"));
- public static final ColumnIdentifier<PlanktonBatchRowModel> FILE = ColumnIdentifier.newId(
- null,
+ public static final ColumnIdentifier<PlanktonBatchRowModel> ATTACHMENTS = ColumnIdentifier.newId(
+ PlanktonBatchRowModel.PROPERTY_ATTACHMENTS,
n_("tutti.table.plankton.batch.header.file"),
n_("tutti.table.plankton.batch.header.file"));
-
public PlanktonBatchTableModel(TableColumnModel columnModel) {
super(columnModel);
- setNoneEditableCols(
- SAMPLE_WEIGHT,
- SAMPLING_RATIO,
- FILE
- );
+ setNoneEditableCols(SAMPLE_WEIGHT, SAMPLING_RATIO);
}
@Override
@@ -110,14 +105,12 @@
if (propertyName == SPECIES_BY_CODE) {
// update also other columns
- fireTableCellUpdated(rowIndex,
- SPECIES_BY_GENUS_CODE);
+ fireTableCellUpdated(rowIndex, SPECIES_BY_GENUS_CODE);
} else if (propertyName == SPECIES_BY_GENUS_CODE) {
// update also other columns
- fireTableCellUpdated(rowIndex,
- SPECIES_BY_CODE);
+ fireTableCellUpdated(rowIndex, SPECIES_BY_CODE);
}
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUI.jaxx
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUI.jaxx 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUI.jaxx 2012-12-15 16:05:45 UTC (rev 77)
@@ -30,6 +30,7 @@
fr.ifremer.tutti.ui.swing.TuttiUIContext
fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI
fr.ifremer.tutti.ui.swing.util.editor.LongTextEditorUI
+ fr.ifremer.tutti.ui.swing.util.editor.AttachmentEditorUI
jaxx.runtime.swing.editor.NumberEditor
@@ -72,8 +73,10 @@
<field name='sampleTotalWeight' component='sampleTotalWeightField'/>
</BeanValidator>
- <LongTextEditorUI id='longTextEditorUI'/>
+ <LongTextEditorUI id='longTextEditor'/>
+ <AttachmentEditorUI id='attachmentEditor'/>
+
<Table id='form' fill='both' constraints='BorderLayout.NORTH'>
<!-- Poids total -->
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/plankton/PlanktonBatchUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -26,40 +26,33 @@
import com.google.common.collect.Lists;
import fr.ifremer.tutti.persistence.entities.TuttiEntities;
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.FishingOperation;
import fr.ifremer.tutti.persistence.entities.data.PlanktonBatch;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.service.DecoratorService;
-import fr.ifremer.tutti.service.PersistenceService;
import fr.ifremer.tutti.ui.swing.TuttiUI;
+import fr.ifremer.tutti.ui.swing.content.operation.AbstractTuttiBatchTableUIHandler;
import fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI;
import fr.ifremer.tutti.ui.swing.util.TuttiBeanMonitor;
-import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
+import fr.ifremer.tutti.ui.swing.util.editor.AttachmentCellComponent;
import fr.ifremer.tutti.ui.swing.util.editor.LongTextCellComponent;
-import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableUIHandler;
-import fr.ifremer.tutti.ui.swing.util.table.TableRowModificationListener;
-import jaxx.runtime.SwingUtil;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.jdesktop.swingx.JXTable;
-import org.jdesktop.swingx.decorator.ComponentAdapter;
-import org.jdesktop.swingx.decorator.HighlightPredicate;
-import org.jdesktop.swingx.decorator.Highlighter;
import org.jdesktop.swingx.table.DefaultTableColumnModelExt;
import org.nuiton.util.decorator.Decorator;
-import javax.swing.event.ListSelectionListener;
import javax.swing.table.TableColumnModel;
-import java.awt.Color;
-import java.awt.Component;
-import java.awt.event.FocusEvent;
import java.util.List;
+import static org.nuiton.i18n.I18n.n_;
+
/**
* @author tchemit <chemit(a)codelutin.com>
* @since 0.2
*/
-public class PlanktonBatchUIHandler extends AbstractTuttiTableUIHandler<PlanktonBatchRowModel, PlanktonBatchUIModel> {
+public class PlanktonBatchUIHandler extends AbstractTuttiBatchTableUIHandler<PlanktonBatchRowModel, PlanktonBatchUIModel> {
/** Logger. */
private static final Log log = LogFactory.getLog(PlanktonBatchUIHandler.class);
@@ -71,32 +64,14 @@
*/
private final PlanktonBatchUI ui;
- /**
- * Persistence service.
- *
- * @since 0.2
- */
- private final PersistenceService persistenceService;
-
- /**
- * To monitor changes on the fishing operation.
- *
- * @since 0.2
- */
- private final TuttiBeanMonitor<PlanktonBatchUIModel> fishingOperationMonitor;
-
public PlanktonBatchUIHandler(FishingOperationsUI parentUi, PlanktonBatchUI ui) {
- super(parentUi.getHandler().getContext(),
+ super(parentUi, new String[]{PlanktonBatchUIModel.PROPERTY_TOTAL_WEIGHT,
+ PlanktonBatchUIModel.PROPERTY_SAMPLE_TOTAL_WEIGHT},
PlanktonBatchRowModel.PROPERTY_SPECIES_TO_CONFIRM,
PlanktonBatchRowModel.PROPERTY_SPECIES,
PlanktonBatchRowModel.PROPERTY_WEIGHT,
PlanktonBatchRowModel.PROPERTY_COMMENT);
this.ui = ui;
- this.persistenceService = context.getService(PersistenceService.class);
- this.fishingOperationMonitor = new TuttiBeanMonitor<PlanktonBatchUIModel>(
- PlanktonBatchUIModel.PROPERTY_TOTAL_WEIGHT,
- PlanktonBatchUIModel.PROPERTY_SAMPLE_TOTAL_WEIGHT
- );
}
//------------------------------------------------------------------------//
@@ -119,6 +94,11 @@
}
@Override
+ protected FishingOperation getFishingOperation() {
+ return getModel().getFishingOperation();
+ }
+
+ @Override
protected String[] getRowPropertiesToIgnore() {
return new String[]{
PlanktonBatchRowModel.PROPERTY_SAMPLE_WEIGHT,
@@ -187,15 +167,19 @@
{ // Comment column
addColumnToModel(columnModel,
- LongTextCellComponent.newEditor(ui.getLongTextEditorUI()),
- LongTextCellComponent.newRender(),
+ LongTextCellComponent.newEditor(ui.getLongTextEditor()),
+ LongTextCellComponent.newRender(n_("tutti.tooltip.comment.none")),
PlanktonBatchTableModel.COMMENT);
}
{ // File column
addColumnToModel(columnModel,
- PlanktonBatchTableModel.FILE);
+ AttachmentCellComponent.newEditor(ui.getAttachmentEditor()),
+ AttachmentCellComponent.newRender(
+ getDecorator(Attachment.class, null),
+ n_("tutti.tooltip.attachment.none")),
+ PlanktonBatchTableModel.ATTACHMENTS);
}
return columnModel;
}
@@ -244,118 +228,71 @@
}
}
- //------------------------------------------------------------------------//
- //-- AbstractTuttiUIHandler methods --//
- //------------------------------------------------------------------------//
-
@Override
- public void beforeInitUI() {
+ protected void saveSelectedRowIfRequired() {
- if (log.isInfoEnabled()) {
- log.info("beforeInit: " + ui);
- }
+ TuttiBeanMonitor<PlanktonBatchRowModel> rowMonitor = getRowMonitor();
- PlanktonBatchUIModel model = new PlanktonBatchUIModel();
- ui.setContextValue(model);
+ PlanktonBatchRowModel bean = rowMonitor.getBean();
+ if (bean != null) {
- fishingOperationMonitor.setBean(model);
- }
+ if (bean.isValid()) {
+ // there is a valid bean attached to the monitor
- @Override
- public void afterInitUI() {
+ if (rowMonitor.wasModified()) {
- if (log.isInfoEnabled()) {
- log.info("afterInit: " + ui);
- }
+ // monitored bean was modified, save it
+ if (log.isInfoEnabled()) {
+ log.info("Row " + bean + " was modified, will save it");
+ }
- initUI(ui);
+ saveRow(bean);
- JXTable table = getTable();
+ // clear modified flag on the monitor
+ rowMonitor.clearModified();
+ }
+ } else {
- // create table column model
- TableColumnModel columnModel = createTableColumnModel();
+ // row is not valid can not save it
- // create table model
- PlanktonBatchTableModel tableModel =
- new PlanktonBatchTableModel(columnModel);
+ PlanktonBatch catchBean = bean.toBean();
- table.setModel(tableModel);
- table.setColumnModel(columnModel);
- installTableKeyListener(columnModel, table);
+ if (!TuttiEntities.isNew(catchBean)) {
- table.getTableHeader().setReorderingAllowed(false);
-
-
- Highlighter readOnlyHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- HighlightPredicate.READ_ONLY, Color.LIGHT_GRAY);
-
- table.addHighlighter(readOnlyHighlighter);
- Highlighter validHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- new HighlightPredicate.AndHighlightPredicate(HighlightPredicate.EDITABLE, new HighlightPredicate() {
- @Override
- public boolean isHighlighted(Component renderer, ComponentAdapter adapter) {
-
- boolean result = false;
- if (adapter.isEditable()) {
- int rowIndex = adapter.convertRowIndexToModel(adapter.row);
- PlanktonBatchRowModel row = getTableModel().getEntry(rowIndex);
- result = !row.isValid();
- }
- return result;
- }
- }), Color.RED);
- table.addHighlighter(validHighlighter);
-
- // when model datas change let's propagate it table model
- listenRowsFromModel();
-
- // save when row chaged and was modified
- ListSelectionListener listener = new TableRowModificationListener<PlanktonBatchRowModel>(
- getTableModel(), getRowMonitor()) {
- @Override
- protected void saveSelectedRow() {
- saveSelectedRowIfRequired();
+ // remove this
+ persistenceService.deletePlanktonBatch(catchBean.getId());
+ }
}
- };
- table.getSelectionModel().addListSelectionListener(listener);
-
- // always scroll to selected row
- SwingUtil.scrollToTableSelection(getTable());
+ }
}
@Override
- public void onCloseUI() {
- if (log.isInfoEnabled()) {
- log.info("closing: " + ui);
- }
+ protected boolean isRowValid(PlanktonBatchRowModel row) {
+ boolean result = row.getSpecies() != null && row.getWeight() != null;
+ return result;
}
- //------------------------------------------------------------------------//
- //-- Public methods --//
- //------------------------------------------------------------------------//
+ @Override
+ protected void saveRow(PlanktonBatchRowModel row) {
- public void saveSelectedRowIfRequired(FocusEvent event) {
+ PlanktonBatch catchBean = row.toBean();
- Component oppositeComponent = event.getOppositeComponent();
-
- JXTable parentContainer = null;
-
- if (oppositeComponent != null) {
-
- // check out if still on table
- parentContainer = SwingUtil.getParentContainer(
- oppositeComponent, JXTable.class);
+ FishingOperation fishingOperation = getModel().getFishingOperation();
+ catchBean.setFishingOperation(fishingOperation);
+ if (log.isInfoEnabled()) {
+ log.info("Selected fishingOperation: " + fishingOperation.getId());
}
- if (parentContainer == null) {
+ if (TuttiEntities.isNew(catchBean)) {
- // out of the table can save
- if (getModel().getFishingOperation() != null) {
- saveSelectedRowIfRequired();
- }
+ catchBean = persistenceService.createPlanktonBatch(catchBean);
+ row.setId(catchBean.getId());
+ } else {
+ persistenceService.savePlanktonBatch(catchBean);
}
}
+ @Override
public void selectFishingOperation(FishingOperation bean) {
JXTable table = getTable();
@@ -419,81 +356,60 @@
fishingOperationMonitor.clearModified();
}
- public void cancel() {
+ //------------------------------------------------------------------------//
+ //-- AbstractTuttiUIHandler methods --//
+ //------------------------------------------------------------------------//
- if (log.isInfoEnabled()) {
- log.info("Cancel edition");
- }
- }
+ @Override
+ public void beforeInitUI() {
- public void save() {
if (log.isInfoEnabled()) {
- log.info("Will save");
+ log.info("beforeInit: " + ui);
}
- }
- //------------------------------------------------------------------------//
- //-- Internal methods --//
- //------------------------------------------------------------------------//
+ PlanktonBatchUIModel model = new PlanktonBatchUIModel();
+ ui.setContextValue(model);
- protected boolean isRowValid(PlanktonBatchRowModel row) {
- boolean result = row.getSpecies() != null && row.getWeight() != null;
- return result;
+ fishingOperationMonitor.setBean(model);
}
- protected void saveSelectedRowIfRequired() {
+ @Override
+ public void afterInitUI() {
- TuttiBeanMonitor<PlanktonBatchRowModel> rowMonitor = getRowMonitor();
+ if (log.isInfoEnabled()) {
+ log.info("afterInit: " + ui);
+ }
- PlanktonBatchRowModel bean = rowMonitor.getBean();
- if (bean != null) {
+ initUI(ui);
- if (bean.isValid()) {
- // there is a valid bean attached to the monitor
+ JXTable table = getTable();
- if (rowMonitor.wasModified()) {
+ // create table column model
+ TableColumnModel columnModel = createTableColumnModel();
- // monitored bean was modified, save it
- if (log.isInfoEnabled()) {
- log.info("Row " + bean + " was modified, will save it");
- }
+ // create table model
+ PlanktonBatchTableModel tableModel =
+ new PlanktonBatchTableModel(columnModel);
- saveRow(bean);
+ table.setModel(tableModel);
+ table.setColumnModel(columnModel);
- // clear modified flag on the monitor
- rowMonitor.clearModified();
- }
- } else {
-
- // row is not valid can not save it
-
- PlanktonBatch catchBean = bean.toBean();
-
- if (!TuttiEntities.isNew(catchBean)) {
-
- // remove this
- persistenceService.deletePlanktonBatch(catchBean.getId());
- }
- }
- }
+ initBatchTable(table, columnModel, tableModel);
}
- protected void saveRow(PlanktonBatchRowModel row) {
-
- PlanktonBatch catchBean = row.toBean();
-
- FishingOperation fishingOperation = getModel().getFishingOperation();
- catchBean.setFishingOperation(fishingOperation);
+ @Override
+ public void onCloseUI() {
if (log.isInfoEnabled()) {
- log.info("Selected fishingOperation: " + fishingOperation.getId());
+ log.info("closing: " + ui);
}
+ }
- if (TuttiEntities.isNew(catchBean)) {
+ //------------------------------------------------------------------------//
+ //-- Public methods --//
+ //------------------------------------------------------------------------//
- catchBean = persistenceService.createPlanktonBatch(catchBean);
- row.setId(catchBean.getId());
- } else {
- persistenceService.savePlanktonBatch(catchBean);
- }
- }
+ //------------------------------------------------------------------------//
+ //-- Internal methods --//
+ //------------------------------------------------------------------------//
+
}
\ No newline at end of file
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchRowModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchRowModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchRowModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -28,8 +28,8 @@
import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.SpeciesBatch;
import fr.ifremer.tutti.persistence.entities.data.SpeciesBatchFrequency;
-import fr.ifremer.tutti.persistence.entities.data.VracHorsVracEnum;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.persistence.entities.referential.WeightCategory;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
@@ -54,7 +54,7 @@
public static final String PROPERTY_SPECIES_TO_CONFIRM = "speciesToConfirm";
- public static final String PROPERTY_VRAC_HORS_VRAC = "vracHorsVrac";
+ public static final String PROPERTY_SORTED_UNSORTED_CATEGORY = "sortedUnsortedCategory";
public static final String PROPERTY_WEIGHT_CATEGORY = "weightCategory";
@@ -99,7 +99,7 @@
*
* @since 0.2
*/
- protected VracHorsVracEnum vracHorsVrac;
+ protected SortedUnsortedCategory sortedUnsortedCategory;
/**
* Weight category (can be null).
@@ -254,14 +254,14 @@
firePropertyChange(PROPERTY_SPECIES_TO_CONFIRM, oldValue, speciesToConfirm);
}
- public VracHorsVracEnum getVracHorsVrac() {
- return vracHorsVrac;
+ public SortedUnsortedCategory getSortedUnsortedCategory() {
+ return sortedUnsortedCategory;
}
- public void setVracHorsVrac(VracHorsVracEnum vracHorsVrac) {
- Object oldValue = getVracHorsVrac();
- this.vracHorsVrac = vracHorsVrac;
- firePropertyChange(PROPERTY_VRAC_HORS_VRAC, oldValue, vracHorsVrac);
+ public void setSortedUnsortedCategory(SortedUnsortedCategory sortedUnsortedCategory) {
+ Object oldValue = getSortedUnsortedCategory();
+ this.sortedUnsortedCategory = sortedUnsortedCategory;
+ firePropertyChange(PROPERTY_SORTED_UNSORTED_CATEGORY, oldValue, sortedUnsortedCategory);
}
public WeightCategory getWeightCategory() {
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTableModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTableModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTableModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -56,10 +56,10 @@
n_("tutti.table.species.batch.header.speciesByGenusCode"),
n_("tutti.table.species.batch.header.speciesByGenusCode"));
- public static final ColumnIdentifier<SpeciesBatchRowModel> VRAC_HORS_VRAC = ColumnIdentifier.newId(
- SpeciesBatchRowModel.PROPERTY_VRAC_HORS_VRAC,
- n_("tutti.table.species.batch.header.vracHorsVrac"),
- n_("tutti.table.species.batch.header.vracHorsVrac"));
+ public static final ColumnIdentifier<SpeciesBatchRowModel> SORTED_UNSORTED_CATEGORY = ColumnIdentifier.newId(
+ SpeciesBatchRowModel.PROPERTY_SORTED_UNSORTED_CATEGORY,
+ n_("tutti.table.species.batch.header.sortedUnsortedCategory"),
+ n_("tutti.table.species.batch.header.sortedUnsortedCategory"));
public static final ColumnIdentifier<SpeciesBatchRowModel> WEIGHT_CATEGORY = ColumnIdentifier.newId(
SpeciesBatchRowModel.PROPERTY_WEIGHT_CATEGORY,
@@ -122,11 +122,7 @@
public SpeciesBatchTableModel(TableColumnModel columnModel) {
super(columnModel);
- setNoneEditableCols(
- SAMPLE_WEIGHT,
- SAMPLING_RATIO/*,
- FILE*/
- );
+ setNoneEditableCols(SAMPLE_WEIGHT, SAMPLING_RATIO);
noneEditableColIfNoSpecies = Sets.newHashSet();
noneEditableColIfNoSpecies.add(COMPUTED_NUMBER);
noneEditableColIfNoSpecies.add(COMPUTED_WEIGHT);
@@ -167,23 +163,19 @@
} else if (propertyName == COMPUTED_NUMBER) {
// update also other columns
- fireTableCellUpdated(rowIndex,
- COMPUTED_WEIGHT);
+ fireTableCellUpdated(rowIndex, COMPUTED_WEIGHT);
} else if (propertyName == COMPUTED_WEIGHT) {
// update also other columns
- fireTableCellUpdated(rowIndex,
- COMPUTED_NUMBER);
+ fireTableCellUpdated(rowIndex, COMPUTED_NUMBER);
}
}
public void updateSamplingRatio(Set<SpeciesBatchRowModel> rows) {
for (SpeciesBatchRowModel row : rows) {
int rowIndex = getRows().indexOf(row);
- fireTableCellUpdated(rowIndex,
- SAMPLE_WEIGHT,
- SAMPLING_RATIO);
+ fireTableCellUpdated(rowIndex, SAMPLE_WEIGHT, SAMPLING_RATIO);
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTreeModel.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTreeModel.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchTreeModel.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -28,7 +28,7 @@
import com.google.common.collect.Maps;
import com.google.common.collect.Multimap;
import com.google.common.collect.Sets;
-import fr.ifremer.tutti.persistence.entities.data.VracHorsVracEnum;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import org.apache.commons.collections.CollectionUtils;
@@ -197,8 +197,9 @@
SpeciesBatchRowModel row = getNodeToRow(node);
if (row != null) {
- VracHorsVracEnum vracHorsVrac = row.getVracHorsVrac();
- if (VracHorsVracEnum.HORS_VRAC.equals(vracHorsVrac)) {
+ SortedUnsortedCategory sortedUnsortedCategory = row.getSortedUnsortedCategory();
+ if (sortedUnsortedCategory != null &&
+ "unsorted".equals(sortedUnsortedCategory.getName())) {
// never take account of a such child
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUI.jaxx
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUI.jaxx 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUI.jaxx 2012-12-15 16:05:45 UTC (rev 77)
@@ -77,11 +77,11 @@
<field name='totalHorsVracWeight' component='totalHorsVracWeightField'/>
</BeanValidator>
- <SpeciesFrequencyUI id='frequencyUI' constructorParams='handler.getContext()'/>
+ <SpeciesFrequencyUI id='frequencyEditor' constructorParams='handler.getContext()'/>
- <LongTextEditorUI id='longTextEditorUI'/>
+ <LongTextEditorUI id='longTextEditor'/>
- <AttachmentEditorUI id='attachmentEditorUI'/>
+ <AttachmentEditorUI id='attachmentEditor'/>
<Table id='form' fill='both' constraints='BorderLayout.NORTH'>
@@ -119,7 +119,7 @@
</Table>
<JScrollPane id='tableScrollPane' constraints='BorderLayout.CENTER'>
- <JXTable id='table' onFocusLost='handler.saveSelectedRowIfRequired(event);'/>
+ <JXTable id='table' onFocusLost='handler.saveSelectedRowIfRequired(event)'/>
</JScrollPane>
</JPanel>
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/species/SpeciesBatchUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -28,64 +28,54 @@
import com.google.common.collect.Lists;
import com.google.common.collect.Sets;
import fr.ifremer.tutti.persistence.entities.TuttiEntities;
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.persistence.entities.data.FishingOperation;
import fr.ifremer.tutti.persistence.entities.data.SpeciesBatch;
import fr.ifremer.tutti.persistence.entities.data.SpeciesBatchFrequency;
-import fr.ifremer.tutti.persistence.entities.data.VracHorsVracEnum;
import fr.ifremer.tutti.persistence.entities.referential.Sex;
+import fr.ifremer.tutti.persistence.entities.referential.SortedUnsortedCategory;
import fr.ifremer.tutti.persistence.entities.referential.Species;
import fr.ifremer.tutti.persistence.entities.referential.WeightCategory;
import fr.ifremer.tutti.service.DecoratorService;
-import fr.ifremer.tutti.service.PersistenceService;
import fr.ifremer.tutti.ui.swing.TuttiUI;
+import fr.ifremer.tutti.ui.swing.content.operation.AbstractTuttiBatchTableUIHandler;
import fr.ifremer.tutti.ui.swing.content.operation.FishingOperationsUI;
import fr.ifremer.tutti.ui.swing.util.TuttiBeanMonitor;
-import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import fr.ifremer.tutti.ui.swing.util.editor.AttachmentCellComponent;
import fr.ifremer.tutti.ui.swing.util.editor.LongTextCellComponent;
-import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableUIHandler;
-import fr.ifremer.tutti.ui.swing.util.table.TableRowModificationListener;
-import jaxx.runtime.SwingUtil;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.jdesktop.swingx.JXTable;
-import org.jdesktop.swingx.decorator.ComponentAdapter;
-import org.jdesktop.swingx.decorator.HighlightPredicate;
-import org.jdesktop.swingx.decorator.Highlighter;
import org.jdesktop.swingx.table.DefaultTableColumnModelExt;
import org.nuiton.util.decorator.Decorator;
-import javax.swing.event.ListSelectionListener;
import javax.swing.table.TableColumnModel;
-import java.awt.Color;
-import java.awt.Component;
-import java.awt.event.FocusEvent;
import java.util.List;
import java.util.Set;
-import com.ezware.oxbow.swingbits.table.filter.TableRowFilterSupport;
+import static org.nuiton.i18n.I18n.n_;
+
/**
* @author tchemit <chemit(a)codelutin.com>
* @since 0.1
*/
-public class SpeciesBatchUIHandler extends AbstractTuttiTableUIHandler<SpeciesBatchRowModel, SpeciesBatchUIModel> {
+public class SpeciesBatchUIHandler extends AbstractTuttiBatchTableUIHandler<SpeciesBatchRowModel, SpeciesBatchUIModel> {
/** Logger. */
- private static final Log log = LogFactory.getLog(SpeciesBatchUIHandler.class);
+ private static final Log log =
+ LogFactory.getLog(SpeciesBatchUIHandler.class);
public static final Set<String> RECOMPUTE_TOTAL_WEIGHT = Sets.newHashSet(
- SpeciesBatchRowModel.PROPERTY_VRAC_HORS_VRAC,
- SpeciesBatchRowModel.PROPERTY_WEIGHT
- );
+ SpeciesBatchRowModel.PROPERTY_SORTED_UNSORTED_CATEGORY,
+ SpeciesBatchRowModel.PROPERTY_WEIGHT);
public static final Set<String> SAMPLING_PROPERTIES = Sets.newHashSet(
SpeciesBatchRowModel.PROPERTY_SPECIES,
- SpeciesBatchRowModel.PROPERTY_VRAC_HORS_VRAC,
+ SpeciesBatchRowModel.PROPERTY_SORTED_UNSORTED_CATEGORY,
SpeciesBatchRowModel.PROPERTY_WEIGHT_CATEGORY,
SpeciesBatchRowModel.PROPERTY_SEX,
SpeciesBatchRowModel.PROPERTY_MATURITY,
- SpeciesBatchRowModel.PROPERTY_AGE
- );
+ SpeciesBatchRowModel.PROPERTY_AGE);
/**
* UI.
@@ -94,25 +84,18 @@
*/
private final SpeciesBatchUI ui;
- /**
- * Persistence service.
- *
- * @since 0.2
- */
- private final PersistenceService persistenceService;
-
- /**
- * To monitor changes on the fishing operation.
- *
- * @since 0.2
- */
- private final TuttiBeanMonitor<SpeciesBatchUIModel> fishingOperationMonitor;
-
- public SpeciesBatchUIHandler(FishingOperationsUI parentUi, SpeciesBatchUI ui) {
- super(parentUi.getHandler().getContext(),
+ public SpeciesBatchUIHandler(FishingOperationsUI parentUi,
+ SpeciesBatchUI ui) {
+ super(parentUi,
+ new String[]{
+ SpeciesBatchUIModel.PROPERTY_SAMPLE_VRAC_WEIGHT,
+ SpeciesBatchUIModel.PROPERTY_TOTAL_HORS_VRAC_WEIGHT,
+ SpeciesBatchUIModel.PROPERTY_TOTAL_VRAC_WEIGHT,
+ SpeciesBatchUIModel.PROPERTY_TOTAL_WEIGHT
+ },
SpeciesBatchRowModel.PROPERTY_SPECIES_TO_CONFIRM,
SpeciesBatchRowModel.PROPERTY_SPECIES,
- SpeciesBatchRowModel.PROPERTY_VRAC_HORS_VRAC,
+ SpeciesBatchRowModel.PROPERTY_SORTED_UNSORTED_CATEGORY,
SpeciesBatchRowModel.PROPERTY_WEIGHT_CATEGORY,
SpeciesBatchRowModel.PROPERTY_SEX,
SpeciesBatchRowModel.PROPERTY_MATURITY,
@@ -122,13 +105,6 @@
SpeciesBatchRowModel.PROPERTY_ATTACHMENTS,
SpeciesBatchRowModel.PROPERTY_FREQUENCY);
this.ui = ui;
- this.persistenceService = context.getService(PersistenceService.class);
- this.fishingOperationMonitor = new TuttiBeanMonitor<SpeciesBatchUIModel>(
- SpeciesBatchUIModel.PROPERTY_SAMPLE_VRAC_WEIGHT,
- SpeciesBatchUIModel.PROPERTY_TOTAL_HORS_VRAC_WEIGHT,
- SpeciesBatchUIModel.PROPERTY_TOTAL_VRAC_WEIGHT,
- SpeciesBatchUIModel.PROPERTY_TOTAL_WEIGHT
- );
}
//------------------------------------------------------------------------//
@@ -151,6 +127,11 @@
}
@Override
+ protected FishingOperation getFishingOperation() {
+ return getModel().getFishingOperation();
+ }
+
+ @Override
protected void onModelRowsChanged(List<SpeciesBatchRowModel> rows) {
super.onModelRowsChanged(rows);
@@ -163,8 +144,7 @@
return new String[]{
SpeciesBatchRowModel.PROPERTY_SAMPLE_WEIGHT,
SpeciesBatchRowModel.PROPERTY_SAMPLING_RATIO,
- SpeciesBatchRowModel.PROPERTY_FREQUENCY
- };
+ SpeciesBatchRowModel.PROPERTY_FREQUENCY};
}
@Override
@@ -208,13 +188,19 @@
}
- if (samplingOrder.contains(SpeciesBatchRowModel.PROPERTY_VRAC_HORS_VRAC)) {
+ if (samplingOrder.contains(SpeciesBatchRowModel.PROPERTY_SORTED_UNSORTED_CATEGORY)) {
- // Vrac / Hors vrac column
+ // SortedUnsortedCategory column
- addComboEnumColumnToModel(columnModel,
- SpeciesBatchTableModel.VRAC_HORS_VRAC,
- VracHorsVracEnum.values());
+ Decorator<SortedUnsortedCategory> decorator =
+ getDecorator(SortedUnsortedCategory.class, null);
+
+ List<SortedUnsortedCategory> data =
+ persistenceService.getAllSortedUnsortedCategory();
+
+ addComboDataColumnToModel(columnModel,
+ SpeciesBatchTableModel.SORTED_UNSORTED_CATEGORY,
+ decorator, data);
}
if (samplingOrder.contains(SpeciesBatchRowModel.PROPERTY_WEIGHT_CATEGORY)) {
@@ -275,7 +261,7 @@
{ // Computed weight column (from frequencies)
addColumnToModel(columnModel,
- FrequencyCellComponent.newEditor(ui.getFrequencyUI()),
+ FrequencyCellComponent.newEditor(ui.getFrequencyEditor()),
FrequencyCellComponent.newRender(),
SpeciesBatchTableModel.COMPUTED_WEIGHT);
}
@@ -283,7 +269,7 @@
{ // Computed number column (from frequencies)
addColumnToModel(columnModel,
- FrequencyCellComponent.newEditor(ui.getFrequencyUI()),
+ FrequencyCellComponent.newEditor(ui.getFrequencyEditor()),
FrequencyCellComponent.newRender(),
SpeciesBatchTableModel.COMPUTED_NUMBER);
}
@@ -303,16 +289,18 @@
{ // Comment column
addColumnToModel(columnModel,
- LongTextCellComponent.newEditor(ui.getLongTextEditorUI()),
- LongTextCellComponent.newRender(),
+ LongTextCellComponent.newEditor(ui.getLongTextEditor()),
+ LongTextCellComponent.newRender(n_("tutti.tooltip.comment.none")),
SpeciesBatchTableModel.COMMENT);
}
{ // File column
addColumnToModel(columnModel,
- AttachmentCellComponent.newEditor(ui.getAttachmentEditorUI()),
- AttachmentCellComponent.newRender(),
+ AttachmentCellComponent.newEditor(ui.getAttachmentEditor()),
+ AttachmentCellComponent.newRender(
+ getDecorator(Attachment.class, null),
+ n_("tutti.tooltip.attachment.none")),
SpeciesBatchTableModel.ATTACHMENTS);
}
return columnModel;
@@ -423,130 +411,91 @@
Boolean newValue) {
}
- //------------------------------------------------------------------------//
- //-- AbstractTuttiUIHandler methods --//
- //------------------------------------------------------------------------//
-
@Override
- public void beforeInitUI() {
+ protected void saveSelectedRowIfRequired() {
- if (log.isInfoEnabled()) {
- log.info("beforeInit: " + ui);
- }
+ TuttiBeanMonitor<SpeciesBatchRowModel> rowMonitor = getRowMonitor();
- SpeciesBatchUIModel model = new SpeciesBatchUIModel();
- ui.setContextValue(model);
+ SpeciesBatchRowModel bean = rowMonitor.getBean();
+ if (bean != null) {
- fishingOperationMonitor.setBean(model);
- }
+ if (bean.isValid()) {
+ // there is a valid bean attached to the monitor
- @Override
- public void afterInitUI() {
+ if (rowMonitor.wasModified()) {
- if (log.isInfoEnabled()) {
- log.info("afterInit: " + ui);
- }
+ // monitored bean was modified, save it
+ if (log.isInfoEnabled()) {
+ log.info("Row " + bean + " was modified, will save it");
+ }
- initUI(ui);
+ saveRow(bean);
- //TODO Will come from protocol
- List<String> samplingOrder = Lists.newArrayList(
- SpeciesBatchRowModel.PROPERTY_SPECIES,
- SpeciesBatchRowModel.PROPERTY_VRAC_HORS_VRAC,
- SpeciesBatchRowModel.PROPERTY_WEIGHT_CATEGORY,
- SpeciesBatchRowModel.PROPERTY_SEX
- );
+ // clear modified flag on the monitor
+ rowMonitor.clearModified();
+ }
+ } else {
- getModel().setSamplingOrder(samplingOrder);
+ // row is not valid can not save it
- JXTable table = getTable();
+ SpeciesBatch catchBean = bean.toBean();
- TableRowFilterSupport.forTable(table).searchable(true).useTableRenderers(true).apply();
+ if (!TuttiEntities.isNew(catchBean)) {
- // create table column model
- TableColumnModel columnModel = createTableColumnModel();
+ // remove this
+ persistenceService.deleteSpeciesBatch(catchBean.getId());
+ }
+ }
+ }
+ }
- // create table model
- SpeciesBatchTableModel tableModel =
- new SpeciesBatchTableModel(columnModel);
+ @Override
+ protected boolean isRowValid(SpeciesBatchRowModel row) {
- table.setModel(tableModel);
- table.setColumnModel(columnModel);
- installTableKeyListener(columnModel, table);
+ SpeciesBatchUIModel model = getModel();
- table.getTableHeader().setReorderingAllowed(false);
-
-
- Highlighter readOnlyHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- HighlightPredicate.READ_ONLY, Color.LIGHT_GRAY);
-
- table.addHighlighter(readOnlyHighlighter);
- Highlighter validHighlighter = TuttiUIUtil.newBackgroundColorHighlighter(
- new HighlightPredicate.AndHighlightPredicate(HighlightPredicate.EDITABLE, new HighlightPredicate() {
- @Override
- public boolean isHighlighted(Component renderer, ComponentAdapter adapter) {
-
- boolean result = false;
- if (adapter.isEditable()) {
- int rowIndex = adapter.convertRowIndexToModel(adapter.row);
- SpeciesBatchRowModel row = getTableModel().getEntry(rowIndex);
- result = !row.isValid();
- }
- return result;
- }
- }), Color.RED);
- table.addHighlighter(validHighlighter);
-
- // when model datas change let's propagate it table model
- listenRowsFromModel();
-
- // save when row chaged and was modified
- ListSelectionListener listener = new TableRowModificationListener<SpeciesBatchRowModel>(
- getTableModel(), getRowMonitor()) {
- @Override
- protected void saveSelectedRow() {
- saveSelectedRowIfRequired();
- }
- };
- table.getSelectionModel().addListSelectionListener(listener);
-
- // always scroll to selected row
- SwingUtil.scrollToTableSelection(getTable());
+ SpeciesBatchTreeModel samplingTreeModel = model.getSamplingTreeModel();
+ SpeciesBatchTreeNode node = samplingTreeModel.getSamplingNode(row);
+ boolean rowValid = samplingTreeModel.isValid(row, node);
+ return rowValid;
}
@Override
- public void onCloseUI() {
+ protected void saveRow(SpeciesBatchRowModel row) {
+
+ SpeciesBatch catchBean = row.toBean();
+
+ FishingOperation fishingOperation = getModel().getFishingOperation();
+ catchBean.setFishingOperation(fishingOperation);
if (log.isInfoEnabled()) {
- log.info("closing: " + ui);
+ log.info("Selected fishingOperation: " + fishingOperation.getId());
}
- }
- //------------------------------------------------------------------------//
- //-- Public methods --//
- //------------------------------------------------------------------------//
+ if (TuttiEntities.isNew(catchBean)) {
- public void saveSelectedRowIfRequired(FocusEvent event) {
+ catchBean = persistenceService.createSpeciesBatch(catchBean);
+ row.setId(catchBean.getId());
+ } else {
+ persistenceService.saveSpeciesBatch(catchBean);
+ }
- Component oppositeComponent = event.getOppositeComponent();
+ List<SpeciesFrequencyRowModel> frequencyRows = row.getFrequency();
- JXTable parentContainer = null;
+ List<SpeciesBatchFrequency> frequency =
+ SpeciesFrequencyRowModel.toBeans(frequencyRows, catchBean);
- if (oppositeComponent != null) {
-
- // check out if still on table
- parentContainer = SwingUtil.getParentContainer(
- oppositeComponent, JXTable.class);
+ if (log.isInfoEnabled()) {
+ log.info("Will save " + frequency.size() + " frequencies.");
}
+ frequency = persistenceService.saveSpeciesBatchFrequency(
+ catchBean.getId(), frequency);
- if (parentContainer == null) {
-
- // out of the table can save
- if (getModel().getFishingOperation() != null) {
- saveSelectedRowIfRequired();
- }
- }
+ // push it back to row model
+ frequencyRows = SpeciesFrequencyRowModel.fromBeans(frequency);
+ row.setFrequency(frequencyRows);
}
+ @Override
public void selectFishingOperation(FishingOperation bean) {
JXTable table = ui.getTable();
@@ -613,6 +562,68 @@
}
//------------------------------------------------------------------------//
+ //-- AbstractTuttiUIHandler methods --//
+ //------------------------------------------------------------------------//
+
+ @Override
+ public void beforeInitUI() {
+
+ if (log.isInfoEnabled()) {
+ log.info("beforeInit: " + ui);
+ }
+
+ SpeciesBatchUIModel model = new SpeciesBatchUIModel();
+ ui.setContextValue(model);
+
+ fishingOperationMonitor.setBean(model);
+ }
+
+ @Override
+ public void afterInitUI() {
+
+ if (log.isInfoEnabled()) {
+ log.info("afterInit: " + ui);
+ }
+
+ initUI(ui);
+
+ //TODO Will come from protocol
+ List<String> samplingOrder = Lists.newArrayList(
+ SpeciesBatchRowModel.PROPERTY_SPECIES,
+ SpeciesBatchRowModel.PROPERTY_SORTED_UNSORTED_CATEGORY,
+ SpeciesBatchRowModel.PROPERTY_WEIGHT_CATEGORY,
+ SpeciesBatchRowModel.PROPERTY_SEX
+ );
+
+ getModel().setSamplingOrder(samplingOrder);
+
+ JXTable table = getTable();
+
+ // create table column model
+ TableColumnModel columnModel = createTableColumnModel();
+
+ // create table model
+ SpeciesBatchTableModel tableModel =
+ new SpeciesBatchTableModel(columnModel);
+
+ table.setModel(tableModel);
+ table.setColumnModel(columnModel);
+
+ initBatchTable(table, columnModel, tableModel);
+ }
+
+ @Override
+ public void onCloseUI() {
+ if (log.isInfoEnabled()) {
+ log.info("closing: " + ui);
+ }
+ }
+
+ //------------------------------------------------------------------------//
+ //-- Public methods --//
+ //------------------------------------------------------------------------//
+
+ //------------------------------------------------------------------------//
//-- Internal methods --//
//------------------------------------------------------------------------//
@@ -660,7 +671,6 @@
getTableModel().updateSamplingRatio(samplingContext.getSamplingRows());
}
-
protected void recomputeTotalHorsVrac() {
// recompute total hors vrac
@@ -668,20 +678,24 @@
Float totalVrac = 0f;
for (SpeciesBatchRowModel batch : getModel().getRows()) {
- VracHorsVracEnum vracHorsVrac = batch.getVracHorsVrac();
+ SortedUnsortedCategory vracHorsVrac = batch.getSortedUnsortedCategory();
+
if (vracHorsVrac == null) {
// can't sum anything
- } else if (vracHorsVrac == VracHorsVracEnum.HORS_VRAC) {
- Float weight = batch.getWeight();
- if (weight != null) {
- totalHorsVrac += weight;
+ } else {
+ boolean unsorted = "unsorted".equals(vracHorsVrac.getName());
+ if (unsorted) {
+ Float weight = batch.getWeight();
+ if (weight != null) {
+ totalHorsVrac += weight;
+ }
+ } else {
+ Float weight = batch.getWeight();
+ if (weight != null) {
+ totalVrac += weight;
+ }
}
- } else if (vracHorsVrac == VracHorsVracEnum.VRAC) {
- Float weight = batch.getWeight();
- if (weight != null) {
- totalVrac += weight;
- }
}
}
if (log.isInfoEnabled()) {
@@ -692,75 +706,4 @@
//TODO Should we also set the total vrac weight ?
// getModel().setTotalVracWeight(totalVrac);
}
-
- protected void saveSelectedRowIfRequired() {
-
- TuttiBeanMonitor<SpeciesBatchRowModel> rowMonitor = getRowMonitor();
-
- SpeciesBatchRowModel bean = rowMonitor.getBean();
- if (bean != null) {
-
- if (bean.isValid()) {
- // there is a valid bean attached to the monitor
-
- if (rowMonitor.wasModified()) {
-
- // monitored bean was modified, save it
- if (log.isInfoEnabled()) {
- log.info("Row " + bean + " was modified, will save it");
- }
-
- saveRow(bean);
-
- // clear modified flag on the monitor
- rowMonitor.clearModified();
- }
- } else {
-
- // row is not valid can not save it
-
- SpeciesBatch catchBean = bean.toBean();
-
- if (!TuttiEntities.isNew(catchBean)) {
-
- // remove this
- persistenceService.deleteSpeciesBatch(catchBean.getId());
- }
- }
- }
- }
-
- protected void saveRow(SpeciesBatchRowModel row) {
-
- SpeciesBatch catchBean = row.toBean();
-
- FishingOperation fishingOperation = getModel().getFishingOperation();
- catchBean.setFishingOperation(fishingOperation);
- if (log.isInfoEnabled()) {
- log.info("Selected fishingOperation: " + fishingOperation.getId());
- }
-
- if (TuttiEntities.isNew(catchBean)) {
-
- catchBean = persistenceService.createSpeciesBatch(catchBean);
- row.setId(catchBean.getId());
- } else {
- persistenceService.saveSpeciesBatch(catchBean);
- }
-
- List<SpeciesFrequencyRowModel> frequencyRows = row.getFrequency();
-
- List<SpeciesBatchFrequency> frequency =
- SpeciesFrequencyRowModel.toBeans(frequencyRows, catchBean);
-
- if (log.isInfoEnabled()) {
- log.info("Will save " + frequency.size() + " frequencies.");
- }
- frequency = persistenceService.saveSpeciesBatchFrequency(
- catchBean.getId(), frequency);
-
- // push it back to row model
- frequencyRows = SpeciesFrequencyRowModel.fromBeans(frequency);
- row.setFrequency(frequencyRows);
- }
}
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -25,6 +25,7 @@
*/
import com.google.common.base.Preconditions;
+import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.ComponentMover;
import fr.ifremer.tutti.ui.swing.util.ComponentResizer;
@@ -36,24 +37,31 @@
import jaxx.runtime.SwingUtil;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
+import org.nuiton.util.decorator.Decorator;
+import javax.swing.AbstractAction;
import javax.swing.AbstractCellEditor;
import javax.swing.BorderFactory;
import javax.swing.JButton;
+import javax.swing.JComponent;
import javax.swing.JDialog;
+import javax.swing.JRootPane;
import javax.swing.JTable;
+import javax.swing.KeyStroke;
import javax.swing.border.LineBorder;
import javax.swing.table.TableCellEditor;
import javax.swing.table.TableCellRenderer;
import java.awt.Color;
import java.awt.Component;
import java.awt.Frame;
+import java.awt.event.ActionEvent;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
+import java.util.Collection;
import static org.nuiton.i18n.I18n._;
@@ -73,11 +81,11 @@
public AttachmentCellComponent() {
setContentAreaFilled(false);
setOpaque(false);
- setIcon(SwingUtil.createActionIcon("edit"));
+ setIcon(SwingUtil.createActionIcon("edit-attachment"));
}
- public static TableCellRenderer newRender() {
- return new AttachmentCellRenderer();
+ public static TableCellRenderer newRender(Decorator<Attachment> decorator, String noneText) {
+ return new AttachmentCellRenderer(decorator, noneText);
}
public static TableCellEditor newEditor(AttachmentEditorUI ui) {
@@ -145,6 +153,16 @@
editor.setUndecorated(true);
editor.add(ui);
editor.setResizable(true);
+ JRootPane rootPane = editor.getRootPane();
+ rootPane.getInputMap(JComponent.WHEN_IN_FOCUSED_WINDOW).put(KeyStroke.getKeyStroke("ESCAPE"), "close");
+ rootPane.getActionMap().put("close", new AbstractAction() {
+ private static final long serialVersionUID = 1L;
+
+ @Override
+ public void actionPerformed(ActionEvent e) {
+ ui.getHandler().close();
+ }
+ });
editor.pack();
ComponentResizer cr = new ComponentResizer();
@@ -250,10 +268,19 @@
protected final AttachmentCellComponent component;
+ public static final String TEXT_PATTERN = "<html><body>%s</body></html>";
+
+ private final String noneText;
+
+ private final Decorator<Attachment> decorator;
+
protected String propertyName;
- public AttachmentCellRenderer() {
+ public AttachmentCellRenderer(Decorator<Attachment> decorator,
+ String noneText) {
component = new AttachmentCellComponent();
+ this.noneText = noneText;
+ this.decorator = decorator;
}
@Override
@@ -264,7 +291,8 @@
int row,
int column) {
- String text;
+ String textValue;
+
if (value == null) {
if (propertyName == null) {
AbstractTuttiTableModel tableModel =
@@ -273,13 +301,18 @@
propertyName = columnIdentifier.getPropertyName();
}
// use HTML to show the tooltip in italic
- text = "<html><body><i>" + _("tutti.tooltip." + propertyName + ".none") + "</i></body></html>";
+ textValue = "<i>" + _(noneText) + "</i>";
} else {
+ Collection<Attachment> attachments = (Collection<Attachment>) value;
+ StringBuilder sb = new StringBuilder();
+ for (Attachment attachment : attachments) {
+ sb.append("<br/>").append(decorator.toString(attachment));
+ }
// use html to display the tooltip on several lines
- text = "<html><body>" + String.valueOf(value).replace("\n", "<br/>") + "</body></html>";
+ textValue = sb.substring(5);
}
-
+ String text = String.format(TEXT_PATTERN, textValue);
boolean editable = table.isCellEditable(row, column);
component.setEnabled(editable);
component.setToolTipText(text);
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -34,20 +34,26 @@
import fr.ifremer.tutti.ui.swing.util.table.ColumnIdentifier;
import jaxx.runtime.JAXXUtil;
import jaxx.runtime.SwingUtil;
+import org.apache.commons.lang3.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
+import javax.swing.AbstractAction;
import javax.swing.AbstractCellEditor;
import javax.swing.BorderFactory;
import javax.swing.JButton;
+import javax.swing.JComponent;
import javax.swing.JDialog;
+import javax.swing.JRootPane;
import javax.swing.JTable;
+import javax.swing.KeyStroke;
import javax.swing.border.LineBorder;
import javax.swing.table.TableCellEditor;
import javax.swing.table.TableCellRenderer;
import java.awt.Color;
import java.awt.Component;
import java.awt.Frame;
+import java.awt.event.ActionEvent;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
@@ -73,11 +79,11 @@
public LongTextCellComponent() {
setContentAreaFilled(false);
setOpaque(false);
- setIcon(SwingUtil.createActionIcon("edit"));
+ setIcon(SwingUtil.createActionIcon("edit-comment"));
}
- public static TableCellRenderer newRender() {
- return new LongTextCellRenderer();
+ public static TableCellRenderer newRender(String noneText) {
+ return new LongTextCellRenderer(noneText);
}
public static TableCellEditor newEditor(LongTextEditorUI ui) {
@@ -150,7 +156,16 @@
editor.add(ui);
editor.setSize(DEFAULT_EDITOR_WIDTH, DEFAULT_EDITOR_HEIGHT);
editor.setResizable(true);
+ JRootPane rootPane = editor.getRootPane();
+ rootPane.getInputMap(JComponent.WHEN_IN_FOCUSED_WINDOW).put(KeyStroke.getKeyStroke("ESCAPE"), "close");
+ rootPane.getActionMap().put("close", new AbstractAction() {
+ private static final long serialVersionUID = 1L;
+ @Override
+ public void actionPerformed(ActionEvent e) {
+ ui.getHandler().close();
+ }
+ });
ComponentResizer cr = new ComponentResizer();
cr.registerComponent(editor);
ComponentMover cm = new ComponentMover();
@@ -256,8 +271,13 @@
protected String propertyName;
- public LongTextCellRenderer() {
+ public static final String TEXT_PATTERN = "<html><body>%s</body></html>";
+
+ private final String noneText;
+
+ public LongTextCellRenderer(String noneText) {
component = new LongTextCellComponent();
+ this.noneText = noneText;
}
@Override
@@ -268,22 +288,26 @@
int row,
int column) {
- String text;
- if (value == null) {
+// String text;
+ String textValue;
+ if (StringUtils.isBlank((String)value)) {
if (propertyName == null) {
AbstractTuttiTableModel tableModel =
(AbstractTuttiTableModel) table.getModel();
- ColumnIdentifier columnIdentifier = tableModel.getPropertyName(column);
+ ColumnIdentifier columnIdentifier =
+ tableModel.getPropertyName(column);
propertyName = columnIdentifier.getPropertyName();
}
// use HTML to show the tooltip in italic
- text = "<html><body><i>" + _("tutti.tooltip." + propertyName + ".none") + "</i></body></html>";
+ textValue = "<i>" + _(noneText) + "</i>";
} else {
// use html to display the tooltip on several lines
- text = "<html><body>" + String.valueOf(value).replace("\n", "<br/>") + "</body></html>";
+ textValue = String.valueOf(value).replace("\n", "<br/>");
}
+ String text = String.format(TEXT_PATTERN, textValue);
+
boolean editable = table.isCellEditable(row, column);
component.setEnabled(editable);
component.setToolTipText(text);
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.jaxx
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.jaxx 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.jaxx 2012-12-15 16:05:45 UTC (rev 77)
@@ -27,7 +27,7 @@
<String id='property' javaBean='""'/>
<!-- bean property -->
- <fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel id='bean' javaBean='null'/>
+ <Object id='bean' javaBean='null'/>
<LongTextEditorUIHandler id='handler' constructorParams='this'/>
@@ -35,7 +35,7 @@
<cell fill='both' weightx='1'>
<JScrollPane>
<JTextArea id='textContent'
- onKeyReleased='handler.setText()'/>
+ onKeyReleased='handler.setText(((JTextArea)event.getSource()).getText())'/>
</JScrollPane>
</cell>
</row>
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -24,7 +24,6 @@
* #L%
*/
-import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import jaxx.runtime.SwingUtil;
import org.apache.commons.lang3.StringUtils;
@@ -43,7 +42,8 @@
*/
public class LongTextEditorUIHandler {
- private static final Log log = LogFactory.getLog(LongTextEditorUIHandler.class);
+ private static final Log log =
+ LogFactory.getLog(LongTextEditorUIHandler.class);
private final LongTextEditorUI ui;
@@ -53,35 +53,23 @@
ui.addPropertyChangeListener(new PropertyChangeListener() {
public void propertyChange(PropertyChangeEvent evt) {
- AbstractTuttiBeanUIModel bean = ui.getBean();
+ Object bean = ui.getBean();
String property = ui.getProperty();
if (bean != null && !StringUtils.isEmpty(property)) {
Object value = TuttiUIUtil.getProperty(bean, property);
- if (value == null) {
- value = "";
- }
- ui.getTextContent().setText(value.toString());
+ ui.getTextContent().setText(SwingUtil.getStringValue(value));
}
}
});
}
/** pushes the typed text in the property of the bean */
- public void setText() {
- String value = ui.getTextContent().getText();
- AbstractTuttiBeanUIModel bean = ui.getBean();
+ public void setText(String value) {
+ Object bean = ui.getBean();
String property = ui.getProperty();
TuttiUIUtil.setProperty(bean, property, value);
}
- public void resetText() {
- AbstractTuttiBeanUIModel bean = ui.getBean();
- String property = ui.getProperty();
- TuttiUIUtil.setProperty(bean, property, null);
-
- ui.getTextContent().setText("");
- }
-
/** closes the editor */
public void close() {
if (log.isInfoEnabled()) {
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/table/AbstractTuttiTableUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/table/AbstractTuttiTableUIHandler.java 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/table/AbstractTuttiTableUIHandler.java 2012-12-15 16:05:45 UTC (rev 77)
@@ -32,13 +32,13 @@
import fr.ifremer.tutti.ui.swing.util.TuttiBeanMonitor;
import jaxx.runtime.SwingUtil;
import jaxx.runtime.swing.JAXXWidgetUtil;
-import jaxx.runtime.swing.editor.EnumEditor;
import jaxx.runtime.swing.editor.bean.BeanUIUtil;
import jaxx.runtime.swing.editor.cell.NumberCellEditor;
import jaxx.runtime.swing.renderer.DecoratorTableCellRenderer;
import org.apache.commons.lang3.ArrayUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
+import org.jdesktop.swingx.JXTable;
import org.jdesktop.swingx.autocomplete.ComboBoxCellEditor;
import org.jdesktop.swingx.autocomplete.ObjectToStringConverter;
import org.jdesktop.swingx.table.TableColumnExt;
@@ -82,7 +82,7 @@
*/
private final TuttiBeanMonitor<R> rowMonitor;
- protected abstract JTable getTable();
+ protected abstract JXTable getTable();
protected abstract AbstractTuttiTableModel<R> getTableModel();
@@ -101,6 +101,7 @@
Boolean oldValue,
Boolean newValue);
+
protected String[] getRowPropertiesToIgnore() {
return ArrayUtils.EMPTY_STRING_ARRAY;
}
@@ -211,7 +212,6 @@
editor.getNumberEditor().getTextField().addKeyListener(keyAdapter);
}
}
-
return keyAdapter;
}
@@ -276,7 +276,8 @@
protected <B> void addComboDataColumnToModel(TableColumnModel model,
ColumnIdentifier<R> identifier,
- Decorator<B> decorator, List<B> data) {
+ Decorator<B> decorator,
+ List<B> data) {
JComboBox comboBox = new JComboBox();
comboBox.setRenderer(newListCellRender(decorator));
SwingUtil.fillComboBox(comboBox, data, null);
@@ -291,19 +292,6 @@
identifier);
}
- protected <B extends Enum<B>> void addComboEnumColumnToModel(TableColumnModel model,
- ColumnIdentifier<R> identifier,
- B[] data) {
- EnumEditor<B> comboBox = EnumEditor.newEditor(data);
- BeanUIUtil.decorate(comboBox, ObjectToStringConverter.DEFAULT_IMPLEMENTATION);
- TableCellEditor editor = new ComboBoxCellEditor(comboBox);
-
- addColumnToModel(model,
- editor,
- null,
- identifier);
- }
-
protected void listenRowsFromModel() {
getModel().addPropertyChangeListener(AbstractTuttiTableUIModel.PROPERTY_ROWS, new PropertyChangeListener() {
@Override
Modified: trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
===================================================================
--- trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-15 00:14:45 UTC (rev 76)
+++ trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-15 16:05:45 UTC (rev 77)
@@ -108,6 +108,7 @@
tutti.label.list.gear=Engin(s)
tutti.label.list.headOfMission=Chef(s) de mission
tutti.label.list.headOfSortRoom=Reponsable(s) de salle de tri
+tutti.label.list.saisisseur=Saisisseur(s)
tutti.label.list.vessel=Navire(s)
tutti.label.macroWaste.totalWeight=Poids total
tutti.label.no.fishingOperation.selected=< Aucun trait sélectionné >
@@ -146,6 +147,11 @@
tutti.menu.synchronisationImport.tip=Effectuer des imports
tutti.menu.synchronisations=Synchronisation
tutti.menu.synchronisations.tip=Import/Export
+tutti.table.accidental.batch.header.comment=Commentaire
+tutti.table.accidental.batch.header.file=Pièces-jointes
+tutti.table.accidental.batch.header.speciesByCode=Espèce
+tutti.table.accidental.batch.header.speciesByGenusCode=Espèce
+tutti.table.accidental.batch.header.weight=Poids observé
tutti.table.benthos.batch.header.comment=Commentaire
tutti.table.benthos.batch.header.elevationRate=Fraction d'élévation
tutti.table.benthos.batch.header.file=Pièces jointes
@@ -156,6 +162,7 @@
tutti.table.benthos.batch.header.weight=Poids
tutti.table.macrowaste.batch.header.comment=Commentaire
tutti.table.macrowaste.batch.header.file=Pièces jointes
+tutti.table.macrowaste.batch.header.macroWasteCategory=Catégorie
tutti.table.macrowaste.batch.header.speciesByCode=Espèce
tutti.table.macrowaste.batch.header.speciesByGenusCode=Espèce
tutti.table.macrowaste.batch.header.weight=Poids
@@ -176,10 +183,10 @@
tutti.table.species.batch.header.maturity=Maturité
tutti.table.species.batch.header.sampleWeight=Poids échantillonné
tutti.table.species.batch.header.sex=Sexe
+tutti.table.species.batch.header.sortedUnsortedCategory=Vrac / Hors Vrac
tutti.table.species.batch.header.speciesByCode=Espèce
tutti.table.species.batch.header.speciesByGenusCode=Espèce
tutti.table.species.batch.header.toConfirm=A Confirmer
-tutti.table.species.batch.header.vracHorsVrac=Vrac / Hors Vrac
tutti.table.species.batch.header.weight=Poids
tutti.table.species.batch.header.weightCategory=Catégorie Poids
tutti.table.species.frequency.header.computedWeight=Poids calculé
@@ -200,7 +207,9 @@
tutti.title.selectedCruise=Campagne %s
tutti.title.selectedProgram=Série de campagne %s
tutti.to.be.done=< A FAIRE >
-tutti.tooltip.comment.none=Aucun
+tutti.tooltip.=
+tutti.tooltip.attachment.none=Pas de pièce-jointes
+tutti.tooltip.comment.none=Pas de commentaire
tutti.validator.error.cruise.beginDate.required=La date de début est obligatoire
tutti.validator.error.cruise.country.required=Le pays est obligatoire
tutti.validator.error.cruise.endDate.required=La date de fin est obligatoire
Added: trunk/tutti-ui-swing/src/main/resources/icons/action-edit-attachment.png
===================================================================
(Binary files differ)
Property changes on: trunk/tutti-ui-swing/src/main/resources/icons/action-edit-attachment.png
___________________________________________________________________
Added: svn:mime-type
+ image/png
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: trunk/tutti-ui-swing/src/main/resources/icons/action-edit-comment.png
===================================================================
(Binary files differ)
Property changes on: trunk/tutti-ui-swing/src/main/resources/icons/action-edit-comment.png
___________________________________________________________________
Added: svn:mime-type
+ image/png
Added: svn:keywords
+ Author Date Id Revision HeadURL
1
0
Author: tchemit
Date: 2012-12-15 01:14:45 +0100 (Sat, 15 Dec 2012)
New Revision: 76
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/76
Log:
use last stable of jaxx
Modified:
trunk/pom.xml
Modified: trunk/pom.xml
===================================================================
--- trunk/pom.xml 2012-12-15 00:09:07 UTC (rev 75)
+++ trunk/pom.xml 2012-12-15 00:14:45 UTC (rev 76)
@@ -91,7 +91,7 @@
<h2Version>1.3.168</h2Version>
<postgresqlVersion>9.1-901-1.jdbc4</postgresqlVersion>
- <jaxxVersion>2.5.8-SNAPSHOT</jaxxVersion>
+ <jaxxVersion>2.5.8</jaxxVersion>
<swingXVersion>1.6.4</swingXVersion>
<xworkVersion>2.3.7</xworkVersion>
1
0
Author: tchemit
Date: 2012-12-15 01:09:07 +0100 (Sat, 15 Dec 2012)
New Revision: 75
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/75
Log:
can not release with a snapshot
Modified:
trunk/pom.xml
Modified: trunk/pom.xml
===================================================================
--- trunk/pom.xml 2012-12-14 23:53:10 UTC (rev 74)
+++ trunk/pom.xml 2012-12-15 00:09:07 UTC (rev 75)
@@ -16,7 +16,7 @@
<modules>
<module>tutti-persistence</module>
<module>tutti-persistence-dev</module>
- <module>tutti-persistence-adagio</module>
+ <!--module>tutti-persistence-adagio</module-->
<module>tutti-service</module>
<module>tutti-ui-swing</module>
</modules>
1
0
14 Dec '12
Author: tchemit
Date: 2012-12-15 00:53:10 +0100 (Sat, 15 Dec 2012)
New Revision: 74
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/74
Log:
fix i18n file (last time\! no now is lats time :D)
Modified:
trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
Modified: trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
===================================================================
--- trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-14 23:52:06 UTC (rev 73)
+++ trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-14 23:53:10 UTC (rev 74)
@@ -44,7 +44,7 @@
tutti.label.attachmentEditor.file=Fichier
tutti.label.attachmentEditor.fileComment=Commentaire
tutti.label.attachmentEditor.fileName=Nom
-tutti.label.benthos.sampleTotalWeight=Poids total \u00c3\u00a9chantillonn\u00c3\u00a9
+tutti.label.benthos.sampleTotalWeight=Poids total échantillonné
tutti.label.benthos.totalWeight=Poids total
tutti.label.comment=Commentaire
tutti.label.cruise=Campagne
1
0
14 Dec '12
Author: tchemit
Date: 2012-12-15 00:52:06 +0100 (Sat, 15 Dec 2012)
New Revision: 73
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/73
Log:
fix i18n file (last time\!)
Modified:
trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
Modified: trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties
===================================================================
--- trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-14 23:44:19 UTC (rev 72)
+++ trunk/tutti-ui-swing/src/main/resources/i18n/tutti-ui-swing_fr_FR.properties 2012-12-14 23:52:06 UTC (rev 73)
@@ -1,7 +1,7 @@
tutti.about.bottomText=Copyright %s - %s - version %s
-tutti.about.message=<h3>Tutti</h3><p><strong>Outil de saisie de donn\u00c3\u00a9es d'op\u00c3\u00a9rations et de captures au cours des campagnes halieutiques.</strong></p><br/><p>Ce logiciel permettra la saisie en mer des donn\u00c3\u00a9es d'op\u00c3\u00a9ration de p\u00c3\u00aache (positions, environnement, engin, etc) et des captures associ\u00c3\u00a9es (composition de la capture en esp\u00c3\u00a8ces scientifiques avec poids, nombres, tailles etc) pour l'ensemble des campagnes halieutiques r\u00c3\u00a9alis\u00c3\u00a9es par l'Ifremer.</p><p>Ce projet a \u00c3\u00a9t\u00c3\u00a9 initi\u00c3\u00a9e en 2012 par l'<a href\="http\://www.ifremer.fr">Ifremer</a> et r\u00c3\u00a9alis\u00c3\u00a9 par la soci\u00c3\u00a9t\u00c3\u00a9 <a href\="http\://codelutin.com">Codelutin</a>.</p><hr/><br/><p>Pour plus d'informations, vous pouvez visiter le <a href\="http\://maven-site.forge.codelutin.com/tutti">site du projet</a>.</p><p>Projet h\u00c3\u00a9berg\u00c3\u00a9 sur la forge <a href\="http\://forge.codelutin.com/projects/tutti">Forge.codelutin.com</a>.</p>
-tutti.action.about=\u00c3\u0080 propos
-tutti.action.about.tip=\u00c3\u0080 Propos
+tutti.about.message=<h3>Tutti</h3><p><strong>Outil de saisie de données d'opérations et de captures au cours des campagnes halieutiques.</strong></p><br/><p>Ce logiciel permettra la saisie en mer des données d'opération de pêche (positions, environnement, engin, etc) et des captures associées (composition de la capture en espèces scientifiques avec poids, nombres, tailles etc) pour l'ensemble des campagnes halieutiques réalisées par l'Ifremer.</p><p>Ce projet a été initiée en 2012 par l'<a href\="http\://www.ifremer.fr">Ifremer</a> et réalisé par la société <a href\="http\://codelutin.com">Codelutin</a>.</p><hr/><br/><p>Pour plus d'informations, vous pouvez visiter le <a href\="http\://maven-site.forge.codelutin.com/tutti">site du projet</a>.</p><p>Projet hébergé sur la forge <a href\="http\://forge.codelutin.com/projects/tutti">Forge.codelutin.com</a>.</p>
+tutti.action.about=À propos
+tutti.action.about.tip=À Propos
tutti.action.cancel=Annuler
tutti.action.casino-import=Import Casino
tutti.action.catches=Captures
@@ -13,21 +13,21 @@
tutti.action.exit.tip=Quitter l'application
tutti.action.fillCatches=Captures
tutti.action.fillCatches.tip=Saisir des captures
-tutti.action.generate=G\u00c3\u00a9n\u00c3\u00a9rer
-tutti.action.generateCampaignName=G\u00c3\u00a9n\u00c3\u00a9rer le nom
+tutti.action.generate=Générer
+tutti.action.generateCampaignName=Générer le nom
tutti.action.manageProtocol=Protocole
-tutti.action.manageProtocol.tip=G\u00c3\u00a9rer les protocoles
+tutti.action.manageProtocol.tip=Gérer les protocoles
tutti.action.new=Nouveau
tutti.action.pupitri-import=Import PUPITRI
tutti.action.reload.actions=Recharger les actions
tutti.action.reload.home=Reload home screen
tutti.action.reload.ui=Recharger l'interface graphique
-tutti.action.reset.fishingOperationValidState=R\u00c3\u00a9initialiser
+tutti.action.reset.fishingOperationValidState=Réinitialiser
tutti.action.save=Enregistrer
tutti.action.selectCampaign=Campagne
-tutti.action.selectCampaign.tip=S\u00c3\u00a9lectionner la campagne \u00c3\u00a0 utiliser
+tutti.action.selectCampaign.tip=Sélectionner la campagne à utiliser
tutti.action.site=Site
-tutti.action.site.tip=Acc\u00c3\u00a9der au site du projet Tutti
+tutti.action.site.tip=Accéder au site du projet Tutti
tutti.application.config=Configuration de l'application Tutti
tutti.application.name=Tutti
tutti.config.category.applications=Application
@@ -36,11 +36,11 @@
tutti.config.category.other.description=Autres options
tutti.config.category.shortcuts=Raccourcis
tutti.config.category.shortcuts.description=Liste des raccourcis clavier
-tutti.config.cruiseId=Identifiant de la derni\u00c3\u00a8re campagne utilis\u00c3\u00a9e
-tutti.config.programId=Identifiant de la derni\u00c3\u00a8re s\u00c3\u00a9rie de campagne utilis\u00c3\u00a9e
-tutti.config.ui.autoPopupNumberEditor=Toujours afficher le pav\u00c3\u00a9 num\u00c3\u00a9rique lors de l'\u00c3\u00a9dition d'un nombre
+tutti.config.cruiseId=Identifiant de la dernière campagne utilisée
+tutti.config.programId=Identifiant de la dernière série de campagne utilisée
+tutti.config.ui.autoPopupNumberEditor=Toujours afficher le pavé numérique lors de l'édition d'un nombre
tutti.config.ui.config=Chemin du fichier de configuration des interfaces graphiques
-tutti.config.ui.showNumberEditorButton=Afficher le pav\u00c3\u00a9 num\u00c3\u00a9rique de saisie
+tutti.config.ui.showNumberEditorButton=Afficher le pavé numérique de saisie
tutti.label.attachmentEditor.file=Fichier
tutti.label.attachmentEditor.fileComment=Commentaire
tutti.label.attachmentEditor.fileName=Nom
@@ -48,75 +48,75 @@
tutti.label.benthos.totalWeight=Poids total
tutti.label.comment=Commentaire
tutti.label.cruise=Campagne
-tutti.label.cruise.beginDate=Date de d\u00c3\u00a9but
+tutti.label.cruise.beginDate=Date de début
tutti.label.cruise.country=Pays
tutti.label.cruise.endDate=Date de fin
tutti.label.cruise.name=Nom
tutti.label.cruise.poche=Nombre de poches
-tutti.label.cruise.program=S\u00c3\u00a9rie
-tutti.label.cruise.surveyPart=S\u00c3\u00a9rie partielle
-tutti.label.cruise.year=Ann\u00c3\u00a9e
-tutti.label.fishingOperation.averageBottomSalinity=Salinit\u00c3\u00a9 de fond moyenne
-tutti.label.fishingOperation.averageBottomTemperature=Temp\u00c3\u00a9rature de fond moyenne
+tutti.label.cruise.program=Série
+tutti.label.cruise.surveyPart=Série partielle
+tutti.label.cruise.year=Année
+tutti.label.fishingOperation.averageBottomSalinity=Salinité de fond moyenne
+tutti.label.fishingOperation.averageBottomTemperature=Température de fond moyenne
tutti.label.fishingOperation.beaufortScale=Force du vent
tutti.label.fishingOperation.date=Date
-tutti.label.fishingOperation.distanceChalutee=Distance chalut\u00c3\u00a9e
-tutti.label.fishingOperation.duree=Dur\u00c3\u00a9e
+tutti.label.fishingOperation.distanceChalutee=Distance chalutée
+tutti.label.fishingOperation.duree=Durée
tutti.label.fishingOperation.fishingOperationInvalid=Trait invalide
-tutti.label.fishingOperation.fishingOperationNumber=Num\u00c3\u00a9ro de Trait
+tutti.label.fishingOperation.fishingOperationNumber=Numéro de Trait
tutti.label.fishingOperation.fishingOperationRectiligne=Trait rectiligne
tutti.label.fishingOperation.fishingOperationValid=Trait valide
tutti.label.fishingOperation.gearDate=Date
tutti.label.fishingOperation.gearLatitude=Latitude
tutti.label.fishingOperation.gearLongitude=Longitude
tutti.label.fishingOperation.gearShootingEnd=Fin de traine
-tutti.label.fishingOperation.gearShootingEndBottomSalinity=Salinit\u00c3\u00a9 de fond fin de traine
-tutti.label.fishingOperation.gearShootingEndBottomTemperature=Temp\u00c3\u00a9rature de fond fin de traine
+tutti.label.fishingOperation.gearShootingEndBottomSalinity=Salinité de fond fin de traine
+tutti.label.fishingOperation.gearShootingEndBottomTemperature=Température de fond fin de traine
tutti.label.fishingOperation.gearShootingEndDepth=Profondeur fin de traine
-tutti.label.fishingOperation.gearShootingEndSurfaceSalinity=Salinit\u00c3\u00a9 de surface fin de traine
+tutti.label.fishingOperation.gearShootingEndSurfaceSalinity=Salinité de surface fin de traine
tutti.label.fishingOperation.gearShootingEndSurfaceTemperature=Temperature de surface fin de traine
-tutti.label.fishingOperation.gearShootingStart=D\u00c3\u00a9but de traine
-tutti.label.fishingOperation.gearShootingStartBottomSalinity=Salinit\u00c3\u00a9 de fond d\u00c3\u00a9but de traine
-tutti.label.fishingOperation.gearShootingStartBottomTemperature=Temp\u00c3\u00a9rature de fond d\u00c3\u00a9but de traine
-tutti.label.fishingOperation.gearShootingStartDepth=Profondeur d\u00c3\u00a9but de traine
-tutti.label.fishingOperation.gearShootingStartSurfaceSalinity=Salinit\u00c3\u00a9 de surface d\u00c3\u00a9but de traine
-tutti.label.fishingOperation.gearShootingStartSurfaceTemperature=Temperature de surface d\u00c3\u00a9but de traine
+tutti.label.fishingOperation.gearShootingStart=Début de traine
+tutti.label.fishingOperation.gearShootingStartBottomSalinity=Salinité de fond début de traine
+tutti.label.fishingOperation.gearShootingStartBottomTemperature=Température de fond début de traine
+tutti.label.fishingOperation.gearShootingStartDepth=Profondeur début de traine
+tutti.label.fishingOperation.gearShootingStartSurfaceSalinity=Salinité de surface début de traine
+tutti.label.fishingOperation.gearShootingStartSurfaceTemperature=Temperature de surface début de traine
tutti.label.fishingOperation.gearTime=Heure
-tutti.label.fishingOperation.geometrieMesuree=G\u00c3\u00a9om\u00c3\u00a9trie mesur\u00c3\u00a9e
-tutti.label.fishingOperation.localite=Localit\u00c3\u00a9
+tutti.label.fishingOperation.geometrieMesuree=Géométrie mesurée
+tutti.label.fishingOperation.localite=Localité
tutti.label.fishingOperation.longueurBras=Longueur des funes
tutti.label.fishingOperation.longueurFunes=Longueur des bras
tutti.label.fishingOperation.ouvertureHorizontale=Ouverture horizontale
tutti.label.fishingOperation.ouvertureVerticale=Ouverture verticale
tutti.label.fishingOperation.seaState=Etat de la mer
-tutti.label.fishingOperation.stationNumber=Num\u00c3\u00a9ro de la station
+tutti.label.fishingOperation.stationNumber=Numéro de la station
tutti.label.fishingOperation.strata=Strate
tutti.label.fishingOperation.subStrata=Sous strate
-tutti.label.fishingOperation.systemeFermetureCul=Syst\u00c3\u00a8me de fermeture de cul
+tutti.label.fishingOperation.systemeFermetureCul=Système de fermeture de cul
tutti.label.fishingOperation.windDirection=Direction du vent
tutti.label.frequencyConfiguration.maxStep=Classe max
tutti.label.frequencyConfiguration.minStep=Classe min
-tutti.label.frequencyConfiguration.mode.autoGen=G\u00c3\u00a9n\u00c3\u00a9ration des classes
-tutti.label.frequencyConfiguration.mode.autoGen.tip=Mode o\u00c3\u00b9 toutes les classes de taille sont g\u00c3\u00a9n\u00c3\u00a9r\u00c3\u00a9es
+tutti.label.frequencyConfiguration.mode.autoGen=Génération des classes
+tutti.label.frequencyConfiguration.mode.autoGen.tip=Mode où toutes les classes de taille sont générées
tutti.label.frequencyConfiguration.mode.rafale=Mode "rafale"
-tutti.label.frequencyConfiguration.mode.rafale.tip=Mode o\u00c3\u00b9 on ne saisit uniquement la classe de taille (les nombres seront alors incr\u00c3\u00a9ment\u00c3\u00a9s...)
+tutti.label.frequencyConfiguration.mode.rafale.tip=Mode où on ne saisit uniquement la classe de taille (les nombres seront alors incrémentés...)
tutti.label.frequencyConfiguration.mode.simple=Mode simple
-tutti.label.frequencyConfiguration.mode.simple.tip=Mode par d\u00c3\u00a9faut on on doit tout saisir (les classes de tailles et les nombres)
+tutti.label.frequencyConfiguration.mode.simple.tip=Mode par défaut on on doit tout saisir (les classes de tailles et les nombres)
tutti.label.frequencyConfiguration.no.configuration=< Pas de configuration >
-tutti.label.frequencyConfiguration.rafaleStep=Classe de taille \u00c3\u00a0 incr\u00c3\u00a9menter
+tutti.label.frequencyConfiguration.rafaleStep=Classe de taille à incrémenter
tutti.label.frequencyConfiguration.step=Pas de la classe de taille
tutti.label.list.gear=Engin(s)
tutti.label.list.headOfMission=Chef(s) de mission
tutti.label.list.headOfSortRoom=Reponsable(s) de salle de tri
tutti.label.list.vessel=Navire(s)
tutti.label.macroWaste.totalWeight=Poids total
-tutti.label.no.fishingOperation.selected=< Aucun trait s\u00c3\u00a9lectionn\u00c3\u00a9 >
-tutti.label.plankton.sampleTotalWeight=Poids total \u00c3\u00a9chantillonn\u00c3\u00a9
+tutti.label.no.fishingOperation.selected=< Aucun trait sélectionné >
+tutti.label.plankton.sampleTotalWeight=Poids total échantillonné
tutti.label.plankton.totalWeight=Poids total
-tutti.label.program=S\u00c3\u00a9rie de campagne
+tutti.label.program=Série de campagne
tutti.label.program.name=Nom
tutti.label.program.zone=Zone
-tutti.label.species.sampleVracWeight=Poids total vrac \u00c3\u00a9chant.
+tutti.label.species.sampleVracWeight=Poids total vrac échant.
tutti.label.species.totalHorsVracWeight=Poids total hors vrac
tutti.label.species.totalVracWeight=Poids total vrac
tutti.label.species.totalWeight=Poids total
@@ -125,12 +125,12 @@
tutti.label.tab.fishingOperation=Trait
tutti.label.tab.fishingOperation.environment=Environnement
tutti.label.tab.fishingOperation.gearShooting=Mise en oeuvre de l'engin
-tutti.label.tab.fishingOperation.general=Caract\u00c3\u00a9ristiques g\u00c3\u00a9n\u00c3\u00a9rales
-tutti.label.tab.fishingOperation.hydrology=Param\u00c3\u00a8tres hydrologiques
-tutti.label.tab.macroDechet=Macro d\u00c3\u00a9chets
+tutti.label.tab.fishingOperation.general=Caractéristiques générales
+tutti.label.tab.fishingOperation.hydrology=Paramètres hydrologiques
+tutti.label.tab.macroDechet=Macro déchets
tutti.label.tab.observationIndividuel=Observations individuelles
tutti.label.tab.plancton=Plancton
-tutti.label.tab.species=Esp\u00c3\u00a8ces
+tutti.label.tab.species=Espèces
tutti.legend.frequencyConfiguration=Configuration
tutti.menu.actions=Actions
tutti.menu.actions.tip=Actions
@@ -138,8 +138,8 @@
tutti.menu.file.tip=Fichier
tutti.menu.help=Aide
tutti.menu.help.tip=Aide
-tutti.menu.synchronisationAllegro=All\u00c3\u00a9gro
-tutti.menu.synchronisationAllegro.tip=Synchronisation All\u00c3\u00a9gro
+tutti.menu.synchronisationAllegro=Allégro
+tutti.menu.synchronisationAllegro.tip=Synchronisation Allégro
tutti.menu.synchronisationExport=Export
tutti.menu.synchronisationExport.tip=Effectuer des exports
tutti.menu.synchronisationImport=Import
@@ -147,72 +147,72 @@
tutti.menu.synchronisations=Synchronisation
tutti.menu.synchronisations.tip=Import/Export
tutti.table.benthos.batch.header.comment=Commentaire
-tutti.table.benthos.batch.header.elevationRate=Fraction d'\u00c3\u00a9l\u00c3\u00a9vation
-tutti.table.benthos.batch.header.file=Pi\u00c3\u00a8ces jointes
-tutti.table.benthos.batch.header.sampleWeight=Poids \u00c3\u00a9chantillonn\u00c3\u00a9
-tutti.table.benthos.batch.header.speciesByCode=Esp\u00c3\u00a8ce
-tutti.table.benthos.batch.header.speciesByGenusCode=Esp\u00c3\u00a8ce
+tutti.table.benthos.batch.header.elevationRate=Fraction d'élévation
+tutti.table.benthos.batch.header.file=Pièces jointes
+tutti.table.benthos.batch.header.sampleWeight=Poids échantillonné
+tutti.table.benthos.batch.header.speciesByCode=Espèce
+tutti.table.benthos.batch.header.speciesByGenusCode=Espèce
tutti.table.benthos.batch.header.toConfirm=A Confirmer
tutti.table.benthos.batch.header.weight=Poids
tutti.table.macrowaste.batch.header.comment=Commentaire
-tutti.table.macrowaste.batch.header.file=Pi\u00c3\u00a8ces jointes
-tutti.table.macrowaste.batch.header.speciesByCode=Esp\u00c3\u00a8ce
-tutti.table.macrowaste.batch.header.speciesByGenusCode=Esp\u00c3\u00a8ce
+tutti.table.macrowaste.batch.header.file=Pièces jointes
+tutti.table.macrowaste.batch.header.speciesByCode=Espèce
+tutti.table.macrowaste.batch.header.speciesByGenusCode=Espèce
tutti.table.macrowaste.batch.header.weight=Poids
tutti.table.plankton.batch.header.comment=Commentaire
-tutti.table.plankton.batch.header.elevationRate=Fraction d'\u00c3\u00a9l\u00c3\u00a9vation
-tutti.table.plankton.batch.header.file=Pi\u00c3\u00a8ces jointes
-tutti.table.plankton.batch.header.sampleWeight=Poids \u00c3\u00a9chantillonn\u00c3\u00a9
-tutti.table.plankton.batch.header.speciesByCode=Esp\u00c3\u00a8ce
-tutti.table.plankton.batch.header.speciesByGenusCode=Esp\u00c3\u00a8ce
+tutti.table.plankton.batch.header.elevationRate=Fraction d'élévation
+tutti.table.plankton.batch.header.file=Pièces jointes
+tutti.table.plankton.batch.header.sampleWeight=Poids échantillonné
+tutti.table.plankton.batch.header.speciesByCode=Espèce
+tutti.table.plankton.batch.header.speciesByGenusCode=Espèce
tutti.table.plankton.batch.header.toConfirm=A Confirmer
tutti.table.plankton.batch.header.weight=Poids
tutti.table.species.batch.header.age=Age
tutti.table.species.batch.header.comment=Commentaire
-tutti.table.species.batch.header.computedNumber=Nombre calcul\u00c3\u00a9
-tutti.table.species.batch.header.computedWeight=Poids calcul\u00c3\u00a9
-tutti.table.species.batch.header.elevationRate=Fraction d'\u00c3\u00a9l\u00c3\u00a9vation
-tutti.table.species.batch.header.file=Pi\u00c3\u00a8ces jointes
-tutti.table.species.batch.header.maturity=Maturit\u00c3\u00a9
-tutti.table.species.batch.header.sampleWeight=Poids \u00c3\u00a9chantillonn\u00c3\u00a9
+tutti.table.species.batch.header.computedNumber=Nombre calculé
+tutti.table.species.batch.header.computedWeight=Poids calculé
+tutti.table.species.batch.header.elevationRate=Fraction d'élévation
+tutti.table.species.batch.header.file=Pièces jointes
+tutti.table.species.batch.header.maturity=Maturité
+tutti.table.species.batch.header.sampleWeight=Poids échantillonné
tutti.table.species.batch.header.sex=Sexe
-tutti.table.species.batch.header.speciesByCode=Esp\u00c3\u00a8ce
-tutti.table.species.batch.header.speciesByGenusCode=Esp\u00c3\u00a8ce
+tutti.table.species.batch.header.speciesByCode=Espèce
+tutti.table.species.batch.header.speciesByGenusCode=Espèce
tutti.table.species.batch.header.toConfirm=A Confirmer
tutti.table.species.batch.header.vracHorsVrac=Vrac / Hors Vrac
tutti.table.species.batch.header.weight=Poids
-tutti.table.species.batch.header.weightCategory=Cat\u00c3\u00a9gorie Poids
-tutti.table.species.frequency.header.computedWeight=Poids calcul\u00c3\u00a9
+tutti.table.species.batch.header.weightCategory=Catégorie Poids
+tutti.table.species.frequency.header.computedWeight=Poids calculé
tutti.table.species.frequency.header.lengthStep=Classe de taille
tutti.table.species.frequency.header.number=Nombre
-tutti.table.species.frequency.header.weight=Poids observ\u00c3\u00a9
+tutti.table.species.frequency.header.weight=Poids observé
tutti.timeeditor.H=H
-tutti.title.about=\u00c3\u0080 propos de Tutti
-tutti.title.create.cruise=Cr\u00c3\u00a9er une nouvelle campagne
-tutti.title.create.program=Cr\u00c3\u00a9er une nouvelle s\u00c3\u00a9rie de campagne
+tutti.title.about=À propos de Tutti
+tutti.title.create.cruise=Créer une nouvelle campagne
+tutti.title.create.program=Créer une nouvelle série de campagne
tutti.title.edit.cruise=Editer une campagne existante
-tutti.title.edit.operations=Saisie des op\u00c3\u00a9rations de p\u00c3\u00aaches (%s)
-tutti.title.edit.program=Editer une s\u00c3\u00a9rie de campagne existante
+tutti.title.edit.operations=Saisie des opérations de pêches (%s)
+tutti.title.edit.program=Editer une série de campagne existante
tutti.title.frequency=Saisie des mensurations
-tutti.title.home=S\u00c3\u00a9lection de la campagne
-tutti.title.noSelectedCruise=Pas de campagne s\u00c3\u00a9lectionn\u00c3\u00a9
-tutti.title.noSelectedProgram=Pas de s\u00c3\u00a9rie de campagne s\u00c3\u00a9lectionn\u00c3\u00a9
+tutti.title.home=Sélection de la campagne
+tutti.title.noSelectedCruise=Pas de campagne sélectionné
+tutti.title.noSelectedProgram=Pas de série de campagne sélectionné
tutti.title.selectedCruise=Campagne %s
-tutti.title.selectedProgram=S\u00c3\u00a9rie de campagne %s
+tutti.title.selectedProgram=Série de campagne %s
tutti.to.be.done=< A FAIRE >
tutti.tooltip.comment.none=Aucun
-tutti.validator.error.cruise.beginDate.required=La date de d\u00c3\u00a9but est obligatoire
+tutti.validator.error.cruise.beginDate.required=La date de début est obligatoire
tutti.validator.error.cruise.country.required=Le pays est obligatoire
tutti.validator.error.cruise.endDate.required=La date de fin est obligatoire
-tutti.validator.error.cruise.gear.required=Au moins un engin doit \u00c3\u00aatre s\u00c3\u00a9lectionn\u00c3\u00a9
-tutti.validator.error.cruise.headOfMission.required=Au moins un chef de mission doit \u00c3\u00aatre s\u00c3\u00a9lectionn\u00c3\u00a9
-tutti.validator.error.cruise.headOfSortRoom.required=Au moins un responsable de salle de tri doit \u00c3\u00aatre s\u00c3\u00a9lectionn\u00c3\u00a9
+tutti.validator.error.cruise.gear.required=Au moins un engin doit être sélectionné
+tutti.validator.error.cruise.headOfMission.required=Au moins un chef de mission doit être sélectionné
+tutti.validator.error.cruise.headOfSortRoom.required=Au moins un responsable de salle de tri doit être sélectionné
tutti.validator.error.cruise.name.required=Le nom de la campagne est obligatoire
tutti.validator.error.cruise.poche.required=Le nombre de poche est obligatoire
-tutti.validator.error.cruise.program.required=La s\u00c3\u00a9rie est obligatoire
-tutti.validator.error.cruise.vessel.required=Au moins un bateau doit \u00c3\u00aatre s\u00c3\u00a9lectionn\u00c3\u00a9
-tutti.validator.error.cruise.year.required=L'ann\u00c3\u00a9e est obligatoire
+tutti.validator.error.cruise.program.required=La série est obligatoire
+tutti.validator.error.cruise.vessel.required=Au moins un bateau doit être sélectionné
+tutti.validator.error.cruise.year.required=L'année est obligatoire
tutti.validator.error.fishingOperation.date.required=La date du fishingOperation est obligatoire
-tutti.validator.error.fishingOperation.stationNumber.required=Le num\u00c3\u00a9ro de station est obligatoire
-tutti.validator.error.program.name.required=Le nom de la s\u00c3\u00a9rie est obligatoire
-tutti.validator.error.program.zone.required=La zone de la s\u00c3\u00a9rie est obligatoire
+tutti.validator.error.fishingOperation.stationNumber.required=Le numéro de station est obligatoire
+tutti.validator.error.program.name.required=Le nom de la série est obligatoire
+tutti.validator.error.program.zone.required=La zone de la série est obligatoire
1
0
r72 - in trunk: . tutti-persistence-adagio tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor
by tchemit@users.forge.codelutin.com 14 Dec '12
by tchemit@users.forge.codelutin.com 14 Dec '12
14 Dec '12
Author: tchemit
Date: 2012-12-15 00:44:19 +0100 (Sat, 15 Dec 2012)
New Revision: 72
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/72
Log:
fix dependencies + use commons.lang3
Modified:
trunk/pom.xml
trunk/tutti-persistence-adagio/pom.xml
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/FishingOperationsUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
Modified: trunk/pom.xml
===================================================================
--- trunk/pom.xml 2012-12-14 23:16:31 UTC (rev 71)
+++ trunk/pom.xml 2012-12-14 23:44:19 UTC (rev 72)
@@ -301,6 +301,11 @@
<artifactId>spring-orm</artifactId>
<version>${spring.version}</version>
</dependency>
+ <dependency>
+ <groupId>org.springframework</groupId>
+ <artifactId>spring-tx</artifactId>
+ <version>${spring.version}</version>
+ </dependency>
<!-- Spring AOP + AspectJ -->
<dependency>
<groupId>org.springframework</groupId>
Modified: trunk/tutti-persistence-adagio/pom.xml
===================================================================
--- trunk/tutti-persistence-adagio/pom.xml 2012-12-14 23:16:31 UTC (rev 71)
+++ trunk/tutti-persistence-adagio/pom.xml 2012-12-14 23:44:19 UTC (rev 72)
@@ -35,7 +35,7 @@
<artifactId>nuiton-utils</artifactId>
</dependency>
- <dependency>
+ <!--dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
</dependency>
@@ -48,7 +48,7 @@
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
- </dependency>
+ </dependency-->
<dependency>
<groupId>commons-logging</groupId>
@@ -58,6 +58,10 @@
<!-- Pour SPRING : -->
<dependency>
<groupId>org.springframework</groupId>
+ <artifactId>spring-tx</artifactId>
+ </dependency>
+ <!--dependency>
+ <groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
</dependency>
<dependency>
@@ -75,9 +79,9 @@
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
- </dependency>
+ </dependency-->
<!-- Spring AOP + AspectJ -->
- <dependency>
+ <!--dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
</dependency>
@@ -88,7 +92,7 @@
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
- </dependency>
+ </dependency-->
<dependency>
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/FishingOperationsUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/FishingOperationsUIHandler.java 2012-12-14 23:16:31 UTC (rev 71)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/content/operation/FishingOperationsUIHandler.java 2012-12-14 23:44:19 UTC (rev 72)
@@ -30,7 +30,7 @@
import fr.ifremer.tutti.service.PersistenceService;
import fr.ifremer.tutti.ui.swing.AbstractTuttiUIHandler;
import fr.ifremer.tutti.ui.swing.TuttiUIContext;
-import org.apache.commons.lang.time.DateUtils;
+import org.apache.commons.lang3.time.DateUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java 2012-12-14 23:16:31 UTC (rev 71)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java 2012-12-14 23:44:19 UTC (rev 72)
@@ -30,7 +30,7 @@
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import jaxx.runtime.SwingUtil;
import jaxx.runtime.swing.HBox;
-import org.apache.commons.lang.StringUtils;
+import org.apache.commons.lang3.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-14 23:16:31 UTC (rev 71)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-14 23:44:19 UTC (rev 72)
@@ -27,7 +27,7 @@
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import jaxx.runtime.SwingUtil;
-import org.apache.commons.lang.StringUtils;
+import org.apache.commons.lang3.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
1
0
r71 - trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor
by tchemit@users.forge.codelutin.com 14 Dec '12
by tchemit@users.forge.codelutin.com 14 Dec '12
14 Dec '12
Author: tchemit
Date: 2012-12-15 00:16:31 +0100 (Sat, 15 Dec 2012)
New Revision: 71
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/71
Log:
reformat some codes
Modified:
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java 2012-12-14 23:13:54 UTC (rev 70)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java 2012-12-14 23:16:31 UTC (rev 71)
@@ -24,15 +24,27 @@
* #L%
*/
-import fr.ifremer.tutti.ui.swing.util.ComponentResizer;
import com.google.common.base.Preconditions;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.ComponentMover;
+import fr.ifremer.tutti.ui.swing.util.ComponentResizer;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import fr.ifremer.tutti.ui.swing.util.table.AbstractSelectTableAction;
import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableModel;
import fr.ifremer.tutti.ui.swing.util.table.ColumnIdentifier;
-import java.awt.event.WindowAdapter;
+import jaxx.runtime.JAXXUtil;
+import jaxx.runtime.SwingUtil;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+
+import javax.swing.AbstractCellEditor;
+import javax.swing.BorderFactory;
+import javax.swing.JButton;
+import javax.swing.JDialog;
+import javax.swing.JTable;
+import javax.swing.border.LineBorder;
+import javax.swing.table.TableCellEditor;
+import javax.swing.table.TableCellRenderer;
import java.awt.Color;
import java.awt.Component;
import java.awt.Frame;
@@ -40,33 +52,24 @@
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
+import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
-import javax.swing.AbstractCellEditor;
-import javax.swing.BorderFactory;
-import javax.swing.JButton;
-import javax.swing.JDialog;
-import javax.swing.JTable;
-import javax.swing.border.LineBorder;
-import javax.swing.table.TableCellEditor;
-import javax.swing.table.TableCellRenderer;
-import jaxx.runtime.JAXXUtil;
-import jaxx.runtime.SwingUtil;
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
import static org.nuiton.i18n.I18n._;
/**
* Component to edit a cell containing attachments
- *
+ *
* @author kmorin
* @since 0.2
*/
public class AttachmentCellComponent extends JButton {
-
+
/** Logger. */
private static final Log log = LogFactory.getLog(AttachmentCellComponent.class);
+ private static final long serialVersionUID = 1L;
+
public AttachmentCellComponent() {
setContentAreaFilled(false);
setOpaque(false);
@@ -80,16 +83,18 @@
public static TableCellEditor newEditor(AttachmentEditorUI ui) {
return new AttachmentCellEditor(ui);
}
-
-
+
+
public static class AttachmentCellEditor extends AbstractCellEditor implements TableCellEditor {
+ private static final long serialVersionUID = 1L;
+
protected final AttachmentCellComponent component;
protected final AttachmentEditorUI ui;
protected Frame frame;
-
+
protected JTable table;
protected AbstractTuttiTableModel<AbstractTuttiBeanUIModel> tableModel;
@@ -101,10 +106,10 @@
protected Integer rowIndex;
protected Integer columnIndex;
-
+
public AttachmentCellEditor(AttachmentEditorUI ui) {
this.ui = ui;
-
+
component = new AttachmentCellComponent();
component.setBorder(new LineBorder(Color.BLACK));
component.addKeyListener(new KeyAdapter() {
@@ -131,23 +136,23 @@
if (frame == null) {
frame = SwingUtil.getParentContainer(ui, Frame.class);
}
-
+
ui.setBorder(BorderFactory.createTitledBorder(_(columnIdentifier.getHeaderI18nKey())));
ui.setBean(editRow);
ui.setProperty(columnIdentifier.getPropertyName());
-
+
JDialog editor = new JDialog(frame, true);
editor.setUndecorated(true);
editor.add(ui);
editor.setResizable(true);
editor.pack();
-
+
ComponentResizer cr = new ComponentResizer();
cr.registerComponent(editor);
ComponentMover cm = new ComponentMover();
cm.setDragInsets(cr.getDragInsets());
cm.registerComponent(editor);
-
+
editor.addWindowListener(new WindowAdapter() {
@Override
@@ -159,7 +164,7 @@
JAXXUtil.destroy(ui);
}
});
-
+
// Computes the location of bottom left corner of the cell
Component comp = component;
int x = 0;
@@ -176,7 +181,7 @@
}
editor.setLocation(x, y);
editor.setVisible(true);
-
+
int r = rowIndex;
int c = columnIndex;
@@ -186,7 +191,7 @@
// reselect this cell
AbstractSelectTableAction.doSelectCell(table, r, c);
}
-
+
@Override
public Component getTableCellEditorComponent(JTable table,
Object value,
@@ -194,7 +199,7 @@
int row,
int column) {
if (tableModel == null) {
- tableModel = (AbstractTuttiTableModel<AbstractTuttiBeanUIModel>) table.getModel();
+ tableModel = (AbstractTuttiTableModel<AbstractTuttiBeanUIModel>) table.getModel();
this.table = table;
columnIdentifier = tableModel.getPropertyName(column);
}
@@ -240,11 +245,11 @@
editRow = null;
}
}
-
+
public static class AttachmentCellRenderer implements TableCellRenderer {
protected final AttachmentCellComponent component;
-
+
protected String propertyName;
public AttachmentCellRenderer() {
@@ -262,19 +267,19 @@
String text;
if (value == null) {
if (propertyName == null) {
- AbstractTuttiTableModel tableModel =
+ AbstractTuttiTableModel tableModel =
(AbstractTuttiTableModel) table.getModel();
ColumnIdentifier columnIdentifier = tableModel.getPropertyName(column);
propertyName = columnIdentifier.getPropertyName();
}
// use HTML to show the tooltip in italic
text = "<html><body><i>" + _("tutti.tooltip." + propertyName + ".none") + "</i></body></html>";
-
+
} else {
// use html to display the tooltip on several lines
text = "<html><body>" + String.valueOf(value).replace("\n", "<br/>") + "</body></html>";
}
-
+
boolean editable = table.isCellEditable(row, column);
component.setEnabled(editable);
component.setToolTipText(text);
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java 2012-12-14 23:13:54 UTC (rev 70)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java 2012-12-14 23:16:31 UTC (rev 71)
@@ -28,8 +28,18 @@
import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
+import jaxx.runtime.SwingUtil;
+import jaxx.runtime.swing.HBox;
+import org.apache.commons.lang.StringUtils;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+
+import javax.swing.JButton;
+import javax.swing.JDialog;
+import javax.swing.JFileChooser;
+import javax.swing.JLabel;
+import javax.swing.SwingConstants;
import java.awt.Cursor;
-import java.awt.Desktop;
import java.awt.Window;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
@@ -38,45 +48,34 @@
import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
import java.io.File;
-import java.io.IOException;
-import java.net.URI;
-import java.net.URISyntaxException;
import java.util.List;
-import javax.swing.JButton;
-import javax.swing.JDialog;
-import javax.swing.JFileChooser;
-import javax.swing.JLabel;
-import javax.swing.SwingConstants;
-import jaxx.runtime.SwingUtil;
-import jaxx.runtime.swing.HBox;
-import org.apache.commons.lang.StringUtils;
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
/**
* Handler of the LongTextEditorUI
+ *
* @author kmorin
* @since 0.2
*/
public class AttachmentEditorUIHandler {
-
+
private static final Log log = LogFactory.getLog(AttachmentEditorUIHandler.class);
-
+
private final AttachmentEditorUI ui;
-
+
private JFileChooser fileChooser = new JFileChooser();
public AttachmentEditorUIHandler(AttachmentEditorUI attachmentEditorUI) {
ui = attachmentEditorUI;
-
+
ui.addPropertyChangeListener(new PropertyChangeListener() {
+ @Override
public void propertyChange(PropertyChangeEvent evt) {
init();
}
});
}
-
+
public void init() {
resetFields();
ui.getAttachments().removeAll();
@@ -91,14 +90,15 @@
}
}
}
-
+
protected void addAttachment(final Attachment attachment) {
final HBox hbox = new HBox();
hbox.setVerticalAlignment(SwingConstants.CENTER);
-
+
JButton deleteButton = new JButton(SwingUtil.createActionIcon("delete"));
deleteButton.addActionListener(new ActionListener() {
+ @Override
public void actionPerformed(ActionEvent e) {
AbstractTuttiBeanUIModel bean = ui.getBean();
String property = ui.getProperty();
@@ -107,17 +107,17 @@
list.remove(attachment);
TuttiUIUtil.setProperty(bean, property, list);
}
-
+
ui.getAttachments().remove(hbox);
-
+
JDialog parent = SwingUtil.getParentContainer(ui, JDialog.class);
parent.pack();
}
});
hbox.add(deleteButton);
-
+
final JLabel label = new JLabel("<html><body><a href=''>"
- + attachment.getName() + "</a></body></html>");
+ + attachment.getName() + "</a></body></html>");
label.setToolTipText(attachment.getComment());
label.addMouseListener(new MouseAdapter() {
@@ -135,23 +135,21 @@
public void mouseExited(MouseEvent e) {
label.setCursor(Cursor.getDefaultCursor());
}
-
+
});
hbox.add(label);
-
+
ui.getAttachments().add(hbox);
}
-
- /**
- * closes the editor
- */
+
+ /** closes the editor */
public void close() {
if (log.isInfoEnabled()) {
log.info("Will close UI " + ui);
}
SwingUtil.getParentContainer(ui, Window.class).dispose();
}
-
+
public void chooseFile() {
if (fileChooser.showOpenDialog(ui) == JFileChooser.APPROVE_OPTION) {
File file = fileChooser.getSelectedFile();
@@ -159,7 +157,7 @@
ui.getFile().setText(file.getAbsolutePath());
}
}
-
+
public void addAttachment() {
AbstractTuttiBeanUIModel bean = ui.getBean();
String property = ui.getProperty();
@@ -186,7 +184,7 @@
parent.pack();
}
}
-
+
protected void resetFields() {
ui.setModel(new Attachment());
fileChooser.setSelectedFile(null);
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java 2012-12-14 23:13:54 UTC (rev 70)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java 2012-12-14 23:16:31 UTC (rev 71)
@@ -24,50 +24,52 @@
* #L%
*/
-import fr.ifremer.tutti.ui.swing.util.ComponentResizer;
import com.google.common.base.Preconditions;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.ComponentMover;
+import fr.ifremer.tutti.ui.swing.util.ComponentResizer;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import fr.ifremer.tutti.ui.swing.util.table.AbstractSelectTableAction;
import fr.ifremer.tutti.ui.swing.util.table.AbstractTuttiTableModel;
import fr.ifremer.tutti.ui.swing.util.table.ColumnIdentifier;
-import java.awt.event.WindowAdapter;
+import jaxx.runtime.JAXXUtil;
+import jaxx.runtime.SwingUtil;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+
+import javax.swing.AbstractCellEditor;
+import javax.swing.BorderFactory;
+import javax.swing.JButton;
+import javax.swing.JDialog;
+import javax.swing.JTable;
+import javax.swing.border.LineBorder;
+import javax.swing.table.TableCellEditor;
+import javax.swing.table.TableCellRenderer;
import java.awt.Color;
import java.awt.Component;
import java.awt.Frame;
-import java.awt.Insets;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
+import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
-import javax.swing.AbstractCellEditor;
-import javax.swing.BorderFactory;
-import javax.swing.JButton;
-import javax.swing.JDialog;
-import javax.swing.JTable;
-import javax.swing.border.LineBorder;
-import javax.swing.table.TableCellEditor;
-import javax.swing.table.TableCellRenderer;
-import jaxx.runtime.JAXXUtil;
-import jaxx.runtime.SwingUtil;
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
import static org.nuiton.i18n.I18n._;
/**
* Component to edit a cell in a popup with a text area
- *
+ *
* @author kmorin
* @since 0.2
*/
-public class LongTextCellComponent extends JButton{
-
+public class LongTextCellComponent extends JButton {
+
/** Logger. */
private static final Log log = LogFactory.getLog(LongTextCellComponent.class);
+ private static final long serialVersionUID = 1L;
+
public LongTextCellComponent() {
setContentAreaFilled(false);
setOpaque(false);
@@ -81,19 +83,22 @@
public static TableCellEditor newEditor(LongTextEditorUI ui) {
return new LongTextCellEditor(ui);
}
-
-
+
+
public static class LongTextCellEditor extends AbstractCellEditor implements TableCellEditor {
public static final int DEFAULT_EDITOR_WIDTH = 400;
+
public static final int DEFAULT_EDITOR_HEIGHT = 200;
-
+
+ private static final long serialVersionUID = 1L;
+
protected final LongTextCellComponent component;
protected final LongTextEditorUI ui;
protected Frame frame;
-
+
protected JTable table;
protected AbstractTuttiTableModel<AbstractTuttiBeanUIModel> tableModel;
@@ -105,10 +110,10 @@
protected Integer rowIndex;
protected Integer columnIndex;
-
+
public LongTextCellEditor(LongTextEditorUI ui) {
this.ui = ui;
-
+
component = new LongTextCellComponent();
component.setBorder(new LineBorder(Color.BLACK));
component.addKeyListener(new KeyAdapter() {
@@ -135,23 +140,23 @@
if (frame == null) {
frame = SwingUtil.getParentContainer(ui, Frame.class);
}
-
+
ui.setBorder(BorderFactory.createTitledBorder(_(columnIdentifier.getHeaderI18nKey())));
ui.setBean(editRow);
ui.setProperty(columnIdentifier.getPropertyName());
-
+
JDialog editor = new JDialog(frame, true);
editor.setUndecorated(true);
editor.add(ui);
editor.setSize(DEFAULT_EDITOR_WIDTH, DEFAULT_EDITOR_HEIGHT);
editor.setResizable(true);
-
+
ComponentResizer cr = new ComponentResizer();
cr.registerComponent(editor);
ComponentMover cm = new ComponentMover();
cm.setDragInsets(cr.getDragInsets());
cm.registerComponent(editor);
-
+
editor.addWindowListener(new WindowAdapter() {
@Override
@@ -163,7 +168,7 @@
JAXXUtil.destroy(ui);
}
});
-
+
// Computes the location of bottom left corner of the cell
Component comp = component;
int x = 0;
@@ -180,7 +185,7 @@
}
editor.setLocation(x, y);
editor.setVisible(true);
-
+
int r = rowIndex;
int c = columnIndex;
@@ -190,7 +195,7 @@
// reselect this cell
AbstractSelectTableAction.doSelectCell(table, r, c);
}
-
+
@Override
public Component getTableCellEditorComponent(JTable table,
Object value,
@@ -198,7 +203,7 @@
int row,
int column) {
if (tableModel == null) {
- tableModel = (AbstractTuttiTableModel<AbstractTuttiBeanUIModel>) table.getModel();
+ tableModel = (AbstractTuttiTableModel<AbstractTuttiBeanUIModel>) table.getModel();
this.table = table;
columnIdentifier = tableModel.getPropertyName(column);
}
@@ -244,11 +249,11 @@
editRow = null;
}
}
-
+
public static class LongTextCellRenderer implements TableCellRenderer {
protected final LongTextCellComponent component;
-
+
protected String propertyName;
public LongTextCellRenderer() {
@@ -266,19 +271,19 @@
String text;
if (value == null) {
if (propertyName == null) {
- AbstractTuttiTableModel tableModel =
+ AbstractTuttiTableModel tableModel =
(AbstractTuttiTableModel) table.getModel();
ColumnIdentifier columnIdentifier = tableModel.getPropertyName(column);
propertyName = columnIdentifier.getPropertyName();
}
// use HTML to show the tooltip in italic
text = "<html><body><i>" + _("tutti.tooltip." + propertyName + ".none") + "</i></body></html>";
-
+
} else {
// use html to display the tooltip on several lines
text = "<html><body>" + String.valueOf(value).replace("\n", "<br/>") + "</body></html>";
}
-
+
boolean editable = table.isCellEditable(row, column);
component.setEnabled(editable);
component.setToolTipText(text);
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-14 23:13:54 UTC (rev 70)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-14 23:16:31 UTC (rev 71)
@@ -26,28 +26,30 @@
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
-import java.awt.Window;
-import java.beans.PropertyChangeEvent;
-import java.beans.PropertyChangeListener;
import jaxx.runtime.SwingUtil;
import org.apache.commons.lang.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
+import java.awt.Window;
+import java.beans.PropertyChangeEvent;
+import java.beans.PropertyChangeListener;
+
/**
* Handler of the LongTextEditorUI
+ *
* @author kmorin
* @since 0.2
*/
public class LongTextEditorUIHandler {
-
+
private static final Log log = LogFactory.getLog(LongTextEditorUIHandler.class);
-
+
private final LongTextEditorUI ui;
public LongTextEditorUIHandler(LongTextEditorUI longTextEditorUI) {
ui = longTextEditorUI;
-
+
ui.addPropertyChangeListener(new PropertyChangeListener() {
public void propertyChange(PropertyChangeEvent evt) {
@@ -63,28 +65,24 @@
}
});
}
-
- /**
- * pushes the typed text in the property of the bean
- */
+
+ /** pushes the typed text in the property of the bean */
public void setText() {
String value = ui.getTextContent().getText();
AbstractTuttiBeanUIModel bean = ui.getBean();
String property = ui.getProperty();
TuttiUIUtil.setProperty(bean, property, value);
}
-
+
public void resetText() {
AbstractTuttiBeanUIModel bean = ui.getBean();
String property = ui.getProperty();
TuttiUIUtil.setProperty(bean, property, null);
-
+
ui.getTextContent().setText("");
}
-
- /**
- * closes the editor
- */
+
+ /** closes the editor */
public void close() {
if (log.isInfoEnabled()) {
log.info("Will close UI " + ui);
1
0
14 Dec '12
Author: tchemit
Date: 2012-12-15 00:13:54 +0100 (Sat, 15 Dec 2012)
New Revision: 70
Url: http://forge.codelutin.com/projects/tutti/repository/revisions/70
Log:
add svn properties and file headers
Modified:
trunk/tutti-persistence-adagio/LICENSE.txt
trunk/tutti-persistence-adagio/README.txt
trunk/tutti-persistence-adagio/changelog.txt
trunk/tutti-persistence-adagio/pom.xml
trunk/tutti-persistence-adagio/src/license/THIRD-PARTY.properties
trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java
trunk/tutti-persistence-adagio/src/main/resources/META-INF/services/fr.ifremer.tutti.persistence.TuttiPersistence
trunk/tutti-persistence-adagio/src/main/resources/applicationContext-service-tutti.xml
trunk/tutti-persistence-adagio/src/main/resources/beanRefFactory.xml
trunk/tutti-persistence-adagio/src/main/resources/queries-override.hbm.xml
trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/BaseDaoTest.java
trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/GearDaoTest.java
trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/ProgramDaoTest.java
trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/VesselDaoTest.java
trunk/tutti-persistence-adagio/src/test/resources/conf.properties
trunk/tutti-persistence-adagio/src/test/resources/log4j.properties
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentMover.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentResizer.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.css
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.jaxx
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.css
trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
trunk/tutti-ui-swing/src/main/resources/icons/action-delete.png
Property changes on: trunk/tutti-persistence-adagio/LICENSE.txt
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Property changes on: trunk/tutti-persistence-adagio/README.txt
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Property changes on: trunk/tutti-persistence-adagio/changelog.txt
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Property changes on: trunk/tutti-persistence-adagio/pom.xml
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Property changes on: trunk/tutti-persistence-adagio/src/license/THIRD-PARTY.properties
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java
===================================================================
--- trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.persistence;
+/*
+ * #%L
+ * Tutti :: Persistence Adagio (impl)
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import fr.ifremer.tutti.persistence.entities.data.AccidentalBatch;
import fr.ifremer.tutti.persistence.entities.data.BenthosBatch;
import fr.ifremer.tutti.persistence.entities.data.Cruise;
Property changes on: trunk/tutti-persistence-adagio/src/main/java/fr/ifremer/tutti/persistence/TuttiPersistenceAdagioImpl.java
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Property changes on: trunk/tutti-persistence-adagio/src/main/resources/META-INF/services/fr.ifremer.tutti.persistence.TuttiPersistence
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-persistence-adagio/src/main/resources/applicationContext-service-tutti.xml
===================================================================
--- trunk/tutti-persistence-adagio/src/main/resources/applicationContext-service-tutti.xml 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/main/resources/applicationContext-service-tutti.xml 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,4 +1,28 @@
<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ #%L
+ Tutti :: Persistence Adagio (impl)
+ $Id$
+ $HeadURL$
+ %%
+ Copyright (C) 2012 Ifremer
+ %%
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as
+ published by the Free Software Foundation, either version 3 of the
+ License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public
+ License along with this program. If not, see
+ <http://www.gnu.org/licenses/gpl-3.0.html>.
+ #L%
+ -->
+
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop"
Property changes on: trunk/tutti-persistence-adagio/src/main/resources/applicationContext-service-tutti.xml
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/main/resources/beanRefFactory.xml
===================================================================
--- trunk/tutti-persistence-adagio/src/main/resources/beanRefFactory.xml 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/main/resources/beanRefFactory.xml 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,4 +1,28 @@
<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ #%L
+ Tutti :: Persistence Adagio (impl)
+ $Id$
+ $HeadURL$
+ %%
+ Copyright (C) 2012 Ifremer
+ %%
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as
+ published by the Free Software Foundation, either version 3 of the
+ License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public
+ License along with this program. If not, see
+ <http://www.gnu.org/licenses/gpl-3.0.html>.
+ #L%
+ -->
+
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
Property changes on: trunk/tutti-persistence-adagio/src/main/resources/beanRefFactory.xml
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/main/resources/queries-override.hbm.xml
===================================================================
--- trunk/tutti-persistence-adagio/src/main/resources/queries-override.hbm.xml 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/main/resources/queries-override.hbm.xml 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,4 +1,28 @@
<?xml version="1.0"?>
+<!--
+ #%L
+ Tutti :: Persistence Adagio (impl)
+ $Id$
+ $HeadURL$
+ %%
+ Copyright (C) 2012 Ifremer
+ %%
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as
+ published by the Free Software Foundation, either version 3 of the
+ License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public
+ License along with this program. If not, see
+ <http://www.gnu.org/licenses/gpl-3.0.html>.
+ #L%
+ -->
+
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
Property changes on: trunk/tutti-persistence-adagio/src/main/resources/queries-override.hbm.xml
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/BaseDaoTest.java
===================================================================
--- trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/BaseDaoTest.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/BaseDaoTest.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.persistence;
+/*
+ * #%L
+ * Tutti :: Persistence Adagio (impl)
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.SessionFactory;
Property changes on: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/BaseDaoTest.java
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/GearDaoTest.java
===================================================================
--- trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/GearDaoTest.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/GearDaoTest.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.persistence;
+/*
+ * #%L
+ * Tutti :: Persistence Adagio (impl)
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import fr.ifremer.adagio.core.dao.Search;
import fr.ifremer.adagio.core.dao.SearchParameter;
import fr.ifremer.adagio.core.dao.referential.gear.Gear;
Property changes on: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/GearDaoTest.java
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/ProgramDaoTest.java
===================================================================
--- trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/ProgramDaoTest.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/ProgramDaoTest.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.persistence;
+/*
+ * #%L
+ * Tutti :: Persistence Adagio (impl)
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import fr.ifremer.adagio.core.dao.administration.programStrategy.Program;
import fr.ifremer.adagio.core.dao.administration.programStrategy.ProgramDao;
import org.apache.commons.logging.Log;
Property changes on: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/ProgramDaoTest.java
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/VesselDaoTest.java
===================================================================
--- trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/VesselDaoTest.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/VesselDaoTest.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.persistence;
+/*
+ * #%L
+ * Tutti :: Persistence Adagio (impl)
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.Query;
Property changes on: trunk/tutti-persistence-adagio/src/test/java/fr/ifremer/tutti/persistence/VesselDaoTest.java
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/test/resources/conf.properties
===================================================================
--- trunk/tutti-persistence-adagio/src/test/resources/conf.properties 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/test/resources/conf.properties 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,3 +1,26 @@
+###
+# #%L
+# Tutti :: Persistence Adagio (impl)
+# $Id$
+# $HeadURL$
+# %%
+# Copyright (C) 2012 Ifremer
+# %%
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public
+# License along with this program. If not, see
+# <http://www.gnu.org/licenses/gpl-3.0.html>.
+# #L%
+###
#--------------------------------------------------------------------------
#
# WARNING : For UNIT TEST ONLY
Property changes on: trunk/tutti-persistence-adagio/src/test/resources/conf.properties
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-persistence-adagio/src/test/resources/log4j.properties
===================================================================
--- trunk/tutti-persistence-adagio/src/test/resources/log4j.properties 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-persistence-adagio/src/test/resources/log4j.properties 2012-12-14 23:13:54 UTC (rev 70)
@@ -2,7 +2,7 @@
# #%L
# Tutti :: Persistence Dev (impl)
# $Id$
-# $HeadURL: http://svn.forge.codelutin.com/svn/tutti/trunk/tutti-persistence-dev/src/te… $
+# $HeadURL$
# %%
# Copyright (C) 2012 Ifremer
# %%
Property changes on: trunk/tutti-persistence-adagio/src/test/resources/log4j.properties
___________________________________________________________________
Modified: svn:keywords
- Author Date Id Revision
+ Author Date Id Revision HeadURL
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentMover.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentMover.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentMover.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,375 +1,380 @@
-package fr.ifremer.tutti.ui.swing.util;
-
-import java.awt.*;
-import java.awt.event.*;
-import javax.swing.JComponent;
-import javax.swing.SwingUtilities;
-
-/**
- * This class allows you to move a Component by using a mouse. The Component
- * moved can be a high level Window (ie. Window, Frame, Dialog) in which case
- * the Window is moved within the desktop. Or the Component can belong to a
- * Container in which case the Component is moved within the Container.
- *
- * When moving a Window, the listener can be added to a child Component of
- * the Window. In this case attempting to move the child will result in the
- * Window moving. For example, you might create a custom "Title Bar" for an
- * undecorated Window and moving of the Window is accomplished by moving the
- * title bar only. Multiple components can be registered as "window movers".
- *
- * Components can be registered when the class is created. Additional
- * components can be added at any time using the registerComponent() method.
- */
-public class ComponentMover extends MouseAdapter
-{
- private Insets dragInsets = new Insets(0, 0, 0, 0);
- private Dimension snapSize = new Dimension(1, 1);
- private Insets edgeInsets = new Insets(0, 0, 0, 0);
- private boolean changeCursor = true;
- private boolean autoLayout = false;
-
- private Class destinationClass;
- private Component destinationComponent;
- private Component destination;
- private Component source;
-
- private Point pressed;
- private Point location;
-
- private Cursor originalCursor;
- private boolean autoscrolls;
- private boolean potentialDrag;
-
-
- /**
- * Constructor for moving individual components. The components must be
- * regisetered using the registerComponent() method.
- */
- public ComponentMover()
- {
- }
-
- /**
- * Constructor to specify a Class of Component that will be moved when
- * drag events are generated on a registered child component. The events
- * will be passed to the first ancestor of this specified class.
- *
- * @param destinationClass the Class of the ancestor component
- * @param component the Components to be registered for forwarding
- * drag events to the ancestor Component.
- */
- public ComponentMover(Class destinationClass, Component... components)
- {
- this.destinationClass = destinationClass;
- registerComponent( components );
- }
-
- /**
- * Constructor to specify a parent component that will be moved when drag
- * events are generated on a registered child component.
- *
- * @param destinationComponent the component drage events should be forwareded to
- * @param components the Components to be registered for forwarding drag
- * events to the parent component to be moved
- */
- public ComponentMover(Component destinationComponent, Component... components)
- {
- this.destinationComponent = destinationComponent;
- registerComponent( components );
- }
-
- /**
- * Get the auto layout property
- *
- * @return the auto layout property
- */
- public boolean isAutoLayout()
- {
- return autoLayout;
- }
-
- /**
- * Set the auto layout property
- *
- * @param autoLayout when true layout will be invoked on the parent container
- */
- public void setAutoLayout(boolean autoLayout)
- {
- this.autoLayout = autoLayout;
- }
-
- /**
- * Get the change cursor property
- *
- * @return the change cursor property
- */
- public boolean isChangeCursor()
- {
- return changeCursor;
- }
-
- /**
- * Set the change cursor property
- *
- * @param changeCursor when true the cursor will be changed to the
- * Cursor.MOVE_CURSOR while the mouse is pressed
- */
- public void setChangeCursor(boolean changeCursor)
- {
- this.changeCursor = changeCursor;
- }
-
- /**
- * Get the drag insets
- *
- * @return the drag insets
- */
- public Insets getDragInsets()
- {
- return dragInsets;
- }
-
- /**
- * Set the drag insets. The insets specify an area where mouseDragged
- * events should be ignored and therefore the component will not be moved.
- * This will prevent these events from being confused with a
- * MouseMotionListener that supports component resizing.
- *
- * @param dragInsets
- */
- public void setDragInsets(Insets dragInsets)
- {
- this.dragInsets = dragInsets;
- }
-
- /**
- * Get the bounds insets
- *
- * @return the bounds insets
- */
- public Insets getEdgeInsets()
- {
- return edgeInsets;
- }
-
- /**
- * Set the edge insets. The insets specify how close to each edge of the parent
- * component that the child component can be moved. Positive values means the
- * component must be contained within the parent. Negative values means the
- * component can be moved outside the parent.
- *
- * @param edgeInsets
- */
- public void setEdgeInsets(Insets edgeInsets)
- {
- this.edgeInsets = edgeInsets;
- }
-
- /**
- * Remove listeners from the specified component
- *
- * @param component the component the listeners are removed from
- */
- public void deregisterComponent(Component... components)
- {
- for (Component component : components)
- component.removeMouseListener( this );
- }
-
- /**
- * Add the required listeners to the specified component
- *
- * @param component the component the listeners are added to
- */
- public void registerComponent(Component... components)
- {
- for (Component component : components)
- component.addMouseListener( this );
- }
-
- /**
- * Get the snap size
- *
- * @return the snap size
- */
- public Dimension getSnapSize()
- {
- return snapSize;
- }
-
- /**
- * Set the snap size. Forces the component to be snapped to
- * the closest grid position. Snapping will occur when the mouse is
- * dragged half way.
- */
- public void setSnapSize(Dimension snapSize)
- {
- if (snapSize.width < 1
- || snapSize.height < 1)
- throw new IllegalArgumentException("Snap sizes must be greater than 0");
-
- this.snapSize = snapSize;
- }
-
- /**
- * Setup the variables used to control the moving of the component:
- *
- * source - the source component of the mouse event
- * destination - the component that will ultimately be moved
- * pressed - the Point where the mouse was pressed in the destination
- * component coordinates.
- */
- @Override
- public void mousePressed(MouseEvent e)
- {
- source = e.getComponent();
- int width = source.getSize().width - dragInsets.left - dragInsets.right;
- int height = source.getSize().height - dragInsets.top - dragInsets.bottom;
- Rectangle r = new Rectangle(dragInsets.left, dragInsets.top, width, height);
-
- if (r.contains(e.getPoint()))
- setupForDragging(e);
- }
-
- private void setupForDragging(MouseEvent e)
- {
- source.addMouseMotionListener( this );
- potentialDrag = true;
-
- // Determine the component that will ultimately be moved
-
- if (destinationComponent != null)
- {
- destination = destinationComponent;
- }
- else if (destinationClass == null)
- {
- destination = source;
- }
- else // forward events to destination component
- {
- destination = SwingUtilities.getAncestorOfClass(destinationClass, source);
- }
-
- pressed = e.getLocationOnScreen();
- location = destination.getLocation();
-
- if (changeCursor)
- {
- originalCursor = source.getCursor();
- source.setCursor( Cursor.getPredefinedCursor(Cursor.MOVE_CURSOR) );
- }
-
- // Making sure autoscrolls is false will allow for smoother dragging of
- // individual components
-
- if (destination instanceof JComponent)
- {
- JComponent jc = (JComponent)destination;
- autoscrolls = jc.getAutoscrolls();
- jc.setAutoscrolls( false );
- }
- }
-
- /**
- * Move the component to its new location. The dragged Point must be in
- * the destination coordinates.
- */
- @Override
- public void mouseDragged(MouseEvent e)
- {
- Point dragged = e.getLocationOnScreen();
- int dragX = getDragDistance(dragged.x, pressed.x, snapSize.width);
- int dragY = getDragDistance(dragged.y, pressed.y, snapSize.height);
-
- int locationX = location.x + dragX;
- int locationY = location.y + dragY;
-
- // Mouse dragged events are not generated for every pixel the mouse
- // is moved. Adjust the location to make sure we are still on a
- // snap value.
-
- while (locationX < edgeInsets.left)
- locationX += snapSize.width;
-
- while (locationY < edgeInsets.top)
- locationY += snapSize.height;
-
- Dimension d = getBoundingSize( destination );
-
- while (locationX + destination.getSize().width + edgeInsets.right > d.width)
- locationX -= snapSize.width;
-
- while (locationY + destination.getSize().height + edgeInsets.bottom > d.height)
- locationY -= snapSize.height;
-
- // Adjustments are finished, move the component
-
- destination.setLocation(locationX, locationY);
- }
-
- /*
- * Determine how far the mouse has moved from where dragging started
- * (Assume drag direction is down and right for positive drag distance)
- */
- private int getDragDistance(int larger, int smaller, int snapSize)
- {
- int halfway = snapSize / 2;
- int drag = larger - smaller;
- drag += (drag < 0) ? -halfway : halfway;
- drag = (drag / snapSize) * snapSize;
-
- return drag;
- }
-
- /*
- * Get the bounds of the parent of the dragged component.
- */
- private Dimension getBoundingSize(Component source)
- {
- if (source instanceof Window)
- {
- GraphicsEnvironment env = GraphicsEnvironment.getLocalGraphicsEnvironment();
- Rectangle bounds = env.getMaximumWindowBounds();
- return new Dimension(bounds.width, bounds.height);
- }
- else
- {
- return source.getParent().getSize();
- }
- }
-
- /**
- * Restore the original state of the Component
- */
- @Override
- public void mouseReleased(MouseEvent e)
- {
- if (!potentialDrag) return;
-
- source.removeMouseMotionListener( this );
- potentialDrag = false;
-
- if (changeCursor)
- source.setCursor( originalCursor );
-
- if (destination instanceof JComponent)
- {
- ((JComponent)destination).setAutoscrolls( autoscrolls );
- }
-
- // Layout the components on the parent container
-
- if (autoLayout)
- {
- if (destination instanceof JComponent)
- {
- ((JComponent)destination).revalidate();
- }
- else
- {
- destination.validate();
- }
- }
- }
-}
+package fr.ifremer.tutti.ui.swing.util;
+
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
+
+import javax.swing.JComponent;
+import javax.swing.SwingUtilities;
+import java.awt.Component;
+import java.awt.Cursor;
+import java.awt.Dimension;
+import java.awt.GraphicsEnvironment;
+import java.awt.Insets;
+import java.awt.Point;
+import java.awt.Rectangle;
+import java.awt.Window;
+import java.awt.event.MouseAdapter;
+import java.awt.event.MouseEvent;
+
+/**
+ * This class allows you to move a Component by using a mouse. The Component
+ * moved can be a high level Window (ie. Window, Frame, Dialog) in which case
+ * the Window is moved within the desktop. Or the Component can belong to a
+ * Container in which case the Component is moved within the Container.
+ * <p/>
+ * When moving a Window, the listener can be added to a child Component of
+ * the Window. In this case attempting to move the child will result in the
+ * Window moving. For example, you might create a custom "Title Bar" for an
+ * undecorated Window and moving of the Window is accomplished by moving the
+ * title bar only. Multiple components can be registered as "window movers".
+ * <p/>
+ * Components can be registered when the class is created. Additional
+ * components can be added at any time using the registerComponent() method.
+ */
+public class ComponentMover extends MouseAdapter {
+ private Insets dragInsets = new Insets(0, 0, 0, 0);
+
+ private Dimension snapSize = new Dimension(1, 1);
+
+ private Insets edgeInsets = new Insets(0, 0, 0, 0);
+
+ private boolean changeCursor = true;
+
+ private boolean autoLayout = false;
+
+ private Class destinationClass;
+
+ private Component destinationComponent;
+
+ private Component destination;
+
+ private Component source;
+
+ private Point pressed;
+
+ private Point location;
+
+ private Cursor originalCursor;
+
+ private boolean autoscrolls;
+
+ private boolean potentialDrag;
+
+
+ /**
+ * Constructor for moving individual components. The components must be
+ * regisetered using the registerComponent() method.
+ */
+ public ComponentMover() {
+ }
+
+ /**
+ * Constructor to specify a Class of Component that will be moved when
+ * drag events are generated on a registered child component. The events
+ * will be passed to the first ancestor of this specified class.
+ *
+ * @param destinationClass the Class of the ancestor component
+ * @param components the Components to be registered for forwarding
+ * drag events to the ancestor Component.
+ */
+ public ComponentMover(Class destinationClass, Component... components) {
+ this.destinationClass = destinationClass;
+ registerComponent(components);
+ }
+
+ /**
+ * Constructor to specify a parent component that will be moved when drag
+ * events are generated on a registered child component.
+ *
+ * @param destinationComponent the component drage events should be forwareded to
+ * @param components the Components to be registered for forwarding drag
+ * events to the parent component to be moved
+ */
+ public ComponentMover(Component destinationComponent, Component... components) {
+ this.destinationComponent = destinationComponent;
+ registerComponent(components);
+ }
+
+ /**
+ * Get the auto layout property
+ *
+ * @return the auto layout property
+ */
+ public boolean isAutoLayout() {
+ return autoLayout;
+ }
+
+ /**
+ * Set the auto layout property
+ *
+ * @param autoLayout when true layout will be invoked on the parent container
+ */
+ public void setAutoLayout(boolean autoLayout) {
+ this.autoLayout = autoLayout;
+ }
+
+ /**
+ * Get the change cursor property
+ *
+ * @return the change cursor property
+ */
+ public boolean isChangeCursor() {
+ return changeCursor;
+ }
+
+ /**
+ * Set the change cursor property
+ *
+ * @param changeCursor when true the cursor will be changed to the
+ * Cursor.MOVE_CURSOR while the mouse is pressed
+ */
+ public void setChangeCursor(boolean changeCursor) {
+ this.changeCursor = changeCursor;
+ }
+
+ /**
+ * Get the drag insets
+ *
+ * @return the drag insets
+ */
+ public Insets getDragInsets() {
+ return dragInsets;
+ }
+
+ /**
+ * Set the drag insets. The insets specify an area where mouseDragged
+ * events should be ignored and therefore the component will not be moved.
+ * This will prevent these events from being confused with a
+ * MouseMotionListener that supports component resizing.
+ *
+ * @param dragInsets
+ */
+ public void setDragInsets(Insets dragInsets) {
+ this.dragInsets = dragInsets;
+ }
+
+ /**
+ * Get the bounds insets
+ *
+ * @return the bounds insets
+ */
+ public Insets getEdgeInsets() {
+ return edgeInsets;
+ }
+
+ /**
+ * Set the edge insets. The insets specify how close to each edge of the parent
+ * component that the child component can be moved. Positive values means the
+ * component must be contained within the parent. Negative values means the
+ * component can be moved outside the parent.
+ *
+ * @param edgeInsets
+ */
+ public void setEdgeInsets(Insets edgeInsets) {
+ this.edgeInsets = edgeInsets;
+ }
+
+ /**
+ * Remove listeners from the specified component
+ *
+ * @param components the component the listeners are removed from
+ */
+ public void deregisterComponent(Component... components) {
+ for (Component component : components)
+ component.removeMouseListener(this);
+ }
+
+ /**
+ * Add the required listeners to the specified component
+ *
+ * @param components the component the listeners are added to
+ */
+ public void registerComponent(Component... components) {
+ for (Component component : components)
+ component.addMouseListener(this);
+ }
+
+ /**
+ * Get the snap size
+ *
+ * @return the snap size
+ */
+ public Dimension getSnapSize() {
+ return snapSize;
+ }
+
+ /**
+ * Set the snap size. Forces the component to be snapped to
+ * the closest grid position. Snapping will occur when the mouse is
+ * dragged half way.
+ */
+ public void setSnapSize(Dimension snapSize) {
+ if (snapSize.width < 1
+ || snapSize.height < 1)
+ throw new IllegalArgumentException("Snap sizes must be greater than 0");
+
+ this.snapSize = snapSize;
+ }
+
+ /**
+ * Setup the variables used to control the moving of the component:
+ * <p/>
+ * source - the source component of the mouse event
+ * destination - the component that will ultimately be moved
+ * pressed - the Point where the mouse was pressed in the destination
+ * component coordinates.
+ */
+ @Override
+ public void mousePressed(MouseEvent e) {
+ source = e.getComponent();
+ int width = source.getSize().width - dragInsets.left - dragInsets.right;
+ int height = source.getSize().height - dragInsets.top - dragInsets.bottom;
+ Rectangle r = new Rectangle(dragInsets.left, dragInsets.top, width, height);
+
+ if (r.contains(e.getPoint()))
+ setupForDragging(e);
+ }
+
+ private void setupForDragging(MouseEvent e) {
+ source.addMouseMotionListener(this);
+ potentialDrag = true;
+
+ // Determine the component that will ultimately be moved
+
+ if (destinationComponent != null) {
+ destination = destinationComponent;
+ } else if (destinationClass == null) {
+ destination = source;
+ } else // forward events to destination component
+ {
+ destination = SwingUtilities.getAncestorOfClass(destinationClass, source);
+ }
+
+ pressed = e.getLocationOnScreen();
+ location = destination.getLocation();
+
+ if (changeCursor) {
+ originalCursor = source.getCursor();
+ source.setCursor(Cursor.getPredefinedCursor(Cursor.MOVE_CURSOR));
+ }
+
+ // Making sure autoscrolls is false will allow for smoother dragging of
+ // individual components
+
+ if (destination instanceof JComponent) {
+ JComponent jc = (JComponent) destination;
+ autoscrolls = jc.getAutoscrolls();
+ jc.setAutoscrolls(false);
+ }
+ }
+
+ /**
+ * Move the component to its new location. The dragged Point must be in
+ * the destination coordinates.
+ */
+ @Override
+ public void mouseDragged(MouseEvent e) {
+ Point dragged = e.getLocationOnScreen();
+ int dragX = getDragDistance(dragged.x, pressed.x, snapSize.width);
+ int dragY = getDragDistance(dragged.y, pressed.y, snapSize.height);
+
+ int locationX = location.x + dragX;
+ int locationY = location.y + dragY;
+
+ // Mouse dragged events are not generated for every pixel the mouse
+ // is moved. Adjust the location to make sure we are still on a
+ // snap value.
+
+ while (locationX < edgeInsets.left)
+ locationX += snapSize.width;
+
+ while (locationY < edgeInsets.top)
+ locationY += snapSize.height;
+
+ Dimension d = getBoundingSize(destination);
+
+ while (locationX + destination.getSize().width + edgeInsets.right > d.width)
+ locationX -= snapSize.width;
+
+ while (locationY + destination.getSize().height + edgeInsets.bottom > d.height)
+ locationY -= snapSize.height;
+
+ // Adjustments are finished, move the component
+
+ destination.setLocation(locationX, locationY);
+ }
+
+ /*
+ * Determine how far the mouse has moved from where dragging started
+ * (Assume drag direction is down and right for positive drag distance)
+ */
+ private int getDragDistance(int larger, int smaller, int snapSize) {
+ int halfway = snapSize / 2;
+ int drag = larger - smaller;
+ drag += (drag < 0) ? -halfway : halfway;
+ drag = (drag / snapSize) * snapSize;
+
+ return drag;
+ }
+
+ /*
+ * Get the bounds of the parent of the dragged component.
+ */
+ private Dimension getBoundingSize(Component source) {
+ if (source instanceof Window) {
+ GraphicsEnvironment env = GraphicsEnvironment.getLocalGraphicsEnvironment();
+ Rectangle bounds = env.getMaximumWindowBounds();
+ return new Dimension(bounds.width, bounds.height);
+ } else {
+ return source.getParent().getSize();
+ }
+ }
+
+ /** Restore the original state of the Component */
+ @Override
+ public void mouseReleased(MouseEvent e) {
+ if (!potentialDrag) return;
+
+ source.removeMouseMotionListener(this);
+ potentialDrag = false;
+
+ if (changeCursor)
+ source.setCursor(originalCursor);
+
+ if (destination instanceof JComponent) {
+ ((JComponent) destination).setAutoscrolls(autoscrolls);
+ }
+
+ // Layout the components on the parent container
+
+ if (autoLayout) {
+ if (destination instanceof JComponent) {
+ ((JComponent) destination).revalidate();
+ } else {
+ destination.validate();
+ }
+ }
+ }
+}
\ No newline at end of file
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentMover.java
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentResizer.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentResizer.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentResizer.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,458 +1,460 @@
-package fr.ifremer.tutti.ui.swing.util;
-
-import java.awt.*;
-import java.awt.event.*;
-import java.util.*;
-import javax.swing.JComponent;
-import javax.swing.SwingUtilities;
-
-/**
- * The ComponentResizer allows you to resize a component by dragging a border
- * of the component.
- */
-public class ComponentResizer extends MouseAdapter
-{
- private final static Dimension MINIMUM_SIZE = new Dimension(10, 10);
- private final static Dimension MAXIMUM_SIZE =
- new Dimension(Integer.MAX_VALUE, Integer.MAX_VALUE);
-
- private static Map<Integer, Integer> cursors = new HashMap<Integer, Integer>();
- {
- cursors.put(1, Cursor.N_RESIZE_CURSOR);
- cursors.put(2, Cursor.W_RESIZE_CURSOR);
- cursors.put(4, Cursor.S_RESIZE_CURSOR);
- cursors.put(8, Cursor.E_RESIZE_CURSOR);
- cursors.put(3, Cursor.NW_RESIZE_CURSOR);
- cursors.put(9, Cursor.NE_RESIZE_CURSOR);
- cursors.put(6, Cursor.SW_RESIZE_CURSOR);
- cursors.put(12, Cursor.SE_RESIZE_CURSOR);
- }
-
- private Insets dragInsets;
- private Dimension snapSize;
-
- private int direction;
- protected static final int NORTH = 1;
- protected static final int WEST = 2;
- protected static final int SOUTH = 4;
- protected static final int EAST = 8;
-
- private Cursor sourceCursor;
- private boolean resizing;
- private Rectangle bounds;
- private Point pressed;
- private boolean autoscrolls;
-
- private Dimension minimumSize = MINIMUM_SIZE;
- private Dimension maximumSize = MAXIMUM_SIZE;
-
- /**
- * Convenience contructor. All borders are resizable in increments of
- * a single pixel. Components must be registered separately.
- */
- public ComponentResizer()
- {
- this(new Insets(5, 5, 5, 5), new Dimension(1, 1));
- }
-
- /**
- * Convenience contructor. All borders are resizable in increments of
- * a single pixel. Components can be registered when the class is created
- * or they can be registered separately afterwards.
- *
- * @param components components to be automatically registered
- */
- public ComponentResizer(Component... components)
- {
- this(new Insets(5, 5, 5, 5), new Dimension(1, 1), components);
- }
-
- /**
- * Convenience contructor. Eligible borders are resisable in increments of
- * a single pixel. Components can be registered when the class is created
- * or they can be registered separately afterwards.
- *
- * @param dragInsets Insets specifying which borders are eligible to be
- * resized.
- * @param components components to be automatically registered
- */
- public ComponentResizer(Insets dragInsets, Component... components)
- {
- this(dragInsets, new Dimension(1, 1), components);
- }
-
- /**
- * Create a ComponentResizer.
- *
- * @param dragInsets Insets specifying which borders are eligible to be
- * resized.
- * @param snapSize Specify the dimension to which the border will snap to
- * when being dragged. Snapping occurs at the halfway mark.
- * @param components components to be automatically registered
- */
- public ComponentResizer(Insets dragInsets, Dimension snapSize, Component... components)
- {
- setDragInsets( dragInsets );
- setSnapSize( snapSize );
- registerComponent( components );
- }
-
- /**
- * Get the drag insets
- *
- * @return the drag insets
- */
- public Insets getDragInsets()
- {
- return dragInsets;
- }
-
- /**
- * Set the drag dragInsets. The insets specify an area where mouseDragged
- * events are recognized from the edge of the border inwards. A value of
- * 0 for any size will imply that the border is not resizable. Otherwise
- * the appropriate drag cursor will appear when the mouse is inside the
- * resizable border area.
- *
- * @param dragInsets Insets to control which borders are resizeable.
- */
- public void setDragInsets(Insets dragInsets)
- {
- validateMinimumAndInsets(minimumSize, dragInsets);
-
- this.dragInsets = dragInsets;
- }
-
- /**
- * Get the components maximum size.
- *
- * @return the maximum size
- */
- public Dimension getMaximumSize()
- {
- return maximumSize;
- }
-
- /**
- * Specify the maximum size for the component. The component will still
- * be constrained by the size of its parent.
- *
- * @param maximumSize the maximum size for a component.
- */
- public void setMaximumSize(Dimension maximumSize)
- {
- this.maximumSize = maximumSize;
- }
-
- /**
- * Get the components minimum size.
- *
- * @return the minimum size
- */
- public Dimension getMinimumSize()
- {
- return minimumSize;
- }
-
- /**
- * Specify the minimum size for the component. The minimum size is
- * constrained by the drag insets.
- *
- * @param minimumSize the minimum size for a component.
- */
- public void setMinimumSize(Dimension minimumSize)
- {
- validateMinimumAndInsets(minimumSize, dragInsets);
-
- this.minimumSize = minimumSize;
- }
-
- /**
- * Remove listeners from the specified component
- *
- * @param component the component the listeners are removed from
- */
- public void deregisterComponent(Component... components)
- {
- for (Component component : components)
- {
- component.removeMouseListener( this );
- component.removeMouseMotionListener( this );
- }
- }
-
- /**
- * Add the required listeners to the specified component
- *
- * @param component the component the listeners are added to
- */
- public void registerComponent(Component... components)
- {
- for (Component component : components)
- {
- component.addMouseListener( this );
- component.addMouseMotionListener( this );
- }
- }
-
- /**
- * Get the snap size.
- *
- * @return the snap size.
- */
- public Dimension getSnapSize()
- {
- return snapSize;
- }
-
- /**
- * Control how many pixels a border must be dragged before the size of
- * the component is changed. The border will snap to the size once
- * dragging has passed the halfway mark.
- *
- * @param snapSize Dimension object allows you to separately spcify a
- * horizontal and vertical snap size.
- */
- public void setSnapSize(Dimension snapSize)
- {
- this.snapSize = snapSize;
- }
-
- /**
- * When the components minimum size is less than the drag insets then
- * we can't determine which border should be resized so we need to
- * prevent this from happening.
- */
- private void validateMinimumAndInsets(Dimension minimum, Insets drag)
- {
- int minimumWidth = drag.left + drag.right;
- int minimumHeight = drag.top + drag.bottom;
-
- if (minimum.width < minimumWidth
- || minimum.height < minimumHeight)
- {
- String message = "Minimum size cannot be less than drag insets";
- throw new IllegalArgumentException( message );
- }
- }
-
- /**
- */
- @Override
- public void mouseMoved(MouseEvent e)
- {
- Component source = e.getComponent();
- Point location = e.getPoint();
- direction = 0;
-
- if (location.x < dragInsets.left)
- direction += WEST;
-
- if (location.x > source.getWidth() - dragInsets.right - 1)
- direction += EAST;
-
- if (location.y < dragInsets.top)
- direction += NORTH;
-
- if (location.y > source.getHeight() - dragInsets.bottom - 1)
- direction += SOUTH;
-
- // Mouse is no longer over a resizable border
-
- if (direction == 0)
- {
- source.setCursor( sourceCursor );
- }
- else // use the appropriate resizable cursor
- {
- int cursorType = cursors.get( direction );
- Cursor cursor = Cursor.getPredefinedCursor( cursorType );
- source.setCursor( cursor );
- }
- }
-
- @Override
- public void mouseEntered(MouseEvent e)
- {
- if (! resizing)
- {
- Component source = e.getComponent();
- sourceCursor = source.getCursor();
- }
- }
-
- @Override
- public void mouseExited(MouseEvent e)
- {
- if (! resizing)
- {
- Component source = e.getComponent();
- source.setCursor( sourceCursor );
- }
- }
-
- @Override
- public void mousePressed(MouseEvent e)
- {
- // The mouseMoved event continually updates this variable
-
- if (direction == 0) return;
-
- // Setup for resizing. All future dragging calculations are done based
- // on the original bounds of the component and mouse pressed location.
-
- resizing = true;
-
- Component source = e.getComponent();
- pressed = e.getPoint();
- SwingUtilities.convertPointToScreen(pressed, source);
- bounds = source.getBounds();
-
- // Making sure autoscrolls is false will allow for smoother resizing
- // of components
-
- if (source instanceof JComponent)
- {
- JComponent jc = (JComponent)source;
- autoscrolls = jc.getAutoscrolls();
- jc.setAutoscrolls( false );
- }
- }
-
- /**
- * Restore the original state of the Component
- */
- @Override
- public void mouseReleased(MouseEvent e)
- {
- resizing = false;
-
- Component source = e.getComponent();
- source.setCursor( sourceCursor );
-
- if (source instanceof JComponent)
- {
- ((JComponent)source).setAutoscrolls( autoscrolls );
- }
- }
-
- /**
- * Resize the component ensuring location and size is within the bounds
- * of the parent container and that the size is within the minimum and
- * maximum constraints.
- *
- * All calculations are done using the bounds of the component when the
- * resizing started.
- */
- @Override
- public void mouseDragged(MouseEvent e)
- {
- if (resizing == false) return;
-
- Component source = e.getComponent();
- Point dragged = e.getPoint();
- SwingUtilities.convertPointToScreen(dragged, source);
-
- changeBounds(source, direction, bounds, pressed, dragged);
- }
-
- protected void changeBounds(Component source, int direction, Rectangle bounds, Point pressed, Point current)
- {
- // Start with original locaton and size
-
- int x = bounds.x;
- int y = bounds.y;
- int width = bounds.width;
- int height = bounds.height;
-
- // Resizing the West or North border affects the size and location
-
- if (WEST == (direction & WEST))
- {
- int drag = getDragDistance(pressed.x, current.x, snapSize.width);
- int maximum = Math.min(width + x, maximumSize.width);
- drag = getDragBounded(drag, snapSize.width, width, minimumSize.width, maximum);
-
- x -= drag;
- width += drag;
- }
-
- if (NORTH == (direction & NORTH))
- {
- int drag = getDragDistance(pressed.y, current.y, snapSize.height);
- int maximum = Math.min(height + y, maximumSize.height);
- drag = getDragBounded(drag, snapSize.height, height, minimumSize.height, maximum);
-
- y -= drag;
- height += drag;
- }
-
- // Resizing the East or South border only affects the size
-
- if (EAST == (direction & EAST))
- {
- int drag = getDragDistance(current.x, pressed.x, snapSize.width);
- Dimension boundingSize = getBoundingSize( source );
- int maximum = Math.min(boundingSize.width - x, maximumSize.width);
- drag = getDragBounded(drag, snapSize.width, width, minimumSize.width, maximum);
- width += drag;
- }
-
- if (SOUTH == (direction & SOUTH))
- {
- int drag = getDragDistance(current.y, pressed.y, snapSize.height);
- Dimension boundingSize = getBoundingSize( source );
- int maximum = Math.min(boundingSize.height - y, maximumSize.height);
- drag = getDragBounded(drag, snapSize.height, height, minimumSize.height, maximum);
- height += drag;
- }
-
- source.setBounds(x, y, width, height);
- source.validate();
- }
-
- /*
- * Determine how far the mouse has moved from where dragging started
- */
- private int getDragDistance(int larger, int smaller, int snapSize)
- {
- int halfway = snapSize / 2;
- int drag = larger - smaller;
- drag += (drag < 0) ? -halfway : halfway;
- drag = (drag / snapSize) * snapSize;
-
- return drag;
- }
-
- /*
- * Adjust the drag value to be within the minimum and maximum range.
- */
- private int getDragBounded(int drag, int snapSize, int dimension, int minimum, int maximum)
- {
- while (dimension + drag < minimum)
- drag += snapSize;
-
- while (dimension + drag > maximum)
- drag -= snapSize;
-
-
- return drag;
- }
-
- /*
- * Keep the size of the component within the bounds of its parent.
- */
- private Dimension getBoundingSize(Component source)
- {
- if (source instanceof Window)
- {
- GraphicsEnvironment env = GraphicsEnvironment.getLocalGraphicsEnvironment();
- Rectangle bounds = env.getMaximumWindowBounds();
- return new Dimension(bounds.width, bounds.height);
- }
- else
- {
- return source.getParent().getSize();
- }
- }
-}
+package fr.ifremer.tutti.ui.swing.util;
+
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
+
+import javax.swing.JComponent;
+import javax.swing.SwingUtilities;
+import java.awt.Component;
+import java.awt.Cursor;
+import java.awt.Dimension;
+import java.awt.GraphicsEnvironment;
+import java.awt.Insets;
+import java.awt.Point;
+import java.awt.Rectangle;
+import java.awt.Window;
+import java.awt.event.MouseAdapter;
+import java.awt.event.MouseEvent;
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * The ComponentResizer allows you to resize a component by dragging a border
+ * of the component.
+ */
+public class ComponentResizer extends MouseAdapter {
+ private final static Dimension MINIMUM_SIZE = new Dimension(10, 10);
+
+ private final static Dimension MAXIMUM_SIZE =
+ new Dimension(Integer.MAX_VALUE, Integer.MAX_VALUE);
+
+ private static Map<Integer, Integer> cursors = new HashMap<Integer, Integer>();
+
+ {
+ cursors.put(1, Cursor.N_RESIZE_CURSOR);
+ cursors.put(2, Cursor.W_RESIZE_CURSOR);
+ cursors.put(4, Cursor.S_RESIZE_CURSOR);
+ cursors.put(8, Cursor.E_RESIZE_CURSOR);
+ cursors.put(3, Cursor.NW_RESIZE_CURSOR);
+ cursors.put(9, Cursor.NE_RESIZE_CURSOR);
+ cursors.put(6, Cursor.SW_RESIZE_CURSOR);
+ cursors.put(12, Cursor.SE_RESIZE_CURSOR);
+ }
+
+ private Insets dragInsets;
+
+ private Dimension snapSize;
+
+ private int direction;
+
+ protected static final int NORTH = 1;
+
+ protected static final int WEST = 2;
+
+ protected static final int SOUTH = 4;
+
+ protected static final int EAST = 8;
+
+ private Cursor sourceCursor;
+
+ private boolean resizing;
+
+ private Rectangle bounds;
+
+ private Point pressed;
+
+ private boolean autoscrolls;
+
+ private Dimension minimumSize = MINIMUM_SIZE;
+
+ private Dimension maximumSize = MAXIMUM_SIZE;
+
+ /**
+ * Convenience contructor. All borders are resizable in increments of
+ * a single pixel. Components must be registered separately.
+ */
+ public ComponentResizer() {
+ this(new Insets(5, 5, 5, 5), new Dimension(1, 1));
+ }
+
+ /**
+ * Convenience contructor. All borders are resizable in increments of
+ * a single pixel. Components can be registered when the class is created
+ * or they can be registered separately afterwards.
+ *
+ * @param components components to be automatically registered
+ */
+ public ComponentResizer(Component... components) {
+ this(new Insets(5, 5, 5, 5), new Dimension(1, 1), components);
+ }
+
+ /**
+ * Convenience contructor. Eligible borders are resisable in increments of
+ * a single pixel. Components can be registered when the class is created
+ * or they can be registered separately afterwards.
+ *
+ * @param dragInsets Insets specifying which borders are eligible to be
+ * resized.
+ * @param components components to be automatically registered
+ */
+ public ComponentResizer(Insets dragInsets, Component... components) {
+ this(dragInsets, new Dimension(1, 1), components);
+ }
+
+ /**
+ * Create a ComponentResizer.
+ *
+ * @param dragInsets Insets specifying which borders are eligible to be
+ * resized.
+ * @param snapSize Specify the dimension to which the border will snap to
+ * when being dragged. Snapping occurs at the halfway mark.
+ * @param components components to be automatically registered
+ */
+ public ComponentResizer(Insets dragInsets, Dimension snapSize, Component... components) {
+ setDragInsets(dragInsets);
+ setSnapSize(snapSize);
+ registerComponent(components);
+ }
+
+ /**
+ * Get the drag insets
+ *
+ * @return the drag insets
+ */
+ public Insets getDragInsets() {
+ return dragInsets;
+ }
+
+ /**
+ * Set the drag dragInsets. The insets specify an area where mouseDragged
+ * events are recognized from the edge of the border inwards. A value of
+ * 0 for any size will imply that the border is not resizable. Otherwise
+ * the appropriate drag cursor will appear when the mouse is inside the
+ * resizable border area.
+ *
+ * @param dragInsets Insets to control which borders are resizeable.
+ */
+ public void setDragInsets(Insets dragInsets) {
+ validateMinimumAndInsets(minimumSize, dragInsets);
+
+ this.dragInsets = dragInsets;
+ }
+
+ /**
+ * Get the components maximum size.
+ *
+ * @return the maximum size
+ */
+ public Dimension getMaximumSize() {
+ return maximumSize;
+ }
+
+ /**
+ * Specify the maximum size for the component. The component will still
+ * be constrained by the size of its parent.
+ *
+ * @param maximumSize the maximum size for a component.
+ */
+ public void setMaximumSize(Dimension maximumSize) {
+ this.maximumSize = maximumSize;
+ }
+
+ /**
+ * Get the components minimum size.
+ *
+ * @return the minimum size
+ */
+ public Dimension getMinimumSize() {
+ return minimumSize;
+ }
+
+ /**
+ * Specify the minimum size for the component. The minimum size is
+ * constrained by the drag insets.
+ *
+ * @param minimumSize the minimum size for a component.
+ */
+ public void setMinimumSize(Dimension minimumSize) {
+ validateMinimumAndInsets(minimumSize, dragInsets);
+
+ this.minimumSize = minimumSize;
+ }
+
+ /**
+ * Remove listeners from the specified component
+ *
+ * @param components the component the listeners are removed from
+ */
+ public void deregisterComponent(Component... components) {
+ for (Component component : components) {
+ component.removeMouseListener(this);
+ component.removeMouseMotionListener(this);
+ }
+ }
+
+ /**
+ * Add the required listeners to the specified component
+ *
+ * @param components the component the listeners are added to
+ */
+ public void registerComponent(Component... components) {
+ for (Component component : components) {
+ component.addMouseListener(this);
+ component.addMouseMotionListener(this);
+ }
+ }
+
+ /**
+ * Get the snap size.
+ *
+ * @return the snap size.
+ */
+ public Dimension getSnapSize() {
+ return snapSize;
+ }
+
+ /**
+ * Control how many pixels a border must be dragged before the size of
+ * the component is changed. The border will snap to the size once
+ * dragging has passed the halfway mark.
+ *
+ * @param snapSize Dimension object allows you to separately spcify a
+ * horizontal and vertical snap size.
+ */
+ public void setSnapSize(Dimension snapSize) {
+ this.snapSize = snapSize;
+ }
+
+ /**
+ * When the components minimum size is less than the drag insets then
+ * we can't determine which border should be resized so we need to
+ * prevent this from happening.
+ */
+ private void validateMinimumAndInsets(Dimension minimum, Insets drag) {
+ int minimumWidth = drag.left + drag.right;
+ int minimumHeight = drag.top + drag.bottom;
+
+ if (minimum.width < minimumWidth
+ || minimum.height < minimumHeight) {
+ String message = "Minimum size cannot be less than drag insets";
+ throw new IllegalArgumentException(message);
+ }
+ }
+
+ /**
+ */
+ @Override
+ public void mouseMoved(MouseEvent e) {
+ Component source = e.getComponent();
+ Point location = e.getPoint();
+ direction = 0;
+
+ if (location.x < dragInsets.left)
+ direction += WEST;
+
+ if (location.x > source.getWidth() - dragInsets.right - 1)
+ direction += EAST;
+
+ if (location.y < dragInsets.top)
+ direction += NORTH;
+
+ if (location.y > source.getHeight() - dragInsets.bottom - 1)
+ direction += SOUTH;
+
+ // Mouse is no longer over a resizable border
+
+ if (direction == 0) {
+ source.setCursor(sourceCursor);
+ } else // use the appropriate resizable cursor
+ {
+ int cursorType = cursors.get(direction);
+ Cursor cursor = Cursor.getPredefinedCursor(cursorType);
+ source.setCursor(cursor);
+ }
+ }
+
+ @Override
+ public void mouseEntered(MouseEvent e) {
+ if (!resizing) {
+ Component source = e.getComponent();
+ sourceCursor = source.getCursor();
+ }
+ }
+
+ @Override
+ public void mouseExited(MouseEvent e) {
+ if (!resizing) {
+ Component source = e.getComponent();
+ source.setCursor(sourceCursor);
+ }
+ }
+
+ @Override
+ public void mousePressed(MouseEvent e) {
+ // The mouseMoved event continually updates this variable
+
+ if (direction == 0) return;
+
+ // Setup for resizing. All future dragging calculations are done based
+ // on the original bounds of the component and mouse pressed location.
+
+ resizing = true;
+
+ Component source = e.getComponent();
+ pressed = e.getPoint();
+ SwingUtilities.convertPointToScreen(pressed, source);
+ bounds = source.getBounds();
+
+ // Making sure autoscrolls is false will allow for smoother resizing
+ // of components
+
+ if (source instanceof JComponent) {
+ JComponent jc = (JComponent) source;
+ autoscrolls = jc.getAutoscrolls();
+ jc.setAutoscrolls(false);
+ }
+ }
+
+ /** Restore the original state of the Component */
+ @Override
+ public void mouseReleased(MouseEvent e) {
+ resizing = false;
+
+ Component source = e.getComponent();
+ source.setCursor(sourceCursor);
+
+ if (source instanceof JComponent) {
+ ((JComponent) source).setAutoscrolls(autoscrolls);
+ }
+ }
+
+ /**
+ * Resize the component ensuring location and size is within the bounds
+ * of the parent container and that the size is within the minimum and
+ * maximum constraints.
+ * <p/>
+ * All calculations are done using the bounds of the component when the
+ * resizing started.
+ */
+ @Override
+ public void mouseDragged(MouseEvent e) {
+ if (resizing == false) return;
+
+ Component source = e.getComponent();
+ Point dragged = e.getPoint();
+ SwingUtilities.convertPointToScreen(dragged, source);
+
+ changeBounds(source, direction, bounds, pressed, dragged);
+ }
+
+ protected void changeBounds(Component source, int direction, Rectangle bounds, Point pressed, Point current) {
+ // Start with original locaton and size
+
+ int x = bounds.x;
+ int y = bounds.y;
+ int width = bounds.width;
+ int height = bounds.height;
+
+ // Resizing the West or North border affects the size and location
+
+ if (WEST == (direction & WEST)) {
+ int drag = getDragDistance(pressed.x, current.x, snapSize.width);
+ int maximum = Math.min(width + x, maximumSize.width);
+ drag = getDragBounded(drag, snapSize.width, width, minimumSize.width, maximum);
+
+ x -= drag;
+ width += drag;
+ }
+
+ if (NORTH == (direction & NORTH)) {
+ int drag = getDragDistance(pressed.y, current.y, snapSize.height);
+ int maximum = Math.min(height + y, maximumSize.height);
+ drag = getDragBounded(drag, snapSize.height, height, minimumSize.height, maximum);
+
+ y -= drag;
+ height += drag;
+ }
+
+ // Resizing the East or South border only affects the size
+
+ if (EAST == (direction & EAST)) {
+ int drag = getDragDistance(current.x, pressed.x, snapSize.width);
+ Dimension boundingSize = getBoundingSize(source);
+ int maximum = Math.min(boundingSize.width - x, maximumSize.width);
+ drag = getDragBounded(drag, snapSize.width, width, minimumSize.width, maximum);
+ width += drag;
+ }
+
+ if (SOUTH == (direction & SOUTH)) {
+ int drag = getDragDistance(current.y, pressed.y, snapSize.height);
+ Dimension boundingSize = getBoundingSize(source);
+ int maximum = Math.min(boundingSize.height - y, maximumSize.height);
+ drag = getDragBounded(drag, snapSize.height, height, minimumSize.height, maximum);
+ height += drag;
+ }
+
+ source.setBounds(x, y, width, height);
+ source.validate();
+ }
+
+ /*
+ * Determine how far the mouse has moved from where dragging started
+ */
+ private int getDragDistance(int larger, int smaller, int snapSize) {
+ int halfway = snapSize / 2;
+ int drag = larger - smaller;
+ drag += (drag < 0) ? -halfway : halfway;
+ drag = (drag / snapSize) * snapSize;
+
+ return drag;
+ }
+
+ /*
+ * Adjust the drag value to be within the minimum and maximum range.
+ */
+ private int getDragBounded(int drag, int snapSize, int dimension, int minimum, int maximum) {
+ while (dimension + drag < minimum)
+ drag += snapSize;
+
+ while (dimension + drag > maximum)
+ drag -= snapSize;
+
+
+ return drag;
+ }
+
+ /*
+ * Keep the size of the component within the bounds of its parent.
+ */
+ private Dimension getBoundingSize(Component source) {
+ if (source instanceof Window) {
+ GraphicsEnvironment env = GraphicsEnvironment.getLocalGraphicsEnvironment();
+ Rectangle bounds = env.getMaximumWindowBounds();
+ return new Dimension(bounds.width, bounds.height);
+ } else {
+ return source.getParent().getSize();
+ }
+ }
+}
\ No newline at end of file
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/ComponentResizer.java
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.ui.swing.util.editor;
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import fr.ifremer.tutti.ui.swing.util.ComponentResizer;
import com.google.common.base.Preconditions;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentCellComponent.java
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.css
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.css 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.css 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,3 +1,26 @@
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
#fileLabel {
text: "tutti.label.attachmentEditor.file";
labelFor: {file};
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.css
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.jaxx
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.jaxx 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUI.jaxx 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,3 +1,26 @@
+<!--
+ #%L
+ Tutti :: UI
+ $Id$
+ $HeadURL$
+ %%
+ Copyright (C) 2012 Ifremer
+ %%
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as
+ published by the Free Software Foundation, either version 3 of the
+ License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public
+ License along with this program. If not, see
+ <http://www.gnu.org/licenses/gpl-3.0.html>.
+ #L%
+ -->
<Table id='mainPanel'>
<import>
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.ui.swing.util.editor;
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import com.google.common.collect.Lists;
import fr.ifremer.tutti.persistence.entities.data.Attachment;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/AttachmentEditorUIHandler.java
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.ui.swing.util.editor;
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import fr.ifremer.tutti.ui.swing.util.ComponentResizer;
import com.google.common.base.Preconditions;
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextCellComponent.java
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.css
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.css 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.css 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,3 +1,26 @@
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
#closeButton {
actionIcon: "close";
text: "tutti.action.close";
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUI.css
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Modified: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
===================================================================
--- trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-14 23:11:08 UTC (rev 69)
+++ trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java 2012-12-14 23:13:54 UTC (rev 70)
@@ -1,5 +1,29 @@
package fr.ifremer.tutti.ui.swing.util.editor;
+/*
+ * #%L
+ * Tutti :: UI
+ * $Id$
+ * $HeadURL$
+ * %%
+ * Copyright (C) 2012 Ifremer
+ * %%
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program. If not, see
+ * <http://www.gnu.org/licenses/gpl-3.0.html>.
+ * #L%
+ */
+
import fr.ifremer.tutti.ui.swing.AbstractTuttiBeanUIModel;
import fr.ifremer.tutti.ui.swing.util.TuttiUIUtil;
import java.awt.Window;
Property changes on: trunk/tutti-ui-swing/src/main/java/fr/ifremer/tutti/ui/swing/util/editor/LongTextEditorUIHandler.java
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
Added: svn:eol-style
+ native
Property changes on: trunk/tutti-ui-swing/src/main/resources/icons/action-delete.png
___________________________________________________________________
Added: svn:keywords
+ Author Date Id Revision HeadURL
1
0