| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229 |
- /* Copyright (c) 2006-2011 by OpenLayers Contributors (see authors.txt for
- * full list of contributors). Published under the Clear BSD license.
- * See http://svn.openlayers.org/trunk/openlayers/license.txt for the
- * full text of the license. */
- /**
- * @requires OpenLayers/Strategy.js
- */
- /**
- * Class: OpenLayers.Strategy.Save
- * A strategy that commits newly created or modified features. By default
- * the strategy waits for a call to <save> before persisting changes. By
- * configuring the strategy with the <auto> option, changes can be saved
- * automatically.
- *
- * Inherits from:
- * - <OpenLayers.Strategy>
- */
- OpenLayers.Strategy.Save = OpenLayers.Class(OpenLayers.Strategy, {
-
- /**
- * Constant: EVENT_TYPES
- * {Array(String)} Supported application event types. Register a listener
- * for a particular event with the following syntax:
- * (code)
- * strategy.events.register(type, obj, listener);
- * (end)
- *
- * - *start* Triggered before saving
- * - *success* Triggered after a successful transaction
- * - *fail* Triggered after a failed transaction
- *
- */
- EVENT_TYPES: ["start", "success", "fail"],
-
- /**
- * Property: events
- * {<OpenLayers.Events>} Events instance for triggering this protocol
- * events.
- */
- events: null,
-
- /**
- * APIProperty: auto
- * {Boolean | Number} Auto-save. Default is false. If true, features will be
- * saved immediately after being added to the layer and with each
- * modification or deletion. If auto is a number, features will be
- * saved on an interval provided by the value (in seconds).
- */
- auto: false,
-
- /**
- * Property: timer
- * {Number} The id of the timer.
- */
- timer: null,
- /**
- * Constructor: OpenLayers.Strategy.Save
- * Create a new Save strategy.
- *
- * Parameters:
- * options - {Object} Optional object whose properties will be set on the
- * instance.
- */
- initialize: function(options) {
- OpenLayers.Strategy.prototype.initialize.apply(this, [options]);
- this.events = new OpenLayers.Events(this, null, this.EVENT_TYPES);
- },
-
- /**
- * APIMethod: activate
- * Activate the strategy. Register any listeners, do appropriate setup.
- *
- * Returns:
- * {Boolean} The strategy was successfully activated.
- */
- activate: function() {
- var activated = OpenLayers.Strategy.prototype.activate.call(this);
- if(activated) {
- if(this.auto) {
- if(typeof this.auto === "number") {
- this.timer = window.setInterval(
- OpenLayers.Function.bind(this.save, this),
- this.auto * 1000
- );
- } else {
- this.layer.events.on({
- "featureadded": this.triggerSave,
- "afterfeaturemodified": this.triggerSave,
- scope: this
- });
- }
- }
- }
- return activated;
- },
-
- /**
- * APIMethod: deactivate
- * Deactivate the strategy. Unregister any listeners, do appropriate
- * tear-down.
- *
- * Returns:
- * {Boolean} The strategy was successfully deactivated.
- */
- deactivate: function() {
- var deactivated = OpenLayers.Strategy.prototype.deactivate.call(this);
- if(deactivated) {
- if(this.auto) {
- if(typeof this.auto === "number") {
- window.clearInterval(this.timer);
- } else {
- this.layer.events.un({
- "featureadded": this.triggerSave,
- "afterfeaturemodified": this.triggerSave,
- scope: this
- });
- }
- }
- }
- return deactivated;
- },
-
- /**
- * Method: triggerSave
- * Registered as a listener. Calls save if a feature has insert, update,
- * or delete state.
- *
- * Parameters:
- * event - {Object} The event this function is listening for.
- */
- triggerSave: function(event) {
- var feature = event.feature;
- if(feature.state === OpenLayers.State.INSERT ||
- feature.state === OpenLayers.State.UPDATE ||
- feature.state === OpenLayers.State.DELETE) {
- this.save([event.feature]);
- }
- },
-
- /**
- * APIMethod: save
- * Tell the layer protocol to commit unsaved features. If the layer
- * projection differs from the map projection, features will be
- * transformed into the layer projection before being committed.
- *
- * Parameters:
- * features - {Array} Features to be saved. If null, then default is all
- * features in the layer. Features are assumed to be in the map
- * projection.
- */
- save: function(features) {
- if(!features) {
- features = this.layer.features;
- }
- this.events.triggerEvent("start", {features:features});
- var remote = this.layer.projection;
- var local = this.layer.map.getProjectionObject();
- if(!local.equals(remote)) {
- var len = features.length;
- var clones = new Array(len);
- var orig, clone;
- for(var i=0; i<len; ++i) {
- orig = features[i];
- clone = orig.clone();
- clone.fid = orig.fid;
- clone.state = orig.state;
- if(orig.url) {
- clone.url = orig.url;
- }
- clone._original = orig;
- clone.geometry.transform(local, remote);
- clones[i] = clone;
- }
- features = clones;
- }
- this.layer.protocol.commit(features, {
- callback: this.onCommit,
- scope: this
- });
- },
-
- /**
- * Method: onCommit
- * Called after protocol commit.
- *
- * Parameters:
- * response - {<OpenLayers.Protocol.Response>} A response object.
- */
- onCommit: function(response) {
- var evt = {"response": response};
- if(response.success()) {
- var features = response.reqFeatures;
- // deal with inserts, updates, and deletes
- var state, feature;
- var destroys = [];
- var insertIds = response.insertIds || [];
- var j = 0;
- for(var i=0, len=features.length; i<len; ++i) {
- feature = features[i];
- // if projection was different, we may be dealing with clones
- feature = feature._original || feature;
- state = feature.state;
- if(state) {
- if(state == OpenLayers.State.DELETE) {
- destroys.push(feature);
- } else if(state == OpenLayers.State.INSERT) {
- feature.fid = insertIds[j];
- ++j;
- }
- feature.state = null;
- }
- }
- if(destroys.length > 0) {
- this.layer.destroyFeatures(destroys);
- }
- this.events.triggerEvent("success", evt);
- } else {
- this.events.triggerEvent("fail", evt);
- }
- },
-
- CLASS_NAME: "OpenLayers.Strategy.Save"
- });
|