Commit dde17309 authored by Alexander.Trofimov's avatar Alexander.Trofimov Committed by Alexander.Trofimov

Правка для совместного редактирования.

При проверке lock на save очищаем callback раньше, чем вызываем его
Сделал очистку timeout ошибки при нормальном результате

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@52193 954022d7-b5bf-4e40-9824-e11837661b57
parent 30ece2bd
...@@ -234,6 +234,7 @@ ...@@ -234,6 +234,7 @@
this._lockCallbacks = {}; this._lockCallbacks = {};
this._saveLock = false; this._saveLock = false;
this._saveCallback = []; this._saveCallback = [];
this.saveCallbackErrorTimeOutId = null;
this._id = ""; this._id = "";
this._indexuser = -1; this._indexuser = -1;
// Если пользователей больше 1, то совместно редактируем // Если пользователей больше 1, то совместно редактируем
...@@ -338,9 +339,14 @@ ...@@ -338,9 +339,14 @@
// Мы еще не отработали старый callback и ждем ответа // Мы еще не отработали старый callback и ждем ответа
return; return;
} }
// Очищаем предыдущий таймер
if (null !== this.saveCallbackErrorTimeOutId)
clearTimeout(this.saveCallbackErrorTimeOutId);
// Проверим состояние, если мы не подсоединились, то сразу отправим ошибку // Проверим состояние, если мы не подсоединились, то сразу отправим ошибку
if (-1 === this.get_state()) { if (-1 === this.get_state()) {
window.setTimeout(function () { this.saveCallbackErrorTimeOutId = window.setTimeout(function () {
if (callback && _.isFunction(callback)) { if (callback && _.isFunction(callback)) {
// Фиктивные вызовы // Фиктивные вызовы
callback({error: "No connection"}); callback({error: "No connection"});
...@@ -355,10 +361,12 @@ ...@@ -355,10 +361,12 @@
//Set reconnectTimeout //Set reconnectTimeout
window.setTimeout(function () { window.setTimeout(function () {
if (t._saveCallback[indexCallback]) { t.saveCallbackErrorTimeOutId = null;
//Not signaled already var oTmpCallback = t._saveCallback[indexCallback];
t._saveCallback[indexCallback]({error: "Timed out"}); if (oTmpCallback) {
t._saveCallback[indexCallback] = null; t._saveCallback[indexCallback] = null;
//Not signaled already
oTmpCallback({error: "Timed out"});
} }
}, 5000);//5 sec to signal lock failure }, 5000);//5 sec to signal lock failure
} }
...@@ -543,9 +551,14 @@ ...@@ -543,9 +551,14 @@
DocsCoApi.prototype._onSaveLock = function (data) { DocsCoApi.prototype._onSaveLock = function (data) {
if (undefined != data["savelock"] && null != data["savelock"]) { if (undefined != data["savelock"] && null != data["savelock"]) {
var indexCallback = this._saveCallback.length - 1; var indexCallback = this._saveCallback.length - 1;
if (this._saveCallback[indexCallback]) { var oTmpCallback = this._saveCallback[indexCallback];
this._saveCallback[indexCallback] (data); if (oTmpCallback) {
// Очищаем предыдущий таймер
if (null !== this.saveCallbackErrorTimeOutId)
clearTimeout(this.saveCallbackErrorTimeOutId);
this._saveCallback[indexCallback] = null; this._saveCallback[indexCallback] = null;
oTmpCallback(data);
} }
} }
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment