Mercurial > dive4elements > river
annotate gwt-client/src/main/java/org/dive4elements/river/client/client/ui/uinfo/AbstractVegZonesTablePanel.java @ 9403:e2da9c8a7c57
VegetationZone umbenennen
author | gernotbelger |
---|---|
date | Wed, 15 Aug 2018 13:22:00 +0200 |
parents | d89976700474 |
children | d421c2bf0195 |
rev | line source |
---|---|
9068 | 1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde |
2 * Software engineering by | |
3 * Björnsen Beratende Ingenieure GmbH | |
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt | |
5 * | |
6 * This file is Free Software under the GNU AGPL (>=v3) | |
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the | |
8 * documentation coming with Dive4Elements River for details. | |
9 */ | |
10 package org.dive4elements.river.client.client.ui.uinfo; | |
11 | |
12 import java.util.ArrayList; | |
13 import java.util.List; | |
14 | |
15 import org.dive4elements.river.client.client.ui.AbstractUIProvider; | |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
16 import org.dive4elements.river.client.client.ui.PanelHelper; |
9260 | 17 import org.dive4elements.river.client.client.ui.VegZonePanelHelper; |
9068 | 18 import org.dive4elements.river.client.shared.model.Data; |
19 import org.dive4elements.river.client.shared.model.DataItem; | |
20 import org.dive4elements.river.client.shared.model.DataList; | |
21 import org.dive4elements.river.client.shared.model.DefaultData; | |
22 import org.dive4elements.river.client.shared.model.DefaultDataItem; | |
9403 | 23 import org.dive4elements.river.client.shared.model.VegetationZoneServerClientXChange; |
9068 | 24 |
9107 | 25 import com.google.gwt.core.client.GWT; |
9260 | 26 import com.google.gwt.user.client.ui.Label; |
9068 | 27 import com.smartgwt.client.data.Record; |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
28 import com.smartgwt.client.types.Alignment; |
9107 | 29 import com.smartgwt.client.types.ListGridFieldType; |
9260 | 30 import com.smartgwt.client.types.SortDirection; |
9068 | 31 import com.smartgwt.client.widgets.Canvas; |
9260 | 32 import com.smartgwt.client.widgets.form.fields.ColorItem; |
9107 | 33 import com.smartgwt.client.widgets.form.validator.IntegerRangeValidator; |
9068 | 34 import com.smartgwt.client.widgets.grid.ListGrid; |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
35 import com.smartgwt.client.widgets.grid.ListGridField; |
9068 | 36 import com.smartgwt.client.widgets.grid.ListGridRecord; |
9114 | 37 import com.smartgwt.client.widgets.grid.SortNormalizer; |
9260 | 38 import com.smartgwt.client.widgets.grid.events.CellSavedEvent; |
39 import com.smartgwt.client.widgets.grid.events.CellSavedHandler; | |
9107 | 40 import com.smartgwt.client.widgets.grid.events.RecordClickEvent; |
41 import com.smartgwt.client.widgets.grid.events.RecordClickHandler; | |
9068 | 42 import com.smartgwt.client.widgets.layout.HLayout; |
9107 | 43 import com.smartgwt.client.widgets.layout.Layout; |
9068 | 44 import com.smartgwt.client.widgets.layout.VLayout; |
45 | |
46 /** | |
47 * @author Domenico Nardi Tironi | |
48 * | |
49 */ | |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
50 public abstract class AbstractVegZonesTablePanel extends AbstractUIProvider { |
9068 | 51 private static final long serialVersionUID = 1L; |
52 | |
9107 | 53 private static final String datakey = "vegzones"; |
9260 | 54 final protected List<ListGridRecord> records = new ArrayList<ListGridRecord>(); |
9346 | 55 private final Label validationLabel = PanelHelper.getValidationLabel(); |
9260 | 56 private final ListGrid elements = new ListGrid() { |
9068 | 57 |
9260 | 58 @Override |
59 protected String getCellCSSText(final ListGridRecord record, final int rowNum, final int colNum) { | |
60 if (record != null) { | |
61 if (getFieldName(colNum).equals("color")) { | |
62 final String color = record.getAttribute("color"); | |
63 return "background-color:" + color + ";"; | |
64 } | |
65 } | |
66 return super.getCellCSSText(record, rowNum, colNum); // is null... | |
67 } | |
68 | |
69 @Override | |
70 protected Canvas getCellHoverComponent(final Record record, final java.lang.Integer rowNum, final java.lang.Integer colNum) { | |
71 if (record != null) { | |
72 if (getFieldName(colNum).equals("color")) { | |
73 return null;// "background-color:" + color + ";"; | |
74 } | |
75 } | |
76 return super.getCellHoverComponent(record, rowNum, colNum); // is null... | |
77 } | |
78 }; | |
9107 | 79 |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
80 protected final ListGrid createTable(final Layout root, final DataList data, final String width, final boolean editable) { |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
81 |
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
82 final Label title = new Label(data.get(0).getDescription()); |
9133
af73fdd96920
Title current/historical diff pair; limit on entries in diff'pair twin_panel
gernotbelger
parents:
9119
diff
changeset
|
83 title.setHeight("35px"); |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
84 |
9133
af73fdd96920
Title current/historical diff pair; limit on entries in diff'pair twin_panel
gernotbelger
parents:
9119
diff
changeset
|
85 this.elements.setWidth(width); |
af73fdd96920
Title current/historical diff pair; limit on entries in diff'pair twin_panel
gernotbelger
parents:
9119
diff
changeset
|
86 this.elements.setHeight(300); |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
87 this.elements.setShowHeaderContextMenu(false); |
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
88 this.elements.setCanReorderFields(false); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
89 this.elements.setCanSort(true); |
9260 | 90 this.elements.setSortField("to"); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
91 this.elements.setCanResizeFields(false); |
9114 | 92 |
9107 | 93 this.elements.setCanEdit(editable); |
94 | |
9260 | 95 final ListGridField internalNumber = new ListGridField("number", "number"); // valid only if no data is to be added |
96 internalNumber.setCanSort(false); | |
97 internalNumber.setHidden(true); | |
98 | |
9107 | 99 final ListGridField vegzoneField = new ListGridField("vegzone", this.MSG.uinfo_vegetation_zones_label()); |
100 vegzoneField.setType(ListGridFieldType.TEXT); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
101 vegzoneField.setWidth("*"); // 245 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
102 vegzoneField.setCanSort(false); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
103 vegzoneField.setCanDragResize(true); |
9260 | 104 vegzoneField.setCanEdit(true); // neue Anforderung - doch nicht? ??? |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
105 |
9260 | 106 final ListGridField fromField = VegZonePanelHelper.createIntTableField("from", this.MSG.uinfo_vegetation_zones_from(), true, getNormalizer(), |
107 getValidator()); | |
108 fromField.addCellSavedHandler(new CellSavedHandler() { | |
109 @Override | |
110 public void onCellSaved(final CellSavedEvent event) { | |
9299 | 111 updateValidationMsgLabel(); |
9260 | 112 } |
113 }); | |
114 // war mal ne anforderung, dass sich die Werte anderer Zellen ändern, sodass keine lücken entstehen... mach das jetzt | |
115 // aber über die Validierung. es sei denn, es soll doch wieder erwünscht sein, dass sihc die werte andere Zellen ändern | |
116 // fromField.addCellSavedHandler(new CellSavedHandler() { | |
117 // | |
118 // @Override | |
119 // public void onCellSaved(final CellSavedEvent event) { | |
120 // | |
121 // final ListGridRecord r = event.getRecord(); | |
122 // | |
123 // final int from = Integer.valueOf(r.getAttribute("from")); | |
124 // final int to = Integer.valueOf(r.getAttribute("to")); | |
125 // final String message = validate(r.getAttribute("from"), r.getAttribute("to"), r.getAttribute("zone"), | |
126 // r.getAttribute("color")); | |
127 // | |
128 // final int key = Integer.valueOf(r.getAttribute("number")); | |
129 // final int lowerKey = key - 1; | |
130 // final int higherKey = key + 1; | |
131 // | |
132 // final ListGridRecord lower = lowerKey > -1 ? AbstractVegZonesTablePanel.this.records.get(lowerKey) : null; | |
133 // final ListGridRecord higher = higherKey < AbstractVegZonesTablePanel.this.records.size() | |
134 // ? AbstractVegZonesTablePanel.this.records.get(higherKey) | |
135 // : null; | |
136 // | |
137 // // primary | |
138 // if (lower != null) { | |
139 // lower.setAttribute("to", r.getAttribute("from")); | |
140 // | |
141 // // additional: | |
142 // final int lowerFrom = Integer.valueOf(lower.getAttribute("from")); | |
143 // if (lowerFrom > from) { | |
144 // lower.setAttribute("from", from); | |
145 // } | |
146 // } | |
147 // | |
148 // if (from > to) { | |
149 // r.setAttribute("to", from); | |
150 // if (higher != null) { | |
151 // // higher.setAttribute("from", from); //ist vermutlich too much | |
152 // final int higherTo = Integer.valueOf(higher.getAttribute("to")); | |
153 // if (from > higherTo) { | |
154 // // higher.setAttribute("to", from); //ist vermutlich too much | |
155 // } | |
156 // } | |
157 // } | |
158 // } | |
159 // }); | |
160 | |
161 final ListGridField toField = VegZonePanelHelper.createIntTableField("to", this.MSG.uinfo_vegetation_zones_to(), false, getNormalizer(), | |
162 getValidator()); | |
163 toField.addCellSavedHandler(new CellSavedHandler() { | |
164 @Override | |
165 public void onCellSaved(final CellSavedEvent event) { | |
9299 | 166 updateValidationMsgLabel(); |
9260 | 167 } |
168 }); | |
169 // nicht | |
170 // sortierbar nach | |
171 // "ÜFDauer bis" | |
172 toField.setCanEdit(true);// neue Anforderung - doch nicht? | |
173 | |
174 final ListGridField colorField = new ListGridField("color", this.MSG.uinfo_vegetation_zone_color()); | |
9403 | 175 colorField.setHidden(VegetationZoneServerClientXChange.HAS_COLORS_EDITABLE ? false : true); |
9260 | 176 final ColorItem item = new ColorItem(); |
177 colorField.setEditorProperties(item); | |
178 | |
179 colorField.setWidth(80); // 25 too small | |
180 colorField.setAlign(Alignment.LEFT); | |
181 colorField.setCanSort(false); | |
182 colorField.setCanDragResize(false); | |
183 | |
184 // sortierbar nach | |
185 // "ÜFDauer bis" | |
186 toField.setCanEdit(true);// neue Anforderung | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
187 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
188 if (editable) { |
9260 | 189 final ListGridField removeField = PanelHelper.createRemoveField(this.elements, GWT.getHostPageBaseURL() + this.MSG.removeFeature()); |
190 this.elements.addRecordClickHandler(new RecordClickHandler() { // adding another custom record-Remove-Handler which is not included in the | |
191 // Panelhelper TODO: MERGE WITH SupraRegionalPanel!! | |
192 @Override | |
193 public void onRecordClick(final RecordClickEvent event) { | |
194 if (event.getField().getName().equals(removeField.getName())) { | |
9299 | 195 updateValidationMsgLabel(); |
9260 | 196 } |
197 } | |
198 }); | |
199 this.elements.setFields(vegzoneField, fromField, toField, colorField, removeField); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
200 } else { |
9260 | 201 this.elements.setFields(internalNumber, vegzoneField, fromField, toField, colorField); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
202 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
203 |
9260 | 204 this.elements.sort("from", SortDirection.ASCENDING); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
205 addDataInit(data); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
206 root.setWidth(width); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
207 root.addMember(title); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
208 root.addMember(this.elements); |
9260 | 209 root.addMember(PanelHelper.getSpacer(3)); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
210 |
9260 | 211 root.addMember(this.validationLabel); |
212 root.addMember(PanelHelper.getSpacer(3)); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
213 return this.elements; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
214 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
215 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
216 private IntegerRangeValidator getValidator() { |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
217 final IntegerRangeValidator validator = new IntegerRangeValidator(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
218 validator.setMin(0); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
219 validator.setMax(365); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
220 validator.setErrorMessage(this.MSG.uinfo_vegetation_zones_validation_range()); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
221 return validator; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
222 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
223 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
224 private SortNormalizer getNormalizer() { |
9114 | 225 final SortNormalizer normalizer = new SortNormalizer() { |
9107 | 226 |
9114 | 227 @Override |
228 public Object normalize(final ListGridRecord record, final String fieldName) { | |
229 final String number = record.getAttribute(fieldName); | |
230 final String numberFormat = "000" + number; | |
231 return numberFormat.substring(numberFormat.length() - 3); | |
232 } | |
233 }; | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
234 return normalizer; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
235 } |
9107 | 236 |
237 public abstract void createWidget(final Layout root, final DataList data); | |
9068 | 238 |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
239 private final void addDataInit(final DataList data) { |
9068 | 240 for (final Data dataItemContainer : data.getAll()) { |
241 if (dataItemContainer.getItems() != null) { | |
242 for (final DataItem dataItem : dataItemContainer.getItems()) { | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
243 if (dataItem.getStringValue() != null) { |
9299 | 244 createTableFromDataStr(dataItem.getStringValue()); |
9068 | 245 } |
246 } | |
247 } | |
248 } | |
249 } | |
250 | |
9299 | 251 protected final void createTableFromDataStr(final String data) { |
252 for (final ListGridRecord r : this.elements.getRecords()) { | |
253 this.elements.removeData(r); | |
254 } | |
9403 | 255 final List<VegetationZoneServerClientXChange> rows = VegetationZoneServerClientXChange.parse(data); |
256 for (final VegetationZoneServerClientXChange row : rows) { | |
9299 | 257 this.elements.addData(createEntry(row)); |
258 } | |
259 } | |
260 | |
9068 | 261 @Override |
262 public final Canvas create(final DataList data) { | |
263 final VLayout layout = new VLayout(); | |
9107 | 264 |
9133
af73fdd96920
Title current/historical diff pair; limit on entries in diff'pair twin_panel
gernotbelger
parents:
9119
diff
changeset
|
265 // TODO: Helper zur Vegetationszonen-Auswahl |
9299 | 266 final Canvas helper = createHelper(data); |
267 if (helper != null) | |
268 this.helperContainer.addMember(helper); | |
9068 | 269 |
270 final Canvas submit = getNextButton(); | |
271 | |
9107 | 272 final VLayout root = new VLayout(); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
273 root.setWidth(450); |
9107 | 274 createWidget(root, data); |
9068 | 275 |
9107 | 276 layout.addMember(root); |
277 layout.addMember(submit); | |
9068 | 278 |
9299 | 279 updateValidationMsgLabel();// init Text |
9260 | 280 |
9068 | 281 return layout; |
282 } | |
283 | |
284 @Override | |
285 public Canvas createOld(final DataList dataList) { | |
286 final HLayout layout = new HLayout(); | |
287 layout.setWidth("400px"); | |
288 final VLayout vLayout = new VLayout(); | |
289 vLayout.setWidth(130); | |
290 final Label label = new Label(dataList.getLabel()); | |
291 label.setWidth("200px"); | |
9260 | 292 label.setHeight("25px"); |
9068 | 293 |
294 final List<Data> items = dataList.getAll(); | |
295 final Data str = getData(items, datakey); | |
296 final DataItem[] strItems = str.getItems(); | |
297 | |
9403 | 298 final List<VegetationZoneServerClientXChange> entries = VegetationZoneServerClientXChange.parse(strItems[0].getLabel()); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
299 |
9403 | 300 for (final VegetationZoneServerClientXChange entry : entries) { |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
301 final Label dateLabel = new Label(entry.getZoneName() + " (" + entry.getMin_day_overflow() + "-" + entry.getMax_day_overflow() + ")"); |
9260 | 302 dateLabel.setHeight("20px"); |
9068 | 303 vLayout.addMember(dateLabel); |
304 } | |
305 final Canvas back = getBackButton(dataList.getState()); | |
306 layout.addMember(label); | |
307 layout.addMember(vLayout); | |
308 layout.addMember(back); | |
309 | |
310 return layout; | |
311 } | |
312 | |
313 @Override | |
314 protected final Data[] getData() { | |
315 final List<Data> data = new ArrayList<Data>(); | |
316 | |
317 final ListGridRecord[] lgr = this.elements.getRecords(); | |
318 if (lgr.length == 0) { | |
9133
af73fdd96920
Title current/historical diff pair; limit on entries in diff'pair twin_panel
gernotbelger
parents:
9119
diff
changeset
|
319 return new Data[0]; // TODO: Klären, ob Vegetationszonen-Auswahl Pflicht ist, ob es ein Fallback geben soll usw. |
9068 | 320 } |
9260 | 321 |
9403 | 322 final DataItem item = new DefaultDataItem(datakey, null, VegetationZoneServerClientXChange.parseListToDataString(getZones(lgr))); // DATA-key |
9260 | 323 data.add(new DefaultData(datakey, null, null, new DataItem[] { item })); |
324 return data.toArray(new Data[data.size()]); | |
325 } | |
326 | |
9403 | 327 protected final List<VegetationZoneServerClientXChange> getZones(final ListGridRecord[] lgr) { |
328 final List<VegetationZoneServerClientXChange> zoneList = new ArrayList<VegetationZoneServerClientXChange>(); | |
9068 | 329 for (final ListGridRecord element : lgr) { |
330 final Record r = element; | |
9403 | 331 final VegetationZoneServerClientXChange zone = VegetationZoneServerClientXChange.createFromTableEntry(r.getAttribute("vegzone"), r.getAttribute("from"), r.getAttribute("to"), |
9260 | 332 r.getAttribute("color")); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
333 zoneList.add(zone); |
9068 | 334 } |
9260 | 335 return zoneList; |
9068 | 336 } |
337 | |
9403 | 338 public final ListGridRecord createEntry(final VegetationZoneServerClientXChange row) { |
9068 | 339 |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
340 final String vegzone = row.getZoneName(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
341 final Integer from = row.getMin_day_overflow(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
342 final Integer to = row.getMax_day_overflow(); |
9260 | 343 final String colorStr = row.getHexColor(); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
344 if (vegzone == null || from == null || to == null) { |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
345 return null; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
346 } |
9068 | 347 |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
348 final ListGridRecord r = new ListGridRecord(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
349 r.setAttribute("vegzone", vegzone); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
350 r.setAttribute("from", from); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
351 r.setAttribute("to", to); |
9260 | 352 r.setAttribute("color", colorStr); |
353 r.setAttribute("number", this.records.size()); | |
354 this.records.add(r); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
355 return r; |
9068 | 356 |
357 } | |
9260 | 358 |
9299 | 359 protected final String validate(final String fromInput, final String toInput, final String zoneName, final String hexColor) { |
9260 | 360 |
361 if (fromInput == null || toInput == null || zoneName == null || hexColor == null || fromInput.trim().isEmpty() || toInput.trim().isEmpty() | |
362 || zoneName.trim().isEmpty() || hexColor.trim().isEmpty()) | |
363 return this.MSG.uinfo_vegetation_zones_validation_empty(); | |
364 | |
365 try { | |
366 final Integer from = Integer.valueOf(fromInput); | |
367 final Integer to = Integer.valueOf(toInput); | |
368 | |
369 if (from < 0 || from > 365) | |
370 return this.MSG.uinfo_vegetation_zones_validation_range(); | |
371 | |
372 if (to < 0 || to > 365) | |
373 return this.MSG.uinfo_vegetation_zones_validation_range(); | |
374 | |
375 if (from > to) | |
376 return this.MSG.uinfo_vegetation_zones_validation_from_greater_to(); | |
377 | |
378 return null; | |
379 } | |
380 catch (final NumberFormatException e) { | |
381 return this.MSG.error_invalid_integer(); | |
382 } | |
383 } | |
384 | |
385 @Override | |
9299 | 386 public final List<String> validate() { |
9260 | 387 final List<String> errors = new ArrayList<String>(); |
388 | |
9403 | 389 if (VegetationZoneServerClientXChange.zonesAreOverlapping(this.getZones(this.elements.getRecords()))) |
9260 | 390 errors.add(this.MSG.uinfo_vegetation_zone_overlap()); |
9403 | 391 if (VegetationZoneServerClientXChange.hasGaps(this.getZones(this.elements.getRecords()), 0, 365)) |
9260 | 392 errors.add(this.MSG.uinfo_vegetation_zone_has_gaps()); |
393 return errors; | |
394 } | |
395 | |
9299 | 396 protected final void updateValidationMsgLabel() { |
9260 | 397 this.validationLabel.setText(validate().toString().replace("[", "").replace("]", "").replace(",", "")); |
398 } | |
9299 | 399 |
400 protected abstract Canvas createHelper(final DataList data); | |
9107 | 401 } |