Commit 13dfeac7 authored by Randall Leeds's avatar Randall Leeds

remove webassets cache from gitignore

parent fad2cd29
/* /*
** Annotator 1.2.6-dev-939cdee ** Annotator 1.2.6-dev-d45a366
** https://github.com/okfn/annotator/ ** https://github.com/okfn/annotator/
** **
** Copyright 2012 Aron Carroll, Rufus Pollock, and Nick Stenning. ** Copyright 2012 Aron Carroll, Rufus Pollock, and Nick Stenning.
** Dual licensed under the MIT and GPLv3 licenses. ** Dual licensed under the MIT and GPLv3 licenses.
** https://github.com/okfn/annotator/blob/master/LICENSE ** https://github.com/okfn/annotator/blob/master/LICENSE
** **
** Built at: 2013-04-10 07:38:34Z ** Built at: 2013-04-12 00:11:35Z
*/ */
(function() { (function() {
var base64Decode, base64UrlDecode, createDateFromISO8601, parseToken, var base64Decode, base64UrlDecode, createDateFromISO8601, parseToken,
__hasProp = Object.prototype.hasOwnProperty, __hasProp = {}.hasOwnProperty,
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor; child.__super__ = parent.prototype; return child; }; __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };
createDateFromISO8601 = function(string) { createDateFromISO8601 = function(string) {
var d, date, offset, regexp, time, _ref; var d, date, offset, regexp, time, _ref;
regexp = "([0-9]{4})(-([0-9]{2})(-([0-9]{2})" + "(T([0-9]{2}):([0-9]{2})(:([0-9]{2})(\.([0-9]+))?)?" + "(Z|(([-+])([0-9]{2}):([0-9]{2})))?)?)?)?"; regexp = "([0-9]{4})(-([0-9]{2})(-([0-9]{2})" + "(T([0-9]{2}):([0-9]{2})(:([0-9]{2})(\.([0-9]+))?)?" + "(Z|(([-+])([0-9]{2}):([0-9]{2})))?)?)?)?";
d = string.match(new RegExp(regexp)); d = string.match(new RegExp(regexp));
offset = 0; offset = 0;
date = new Date(d[1], 0, 1); date = new Date(d[1], 0, 1);
if (d[3]) date.setMonth(d[3] - 1); if (d[3]) {
if (d[5]) date.setDate(d[5]); date.setMonth(d[3] - 1);
if (d[7]) date.setHours(d[7]); }
if (d[8]) date.setMinutes(d[8]); if (d[5]) {
if (d[10]) date.setSeconds(d[10]); date.setDate(d[5]);
if (d[12]) date.setMilliseconds(Number("0." + d[12]) * 1000); }
if (d[7]) {
date.setHours(d[7]);
}
if (d[8]) {
date.setMinutes(d[8]);
}
if (d[10]) {
date.setSeconds(d[10]);
}
if (d[12]) {
date.setMilliseconds(Number("0." + d[12]) * 1000);
}
if (d[14]) { if (d[14]) {
offset = (Number(d[16]) * 60) + Number(d[17]); offset = (Number(d[16]) * 60) + Number(d[17]);
offset *= (_ref = d[15] === '-') != null ? _ref : { offset *= (_ref = d[15] === '-') != null ? _ref : {
...@@ -40,6 +54,7 @@ ...@@ -40,6 +54,7 @@
base64Decode = function(data) { base64Decode = function(data) {
var ac, b64, bits, dec, h1, h2, h3, h4, i, o1, o2, o3, tmp_arr; var ac, b64, bits, dec, h1, h2, h3, h4, i, o1, o2, o3, tmp_arr;
if (typeof atob !== "undefined" && atob !== null) { if (typeof atob !== "undefined" && atob !== null) {
return atob(data); return atob(data);
} else { } else {
...@@ -48,7 +63,9 @@ ...@@ -48,7 +63,9 @@
ac = 0; ac = 0;
dec = ""; dec = "";
tmp_arr = []; tmp_arr = [];
if (!data) return data; if (!data) {
return data;
}
data += ''; data += '';
while (i < data.length) { while (i < data.length) {
h1 = b64.indexOf(data.charAt(i++)); h1 = b64.indexOf(data.charAt(i++));
...@@ -72,10 +89,11 @@ ...@@ -72,10 +89,11 @@
}; };
base64UrlDecode = function(data) { base64UrlDecode = function(data) {
var i, m, _ref; var i, m, _i, _ref;
m = data.length % 4; m = data.length % 4;
if (m !== 0) { if (m !== 0) {
for (i = 0, _ref = 4 - m; 0 <= _ref ? i < _ref : i > _ref; 0 <= _ref ? i++ : i--) { for (i = _i = 0, _ref = 4 - m; 0 <= _ref ? _i < _ref : _i > _ref; i = 0 <= _ref ? ++_i : --_i) {
data += '='; data += '=';
} }
} }
...@@ -86,12 +104,12 @@ ...@@ -86,12 +104,12 @@
parseToken = function(token) { parseToken = function(token) {
var head, payload, sig, _ref; var head, payload, sig, _ref;
_ref = token.split('.'), head = _ref[0], payload = _ref[1], sig = _ref[2]; _ref = token.split('.'), head = _ref[0], payload = _ref[1], sig = _ref[2];
return JSON.parse(base64UrlDecode(payload)); return JSON.parse(base64UrlDecode(payload));
}; };
Annotator.Plugin.Auth = (function(_super) { Annotator.Plugin.Auth = (function(_super) {
__extends(Auth, _super); __extends(Auth, _super);
Auth.prototype.options = { Auth.prototype.options = {
...@@ -112,6 +130,7 @@ ...@@ -112,6 +130,7 @@
Auth.prototype.requestToken = function() { Auth.prototype.requestToken = function() {
var _this = this; var _this = this;
this.requestInProgress = true; this.requestInProgress = true;
return $.ajax({ return $.ajax({
url: this.options.tokenUrl, url: this.options.tokenUrl,
...@@ -123,6 +142,7 @@ ...@@ -123,6 +142,7 @@
return _this.setToken(data); return _this.setToken(data);
}).fail(function(xhr, status, err) { }).fail(function(xhr, status, err) {
var msg; var msg;
msg = Annotator._t("Couldn't get auth token:"); msg = Annotator._t("Couldn't get auth token:");
console.error("" + msg + " " + err, xhr); console.error("" + msg + " " + err, xhr);
return Annotator.showNotification("" + msg + " " + xhr.responseText, Annotator.Notification.ERROR); return Annotator.showNotification("" + msg + " " + xhr.responseText, Annotator.Notification.ERROR);
...@@ -134,6 +154,7 @@ ...@@ -134,6 +154,7 @@
Auth.prototype.setToken = function(token) { Auth.prototype.setToken = function(token) {
var _results, var _results,
_this = this; _this = this;
this.token = token; this.token = token;
this._unsafeToken = parseToken(token); this._unsafeToken = parseToken(token);
if (this.haveValidToken()) { if (this.haveValidToken()) {
...@@ -161,12 +182,14 @@ ...@@ -161,12 +182,14 @@
Auth.prototype.haveValidToken = function() { Auth.prototype.haveValidToken = function() {
var allFields; var allFields;
allFields = this._unsafeToken && this._unsafeToken.issuedAt && this._unsafeToken.ttl && this._unsafeToken.consumerKey; allFields = this._unsafeToken && this._unsafeToken.issuedAt && this._unsafeToken.ttl && this._unsafeToken.consumerKey;
return allFields && this.timeToExpiry() > 0; return allFields && this.timeToExpiry() > 0;
}; };
Auth.prototype.timeToExpiry = function() { Auth.prototype.timeToExpiry = function() {
var expiry, issue, now, timeToExpiry; var expiry, issue, now, timeToExpiry;
now = new Date().getTime() / 1000; now = new Date().getTime() / 1000;
issue = createDateFromISO8601(this._unsafeToken.issuedAt).getTime() / 1000; issue = createDateFromISO8601(this._unsafeToken.issuedAt).getTime() / 1000;
expiry = issue + this._unsafeToken.ttl; expiry = issue + this._unsafeToken.ttl;
...@@ -180,6 +203,7 @@ ...@@ -180,6 +203,7 @@
Auth.prototype.updateHeaders = function() { Auth.prototype.updateHeaders = function() {
var current; var current;
current = this.element.data('annotator:headers'); current = this.element.data('annotator:headers');
return this.element.data('annotator:headers', $.extend(current, { return this.element.data('annotator:headers', $.extend(current, {
'x-annotator-auth-token': this.token 'x-annotator-auth-token': this.token
...@@ -187,12 +211,16 @@ ...@@ -187,12 +211,16 @@
}; };
Auth.prototype.withToken = function(callback) { Auth.prototype.withToken = function(callback) {
if (!(callback != null)) return; if (callback == null) {
return;
}
if (this.haveValidToken()) { if (this.haveValidToken()) {
return callback(this._unsafeToken); return callback(this._unsafeToken);
} else { } else {
this.waitingForToken.push(callback); this.waitingForToken.push(callback);
if (!this.requestInProgress) return this.requestToken(); if (!this.requestInProgress) {
return this.requestToken();
}
} }
}; };
......
This diff is collapsed.
/* /*
** Annotator 1.2.6-dev-939cdee ** Annotator 1.2.6-dev-d45a366
** https://github.com/okfn/annotator/ ** https://github.com/okfn/annotator/
** **
** Copyright 2012 Aron Carroll, Rufus Pollock, and Nick Stenning. ** Copyright 2012 Aron Carroll, Rufus Pollock, and Nick Stenning.
** Dual licensed under the MIT and GPLv3 licenses. ** Dual licensed under the MIT and GPLv3 licenses.
** https://github.com/okfn/annotator/blob/master/LICENSE ** https://github.com/okfn/annotator/blob/master/LICENSE
** **
** Built at: 2013-04-10 07:38:36Z ** Built at: 2013-04-12 00:11:37Z
*/ */
(function() { (function() {
var __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; }, var __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
__hasProp = Object.prototype.hasOwnProperty, __hasProp = {}.hasOwnProperty,
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor; child.__super__ = parent.prototype; return child; }; __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };
Annotator.Plugin.Permissions = (function(_super) { Annotator.Plugin.Permissions = (function(_super) {
__extends(Permissions, _super); __extends(Permissions, _super);
Permissions.prototype.events = { Permissions.prototype.events = {
...@@ -33,12 +33,17 @@ ...@@ -33,12 +33,17 @@
}, },
userAuthorize: function(action, annotation, user) { userAuthorize: function(action, annotation, user) {
var token, tokens, _i, _len; var token, tokens, _i, _len;
if (annotation.permissions) { if (annotation.permissions) {
tokens = annotation.permissions[action] || []; tokens = annotation.permissions[action] || [];
if (tokens.length === 0) return true; if (tokens.length === 0) {
return true;
}
for (_i = 0, _len = tokens.length; _i < _len; _i++) { for (_i = 0, _len = tokens.length; _i < _len; _i++) {
token = tokens[_i]; token = tokens[_i];
if (this.userId(user) === token) return true; if (this.userId(user) === token) {
return true;
}
} }
return false; return false;
} else if (annotation.user) { } else if (annotation.user) {
...@@ -70,7 +75,10 @@ ...@@ -70,7 +75,10 @@
Permissions.prototype.pluginInit = function() { Permissions.prototype.pluginInit = function() {
var createCallback, self, var createCallback, self,
_this = this; _this = this;
if (!Annotator.supported()) return;
if (!Annotator.supported()) {
return;
}
self = this; self = this;
createCallback = function(method, type) { createCallback = function(method, type) {
return function(field, annotation) { return function(field, annotation) {
...@@ -105,12 +113,17 @@ ...@@ -105,12 +113,17 @@
property: 'user', property: 'user',
isFiltered: function(input, user) { isFiltered: function(input, user) {
var keyword, _i, _len, _ref; var keyword, _i, _len, _ref;
user = _this.options.userString(user); user = _this.options.userString(user);
if (!(input && user)) return false; if (!(input && user)) {
return false;
}
_ref = input.split(/\s*/); _ref = input.split(/\s*/);
for (_i = 0, _len = _ref.length; _i < _len; _i++) { for (_i = 0, _len = _ref.length; _i < _len; _i++) {
keyword = _ref[_i]; keyword = _ref[_i];
if (user.indexOf(keyword) === -1) return false; if (user.indexOf(keyword) === -1) {
return false;
}
} }
return true; return true;
} }
...@@ -125,12 +138,16 @@ ...@@ -125,12 +138,16 @@
Permissions.prototype.addFieldsToAnnotation = function(annotation) { Permissions.prototype.addFieldsToAnnotation = function(annotation) {
if (annotation) { if (annotation) {
annotation.permissions = this.options.permissions; annotation.permissions = this.options.permissions;
if (this.user) return annotation.user = this.user; if (this.user) {
return annotation.user = this.user;
}
} }
}; };
Permissions.prototype.authorize = function(action, annotation, user) { Permissions.prototype.authorize = function(action, annotation, user) {
if (user === void 0) user = this.user; if (user === void 0) {
user = this.user;
}
if (this.options.userAuthorize) { if (this.options.userAuthorize) {
return this.options.userAuthorize.call(this.options, action, annotation, user); return this.options.userAuthorize.call(this.options, action, annotation, user);
} else { } else {
...@@ -140,9 +157,12 @@ ...@@ -140,9 +157,12 @@
Permissions.prototype.updatePermissionsField = function(action, field, annotation) { Permissions.prototype.updatePermissionsField = function(action, field, annotation) {
var input; var input;
field = $(field).show(); field = $(field).show();
input = field.find('input').removeAttr('disabled'); input = field.find('input').removeAttr('disabled');
if (!this.authorize('admin', annotation)) field.hide(); if (!this.authorize('admin', annotation)) {
field.hide();
}
if (this.authorize(action, annotation || {}, null)) { if (this.authorize(action, annotation || {}, null)) {
return input.attr('checked', 'checked'); return input.attr('checked', 'checked');
} else { } else {
...@@ -152,6 +172,7 @@ ...@@ -152,6 +172,7 @@
Permissions.prototype.updateAnnotationPermissions = function(type, field, annotation) { Permissions.prototype.updateAnnotationPermissions = function(type, field, annotation) {
var dataKey; var dataKey;
if (!annotation.permissions) { if (!annotation.permissions) {
annotation.permissions = this.options.permissions; annotation.permissions = this.options.permissions;
} }
...@@ -165,6 +186,7 @@ ...@@ -165,6 +186,7 @@
Permissions.prototype.updateViewer = function(field, annotation, controls) { Permissions.prototype.updateViewer = function(field, annotation, controls) {
var user, username; var user, username;
field = $(field); field = $(field);
username = this.options.userString(annotation.user); username = this.options.userString(annotation.user);
if (annotation.user && username && typeof username === 'string') { if (annotation.user && username && typeof username === 'string') {
...@@ -174,8 +196,12 @@ ...@@ -174,8 +196,12 @@
field.remove(); field.remove();
} }
if (controls) { if (controls) {
if (!this.authorize('update', annotation)) controls.hideEdit(); if (!this.authorize('update', annotation)) {
if (!this.authorize('delete', annotation)) return controls.hideDelete(); controls.hideEdit();
}
if (!this.authorize('delete', annotation)) {
return controls.hideDelete();
}
} }
}; };
......
/* /*
** Annotator 1.2.6-dev-939cdee ** Annotator 1.2.6-dev-d45a366
** https://github.com/okfn/annotator/ ** https://github.com/okfn/annotator/
** **
** Copyright 2012 Aron Carroll, Rufus Pollock, and Nick Stenning. ** Copyright 2012 Aron Carroll, Rufus Pollock, and Nick Stenning.
** Dual licensed under the MIT and GPLv3 licenses. ** Dual licensed under the MIT and GPLv3 licenses.
** https://github.com/okfn/annotator/blob/master/LICENSE ** https://github.com/okfn/annotator/blob/master/LICENSE
** **
** Built at: 2013-04-10 07:38:36Z ** Built at: 2013-04-12 00:11:38Z
*/ */
(function() { (function() {
var __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; }, var __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },
__hasProp = Object.prototype.hasOwnProperty, __hasProp = {}.hasOwnProperty,
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor; child.__super__ = parent.prototype; return child; }, __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
__indexOf = Array.prototype.indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; __indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };
Annotator.Plugin.Store = (function(_super) { Annotator.Plugin.Store = (function(_super) {
__extends(Store, _super); __extends(Store, _super);
Store.prototype.events = { Store.prototype.events = {
...@@ -48,7 +48,9 @@ ...@@ -48,7 +48,9 @@
} }
Store.prototype.pluginInit = function() { Store.prototype.pluginInit = function() {
if (!Annotator.supported()) return; if (!Annotator.supported()) {
return;
}
if (this.annotator.plugins.Auth) { if (this.annotator.plugins.Auth) {
return this.annotator.plugins.Auth.withToken(this._getAnnotations); return this.annotator.plugins.Auth.withToken(this._getAnnotations);
} else { } else {
...@@ -66,10 +68,11 @@ ...@@ -66,10 +68,11 @@
Store.prototype.annotationCreated = function(annotation) { Store.prototype.annotationCreated = function(annotation) {
var _this = this; var _this = this;
if (__indexOf.call(this.annotations, annotation) < 0) { if (__indexOf.call(this.annotations, annotation) < 0) {
this.registerAnnotation(annotation); this.registerAnnotation(annotation);
return this._apiRequest('create', annotation, function(data) { return this._apiRequest('create', annotation, function(data) {
if (!(data.id != null)) { if (data.id == null) {
console.warn(Annotator._t("Warning: No ID returned from server for annotation "), annotation); console.warn(Annotator._t("Warning: No ID returned from server for annotation "), annotation);
} }
return _this.updateAnnotation(annotation, data); return _this.updateAnnotation(annotation, data);
...@@ -81,6 +84,7 @@ ...@@ -81,6 +84,7 @@
Store.prototype.annotationUpdated = function(annotation) { Store.prototype.annotationUpdated = function(annotation) {
var _this = this; var _this = this;
if (__indexOf.call(this.annotations, annotation) >= 0) { if (__indexOf.call(this.annotations, annotation) >= 0) {
return this._apiRequest('update', annotation, (function(data) { return this._apiRequest('update', annotation, (function(data) {
return _this.updateAnnotation(annotation, data); return _this.updateAnnotation(annotation, data);
...@@ -90,6 +94,7 @@ ...@@ -90,6 +94,7 @@
Store.prototype.annotationDeleted = function(annotation) { Store.prototype.annotationDeleted = function(annotation) {
var _this = this; var _this = this;
if (__indexOf.call(this.annotations, annotation) >= 0) { if (__indexOf.call(this.annotations, annotation) >= 0) {
return this._apiRequest('destroy', annotation, (function() { return this._apiRequest('destroy', annotation, (function() {
return _this.unregisterAnnotation(annotation); return _this.unregisterAnnotation(annotation);
...@@ -119,7 +124,9 @@ ...@@ -119,7 +124,9 @@
}; };
Store.prototype._onLoadAnnotations = function(data) { Store.prototype._onLoadAnnotations = function(data) {
if (data == null) data = []; if (data == null) {
data = [];
}
this.annotations = this.annotations.concat(data); this.annotations = this.annotations.concat(data);
return this.annotator.loadAnnotations(data.slice()); return this.annotator.loadAnnotations(data.slice());
}; };
...@@ -129,12 +136,15 @@ ...@@ -129,12 +136,15 @@
}; };
Store.prototype._onLoadAnnotationsFromSearch = function(data) { Store.prototype._onLoadAnnotationsFromSearch = function(data) {
if (data == null) data = {}; if (data == null) {
data = {};
}
return this._onLoadAnnotations(data.rows || []); return this._onLoadAnnotations(data.rows || []);
}; };
Store.prototype.dumpAnnotations = function() { Store.prototype.dumpAnnotations = function() {
var ann, _i, _len, _ref, _results; var ann, _i, _len, _ref, _results;
_ref = this.annotations; _ref = this.annotations;
_results = []; _results = [];
for (_i = 0, _len = _ref.length; _i < _len; _i++) { for (_i = 0, _len = _ref.length; _i < _len; _i++) {
...@@ -146,6 +156,7 @@ ...@@ -146,6 +156,7 @@
Store.prototype._apiRequest = function(action, obj, onSuccess) { Store.prototype._apiRequest = function(action, obj, onSuccess) {
var id, options, request, url; var id, options, request, url;
id = obj && obj.id; id = obj && obj.id;
url = this._urlFor(action, id); url = this._urlFor(action, id);
options = this._apiRequestOptions(action, obj, onSuccess); options = this._apiRequestOptions(action, obj, onSuccess);
...@@ -157,6 +168,7 @@ ...@@ -157,6 +168,7 @@
Store.prototype._apiRequestOptions = function(action, obj, onSuccess) { Store.prototype._apiRequestOptions = function(action, obj, onSuccess) {
var data, method, opts; var data, method, opts;
method = this._methodFor(action); method = this._methodFor(action);
opts = { opts = {
type: method, type: method,
...@@ -182,7 +194,9 @@ ...@@ -182,7 +194,9 @@
opts.data = { opts.data = {
json: data json: data
}; };
if (this.options.emulateHTTP) opts.data._method = method; if (this.options.emulateHTTP) {
opts.data._method = method;
}
return opts; return opts;
} }
opts = $.extend(opts, { opts = $.extend(opts, {
...@@ -194,6 +208,7 @@ ...@@ -194,6 +208,7 @@
Store.prototype._urlFor = function(action, id) { Store.prototype._urlFor = function(action, id) {
var url; var url;
url = this.options.prefix != null ? this.options.prefix : ''; url = this.options.prefix != null ? this.options.prefix : '';
url += this.options.urls[action]; url += this.options.urls[action];
url = url.replace(/\/:id/, id != null ? '/' + id : ''); url = url.replace(/\/:id/, id != null ? '/' + id : '');
...@@ -203,6 +218,7 @@ ...@@ -203,6 +218,7 @@
Store.prototype._methodFor = function(action) { Store.prototype._methodFor = function(action) {
var table; var table;
table = { table = {
'create': 'POST', 'create': 'POST',
'read': 'GET', 'read': 'GET',
...@@ -215,16 +231,20 @@ ...@@ -215,16 +231,20 @@
Store.prototype._dataFor = function(annotation) { Store.prototype._dataFor = function(annotation) {
var data, highlights; var data, highlights;
highlights = annotation.highlights; highlights = annotation.highlights;
delete annotation.highlights; delete annotation.highlights;
$.extend(annotation, this.options.annotationData); $.extend(annotation, this.options.annotationData);
data = JSON.stringify(annotation); data = JSON.stringify(annotation);
if (highlights) annotation.highlights = highlights; if (highlights) {
annotation.highlights = highlights;
}
return data; return data;
}; };
Store.prototype._onError = function(xhr) { Store.prototype._onError = function(xhr) {
var action, message; var action, message;
action = xhr._action; action = xhr._action;
message = Annotator._t("Sorry we could not ") + action + Annotator._t(" this annotation"); message = Annotator._t("Sorry we could not ") + action + Annotator._t(" this annotation");
if (xhr._action === 'search') { if (xhr._action === 'search') {
......
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