634 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
		
		
			
		
	
	
			634 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
|   | <!--
 | ||
|  |   Copyright (c) 2006-2013, JGraph Ltd | ||
|  |    | ||
|  |   Ports example for mxGraph. This example demonstrates implementing | ||
|  |   ports as child vertices with relative positions and drag and drop | ||
|  |   as well as the use of images and HTML in cells. | ||
|  | --> | ||
|  | <html> | ||
|  | <head> | ||
|  | 	<title>Ports example</title> | ||
|  | 	<style type="text/css" media="screen"> | ||
|  | 		BODY { | ||
|  | 			font-family: Arial; | ||
|  | 		} | ||
|  | 		H1 { | ||
|  | 			font-size: 18px; | ||
|  | 		} | ||
|  | 		H2 { | ||
|  | 			font-size: 16px; | ||
|  | 		} | ||
|  | 	</style> | ||
|  | 
 | ||
|  | 	<!-- Sets the basepath for the library if not in same directory --> | ||
|  | 	<script type="text/javascript"> | ||
|  | 		mxBasePath = '../src'; | ||
|  | 	</script> | ||
|  | 
 | ||
|  | 	<!-- Loads and initializes the library --> | ||
|  | 	<script type="text/javascript" src="../src/js/mxClient.js"></script> | ||
|  | 
 | ||
