mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-05 05:29:13 +01:00
Api: Handle refreshing multiple UIDs but not getting them all back.
Previously we were assuming only 1 was requested, now properly handling multiple UIDs in a single request and not all of them being returned (eg ACL or doesn't match filters)
This commit is contained in:
parent
3ff331c22b
commit
b43f51b52e
@ -176,7 +176,7 @@ egw.extend("data", egw.MODULE_APP_LOCAL, function (_app, _wnd)
|
|||||||
// Load all data entries that have been sent or delete them
|
// Load all data entries that have been sent or delete them
|
||||||
for (var key in _result.data)
|
for (var key in _result.data)
|
||||||
{
|
{
|
||||||
var uid = UID(key, (typeof _context == "object" && _context != null) ?_context.prefix : "");
|
let uid = UID(key, (typeof _context == "object" && _context != null) ?_context.prefix : "");
|
||||||
if (_result.data[key] === null &&
|
if (_result.data[key] === null &&
|
||||||
(
|
(
|
||||||
typeof _context.refresh == "undefined" || _context.refresh && !jQuery.inArray(key,_context.refresh)
|
typeof _context.refresh == "undefined" || _context.refresh && !jQuery.inArray(key,_context.refresh)
|
||||||
@ -190,13 +190,17 @@ egw.extend("data", egw.MODULE_APP_LOCAL, function (_app, _wnd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tried to refresh a specific row and got nothing, so set it to null
|
// Check if we tried to refresh a specific row and didn't get it, so set it to null
|
||||||
// (triggers update for listeners), then remove it
|
// (triggers update for listeners), then remove it
|
||||||
if(_result.order.length == 0 && typeof _context == "object" && _context.refresh)
|
if(typeof _context == "object" && _context.refresh)
|
||||||
{
|
{
|
||||||
for(var i = 0; i < _context.refresh.length; i++)
|
for(let i = 0; i < _context.refresh.length; i++)
|
||||||
{
|
{
|
||||||
var uid = UID(_context.refresh[i], _context.prefix);
|
let uid = UID(_context.refresh[i], _context.prefix);
|
||||||
|
if(_result.order.indexOf(uid) >= 0)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
egw.dataStoreUID(uid, null);
|
egw.dataStoreUID(uid, null);
|
||||||
egw.dataDeleteUID(uid);
|
egw.dataDeleteUID(uid);
|
||||||
}
|
}
|
||||||
@ -657,10 +661,15 @@ egw.extend("data_storage", egw.MODULE_GLOBAL, function (_app, _wnd) {
|
|||||||
if (typeof queue[hash] === "undefined")
|
if (typeof queue[hash] === "undefined")
|
||||||
{
|
{
|
||||||
var self = this;
|
var self = this;
|
||||||
queue[hash] = { "uids": [], "timer": null };
|
queue[hash] = {"uids": [], "timer": null};
|
||||||
queue[hash].timer = window.setTimeout(function () {
|
queue[hash].timer = window.setTimeout(function () {
|
||||||
// Fetch the data
|
// Fetch the data
|
||||||
self.dataFetch(_execId, {"start": 0, "num_rows": 0, "only_data": true, "refresh": queue[hash].uids},
|
self.dataFetch(_execId, {
|
||||||
|
"start": 0,
|
||||||
|
"num_rows": 0,
|
||||||
|
"only_data": true,
|
||||||
|
"refresh": queue[hash].uids
|
||||||
|
},
|
||||||
[], _widgetId, null, _context, null);
|
[], _widgetId, null, _context, null);
|
||||||
|
|
||||||
// Delete the queue entry
|
// Delete the queue entry
|
||||||
@ -671,8 +680,11 @@ egw.extend("data_storage", egw.MODULE_GLOBAL, function (_app, _wnd) {
|
|||||||
// Push the uid onto the queue, removing the prefix
|
// Push the uid onto the queue, removing the prefix
|
||||||
var parts = _uid.split("::");
|
var parts = _uid.split("::");
|
||||||
parts.shift();
|
parts.shift();
|
||||||
|
if (queue[hash].uids.indexOf(parts.join("::")) === -1)
|
||||||
|
{
|
||||||
queue[hash].uids.push(parts.join('::'));
|
queue[hash].uids.push(parts.join('::'));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this.debug("log", "Data for uid " + _uid + " not available.");
|
this.debug("log", "Data for uid " + _uid + " not available.");
|
||||||
|
Loading…
Reference in New Issue
Block a user