+/*******************************************************************************\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.document.ui.actions;\r
+\r
+import org.eclipse.jface.dialogs.InputDialog;\r
+import org.eclipse.swt.widgets.Display;\r
+import org.simantics.Simantics;\r
+import org.simantics.db.ReadGraph;\r
+import org.simantics.db.Resource;\r
+import org.simantics.db.WriteGraph;\r
+import org.simantics.db.common.request.WriteRequest;\r
+import org.simantics.db.exception.DatabaseException;\r
+import org.simantics.db.exception.ManyObjectsForFunctionalRelationException;\r
+import org.simantics.db.exception.ServiceException;\r
+import org.simantics.document.DocumentResource;\r
+import org.simantics.document.ui.dialogs.UrlDetailDialog;\r
+import org.simantics.layer0.Layer0;\r
+import org.simantics.utils.datastructures.Callback;\r
+import org.simantics.utils.ui.ExceptionUtils;\r
+\r
+/**\r
+ * Action for adding URI-links as documents.\r
+ * \r
+ * @author Marko Luukkainen <marko.luukkainen@vtt.fi>\r
+ *\r
+ */\r
+public class AddUrlDocumentWithDetail extends AddDocumentAction {\r
+\r
+ public AddUrlDocumentWithDetail(ReadGraph graph, String relationUri)\r
+ throws DatabaseException {\r
+ super(graph, relationUri);\r
+ }\r
+\r
+\r
+ @Override\r
+ public Runnable create(Object target) {\r
+ if(!(target instanceof Resource))\r
+ return null;\r
+ final Resource resource = (Resource)target;\r
+ return new Runnable() {\r
+ \r
+ @Override\r
+ public void run() {\r
+ final UrlDetailDialog dialog = new UrlDetailDialog(Display.getCurrent().getActiveShell(),resource);\r
+ if (dialog.open() != InputDialog.OK) {\r
+ dialog.getAnnotationConfigurator().dispose();\r
+ return;\r
+ }\r
+ final String uriString = dialog.getUrl();\r
+ final String name = dialog.getName();\r
+ Simantics.getSession().asyncRequest(new WriteRequest() {\r
+ @Override\r
+ public void perform(WriteGraph graph)\r
+ throws DatabaseException {\r
+ graph.markUndoPoint();\r
+ Resource urlDocument = doAddUrl(graph, name, uriString);\r
+ linkDocument(graph, resource, urlDocument);\r
+ dialog.getAnnotationConfigurator().apply(graph,urlDocument);\r
+ }\r
+ },new Callback<DatabaseException>() {\r
+ @Override\r
+ public void run(DatabaseException parameter) {\r
+ dialog.getAnnotationConfigurator().dispose();\r
+ if (parameter != null) {\r
+ ExceptionUtils.logAndShowError("Cannot add URL link.", parameter);\r
+ }\r
+ \r
+ }\r
+ });\r
+ }\r
+ };\r
+ }\r
+\r
+ private Resource doAddUrl(WriteGraph graph, String name, String uriString) throws ManyObjectsForFunctionalRelationException, ServiceException {\r
+ Layer0 l0 = Layer0.getInstance(graph);\r
+ DocumentResource doc = DocumentResource.getInstance(graph);\r
+ Resource urlDocument = graph.newResource();\r
+ graph.claim(urlDocument, l0.InstanceOf, doc.UrlDocument);\r
+ graph.claimLiteral(urlDocument, l0.HasName, name);\r
+ graph.claimLiteral(urlDocument, doc.HasUrl, uriString);\r
+ return urlDocument;\r
+ }\r
+ \r
+ public static Resource addUrlDocumentWithDetailSCL(WriteGraph graph, Resource target, String name, String uriString) throws DatabaseException {\r
+ AddUrlDocumentWithDetail urlDocument = new AddUrlDocumentWithDetail(graph, "http://www.simantics.org/Layer0-1.1/ConsistsOf");\r
+ Resource urlResource = urlDocument.doAddUrl(graph, name, uriString);\r
+ urlDocument.linkDocument(graph, target, urlResource);\r
+ return urlResource;\r
+ }\r
+\r
+ \r
+// @Override\r
+// public Runnable create(Object target) {\r
+//\r
+// if(!(target instanceof Resource))\r
+// return null;\r
+//\r
+// final Resource resource = (Resource)target;\r
+//\r
+// return new Runnable() {\r
+// @Override\r
+// public void run() {\r
+// InputDialog dialog = new InputDialog(Display.getCurrent().getActiveShell(), "Add URL", "Input URL", "", new URLValidator());\r
+// if (dialog.open() != InputDialog.OK)\r
+// return;\r
+// final String uriString = dialog.getValue();\r
+// Simantics.getSession().asyncRequest(new WriteRequest() {\r
+// \r
+// @Override\r
+// public void perform(WriteGraph graph) throws DatabaseException {\r
+// Layer0 l0 = Layer0.getInstance(graph);\r
+// DocumentResource doc = DocumentResource.getInstance(graph);\r
+// Resource urlDocument = graph.newResource();\r
+// graph.claim(urlDocument, l0.InstanceOf, doc.UrlDocument);\r
+// graph.claimLiteral(urlDocument, l0.HasName, uriString);\r
+// graph.claimLiteral(urlDocument, doc.HasUrl, uriString);\r
+// \r
+// if (graph.isInstanceOf(resource, doc.UrlDocument)) {\r
+// if (graph.hasStatement(resource, doc.HasNewerVersion))\r
+// throw new DatabaseException("Document " + NameUtils.getSafeName(graph, resource) +" has already new version");\r
+// // adding a new revision\r
+// Resource inverse = graph.getInverse(relation);\r
+// Resource lib = graph.getSingleObject(resource, inverse);\r
+// graph.claim(lib, relation, urlDocument);\r
+// graph.claim(resource, doc.HasNewerVersion, urlDocument);\r
+// } else {\r
+// // adding to a library\r
+// graph.claim(resource, relation, urlDocument);\r
+// }\r
+// }\r
+// },new Callback<DatabaseException>() {\r
+// \r
+// @Override\r
+// public void run(DatabaseException parameter) {\r
+// if (parameter != null) {\r
+// ExceptionUtils.logAndShowError("Cannot add URL link.", parameter);\r
+// }\r
+// \r
+// }\r
+// });\r
+// \r
+// }\r
+// };\r
+// }\r
+}\r