Mon 21 Jul 22:43:21 CEST 2025
This commit is contained in:
		
							parent
							
								
									94363c1d0e
								
							
						
					
					
						commit
						2bf95ff31a
					
				
							
								
								
									
										213
									
								
								js/ui/mxgraph/src/js/util/mxAutoSaveManager.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										213
									
								
								js/ui/mxgraph/src/js/util/mxAutoSaveManager.js
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,213 @@ | |||
| /** | ||||
|  * Copyright (c) 2006-2015, JGraph Ltd | ||||
|  * Copyright (c) 2006-2015, Gaudenz Alder | ||||
|  */ | ||||
| /** | ||||
|  * Class: mxAutoSaveManager | ||||
|  *  | ||||
|  * Manager for automatically saving diagrams. The <save> hook must be | ||||
|  * implemented. | ||||
|  *  | ||||
|  * Example: | ||||
|  *  | ||||
|  * (code) | ||||
|  * var mgr = new mxAutoSaveManager(editor.graph); | ||||
|  * mgr.save = function() | ||||
|  * { | ||||
|  *   mxLog.show(); | ||||
|  *   mxLog.debug('save'); | ||||
|  * }; | ||||
|  * (end) | ||||
|  *  | ||||
|  * Constructor: mxAutoSaveManager | ||||
|  * | ||||
|  * Constructs a new automatic layout for the given graph. | ||||
|  * | ||||
|  * Arguments: | ||||
|  *  | ||||
|  * graph - Reference to the enclosing graph.  | ||||
|  */ | ||||
| function mxAutoSaveManager(graph) | ||||
| { | ||||
| 	// Notifies the manager of a change
 | ||||
| 	this.changeHandler = mxUtils.bind(this, function(sender, evt) | ||||
| 	{ | ||||
| 		if (this.isEnabled()) | ||||
| 		{ | ||||
| 			this.graphModelChanged(evt.getProperty('edit').changes); | ||||
| 		} | ||||
| 	}); | ||||
| 
 | ||||
| 	this.setGraph(graph); | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Extends mxEventSource. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype = new mxEventSource(); | ||||
| mxAutoSaveManager.prototype.constructor = mxAutoSaveManager; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: graph | ||||
|  *  | ||||
|  * Reference to the enclosing <mxGraph>. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.graph = null; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: autoSaveDelay | ||||
|  *  | ||||
|  * Minimum amount of seconds between two consecutive autosaves. Eg. a | ||||
|  * value of 1 (s) means the graph is not stored more than once per second. | ||||
|  * Default is 10. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.autoSaveDelay = 10; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: autoSaveThrottle | ||||
|  *  | ||||
|  * Minimum amount of seconds between two consecutive autosaves triggered by | ||||
|  * more than <autoSaveThreshhold> changes within a timespan of less than | ||||
|  * <autoSaveDelay> seconds. Eg. a value of 1 (s) means the graph is not | ||||
|  * stored more than once per second even if there are more than | ||||
|  * <autoSaveThreshold> changes within that timespan. Default is 2. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.autoSaveThrottle = 2; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: autoSaveThreshold | ||||
|  *  | ||||
|  * Minimum amount of ignored changes before an autosave. Eg. a value of 2 | ||||
|  * means after 2 change of the graph model the autosave will trigger if the | ||||
|  * condition below is true. Default is 5. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.autoSaveThreshold = 5; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: ignoredChanges | ||||
|  *  | ||||
|  * Counter for ignored changes in autosave. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.ignoredChanges = 0; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: lastSnapshot | ||||
|  *  | ||||
|  * Used for autosaving. See <autosave>. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.lastSnapshot = 0; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: enabled | ||||
|  *  | ||||
|  * Specifies if event handling is enabled. Default is true. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.enabled = true; | ||||
| 
 | ||||
| /** | ||||
|  * Variable: changeHandler | ||||
|  *  | ||||
|  * Holds the function that handles graph model changes. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.changeHandler = null; | ||||
| 
 | ||||
| /** | ||||
|  * Function: isEnabled | ||||
|  *  | ||||
|  * Returns true if events are handled. This implementation | ||||
|  * returns <enabled>. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.isEnabled = function() | ||||
| { | ||||
| 	return this.enabled; | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Function: setEnabled | ||||
|  *  | ||||
|  * Enables or disables event handling. This implementation | ||||
|  * updates <enabled>. | ||||
|  *  | ||||
|  * Parameters: | ||||
|  *  | ||||
|  * enabled - Boolean that specifies the new enabled state. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.setEnabled = function(value) | ||||
| { | ||||
| 	this.enabled = value; | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Function: setGraph | ||||
|  *  | ||||
|  * Sets the graph that the layouts operate on. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.setGraph = function(graph) | ||||
| { | ||||
| 	if (this.graph != null) | ||||
| 	{ | ||||
| 		this.graph.getModel().removeListener(this.changeHandler); | ||||
| 	} | ||||
| 	 | ||||
| 	this.graph = graph; | ||||
| 	 | ||||
| 	if (this.graph != null) | ||||
| 	{ | ||||
| 		this.graph.getModel().addListener(mxEvent.CHANGE, this.changeHandler); | ||||
| 	} | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Function: save | ||||
|  *  | ||||
|  * Empty hook that is called if the graph should be saved. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.save = function() | ||||
| { | ||||
| 	// empty
 | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Function: graphModelChanged | ||||
|  *  | ||||
|  * Invoked when the graph model has changed. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.graphModelChanged = function(changes) | ||||
| { | ||||
| 	var now = new Date().getTime(); | ||||
| 	var dt = (now - this.lastSnapshot) / 1000; | ||||
| 	 | ||||
| 	if (dt > this.autoSaveDelay || | ||||
| 		(this.ignoredChanges >= this.autoSaveThreshold && | ||||
| 		 dt > this.autoSaveThrottle)) | ||||
| 	{ | ||||
| 		this.save(); | ||||
| 		this.reset(); | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		// Increments the number of ignored changes
 | ||||
| 		this.ignoredChanges++; | ||||
| 	} | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Function: reset | ||||
|  *  | ||||
|  * Resets all counters. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.reset = function() | ||||
| { | ||||
| 	this.lastSnapshot = new Date().getTime(); | ||||
| 	this.ignoredChanges = 0; | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Function: destroy | ||||
|  *  | ||||
|  * Removes all handlers from the <graph> and deletes the reference to it. | ||||
|  */ | ||||
| mxAutoSaveManager.prototype.destroy = function() | ||||
| { | ||||
| 	this.setGraph(null); | ||||
| }; | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user