|  | 	<!-- Example code --> | ||
|  | 	<script type="text/javascript"> | ||
|  | 		// Program starts here. Creates a sample graph in the | ||
|  | 		// DOM node with the specified ID. This function is invoked | ||
|  | 		// from the onLoad event handler of the document (see below). | ||
|  | 		function main(container, outline, toolbar, sidebar, status) | ||
|  | 		{ | ||
|  | 			// Checks if the browser is supported | ||
|  | 			if (!mxClient.isBrowserSupported()) | ||
|  | 			{ | ||
|  | 				// Displays an error message if the browser is not supported. | ||
|  | 				mxUtils.error('Browser is not supported!', 200, false); | ||
|  | 			} | ||
|  | 			else | ||
|  | 			{ | ||
|  | 				// Assigns some global constants for general behaviour, eg. minimum | ||
|  | 				// size (in pixels) of the active region for triggering creation of | ||
|  | 				// new connections, the portion (100%) of the cell area to be used | ||
|  | 				// for triggering new connections, as well as some fading options for | ||
|  | 				// windows and the rubberband selection. | ||
|  | 				mxConstants.MIN_HOTSPOT_SIZE = 16; | ||
|  | 				mxConstants.DEFAULT_HOTSPOT = 1; | ||
|  | 				 | ||
|  | 				// Enables guides | ||
|  | 				mxGraphHandler.prototype.guidesEnabled = true; | ||
|  | 
 | ||
|  | 			    // Alt disables guides | ||
|  | 			    mxGuide.prototype.isEnabledForEvent = function(evt) | ||
|  | 				{ | ||
|  | 					return !mxEvent.isAltDown(evt); | ||
|  | 				}; | ||
|  | 
 | ||
|  | 				// Enables snapping waypoints to terminals | ||
|  | 				mxEdgeHandler.prototype.snapToTerminals = true; | ||
|  | 
 | ||
|  | 				// Workaround for Internet Explorer ignoring certain CSS directives | ||
|  | 				if (mxClient.IS_QUIRKS) | ||
|  | 				{ | ||
|  | 					document.body.style.overflow = 'hidden'; | ||
|  | 					new mxDivResizer(container); | ||
|  | 					new mxDivResizer(outline); | ||
|  | 					new mxDivResizer(toolbar); | ||
|  | 					new mxDivResizer(sidebar); | ||
|  | 					new mxDivResizer(status); | ||
|  | 				} | ||
|  | 				 | ||
|  | 				// Creates a wrapper editor with a graph inside the given container. | ||
|  | 				// The editor is used to create certain functionality for the | ||
|  | 				// graph, such as the rubberband selection, but most parts | ||
|  | 				// of the UI are custom in this example. | ||
|  | 				var editor = new mxEditor(); | ||
|  | 				var graph = editor.graph; | ||
|  | 				var model = graph.getModel(); | ||
|  | 
 | ||
|  | 				// Disable highlight of cells when dragging from toolbar | ||
|  | 				graph.setDropEnabled(false); | ||
|  | 
 | ||
|  | 				// Uses the port icon while connections are previewed | ||
|  | 				graph.connectionHandler.getConnectImage = function(state) | ||
|  | 				{ | ||
|  | 					return new mxImage(state.style[mxConstants.STYLE_IMAGE], 16, 16); | ||
|  | 				}; | ||
|  | 
 | ||
|  | 				// Centers the port icon on the target port | ||
|  | 				graph.connectionHandler.targetConnectImage = true; | ||
|  | 
 | ||
|  | 				// Does not allow dangling edges | ||
|  | 				graph.setAllowDanglingEdges(false); | ||
|  | 
 | ||
|  | 				// Sets the graph container and configures the editor | ||
|  | 				editor.setGraphContainer(container); | ||
|  | 				var config = mxUtils.load( | ||
|  | 					'editors/config/keyhandler-commons.xml'). | ||
|  | 						getDocumentElement(); | ||
|  | 				editor.configure(config); | ||
|  | 				 | ||
|  | 				// Defines the default group to be used for grouping. The | ||
|  | 				// default group is a field in the mxEditor instance that | ||
|  | 				// is supposed to be a cell which is cloned for new cells. | ||
|  | 				// The groupBorderSize is used to define the spacing between | ||
|  | 				// the children of a group and the group bounds. | ||
|  | 				var group = new mxCell('Group', new mxGeometry(), 'group'); | ||
|  | 				group.setVertex(true); | ||
|  | 				group.setConnectable(false); | ||
|  | 				editor.defaultGroup = group; | ||
|  | 				editor.groupBorderSize = 20; | ||
|  | 
 | ||
|  | 				// Disables drag-and-drop into non-swimlanes. | ||
|  | 				graph.isValidDropTarget = function(cell, cells, evt) | ||
|  | 				{ | ||
|  | 					return this.isSwimlane(cell); | ||
|  | 				}; | ||
|  | 				 | ||
|  | 				// Disables drilling into non-swimlanes. | ||
|  | 				graph.isValidRoot = function(cell) | ||
|  | 				{ | ||
|  | 					return this.isValidDropTarget(cell); | ||
|  | 				} | ||
|  | 
 | ||
|  | 				// Does not allow selection of locked cells | ||
|  | 				graph.isCellSelectable = function(cell) | ||
|  | 				{ | ||
|  | 					return !this.isCellLocked(cell); | ||
|  | 				}; | ||
|  | 
 | ||
|  | 				// Returns a shorter label if the cell is collapsed and no | ||
|  | 				// label for expanded groups | ||
|  | 				graph.getLabel = function(cell) | ||
|  | 				{ | ||
|  | 					var tmp = mxGraph.prototype.getLabel.apply(this, arguments); // "supercall" | ||
|  | 					 | ||
|  | 					if (this.isCellLocked(cell)) | ||
|  | 					{ | ||
|  | 						// Returns an empty label but makes sure an HTML | ||
|  | 						// element is created for the label (for event | ||
|  | 						// processing wrt the parent label) | ||
|  | 						return ''; | ||
|  | 					} | ||
|  | 					else if (this.isCellCollapsed(cell)) | ||
|  | 					{ | ||
|  | 						var index = tmp.indexOf('</h1>'); | ||
|  | 						 | ||
|  | 						if (index > 0) | ||
|  | 						{ | ||
|  | 							tmp = tmp.substring(0, index+5); | ||
|  | 						} | ||
|  | 					} | ||
|  | 					 | ||
|  | 					return tmp; | ||
|  | 				} | ||
|  | 
 | ||
|  | 				// Disables HTML labels for swimlanes to avoid conflict | ||
|  | 				// for the event processing on the child cells. HTML | ||
|  | 				// labels consume events before underlying cells get the | ||
|  | 				// chance to process those events. | ||
|  | 				// | ||
|  | 				// NOTE: Use of HTML labels is only recommended if the specific | ||
|  | 				// features of such labels are required, such as special label | ||
|  | 				// styles or interactive form fields. Otherwise non-HTML labels | ||
|  | 				// should be used by not overidding the following function. | ||
|  | 				// See also: configureStylesheet. | ||
|  | 				graph.isHtmlLabel = function(cell) | ||
|  | 				{ | ||
|  | 					return !this.isSwimlane(cell); | ||
|  | 				} | ||
|  | 
 | ||
|  | 				// To disable the folding icon, use the following code: | ||
|  | 				/*graph.isCellFoldable = function(cell) | ||
|  | 				{ | ||
|  | 					return false; | ||
|  | 				}*/ | ||
|  | 
 | ||
|  | 				// Shows a "modal" window when double clicking a vertex. | ||
|  | 				graph.dblClick = function(evt, cell) | ||
|  | 				{ | ||
|  | 					// Do not fire a DOUBLE_CLICK event here as mxEditor will | ||
|  | 					// consume the event and start the in-place editor. | ||
|  | 					if (this.isEnabled() && | ||
|  | 						!mxEvent.isConsumed(evt) && | ||
|  | 						cell != null && | ||
|  | 						this.isCellEditable(cell)) | ||
|  | 					{ | ||
|  | 						if (this.model.isEdge(cell) || | ||
|  | 							!this.isHtmlLabel(cell)) | ||
|  | 						{ | ||
|  | 							this.startEditingAtCell(cell); | ||
|  | 						} | ||
|  | 						else | ||
|  | 						{ | ||
|  | 							var content = document.createElement('div'); | ||
|  | 							content.innerHTML = this.convertValueToString(cell); | ||
|  | 							showModalWindow(this, 'Properties', content, 400, 300); | ||
|  | 						} | ||
|  | 					} | ||
|  | 
 | ||
|  | 					// Disables any default behaviour for the double click | ||
|  | 					mxEvent.consume(evt); | ||
|  | 				}; | ||
|  | 
 | ||
|  | 				// Enables new connections | ||
|  | 				graph.setConnectable(true); | ||
|  | 
 | ||
|  | 				// Adds all required styles to the graph (see below) | ||
|  | 				configureStylesheet(graph); | ||
|  | 
 | ||
|  | 				// Adds sidebar icons. | ||
|  | 				// | ||
|  | 				// NOTE: For non-HTML labels a simple string as the third argument | ||
|  | 				// and the alternative style as shown in configureStylesheet should | ||
|  | 				// be used. For example, the first call to addSidebar icon would | ||
|  | 				// be as follows: | ||
|  | 				// addSidebarIcon(graph, sidebar, 'Website', 'images/icons48/earth.png'); | ||
|  | 				addSidebarIcon(graph, sidebar, | ||
|  | 					'<h1 style="margin:0px;">Website</h1><br>'+ | ||
|  | 					'<img src="images/icons48/earth.png" width="48" height="48">'+ | ||
|  | 					'<br>'+ | ||
|  | 					'<a href="http://www.jgraph.com" target="_blank">Browse</a>', | ||
|  | 					'images/icons48/earth.png'); | ||
|  | 				addSidebarIcon(graph, sidebar, | ||
|  | 					'<h1 style="margin:0px;">Process</h1><br>'+ | ||
|  | 					'<img src="images/icons48/gear.png" width="48" height="48">'+ | ||
|  | 					'<br><select><option>Value1</option><option>Value2</option></select><br>', | ||
|  | 					'images/icons48/gear.png'); | ||
|  | 				addSidebarIcon(graph, sidebar, | ||
|  | 					'<h1 style="margin:0px;">Keys</h1><br>'+ | ||
|  | 					'<img src="images/icons48/keys.png" width="48" height="48">'+ | ||
|  | 					'<br>'+ | ||
|  | 					'<button onclick="mxUtils.alert(\'generate\');">Generate</button>', | ||
|  | 					'images/icons48/keys.png'); | ||
|  | 				addSidebarIcon(graph, sidebar, | ||
|  | 					'<h1 style="margin:0px;">New Mail</h1><br>'+ | ||
|  | 					'<img src="images/icons48/mail_new.png" width="48" height="48">'+ | ||
|  | 					'<br><input type="checkbox"/>CC Archive', | ||
|  | 					'images/icons48/mail_new.png'); | ||
|  | 				addSidebarIcon(graph, sidebar, | ||
|  | 					'<h1 style="margin:0px;">Server</h1><br>'+ | ||
|  | 					'<img src="images/icons48/server.png" width="48" height="48">'+ | ||
|  | 					'<br>'+ | ||
|  | 					'<input type="text" size="12" value="127.0.0.1"/>', | ||
|  | 					'images/icons48/server.png'); | ||
|  | 
 | ||
|  | 				// Displays useful hints in a small semi-transparent box. | ||
|  | 				var hints = document.createElement('div'); | ||
|  | 				hints.style.position = 'absolute'; | ||
|  | 				hints.style.overflow = 'hidden'; | ||
|  | 				hints.style.width = '230px'; | ||
|  | 				hints.style.bottom = '56px'; | ||
|  | 				hints.style.height = '76px'; | ||
|  | 				hints.style.right = '20px'; | ||
|  | 				 | ||
|  | 				hints.style.background = 'black'; | ||
|  | 				hints.style.color = 'white'; | ||
|  | 				hints.style.fontFamily = 'Arial'; | ||
|  | 				hints.style.fontSize = '10px'; | ||
|  | 				hints.style.padding = '4px'; | ||
|  | 
 | ||
|  | 				mxUtils.setOpacity(hints, 50); | ||
|  | 				 | ||
|  | 				mxUtils.writeln(hints, '- Drag an image from the sidebar to the graph'); | ||
|  | 				mxUtils.writeln(hints, '- Doubleclick on a vertex or edge to edit'); | ||
|  | 				mxUtils.writeln(hints, '- Shift- or Rightclick and drag for panning'); | ||
|  | 				mxUtils.writeln(hints, '- Move the mouse over a cell to see a tooltip'); | ||
|  | 				mxUtils.writeln(hints, '- Click and drag a vertex to move and connect'); | ||
|  | 				document.body.appendChild(hints); | ||
|  | 				 | ||
|  | 				// Creates a new DIV that is used as a toolbar and adds | ||
|  | 				// toolbar buttons. | ||
|  | 				var spacer = document.createElement('div'); | ||
|  | 				spacer.style.display = 'inline'; | ||
|  | 				spacer.style.padding = '8px'; | ||
|  | 				 | ||
|  | 				addToolbarButton(editor, toolbar, 'groupOrUngroup', '(Un)group', 'images/group.png'); | ||
|  | 				 | ||
|  | 				// Defines a new action for deleting or ungrouping | ||
|  | 				editor.addAction('groupOrUngroup', function(editor, cell) | ||
|  | 				{ | ||
|  | 					cell = cell || editor.graph.getSelectionCell(); | ||
|  | 					if (cell != null && editor.graph.isSwimlane(cell)) | ||
|  | 					{ | ||
|  | 						editor.execute('ungroup', cell); | ||
|  | 					} | ||
|  | 					else | ||
|  | 					{ | ||
|  | 						editor.execute('group'); | ||
|  | 					} | ||
|  | 				}); | ||
|  | 
 | ||
|  | 				addToolbarButton(editor, toolbar, 'delete', 'Delete', 'images/delete2.png'); | ||
|  | 				 | ||
|  | 				toolbar.appendChild(spacer.cloneNode(true)); | ||
|  | 				 | ||
|  | 				addToolbarButton(editor, toolbar, 'cut', 'Cut', 'images/cut.png'); | ||
|  | 				addToolbarButton(editor, toolbar, 'copy', 'Copy', 'images/copy.png'); | ||
|  | 				addToolbarButton(editor, toolbar, 'paste', 'Paste', 'images/paste.png'); | ||
|  | 
 | ||
|  | 				toolbar.appendChild(spacer.cloneNode(true)); | ||
|  | 				 | ||
|  | 				addToolbarButton(editor, toolbar, 'undo', '', 'images/undo.png'); | ||
|  | 				addToolbarButton(editor, toolbar, 'redo', '', 'images/redo.png'); | ||
|  | 				 | ||
|  | 				toolbar.appendChild(spacer.cloneNode(true)); | ||
|  | 				 | ||
|  | 				addToolbarButton(editor, toolbar, 'show', 'Show', 'images/camera.png'); | ||
|  | 				addToolbarButton(editor, toolbar, 'print', 'Print', 'images/printer.png'); | ||
|  | 				 | ||
|  | 				toolbar.appendChild(spacer.cloneNode(true)); | ||
|  | 
 | ||
|  | 				// Defines a new export action | ||
|  | 				editor.addAction('export', function(editor, cell) | ||
|  | 				{ | ||
|  | 					var textarea = document.createElement('textarea'); | ||
|  | 					textarea.style.width = '400px'; | ||
|  | 					textarea.style.height = '400px'; | ||
|  | 					var enc = new mxCodec(mxUtils.createXmlDocument()); | ||
|  | 					var node = enc.encode(editor.graph.getModel()); | ||
|  | 					textarea.value = mxUtils.getPrettyXml(node); | ||
|  | 					showModalWindow(graph, 'XML', textarea, 410, 440); | ||
|  | 				}); | ||
|  | 
 | ||
|  | 				addToolbarButton(editor, toolbar, 'export', 'Export', 'images/export1.png'); | ||
|  | 
 | ||
|  | 				// --- | ||
|  | 				 | ||
|  | 				// Adds toolbar buttons into the status bar at the bottom | ||
|  | 				// of the window. | ||
|  | 				addToolbarButton(editor, status, 'collapseAll', 'Collapse All', 'images/navigate_minus.png', true); | ||
|  | 				addToolbarButton(editor, status, 'expandAll', 'Expand All', 'images/navigate_plus.png', true); | ||
|  | 
 | ||
|  | 				status.appendChild(spacer.cloneNode(true)); | ||
|  | 				 | ||
|  | 				addToolbarButton(editor, status, 'enterGroup', 'Enter', 'images/view_next.png', true); | ||
|  | 				addToolbarButton(editor, status, 'exitGroup', 'Exit', 'images/view_previous.png', true); | ||
|  | 
 | ||
|  | 				status.appendChild(spacer.cloneNode(true)); | ||
|  | 
 | ||
|  | 				addToolbarButton(editor, status, 'zoomIn', '', 'images/zoom_in.png', true); | ||
|  | 				addToolbarButton(editor, status, 'zoomOut', '', 'images/zoom_out.png', true); | ||
|  | 				addToolbarButton(editor, status, 'actualSize', '', 'images/view_1_1.png', true); | ||
|  | 				addToolbarButton(editor, status, 'fit', '', 'images/fit_to_size.png', true); | ||
|  | 				 | ||
|  | 				// Creates the outline (navigator, overview) for moving | ||
|  | 				// around the graph in the top, right corner of the window. | ||
|  | 				var outln = new mxOutline(graph, outline); | ||
|  | 
 | ||
|  | 				// To show the images in the outline, uncomment the following code | ||
|  | 				//outln.outline.labelsVisible = true; | ||
|  | 				//outln.outline.setHtmlLabels(true); | ||
|  | 				 | ||
|  | 				// Fades-out the splash screen after the UI has been loaded. | ||
|  | 				var splash = document.getElementById('splash'); | ||
|  | 				if (splash != null) | ||
|  | 				{ | ||
|  | 					try | ||
|  | 					{ | ||
|  | 						mxEvent.release(splash); | ||
|  | 						mxEffects.fadeOut(splash, 100, true); | ||
|  | 					} | ||
|  | 					catch (e) | ||
|  | 					{ | ||
|  | 					 | ||
|  | 						// mxUtils is not available (library not loaded) | ||
|  | 						splash.parentNode.removeChild(splash); | ||
|  | 					} | ||
|  | 				} | ||
|  | 			} | ||
|  | 		}; | ||
|  | 		 | ||
|  | 		function addToolbarButton(editor, toolbar, action, label, image, isTransparent) | ||
|  | 		{ | ||
|  | 			var button = document.createElement('button'); | ||
|  | 			button.style.fontSize = '10'; | ||
|  | 			if (image != null) | ||
|  | 			{ | ||
|  | 				var img = document.createElement('img'); | ||
|  | 				img.setAttribute('src', image); | ||
|  | 				img.style.width = '16px'; | ||
|  | 				img.style.height = '16px'; | ||
|  | 				img.style.verticalAlign = 'middle'; | ||
|  | 				img.style.marginRight = '2px'; | ||
|  | 				button.appendChild(img); | ||
|  | 			} | ||
|  | 			if (isTransparent) | ||
|  | 			{ | ||
|  | 				button.style.background = 'transparent'; | ||
|  | 				button.style.color = '#FFFFFF'; | ||
|  | 				button.style.border = 'none'; | ||
|  | 			} | ||
|  | 			mxEvent.addListener(button, 'click', function(evt) | ||
|  | 			{ | ||
|  | 				editor.execute(action); | ||
|  | 			}); | ||
|  | 			mxUtils.write(button, label); | ||
|  | 			toolbar.appendChild(button); | ||
|  | 		}; | ||
|  | 
 | ||
