]> gerrit.simantics Code Review - simantics/district.git/blobdiff - org.simantics.district.network.ui/src/org/simantics/district/network/ui/techtype/table/TechTypeTable.java
Read tech type table data from model
[simantics/district.git] / org.simantics.district.network.ui / src / org / simantics / district / network / ui / techtype / table / TechTypeTable.java
index 725700f89c50b1c660d9b95418e65e479e91c223..eb83c902ddf535c9bcd8ae236de40913d33bf4a6 100644 (file)
@@ -1,6 +1,10 @@
 package org.simantics.district.network.ui.techtype.table;
 
-import java.io.Serializable;
+import java.io.IOException;
+import java.nio.charset.Charset;
+import java.nio.file.Files;
+import java.nio.file.Paths;
+import java.util.stream.Collectors;
 
 import org.eclipse.jface.layout.GridDataFactory;
 import org.eclipse.jface.layout.GridLayoutFactory;
@@ -9,7 +13,6 @@ import org.eclipse.nebula.widgets.nattable.config.DefaultNatTableStyleConfigurat
 import org.eclipse.nebula.widgets.nattable.config.IConfigRegistry;
 import org.eclipse.nebula.widgets.nattable.copy.command.CopyDataCommandHandler;
 import org.eclipse.nebula.widgets.nattable.data.IDataProvider;
-import org.eclipse.nebula.widgets.nattable.data.IRowIdAccessor;
 import org.eclipse.nebula.widgets.nattable.freeze.CompositeFreezeLayer;
 import org.eclipse.nebula.widgets.nattable.freeze.FreezeLayer;
 import org.eclipse.nebula.widgets.nattable.grid.GridRegion;
@@ -29,7 +32,6 @@ import org.eclipse.nebula.widgets.nattable.layer.DataLayer;
 import org.eclipse.nebula.widgets.nattable.layer.ILayer;
 import org.eclipse.nebula.widgets.nattable.layer.IUniqueIndexLayer;
 import org.eclipse.nebula.widgets.nattable.reorder.RowReorderLayer;
-import org.eclipse.nebula.widgets.nattable.selection.RowSelectionModel;
 import org.eclipse.nebula.widgets.nattable.selection.SelectionLayer;
 import org.eclipse.nebula.widgets.nattable.sort.SortHeaderLayer;
 import org.eclipse.nebula.widgets.nattable.viewport.ViewportLayer;
@@ -39,9 +41,17 @@ import org.eclipse.swt.events.ModifyEvent;
 import org.eclipse.swt.events.ModifyListener;
 import org.eclipse.swt.widgets.Composite;
 import org.eclipse.swt.widgets.Text;
