Cache results in datavalue rendering
This commit is contained in:
parent
3bf3f84ca6
commit
c71bc9096c
@ -208,6 +208,8 @@ EditRenderer._updateReferencesNumber = function(container) {
|
|||||||
* VALUE RENDERING *
|
* VALUE RENDERING *
|
||||||
*******************/
|
*******************/
|
||||||
|
|
||||||
|
EditRenderer.renderedValueCache = {};
|
||||||
|
|
||||||
EditRenderer._renderEntity = function(json, container) {
|
EditRenderer._renderEntity = function(json, container) {
|
||||||
var html = WarningsRenderer._renderEntity(json);
|
var html = WarningsRenderer._renderEntity(json);
|
||||||
$(html).appendTo(container);
|
$(html).appendTo(container);
|
||||||
@ -219,11 +221,15 @@ EditRenderer._renderValue = function(json, container) {
|
|||||||
|
|
||||||
if (mode === "wikibase-item" || mode === "wikibase-property") {
|
if (mode === "wikibase-item" || mode === "wikibase-property") {
|
||||||
EditRenderer._renderEntity(json.datavalue, container);
|
EditRenderer._renderEntity(json.datavalue, container);
|
||||||
|
} else {
|
||||||
|
var jsonValue = JSON.stringify(json.datavalue);
|
||||||
|
if (jsonValue in EditRenderer.renderedValueCache) {
|
||||||
|
$('<span>'+EditRenderer.renderedValueCache[jsonValue]+'</span>').appendTo(container);
|
||||||
} else {
|
} else {
|
||||||
var params = {
|
var params = {
|
||||||
action: 'wbformatvalue',
|
action: 'wbformatvalue',
|
||||||
generate: 'text/html',
|
generate: 'text/html',
|
||||||
datavalue: JSON.stringify(json.datavalue),
|
datavalue: jsonValue,
|
||||||
options: '{"lang":"'+$.i18n._('core-recon')["wd-recon-lang"]+'"}',
|
options: '{"lang":"'+$.i18n._('core-recon')["wd-recon-lang"]+'"}',
|
||||||
format: 'json'
|
format: 'json'
|
||||||
};
|
};
|
||||||
@ -237,54 +243,14 @@ EditRenderer._renderValue = function(json, container) {
|
|||||||
params,
|
params,
|
||||||
function (data) {
|
function (data) {
|
||||||
if('result' in data) {
|
if('result' in data) {
|
||||||
|
EditRenderer.renderedValueCache[jsonValue] = data.result;
|
||||||
$('<span>'+data.result+'</span>').appendTo(container);
|
$('<span>'+data.result+'</span>').appendTo(container);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'jsonp'
|
'jsonp'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
/*
|
|
||||||
if (mode === "time") {
|
|
||||||
input.text(json.datavalue.value.time);
|
|
||||||
} else if (mode === "globe-coordinate") {
|
|
||||||
// TODO
|
|
||||||
} else if (mode === "language") {
|
|
||||||
// TODO
|
|
||||||
} else if (mode === "monolingualtext") {
|
|
||||||
input.remove();
|
|
||||||
var inputContainerLanguage = $('<div></div>')
|
|
||||||
.addClass('wbs-monolingual-container')
|
|
||||||
.width('30%')
|
|
||||||
.appendTo(container);
|
|
||||||
var inputContainerValue = $('<div></div>')
|
|
||||||
.addClass('wbs-monolingual-container')
|
|
||||||
.width('70%')
|
|
||||||
.appendTo(container);
|
|
||||||
|
|
||||||
EditRenderer._renderValue({datatype:"language",datavalue:json.language}, inputContainerLanguage);
|
|
||||||
EditRenderer._renderValue({datatype:"string",datavalue:{value:json.value}}, inputContainerValue);
|
|
||||||
} else if (mode === "quantity") {
|
|
||||||
input.remove();
|
|
||||||
var inputContainerAmount = $('<div></div>')
|
|
||||||
.addClass('wbs-quantity-container')
|
|
||||||
.width('60%')
|
|
||||||
.appendTo(inputContainer);
|
|
||||||
var inputContainerUnit = $('<div></div>')
|
|
||||||
.addClass('wbs-quantity-container')
|
|
||||||
.width('40%')
|
|
||||||
.appendTo(inputContainer);
|
|
||||||
|
|
||||||
var amountValue = null;
|
|
||||||
var unitValue = null;
|
|
||||||
|
|
||||||
// TODO
|
|
||||||
//EditRenderer._renderValue(inputContainerAmount, "amount", amountValue, propagateValue);
|
|
||||||
// EditRenderer._renderEntity( , inputContainerUnit);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
input.text(json.datavalue.value);
|
|
||||||
} */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user