|  | 		function showModalWindow(graph, title, content, width, height) | ||
|  | 		{ | ||
|  | 			var background = document.createElement('div'); | ||
|  | 			background.style.position = 'absolute'; | ||
|  | 			background.style.left = '0px'; | ||
|  | 			background.style.top = '0px'; | ||
|  | 			background.style.right = '0px'; | ||
|  | 			background.style.bottom = '0px'; | ||
|  | 			background.style.background = 'black'; | ||
|  | 			mxUtils.setOpacity(background, 50); | ||
|  | 			document.body.appendChild(background); | ||
|  | 			 | ||
|  | 			if (mxClient.IS_IE) | ||
|  | 			{ | ||
|  | 				new mxDivResizer(background); | ||
|  | 			} | ||
|  | 			 | ||
|  | 			var x = Math.max(0, document.body.scrollWidth/2-width/2); | ||
|  | 			var y = Math.max(10, (document.body.scrollHeight || | ||
|  | 						document.documentElement.scrollHeight)/2-height*2/3); | ||
|  | 			var wnd = new mxWindow(title, content, x, y, width, height, false, true); | ||
|  | 			wnd.setClosable(true); | ||
|  | 			 | ||
|  | 			// Fades the background out after after the window has been closed | ||
|  | 			wnd.addListener(mxEvent.DESTROY, function(evt) | ||
|  | 			{ | ||
|  | 				graph.setEnabled(true); | ||
|  | 				mxEffects.fadeOut(background, 50, true,  | ||
|  | 					10, 30, true); | ||
|  | 			}); | ||
|  | 
 | ||
|  | 			graph.setEnabled(false); | ||
|  | 			graph.tooltipHandler.hide(); | ||
|  | 			wnd.setVisible(true); | ||
|  | 		}; | ||
|  | 		 | ||
|  | 		function addSidebarIcon(graph, sidebar, label, image) | ||
|  | 		{ | ||
|  | 			// Function that is executed when the image is dropped on | ||
|  | 			// the graph. The cell argument points to the cell under | ||
|  | 			// the mousepointer if there is one. | ||
|  | 			var funct = function(graph, evt, cell, x, y) | ||
|  | 			{ | ||
|  | 				var parent = graph.getDefaultParent(); | ||
|  | 				var model = graph.getModel(); | ||
|  | 				 | ||
|  | 				var v1 = null; | ||
|  | 				 | ||
|  | 				model.beginUpdate(); | ||
|  | 				try | ||
|  | 				{ | ||
|  | 					// NOTE: For non-HTML labels the image must be displayed via the style | ||
|  | 					// rather than the label markup, so use 'image=' + image for the style. | ||
|  | 					// as follows: v1 = graph.insertVertex(parent, null, label, | ||
|  | 					// pt.x, pt.y, 120, 120, 'image=' + image); | ||
|  | 					v1 = graph.insertVertex(parent, null, label, x, y, 120, 120); | ||
|  | 					v1.setConnectable(false); | ||
|  | 					 | ||
|  | 					// Presets the collapsed size | ||
|  | 					v1.geometry.alternateBounds = new mxRectangle(0, 0, 120, 40); | ||
|  | 										 | ||
|  | 					// Adds the ports at various relative locations | ||
|  | 					var port = graph.insertVertex(v1, null, 'Trigger', 0, 0.25, 16, 16, | ||
|  | 							'port;image=editors/images/overlays/flash.png;align=right;imageAlign=right;spacingRight=18', true); | ||
|  | 					port.geometry.offset = new mxPoint(-6, -8); | ||
|  | 		 | ||
|  | 					var port = graph.insertVertex(v1, null, 'Input', 0, 0.75, 16, 16, | ||
|  | 							'port;image=editors/images/overlays/check.png;align=right;imageAlign=right;spacingRight=18', true); | ||
|  | 					port.geometry.offset = new mxPoint(-6, -4); | ||
|  | 					 | ||
|  | 					var port = graph.insertVertex(v1, null, 'Error', 1, 0.25, 16, 16, | ||
|  | 							'port;image=editors/images/overlays/error.png;spacingLeft=18', true); | ||
|  | 					port.geometry.offset = new mxPoint(-8, -8); | ||
|  | 
 | ||
|  | 					var port = graph.insertVertex(v1, null, 'Result', 1, 0.75, 16, 16, | ||
|  | 							'port;image=editors/images/overlays/information.png;spacingLeft=18', true); | ||
|  | 					port.geometry.offset = new mxPoint(-8, -4); | ||
|  | 				} | ||
|  | 				finally | ||
|  | 				{ | ||
|  | 					model.endUpdate(); | ||
|  | 				} | ||
|  | 				 | ||
|  | 				graph.setSelectionCell(v1); | ||
|  | 			} | ||
|  | 			 | ||
|  | 			// Creates the image which is used as the sidebar icon (drag source) | ||
|  | 			var img = document.createElement('img'); | ||
|  | 			img.setAttribute('src', image); | ||
|  | 			img.style.width = '48px'; | ||
|  | 			img.style.height = '48px'; | ||
|  | 			img.title = 'Drag this to the diagram to create a new vertex'; | ||
|  | 			sidebar.appendChild(img); | ||
|  | 			 | ||
|  | 			var dragElt = document.createElement('div'); | ||
|  | 			dragElt.style.border = 'dashed black 1px'; | ||
|  | 			dragElt.style.width = '120px'; | ||
|  | 			dragElt.style.height = '120px'; | ||
|  | 			  					 | ||
|  | 			// Creates the image which is used as the drag icon (preview) | ||
|  | 			var ds = mxUtils.makeDraggable(img, graph, funct, dragElt, 0, 0, true, true); | ||
|  | 			ds.setGuidesEnabled(true); | ||
|  | 		}; | ||
|  | 		 | ||
|  | 		function configureStylesheet(graph) | ||
|  | 		{ | ||
|  | 			var style = new Object(); | ||
|  | 			style[mxConstants.STYLE_SHAPE] = mxConstants.SHAPE_RECTANGLE; | ||
|  | 			style[mxConstants.STYLE_PERIMETER] = mxPerimeter.RectanglePerimeter; | ||
|  | 			style[mxConstants.STYLE_ALIGN] = mxConstants.ALIGN_CENTER; | ||
|  | 			style[mxConstants.STYLE_VERTICAL_ALIGN] = mxConstants.ALIGN_MIDDLE; | ||
|  | 			style[mxConstants.STYLE_GRADIENTCOLOR] = '#41B9F5'; | ||
|  | 			style[mxConstants.STYLE_FILLCOLOR] = '#8CCDF5'; | ||
|  | 			style[mxConstants.STYLE_STROKECOLOR] = '#1B78C8'; | ||
|  | 			style[mxConstants.STYLE_FONTCOLOR] = '#000000'; | ||
|  | 			style[mxConstants.STYLE_ROUNDED] = true; | ||
|  | 			style[mxConstants.STYLE_OPACITY] = '80'; | ||
|  | 			style[mxConstants.STYLE_FONTSIZE] = '12'; | ||
|  | 			style[mxConstants.STYLE_FONTSTYLE] = 0; | ||
|  | 			style[mxConstants.STYLE_IMAGE_WIDTH] = '48'; | ||
|  | 			style[mxConstants.STYLE_IMAGE_HEIGHT] = '48'; | ||
|  | 			graph.getStylesheet().putDefaultVertexStyle(style); | ||
|  | 
 | ||
|  | 			// NOTE: Alternative vertex style for non-HTML labels should be as | ||
|  | 			// follows. This repaces the above style for HTML labels. | ||
|  | 			/*var style = new Object(); | ||
|  | 			style[mxConstants.STYLE_SHAPE] = mxConstants.SHAPE_LABEL; | ||
|  | 			style[mxConstants.STYLE_PERIMETER] = mxPerimeter.RectanglePerimeter; | ||
|  | 			style[mxConstants.STYLE_VERTICAL_ALIGN] = mxConstants.ALIGN_TOP; | ||
|  | 			style[mxConstants.STYLE_ALIGN] = mxConstants.ALIGN_CENTER; | ||
|  | 			style[mxConstants.STYLE_IMAGE_ALIGN] = mxConstants.ALIGN_CENTER; | ||
|  | 			style[mxConstants.STYLE_IMAGE_VERTICAL_ALIGN] = mxConstants.ALIGN_TOP; | ||
|  | 			style[mxConstants.STYLE_SPACING_TOP] = '56'; | ||
|  | 			style[mxConstants.STYLE_GRADIENTCOLOR] = '#7d85df'; | ||
|  | 			style[mxConstants.STYLE_STROKECOLOR] = '#5d65df'; | ||
|  | 			style[mxConstants.STYLE_FILLCOLOR] = '#adc5ff'; | ||
|  | 			style[mxConstants.STYLE_FONTCOLOR] = '#1d258f'; | ||
|  | 			style[mxConstants.STYLE_FONTFAMILY] = 'Verdana'; | ||
|  | 			style[mxConstants.STYLE_FONTSIZE] = '12'; | ||
|  | 			style[mxConstants.STYLE_FONTSTYLE] = '1'; | ||
|  | 			style[mxConstants.STYLE_ROUNDED] = '1'; | ||
|  | 			style[mxConstants.STYLE_IMAGE_WIDTH] = '48'; | ||
|  | 			style[mxConstants.STYLE_IMAGE_HEIGHT] = '48'; | ||
|  | 			style[mxConstants.STYLE_OPACITY] = '80'; | ||
|  | 			graph.getStylesheet().putDefaultVertexStyle(style);*/ | ||
|  | 
 | ||
|  | 			style = new Object(); | ||
|  | 			style[mxConstants.STYLE_SHAPE] = mxConstants.SHAPE_SWIMLANE; | ||
|  | 			style[mxConstants.STYLE_PERIMETER] = mxPerimeter.RectanglePerimeter; | ||
|  | 			style[mxConstants.STYLE_ALIGN] = mxConstants.ALIGN_CENTER; | ||
|  | 			style[mxConstants.STYLE_VERTICAL_ALIGN] = mxConstants.ALIGN_TOP; | ||
|  | 			style[mxConstants.STYLE_FILLCOLOR] = '#FF9103'; | ||
|  | 			style[mxConstants.STYLE_GRADIENTCOLOR] = '#F8C48B'; | ||
|  | 			style[mxConstants.STYLE_STROKECOLOR] = '#E86A00'; | ||
|  | 			style[mxConstants.STYLE_FONTCOLOR] = '#000000'; | ||
|  | 			style[mxConstants.STYLE_ROUNDED] = true; | ||
|  | 			style[mxConstants.STYLE_OPACITY] = '80'; | ||
|  | 			style[mxConstants.STYLE_STARTSIZE] = '30'; | ||
|  | 			style[mxConstants.STYLE_FONTSIZE] = '16'; | ||
|  | 			style[mxConstants.STYLE_FONTSTYLE] = 1; | ||
|  | 			graph.getStylesheet().putCellStyle('group', style); | ||
|  | 			 | ||
|  | 			style = new Object(); | ||
|  | 			style[mxConstants.STYLE_SHAPE] = mxConstants.SHAPE_IMAGE; | ||
|  | 			style[mxConstants.STYLE_FONTCOLOR] = '#774400'; | ||
|  | 			style[mxConstants.STYLE_PERIMETER] = mxPerimeter.RectanglePerimeter; | ||
|  | 			style[mxConstants.STYLE_PERIMETER_SPACING] = '6'; | ||
|  | 			style[mxConstants.STYLE_ALIGN] = mxConstants.ALIGN_LEFT; | ||
|  | 			style[mxConstants.STYLE_VERTICAL_ALIGN] = mxConstants.ALIGN_MIDDLE; | ||
|  | 			style[mxConstants.STYLE_FONTSIZE] = '10'; | ||
|  | 			style[mxConstants.STYLE_FONTSTYLE] = 2; | ||
|  | 			style[mxConstants.STYLE_IMAGE_WIDTH] = '16'; | ||
|  | 			style[mxConstants.STYLE_IMAGE_HEIGHT] = '16'; | ||
|  | 			graph.getStylesheet().putCellStyle('port', style); | ||
|  | 			 | ||
|  | 			style = graph.getStylesheet().getDefaultEdgeStyle(); | ||
|  | 			style[mxConstants.STYLE_LABEL_BACKGROUNDCOLOR] = '#FFFFFF'; | ||
|  | 			style[mxConstants.STYLE_STROKEWIDTH] = '2'; | ||
|  | 			style[mxConstants.STYLE_ROUNDED] = true; | ||
|  | 			style[mxConstants.STYLE_EDGE] = mxEdgeStyle.EntityRelation; | ||
|  | 		}; | ||
|  | 	</script> | ||
|  | </head> | ||
|  | 
 | ||
