X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/73ef2b8442dc95f8b7279de812c30ac8626d5f39..1400a93ea8a6f010819158ad6b78c95718f68dd8:/redakcja/static/js/wiki_img/wikiapi.js

diff --git a/redakcja/static/js/wiki_img/wikiapi.js b/redakcja/static/js/wiki_img/wikiapi.js
index 0f56ffe7..377e4f94 100644
--- a/redakcja/static/js/wiki_img/wikiapi.js
+++ b/redakcja/static/js/wiki_img/wikiapi.js
@@ -17,27 +17,23 @@
 		var vname = arguments[0];
 		var base_path = "/images";
 
-		if (vname == "ajax_document_text") {
-			return base_path + "/text/" + arguments[1] + "/";
-		}
+		if (vname == "ajax_document_text")
+		    return base_path + "/text/" + arguments[1] + "/";
 
-		if (vname == "ajax_document_history") {
 
-			return base_path + "/history/" + arguments[1] + "/";
-		}
-*/
-/*
-		if (vname == "ajax_document_diff")
-			return base_path + "/" + arguments[1] + "/diff";
+        if (vname == "ajax_document_revert") {
+            return base_path + "/revert/" + arguments[1] + '/';
+        }
 
-        if (vname == "ajax_document_rev")
-            return base_path + "/" + arguments[1] + "/rev";
+		if (vname == "ajax_document_history") {
+			return base_path + "/history/" + arguments[1] + '/';
+		}
 
-		if (vname == "ajax_document_addtag")
-			return base_path + "/" + arguments[1] + "/tags";
+		if (vname == "ajax_document_diff")
+			return base_path + "/diff/" + arguments[1] + '/';
 
-		if (vname == "ajax_publish")
-			return base_path + "/" + arguments[1] + "/publish";*/
+		if (vname == "ajax_document_pubmark")
+			return base_path + "/pubmark/" + arguments[1] + '/';
 
 		console.log("Couldn't reverse match:", vname);
 		return "/404.html";
@@ -53,6 +49,18 @@
 		this.revision = $("*[data-key='revision']", meta).text();
 		this.readonly = !!$("*[data-key='readonly']", meta).text();
 
+        var diff = $("*[data-key='diff']", meta).text();
+        if (diff) {
+            diff = diff.split(',');
+            if (diff.length == 2 && diff[0] < diff[1])
+                this.diff = diff;
+            else if (diff.length == 1) {
+                diff = parseInt(diff);
+                if (diff != NaN)
+                    this.diff = [diff - 1, diff];
+            }
+        }
+
 		this.text = null;
 		this.has_local_changes = false;
 		this._lock = -1;
@@ -72,18 +80,18 @@
 		$.ajax({
 			method: "GET",
 			url: reverse("ajax_document_text", self.id),
-			data: {"commit": self.commit},
+			data: {"revision": self.revision},
 			dataType: 'json',
 			success: function(data) {
 				var changed = false;
 
-				if (self.text === null || self.commit !== data.commit) {
+				if (self.text === null || self.revision !== data.revision) {
 					self.text = data.text;
 					if (self.text === '') {
-					    self.text = '<obraz></obraz>';
+					    self.text = '<picture></picture>';
 					}
 					self.revision = data.revision;
-                    self.commit = data.commit;
+//                    self.commit = data.commit;
 					changed = true;
 					self.triggerDocumentChanged();
 				};
@@ -123,6 +131,29 @@
 			}
 		});
 	};
+	WikiDocument.prototype.fetchDiff = function(params) {
+		/* this doesn't modify anything, so no locks */
+		var self = this;
+		params = $.extend({
+			'from': self.revision,
+			'to': self.revision
+		}, noops, params);
+		$.ajax({
+			method: "GET",
+			url: reverse("ajax_document_diff", self.id),
+			dataType: 'html',
+			data: {
+				"from": params['from'],
+				"to": params['to']
+			},
+			success: function(data) {
+				params['success'](self, data);
+			},
+			error: function() {
+				params['failure'](self, "Nie udało się wczytać porównania wersji.");
+			}
+		});
+	};
 
 	/*
 	 * Set document's text
@@ -165,7 +196,7 @@
 				if (data.text) {
 					self.text = data.text;
 					self.revision = data.revision;
-                    self.commit = data.commit;
+//                    self.commit = data.commit;
 					changed = true;
 					self.triggerDocumentChanged();
 				};
@@ -200,37 +231,50 @@
         });
 	}; /* end of save() */
 