+import org.simantics.Simantics;
+import org.simantics.db.Resource;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.district.network.ui.techtype.requests.WriteTechTypeTableRequest;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 
 public class TechTypeTable extends Composite {
 
+       private final static Logger LOGGER = LoggerFactory.getLogger(TechTypeTable.class);
+
        NatTable table;
        private TechTypeTableDataProvider bodyDataProvider;
        DataLayer bodyDataLayer;
@@ -50,63 +60,69 @@ public class TechTypeTable extends Composite {
        private ViewportLayer viewportLayer;
        private CompositeFreezeLayer compositeFreezeLayer;
        private FreezeLayer freezeLayer;
-       //private TableDataSortModel sortModel;
+       // private TableDataSortModel sortModel;
        private ColumnHideShowLayer columnHideShowLayer;
        private ColumnGroupModel columnGroupModel = new ColumnGroupModel();
        private TechTypeColumnHeaderTableDataProvider columnHeaderDataProvider;
        Clipboard cpb;
        public SelectionLayer selectionLayer;
-    private TechTypeTableSortModel sortModel;
+       private TechTypeTableSortModel sortModel;
+
+       private Resource componentType;
 
-       public TechTypeTable(Composite parent, int style) {
+       public TechTypeTable(Composite parent, int style, Resource componentType, String data) {
                super(parent, style);
-               defaultInitializeUI();
+               this.componentType = componentType;
+
+               defaultInitializeUI(data);
        }
 
-       private void defaultInitializeUI() {
+       private void defaultInitializeUI(String data) {
                GridDataFactory.fillDefaults().grab(true, true).applyTo(this);
                GridLayoutFactory.fillDefaults().numColumns(1).applyTo(this);
-               
+
                Composite filterComposite = new Composite(this, SWT.NONE);
                GridDataFactory.fillDefaults().grab(true, false).applyTo(filterComposite);
-        GridLayoutFactory.fillDefaults().numColumns(1).applyTo(filterComposite);
-        
+               GridLayoutFactory.fillDefaults().numColumns(1).applyTo(filterComposite);
+
+               createFilterBar(filterComposite);
 
-        createFilterBar(filterComposite);
-        
                Composite tableComposite = new Composite(this, SWT.NONE);
                GridDataFactory.fillDefaults().grab(true, true).applyTo(tableComposite);
-        GridLayoutFactory.fillDefaults().numColumns(1).applyTo(tableComposite);
-               createTable(tableComposite);
+               GridLayoutFactory.fillDefaults().numColumns(1).applyTo(tableComposite);
+
+               createTable(tableComposite, data);
        }
 
        private void createFilterBar(Composite filterComposite) {
-           
-        Text filterText = new Text(filterComposite, SWT.BORDER);
-        GridDataFactory.fillDefaults().grab(true, true).applyTo(filterText);
-        filterText.addModifyListener(new ModifyListener() {
-            
-            @Override
-            public void modifyText(ModifyEvent e) {
-                System.out.println("text modified");
-                bodyDataProvider.setFilter(filterText.getText());
-                table.refresh(true);
-            }
-        });
-        
-    }
-
-    private void createTable(Composite parent) {
-
-               // build the body layer stack 
-               // Usually you would create a new layer stack by extending AbstractIndexLayerTransform and
-               // setting the ViewportLayer as underlying layer. But in this case using the ViewportLayer
+
+               Text filterText = new Text(filterComposite, SWT.BORDER);
+               GridDataFactory.fillDefaults().grab(true, true).applyTo(filterText);
+               filterText.addModifyListener(new ModifyListener() {
+
+                       @Override
+                       public void modifyText(ModifyEvent e) {
+                               System.out.println("text modified");
+                               bodyDataProvider.setFilter(filterText.getText());
+                               table.refresh(true);
+                       }
+               });
+
+       }
+
+       private void createTable(Composite parent, String data) {
+
+               // build the body layer stack
+               // Usually you would create a new layer stack by extending
+               // AbstractIndexLayerTransform and
+               // setting the ViewportLayer as underlying layer. But in this case using the
+               // ViewportLayer
                // directly as body layer is also working.
-               bodyDataProvider = new TechTypeTableDataProvider();
+               bodyDataProvider = new TechTypeTableDataProvider(data);
                bodyDataLayer = new DataLayer(bodyDataProvider);
 
-               RowReorderLayer rowReorderLayer =
-                               new RowReorderLayer(columnHideShowLayer = new ColumnHideShowLayer(bodyDataLayer));
+               RowReorderLayer rowReorderLayer = new RowReorderLayer(
+                               columnHideShowLayer = new ColumnHideShowLayer(bodyDataLayer));
 
                HoverLayer hoverLayer = new HoverLayer(rowReorderLayer, false);
                // we need to ensure that the hover styling is removed when the mouse
@@ -114,7 +130,7 @@ public class TechTypeTable extends Composite {
                hoverLayer.addConfiguration(new BodyHoverStylingBindings(hoverLayer));
 
                selectionLayer = new SelectionLayer(hoverLayer);
-               
+
                viewportLayer = new ViewportLayer(selectionLayer);
                viewportLayer.setRegionName(GridRegion.BODY);
                freezeLayer = new FreezeLayer(selectionLayer);
@@ -125,10 +141,13 @@ public class TechTypeTable extends Composite {
                DataLayer columnHeaderDataLayer = new DefaultColumnHeaderDataLayer(columnHeaderDataProvider);
                columnHeaderDataLayer.setRowsResizableByDefault(false);
                columnHeaderDataLayer.setColumnsResizableByDefault(true);
-               ColumnHeaderLayer columnHeaderLayer = new ColumnHeaderLayer(columnHeaderDataLayer, compositeFreezeLayer, selectionLayer);
-               ColumnGroupHeaderLayer columnGroupHeaderLayer = new ColumnGroupHeaderLayer(columnHeaderLayer, selectionLayer, columnGroupModel);
+               ColumnHeaderLayer columnHeaderLayer = new ColumnHeaderLayer(columnHeaderDataLayer, compositeFreezeLayer,
+                               selectionLayer);
+               ColumnGroupHeaderLayer columnGroupHeaderLayer = new ColumnGroupHeaderLayer(columnHeaderLayer, selectionLayer,
+                               columnGroupModel);
                columnGroupHeaderLayer.setCalculateHeight(true);
-               SortHeaderLayer<String> columnSortHeaderLayer = new SortHeaderLayer<>(columnGroupHeaderLayer, sortModel = new TechTypeTableSortModel(bodyDataProvider));
+               SortHeaderLayer<String> columnSortHeaderLayer = new SortHeaderLayer<>(columnGroupHeaderLayer,
+                               sortModel = new TechTypeTableSortModel(bodyDataProvider));
 
                // build the row header layer
                IDataProvider rowHeaderDataProvider = new TechTypeRowHeaderTableDataProvider(bodyDataProvider);
@@ -138,44 +157,59 @@ public class TechTypeTable extends Composite {
                RowHeaderLayer rowHeaderLayer = new RowHeaderLayer(rowHeaderDataLayer, compositeFreezeLayer, selectionLayer);
 
                // build the corner layer
-               IDataProvider cornerDataProvider = new DefaultCornerDataProvider(columnHeaderDataProvider, rowHeaderDataProvider);
+               IDataProvider cornerDataProvider = new DefaultCornerDataProvider(columnHeaderDataProvider,
+                               rowHeaderDataProvider);
                DataLayer cornerDataLayer = new DataLayer(cornerDataProvider);
                ILayer cornerLayer = new CornerLayer(cornerDataLayer, rowHeaderLayer, columnSortHeaderLayer);
 
                // build the grid layer
                GridLayer gridLayer = new GridLayer(compositeFreezeLayer, columnSortHeaderLayer, rowHeaderLayer, cornerLayer);
-               
+
                table = new NatTable(parent, NatTable.DEFAULT_STYLE_OPTIONS | SWT.BORDER, gridLayer, false);
                GridDataFactory.fillDefaults().grab(true, true).applyTo(table);
-               
+
                // Register a CopyDataCommandHandler that also copies the headers and
                // uses the configured IDisplayConverters
-               CopyDataCommandHandler copyHandler = new CopyDataCommandHandler(
-                               selectionLayer,
-                               columnHeaderDataLayer,
+               CopyDataCommandHandler copyHandler = new CopyDataCommandHandler(selectionLayer, columnHeaderDataLayer,
                                rowHeaderDataLayer);
                copyHandler.setCopyFormattedText(true);
                gridLayer.registerCommandHandler(copyHandler);
-               
+
                // initialize paste handler with SWT clipboard
                cpb = new Clipboard(getDisplay());
-               //PasteDataCommandHandler pasteHandler = new PasteDataCommandHandler(bodyDataProvider, bodyDataLayer, selectionLayer, cpb);
-               //bodyDataLayer.registerCommandHandler(pasteHandler);
-               
+               // PasteDataCommandHandler pasteHandler = new
+               // PasteDataCommandHandler(bodyDataProvider, bodyDataLayer, selectionLayer,
+               // cpb);
+               // bodyDataLayer.registerCommandHandler(pasteHandler);
+
                table.addConfiguration(new DefaultNatTableStyleConfiguration());
-               //table.addConfiguration(new EditingSupportConfiguration(bodyDataProvider));
+               // table.addConfiguration(new EditingSupportConfiguration(bodyDataProvider));
                table.configure();
        }
-       
+
        @Override
        public void dispose() {
                cpb.dispose();
                super.dispose();
        }
 
-    public void setTechTypePath(String path) {
-        bodyDataProvider.setPath(path);
-        table.refresh(true);
-    }
+       public void setTechTypePath(String path) {
+               String data;
+               try {
+                       data = Files.lines(Paths.get(path)).collect(Collectors.joining("\n"));
+               } catch (IOException e) {
+                       LOGGER.error("Failed to read contents of file '{}' as {}", path, Charset.defaultCharset(), e);
+                       return;
+               }
+
+               try {
+                       Simantics.getSession().syncRequest(new WriteTechTypeTableRequest(componentType, data));
+               } catch (DatabaseException e) {
+                       LOGGER.error("Failed to write tech type table data to model", e);
+               }
+
+               bodyDataProvider.setData(data);
+               table.refresh(true);
+       }
 
 }