|  | <!-- Page passes the container for the graph to the program --> | ||
|  | <body onload="main(document.getElementById('graphContainer'), | ||
|  | 			document.getElementById('outlineContainer'), | ||
|  | 		 	document.getElementById('toolbarContainer'), | ||
|  | 			document.getElementById('sidebarContainer'), | ||
|  | 			document.getElementById('statusContainer'));" style="margin:0px;"> | ||
|  | 	 | ||
|  | 	<!-- Creates a container for the splash screen --> | ||
|  | 	<div id="splash" | ||
|  | 		style="position:absolute;top:0px;left:0px;width:100%;height:100%;background:white;z-index:1;"> | ||
|  | 		<center id="splash" style="padding-top:230px;"> | ||
|  | 			<img src="editors/images/loading.gif"> | ||
|  | 		</center> | ||
|  | 	</div> | ||
|  | 	 | ||
|  | 	<!-- Creates a container for the sidebar --> | ||
|  | 	<div id="toolbarContainer" | ||
|  | 		style="position:absolute;white-space:nowrap;overflow:hidden;top:0px;left:0px;max-height:24px;height:36px;right:0px;padding:6px;background-image:url('images/toolbar_bg.gif');"> | ||
|  | 	</div> | ||
|  | 
 | ||
|  | 	<!-- Creates a container for the toolboox --> | ||
|  | 	<div id="sidebarContainer" | ||
|  | 		style="position:absolute;overflow:hidden;top:36px;left:0px;bottom:36px;max-width:52px;width:56px;padding-top:10px;padding-left:4px;background-image:url('images/sidebar_bg.gif');"> | ||
|  | 	</div> | ||
|  | 
 | ||
