--- /dev/null
+/*******************************************************************************\r
+ * Copyright (c) 2007, 2010 Association for Decentralized Information Management\r
+ * in Industry THTH ry.\r
+ * All rights reserved. This program and the accompanying materials\r
+ * are made available under the terms of the Eclipse Public License v1.0\r
+ * which accompanies this distribution, and is available at\r
+ * http://www.eclipse.org/legal/epl-v10.html\r
+ *\r
+ * Contributors:\r
+ * VTT Technical Research Centre of Finland - initial API and implementation\r
+ *******************************************************************************/\r
+package org.simantics.spreadsheet.ui.editor;\r
+\r
+import java.util.Collections;\r
+\r
+import org.eclipse.swt.SWT;\r
+import org.eclipse.swt.layout.GridData;\r
+import org.eclipse.swt.widgets.Composite;\r
+import org.eclipse.ui.contexts.IContextService;\r
+import org.simantics.db.ReadGraph;\r
+import org.simantics.db.exception.DatabaseException;\r
+import org.simantics.db.layer0.variable.Variable;\r
+import org.simantics.db.request.Read;\r
+import org.simantics.selectionview.StandardPropertyPage;\r
+import org.simantics.spreadsheet.graph.GraphUI;\r
+import org.simantics.spreadsheet.resource.SpreadsheetResource;\r
+import org.simantics.spreadsheet.ui.Spreadsheet;\r
+import org.simantics.ui.workbench.IPropertyPage;\r
+import org.simantics.ui.workbench.ResourceEditorPart2;\r
+import org.simantics.utils.ui.LayoutUtils;\r
+import org.simantics.utils.ui.jface.ActiveSelectionProvider;\r
+\r
+public class SpreadsheetEditor extends ResourceEditorPart2 {\r
+\r
+ public static final boolean EXCEL = true;\r
+ public static final String EDITOR_ID = "org.simantics.spreadsheet.ui.editor";\r
+\r
+ private Spreadsheet spreadsheet;\r
+// private SimpleContainerTableModel tableModel;\r
+ private final ActiveSelectionProvider selectionProvider = new ActiveSelectionProvider();\r
+ //private ExcelLink excelLink;\r
+ private GraphUI ui;\r
+\r
+ public Spreadsheet getSpreadsheet() {\r
+ return spreadsheet;\r
+ }\r
+\r
+ @Override\r
+ public void createPartControl(Composite parent) {\r
+\r
+ // Create UI\r
+ parent.setLayout(LayoutUtils.createNoBorderGridLayout(1));\r
+ parent.setBackground(parent.getDisplay().getSystemColor(SWT.COLOR_WHITE));\r
+\r
+ ui = new GraphUI(getSession());\r
+\r
+ try {\r
+\r
+ Variable variable = getSession().syncRequest(new Read<Variable>() {\r
+\r
+ @Override\r
+ public Variable perform(ReadGraph graph) throws DatabaseException {\r
+ \r
+// String modelURI = getResourceInput2().getModelURI();\r
+// String rvi = getResourceInput2().getRVI();\r
+// Resource model = graph.getResource(modelURI);\r
+// Resource config = getInputResource();\r
+//// String configName = URIStringUtils.escape((String)graph.getPossibleRelatedValue(config, b.HasName, Bindings.STRING));\r
+//// Resource model = StructuralVariables.getModel(graph, config);\r
+// Resource realization = graph.getPossibleObject(model, b.HasBaseRealization);\r
+// Variable base = graph.adapt(realization, Variable.class);\r
+// return base.browse(graph, rvi);\r
+ return null;\r
+ \r
+ }\r
+\r
+ });\r
+\r
+ spreadsheet = new Spreadsheet(parent, SWT.NONE, ui, selectionProvider);\r
+ spreadsheet.setBackground(parent.getDisplay().getSystemColor(SWT.COLOR_WHITE));\r
+\r
+ ui.load(variable, spreadsheet.getClientInterface());\r
+ } catch (DatabaseException e) {\r
+ e.printStackTrace();\r
+ }\r
+\r
+ spreadsheet.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true));\r
+ spreadsheet.defaultInitializeUI();\r
+\r
+ getSite().setSelectionProvider(selectionProvider);\r
+\r
+ IContextService contexts = (IContextService)getSite().getService(IContextService.class);\r
+ contexts.activateContext("org.simantics.spreadsheet.ui.context");\r
+\r
+ }\r
+\r
+ @Override\r
+ public void setFocus() {\r
+ if (spreadsheet != null)\r
+ spreadsheet.setFocus();\r
+ }\r
+\r
+ @Override\r
+ public Object getAdapter(Class adapter) {\r
+ if (adapter == IPropertyPage.class)\r
+ return new StandardPropertyPage(getSite(), Collections.singleton(SpreadsheetResource.URIs.BrowseContext));\r
+ if (adapter == GraphUI.class)\r
+ return ui;\r
+ if (adapter == Spreadsheet.class)\r
+ return getSpreadsheet();\r
+ return null;\r
+ }\r
+\r
+ @Override\r
+ public void dispose() {\r
+\r
+// if(EXCEL)\r
+// excelLink.dispose();\r
+ \r
+// backend.dispose();\r
+\r
+// tableModel.dispose();\r
+\r
+ super.dispose();\r
+\r
+ }\r
+\r
+}\r