--- /dev/null
+package org.simantics.modeling.ui.handlers.e4;\r
+\r
+import javax.inject.Named;\r
+\r
+import org.eclipse.e4.core.di.annotations.CanExecute;\r
+import org.eclipse.e4.core.di.annotations.Execute;\r
+import org.eclipse.e4.ui.model.application.ui.basic.MPart;\r
+import org.eclipse.e4.ui.services.IServiceConstants;\r
+import org.eclipse.jface.dialogs.MessageDialog;\r
+import org.eclipse.swt.widgets.Shell;\r
+import org.eclipse.ui.IEditorPart;\r
+import org.eclipse.ui.internal.e4.compatibility.CompatibilityEditor;\r
+import org.simantics.Simantics;\r
+import org.simantics.db.Resource;\r
+import org.simantics.db.Session;\r
+import org.simantics.db.exception.DatabaseException;\r
+import org.simantics.modeling.typicals.SyncTypicalTemplatesToInstances;\r
+import org.simantics.modeling.ui.documents.OpenPlainTextDocumentAdapter;\r
+import org.simantics.modeling.ui.property.TypicalPropertyTester;\r
+import org.simantics.modeling.ui.typicals.RuleChooserDialog;\r
+import org.simantics.ui.workbench.IResourceEditorInput;\r
+import org.simantics.utils.ui.ErrorLogger;\r
+import org.simantics.utils.ui.workbench.WorkbenchUtils;\r
+\r
+/**\r
+ * @author Tuukka Lehtonen\r
+ *\r
+ */\r
+public class SyncCurrentTypicalInstanceWithTemplate {\r
+\r
+ @CanExecute\r
+ public boolean canExecute(@Named(IServiceConstants.ACTIVE_PART) MPart part) throws DatabaseException, InterruptedException {\r
+ // TODO: Fix this when we get rid of CompatibilityEditors\r
+ IEditorPart activeEditor = null;\r
+ if (part != null && part.getObject() instanceof CompatibilityEditor) {\r
+ CompatibilityEditor compEditor = (CompatibilityEditor) part.getObject();\r
+ activeEditor = compEditor.getEditor();\r
+ } else {\r
+ // TODO: This is not good practice with E4 but an OK fallback for now\r
+ activeEditor = WorkbenchUtils.getActiveEditor();\r
+ }\r
+ if (activeEditor == null)\r
+ return false;\r
+ IResourceEditorInput input = (IResourceEditorInput) activeEditor.getEditorInput();\r
+ return TypicalPropertyTester.isTypicalInstanceEditor(Simantics.getSession(), input.getResource());\r
+ }\r
+ \r
+ @Execute\r
+ public void execute(@Named(IServiceConstants.ACTIVE_SHELL) Shell shell, @Named(IServiceConstants.ACTIVE_PART) MPart mActiveEditor) {\r
+\r
+ // TODO: Fix this when we get rid of CompatibilityEditors\r
+ IEditorPart activeEditor = null;\r
+ Object editor = mActiveEditor.getObject();\r
+ if (editor instanceof CompatibilityEditor) {\r
+ CompatibilityEditor compEditor = (CompatibilityEditor) editor;\r
+ activeEditor = compEditor.getEditor();\r
+ } else {\r
+ // TODO: This is not good practice with E4 but an OK fallback for now\r
+ activeEditor = WorkbenchUtils.getActiveEditor();\r
+ }\r
+ if (activeEditor == null)\r
+ return;\r
+\r
+ IResourceEditorInput input = (IResourceEditorInput) activeEditor.getEditorInput();\r
+ Session session = Simantics.getSession();\r
+\r
+// if (!MessageDialog\r
+// .openConfirm(shell,\r
+// "Synchronize Typical Instance With Template",\r
+// "Are you sure you want to synchronize this typical instance with its template?"))\r
+// return null;\r
+\r
+ try {\r
+ if (!TypicalPropertyTester.isTypicalInstanceEditor(session, input.getResource())) {\r
+ MessageDialog.openInformation(shell, "Not Synchronizing", "Currently active editor is not a typical diagram instance editor.");\r
+ return;\r
+ }\r
+\r
+ RuleChooserDialog.RuleResult result = RuleChooserDialog.choose(shell, "Synchronizing typical instance with its template.", new Resource[] { input.getResource() });\r
+ if(result == null) return;\r
+\r
+ SyncTypicalTemplatesToInstances req = SyncTypicalTemplatesToInstances.syncSingleInstance(result.selectedRules, input.getResource()).logging(result.logging); \r
+ session.syncRequest(req);\r
+ if (result.logging) {\r
+ for(Resource log : req.logs)\r
+ new OpenPlainTextDocumentAdapter().openEditor(log);\r
+ }\r
+ } catch (Exception e) {\r
+ ErrorLogger.defaultLogError(e);\r
+ }\r
+ return;\r
+ \r
+ }\r
+\r
+}\r