|  | 	<!-- Creates a container for the graph --> | ||
|  | 	<div id="graphContainer" | ||
|  | 		style="position:absolute;overflow:hidden;top:36px;left:60px;bottom:36px;right:0px;background-image:url('editors/images/grid.gif');cursor:default;"> | ||
|  | 	</div> | ||
|  | 
 | ||
|  | 	<!-- Creates a container for the outline --> | ||
|  | 	<div id="outlineContainer" | ||
|  | 		style="position:absolute;overflow:hidden;top:36px;right:0px;width:200px;height:140px;background:transparent;border-style:solid;border-color:black;"> | ||
|  | 	</div> | ||
|  | 		 | ||
|  | 	<!-- Creates a container for the sidebar --> | ||
|  | 	<div id="statusContainer" | ||
|  | 		style="text-align:right;position:absolute;overflow:hidden;bottom:0px;left:0px;max-height:24px;height:36px;right:0px;color:white;padding:6px;background-image:url('images/toolbar_bg.gif');"> | ||
|  | 		<div style="font-size:10pt;float:left;"> | ||
|  | 			Created with <a href="http://www.jgraph.com" target="_blank">mxGraph</a> | ||
|  | 		</div> | ||
|  | 	</div> | ||
|  | </body> | ||
|  | </html> |