Mercurial > dive4elements > river
annotate gwt-client/src/main/java/org/dive4elements/river/client/client/ui/uinfo/AbstractVegZonesTablePanel.java @ 9299:4a6cc7c6716a
uinfo.inundation_duration veg'zone select
author | gernotbelger |
---|---|
date | Wed, 25 Jul 2018 14:42:44 +0200 |
parents | b570b6fcc052 |
children | d89976700474 |
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; | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
23 import org.dive4elements.river.client.shared.model.VegetationZone; |
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>(); |
55 private final Label validationLabel = new Label(); | |
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()); | |
175 colorField.setHidden(VegetationZone.HAS_COLORS_EDITABLE ? false : true); | |
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); |
205 this.validationLabel.setHeight("10px"); | |
206 this.validationLabel.getElement().getStyle().setColor("red"); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
207 addDataInit(data); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
208 root.setWidth(width); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
209 root.addMember(title); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
210 root.addMember(this.elements); |
9260 | 211 root.addMember(PanelHelper.getSpacer(3)); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
212 |
9260 | 213 root.addMember(this.validationLabel); |
214 root.addMember(PanelHelper.getSpacer(3)); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
215 return this.elements; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
216 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
217 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
218 private IntegerRangeValidator getValidator() { |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
219 final IntegerRangeValidator validator = new IntegerRangeValidator(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
220 validator.setMin(0); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
221 validator.setMax(365); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
222 validator.setErrorMessage(this.MSG.uinfo_vegetation_zones_validation_range()); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
223 return validator; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
224 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
225 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
226 private SortNormalizer getNormalizer() { |
9114 | 227 final SortNormalizer normalizer = new SortNormalizer() { |
9107 | 228 |
9114 | 229 @Override |
230 public Object normalize(final ListGridRecord record, final String fieldName) { | |
231 final String number = record.getAttribute(fieldName); | |
232 final String numberFormat = "000" + number; | |
233 return numberFormat.substring(numberFormat.length() - 3); | |
234 } | |
235 }; | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
236 return normalizer; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
237 } |
9107 | 238 |
239 public abstract void createWidget(final Layout root, final DataList data); | |
9068 | 240 |
9070
611a523fc42f
VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents:
9069
diff
changeset
|
241 private final void addDataInit(final DataList data) { |
9068 | 242 for (final Data dataItemContainer : data.getAll()) { |
243 if (dataItemContainer.getItems() != null) { | |
244 for (final DataItem dataItem : dataItemContainer.getItems()) { | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
245 if (dataItem.getStringValue() != null) { |
9299 | 246 createTableFromDataStr(dataItem.getStringValue()); |
9068 | 247 } |
248 } | |
249 } | |
250 } | |
251 } | |
252 | |
9299 | 253 protected final void createTableFromDataStr(final String data) { |
254 for (final ListGridRecord r : this.elements.getRecords()) { | |
255 this.elements.removeData(r); | |
256 } | |
257 final List<VegetationZone> rows = VegetationZone.parse(data); | |
258 for (final VegetationZone row : rows) { | |
259 this.elements.addData(createEntry(row)); | |
260 } | |
261 } | |
262 | |
9068 | 263 @Override |
264 public final Canvas create(final DataList data) { | |
265 final VLayout layout = new VLayout(); | |
9107 | 266 |
9133
af73fdd96920
Title current/historical diff pair; limit on entries in diff'pair twin_panel
gernotbelger
parents:
9119
diff
changeset
|
267 // TODO: Helper zur Vegetationszonen-Auswahl |
9299 | 268 final Canvas helper = createHelper(data); |
269 if (helper != null) | |
270 this.helperContainer.addMember(helper); | |
9068 | 271 |
272 final Canvas submit = getNextButton(); | |
273 | |
9107 | 274 final VLayout root = new VLayout(); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
275 root.setWidth(450); |
9107 | 276 createWidget(root, data); |
9068 | 277 |
9107 | 278 layout.addMember(root); |
279 layout.addMember(submit); | |
9068 | 280 |
9299 | 281 updateValidationMsgLabel();// init Text |
9260 | 282 |
9068 | 283 return layout; |
284 } | |
285 | |
286 @Override | |
287 public Canvas createOld(final DataList dataList) { | |
288 final HLayout layout = new HLayout(); | |
289 layout.setWidth("400px"); | |
290 final VLayout vLayout = new VLayout(); | |
291 vLayout.setWidth(130); | |
292 final Label label = new Label(dataList.getLabel()); | |
293 label.setWidth("200px"); | |
9260 | 294 label.setHeight("25px"); |
9068 | 295 |
296 final List<Data> items = dataList.getAll(); | |
297 final Data str = getData(items, datakey); | |
298 final DataItem[] strItems = str.getItems(); | |
299 | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
300 final List<VegetationZone> entries = VegetationZone.parse(strItems[0].getLabel()); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
301 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
302 for (final VegetationZone entry : entries) { |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
303 final Label dateLabel = new Label(entry.getZoneName() + " (" + entry.getMin_day_overflow() + "-" + entry.getMax_day_overflow() + ")"); |
9260 | 304 dateLabel.setHeight("20px"); |
9068 | 305 vLayout.addMember(dateLabel); |
306 } | |
307 final Canvas back = getBackButton(dataList.getState()); | |
308 layout.addMember(label); | |
309 layout.addMember(vLayout); | |
310 layout.addMember(back); | |
311 | |
312 return layout; | |
313 } | |
314 | |
315 @Override | |
316 protected final Data[] getData() { | |
317 final List<Data> data = new ArrayList<Data>(); | |
318 | |
319 final ListGridRecord[] lgr = this.elements.getRecords(); | |
320 if (lgr.length == 0) { | |
9133
af73fdd96920
Title current/historical diff pair; limit on entries in diff'pair twin_panel
gernotbelger
parents:
9119
diff
changeset
|
321 return new Data[0]; // TODO: Klären, ob Vegetationszonen-Auswahl Pflicht ist, ob es ein Fallback geben soll usw. |
9068 | 322 } |
9260 | 323 |
324 final DataItem item = new DefaultDataItem(datakey, null, VegetationZone.parseListToDataString(getZones(lgr))); // DATA-key | |
325 data.add(new DefaultData(datakey, null, null, new DataItem[] { item })); | |
326 return data.toArray(new Data[data.size()]); | |
327 } | |
328 | |
329 protected final List<VegetationZone> getZones(final ListGridRecord[] lgr) { | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
330 final List<VegetationZone> zoneList = new ArrayList<VegetationZone>(); |
9068 | 331 for (final ListGridRecord element : lgr) { |
332 final Record r = element; | |
9260 | 333 final VegetationZone zone = VegetationZone.createFromTableEntry(r.getAttribute("vegzone"), r.getAttribute("from"), r.getAttribute("to"), |
334 r.getAttribute("color")); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
335 zoneList.add(zone); |
9068 | 336 } |
9260 | 337 return zoneList; |
9068 | 338 } |
339 | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
340 public final ListGridRecord createEntry(final VegetationZone row) { |
9068 | 341 |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
342 final String vegzone = row.getZoneName(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
343 final Integer from = row.getMin_day_overflow(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
344 final Integer to = row.getMax_day_overflow(); |
9260 | 345 final String colorStr = row.getHexColor(); |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
346 if (vegzone == null || from == null || to == null) { |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
347 return null; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
348 } |
9068 | 349 |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
350 final ListGridRecord r = new ListGridRecord(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
351 r.setAttribute("vegzone", vegzone); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
352 r.setAttribute("from", from); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
353 r.setAttribute("to", to); |
9260 | 354 r.setAttribute("color", colorStr); |
355 r.setAttribute("number", this.records.size()); | |
356 this.records.add(r); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9114
diff
changeset
|
357 return r; |
9068 | 358 |
359 } | |
9260 | 360 |
9299 | 361 protected final String validate(final String fromInput, final String toInput, final String zoneName, final String hexColor) { |
9260 | 362 |
363 if (fromInput == null || toInput == null || zoneName == null || hexColor == null || fromInput.trim().isEmpty() || toInput.trim().isEmpty() | |
364 || zoneName.trim().isEmpty() || hexColor.trim().isEmpty()) | |
365 return this.MSG.uinfo_vegetation_zones_validation_empty(); | |
366 | |
367 try { | |
368 final Integer from = Integer.valueOf(fromInput); | |
369 final Integer to = Integer.valueOf(toInput); | |
370 | |
371 if (from < 0 || from > 365) | |
372 return this.MSG.uinfo_vegetation_zones_validation_range(); | |
373 | |
374 if (to < 0 || to > 365) | |
375 return this.MSG.uinfo_vegetation_zones_validation_range(); | |
376 | |
377 if (from > to) | |
378 return this.MSG.uinfo_vegetation_zones_validation_from_greater_to(); | |
379 | |
380 return null; | |
381 } | |
382 catch (final NumberFormatException e) { | |
383 return this.MSG.error_invalid_integer(); | |
384 } | |
385 } | |
386 | |
387 @Override | |
9299 | 388 public final List<String> validate() { |
9260 | 389 final List<String> errors = new ArrayList<String>(); |
390 | |
391 if (VegetationZone.zonesAreOverlapping(this.getZones(this.elements.getRecords()))) | |
392 errors.add(this.MSG.uinfo_vegetation_zone_overlap()); | |
393 if (VegetationZone.hasGaps(this.getZones(this.elements.getRecords()), 0, 365)) | |
394 errors.add(this.MSG.uinfo_vegetation_zone_has_gaps()); | |
395 return errors; | |
396 } | |
397 | |
9299 | 398 protected final void updateValidationMsgLabel() { |
9260 | 399 this.validationLabel.setText(validate().toString().replace("[", "").replace("]", "").replace(",", "")); |
400 } | |
9299 | 401 |
402 protected abstract Canvas createHelper(final DataList data); | |
9107 | 403 } |