data: [],
state: 'empty',
- init: function(serverURL) {
+ init: function(document, serverURL) {
this._super();
this.set('state', 'empty');
this.serverURL = serverURL;
load: function(force) {
if (force || this.get('state') == 'empty') {
+ console.log("setting state");
this.set('state', 'loading');
+ console.log("going ajax");
$.ajax({
url: this.serverURL,
dataType: 'json',
- success: this.loadingSucceeded.bind(this)
+ success: this.loadingSucceeded.bind(this),
+ error: this.loadingFailed.bind(this)
});
}
},
- loadingSucceeded: function(data) {
+ loadingSucceeded: function(data)
+ {
+ console.log("success");
+
if (this.get('state') != 'loading') {
alert('erroneous state:', this.get('state'));
}
this.set('state', 'synced');
},
+ loadingFailed: function(data) {
+ console.log("failed");
+
+ if (this.get('state') != 'loading') {
+ alert('erroneous state:', this.get('state'));
+ }
+
+ this.set('state', 'error');
+ },
+
set: function(property, value) {
if (property == 'state') {
console.log(this.description(), ':', property, '=', value);
Editor.DocumentModel = Editor.Model.extend({
_className: 'Editor.DocumentModel',
- data: null, // name, text_url, user_revision, latest_shared_rev, parts_url, dc_url, size, merge_url
+ data: null, // name, text_url, revision, latest_shared_rev, parts_url, dc_url, size, merge_url
contentModels: {},
state: 'empty',
errors: '',
this.set('data', data);
this.set('state', 'synced');
- this.set('revision', data.user_revision);
+ this.set('revision', data.revision);
this.set('user', data.user);
this.contentModels = {
for (key in this.contentModels) {
if (this.contentModels[key].guid() == contentModel.guid()) {
this.contentModels[key].set('state', 'synced');
- this.data.user_revision = this.contentModels[key].get('revision');
+ this.revision = this.contentModels[key].get('revision');
+
}
}
for (key in this.contentModels) {
if (this.contentModels[key].guid() != contentModel.guid()) {
- this.contentModels[key].set('revision', this.data.user_revision);
+ this.contentModels[key].set('revision', this.revision);
this.contentModels[key].set('state', 'empty');
}
}
update: function() {
this.set('state', 'loading');
- messageCenter.addMessage('info', 'Uaktualniam dokument...');
+
+ messageCenter.addMessage('info', 'doc_update',
+ 'Uaktualniam dokument...');
+
$.ajax({
url: this.data.merge_url,
dataType: 'json',
type: 'post',
data: {
type: 'update',
- revision: this.revision,
- user: this.user
+ revision: this.get('revision'),
+ user: this.get('user')
},
complete: this.updateCompleted.bind(this),
success: function(data) {
this.set('updateData', data);
+ console.log("new data:", data)
}.bind(this)
});
},
updateCompleted: function(xhr, textStatus) {
console.log(xhr.status, textStatus);
- if (xhr.status == 200) { // Sukces
- this.data = this.get('updateData');
- this.revision = this.data.user_revision;
- this.user = this.data.user;
-
- messageCenter.addMessage('info', null, 'Uaktualnienie dokumentu do wersji ' + this.get('updateData').revision,
- 'Uaktualnienie dokumentu do wersji ' + this.get('updateData').revision);
- for (var key in this.contentModels) {
- this.contentModels[key].set('revision', this.data.user_revision);
- this.contentModels[key].set('state', 'empty');
+
+ if (xhr.status == 200)
+ {
+ var udata = this.get('updateData');
+ if(udata.timestamp == udata.parent_timestamp)
+ {
+ // no change
+ messageCenter.addMessage('info', 'doc_update',
+ 'Nic się nie zmieniło od ostatniej aktualizacji. Po co mam uaktualniać?');
+
}
- messageCenter.addMessage('success', null, 'Uaktualniłem dokument do najnowszej wersji :-)');
- } else if (xhr.status == 202) { // Wygenerowano PullRequest (tutaj?)
- } else if (xhr.status == 204) { // Nic nie zmieniono
- messageCenter.addMessage('info', null, 'Nic się nie zmieniło od ostatniej aktualizacji. Po co mam uaktualniać?');
+ else {
+ this.set('revision', udata.revision);
+ this.set('user', udata.user);
+ messageCenter.addMessage('info', 'doc_update',
+ 'Uaktualnienie dokumentu do wersji ' + udata.revision);
+
+ for (var key in this.contentModels) {
+ this.contentModels[key].set('revision', this.get('revision') );
+ this.contentModels[key].set('state', 'empty');
+ }
+ }
} else if (xhr.status == 409) { // Konflikt podczas operacji
- messageCenter.addMessage('error', null, 'Wystąpił konflikt podczas aktualizacji. Pędź po programistów! :-(');
- } else if (xhr.status == 500) {
- messageCenter.addMessage('critical', null, 'Błąd serwera. Pędź po programistów! :-(');
+ messageCenter.addMessage('error', 'doc_update',
+ 'Wystąpił konflikt podczas aktualizacji. Pędź po programistów! :-(');
+ } else {
+ messageCenter.addMessage('critical', 'doc_update',
+ 'Nieoczekiwany błąd. Pędź po programistów! :-(');
}
+
this.set('state', 'synced');
this.set('updateData', null);
},
merge: function(message) {
this.set('state', 'loading');
- messageCenter.addMessage('info', null, 'Scalam dokument z głównym repozytorium...');
+ messageCenter.addMessage('info', null,
+ 'Scalam dokument z głównym repozytorium...');
+
$.ajax({
url: this.data.merge_url,
type: 'post',
dataType: 'json',
data: {
type: 'share',
- revision: this.revision,
- user: this.user,
+ revision: this.get('revision'),
+ user: this.get('user'),
message: message
},
complete: this.mergeCompleted.bind(this),
mergeCompleted: function(xhr, textStatus) {
console.log(xhr.status, textStatus);
if (xhr.status == 200) { // Sukces
- this.data = this.get('updateData');
- this.revision = this.data.user_revision;
- this.user = this.data.user;
+ this.set('revision', this.get('updateData').revision);
+ this.set('user', this.get('updateData').user);
for (var key in this.contentModels) {
- this.contentModels[key].set('revision', this.revision);
+ this.contentModels[key].set('revision', this.get('revision'));
this.contentModels[key].set('state', 'empty');
}