-	WikiDocument.prototype.publish = function(params) {
-		params = $.extend({}, noops, params);
-		var self = this;
-		$.ajax({
-			url: reverse("ajax_publish", self.id),
-			type: "POST",
-			dataType: "json",
-			success: function(data) {
-				params.success(self, data);
-			},
-			error: function(xhr) {
-				if (xhr.status == 403 || xhr.status == 401) {
-					params.failure(self, "Nie masz uprawnień lub nie jesteś zalogowany.");
-				}
-				else {
-					try {
-						params.failure(self, xhr.responseText);
-					}
-					catch (e) {
-						params.failure(self, "Nie udało się - błąd serwera.");
-					};
-				};
+    WikiDocument.prototype.revertToVersion = function(params) {
+        var self = this;
+        params = $.extend({}, noops, params);
 
-			}
-		});
-	};
-	WikiDocument.prototype.setTag = function(params) {
+        if (params.revision >= this.revision) {
+            params.failure(self, 'Proszę wybrać rewizję starszą niż aktualna.');
+            return;
+        }
+
+        // Serialize form to dictionary
+        var data = {};
+        $.each(params['form'].serializeArray(), function() {
+            data[this.name] = this.value;
+        });
+
+        $.ajax({
+            url: reverse("ajax_document_revert", self.id),
+            type: "POST",
+            dataType: "json",
+            data: data,
+            success: function(data) {
+                if (data.text) {
+                    self.text = data.text;
+                    self.revision = data.revision;
+                    self.gallery = data.gallery;
+                    self.triggerDocumentChanged();
+
+                    params.success(self, "Udało się przywrócić wersję :)");
+                }
+                else {
+                    params.failure(self, "Przywracana wersja identyczna z aktualną. Anulowano przywracanie.");
+                }
+            },
+            error: function(xhr) {
+                params.failure(self, "Nie udało się przywrócić wersji - błąd serwera.");
+            }
+        });
+    };
+
+	WikiDocument.prototype.pubmark = function(params) {
 		params = $.extend({}, noops, params);
 		var self = this;
 		var data = {
-			"addtag-id": self.id,
+			"pubmark-id": self.id,
 		};
 
 		/* unpack form */
@@ -239,7 +283,7 @@
 		});
 
 		$.ajax({
-			url: reverse("ajax_document_addtag", self.id),
+			url: reverse("ajax_document_pubmark", self.id),
 			type: "POST",
 			dataType: "json",
 			data: data,
@@ -266,6 +310,8 @@
 		});
 	};
 
+
+
     WikiDocument.prototype.getImageItems = function(tag) {
         var self = this;
 
@@ -278,15 +324,30 @@
         }
 
         var a = [];
-        $(tag, doc).each(function(i, e) {
+        $('sem[type="'+tag+'"]', doc).each(function(i, e) {
             var $e = $(e);
-            a.push([
-                $e.text(),
-                $e.attr('x1'),
-                $e.attr('y1'),
-                $e.attr('x2'),
-                $e.attr('y2')
-            ]);
+            var $div = $e.children().first()
+            var value = $e.attr(tag);
+            $e.find('div').each(function(i, div) {
+                var $div = $(div);
+                switch ($div.attr('type')) {
+                    case 'rect':
+                        a.push([
+                            value,
+                            $div.attr('x1'),
+                            $div.attr('y1'),
+                            $div.attr('x2'),
+                            $div.attr('y2')
+                        ]);
+                        break;
+                    case 'whole':
+                        a.push([
+                            value,
+                            null, null, null, null
+                        ]);
+                        break
+                }
+            });
         });
 
         return a;
@@ -304,18 +365,25 @@
             return null;
         }
 
-        $(tag, doc).remove();
+        $('sem[type="'+tag+'"]', doc).remove();
         $root = $(doc.firstChild);
         $.each(items, function(i, e) {
-            var el = $(doc.createElement(tag));
-            el.text(e[0]);
-            if (e[1] !== null) {
-                el.attr('x1', e[1]);
-                el.attr('y1', e[2]);
-                el.attr('x2', e[3]);
-                el.attr('y2', e[4]);
+            var $sem = $(doc.createElement("sem"));
+            $sem.attr('type', tag);
+            $sem.attr(tag, e[0]);
+            $div = $(doc.createElement("div"));
+            if (e[1]) {
+                $div.attr('type', 'rect');
+                $div.attr('x1', e[1]);
+                $div.attr('y1', e[2]);
+                $div.attr('x2', e[3]);
+                $div.attr('y2', e[4]);
+            }
+            else {
+                $div.attr('type', 'whole');
             }
-            $root.append(el);
+            $sem.append($div);
+            $root.append($sem);
         });
         self.setText(serializer.serializeToString(doc));
     }