forked from extern/egroupware
CRM: Fix some list bugs
- Adding an infolog did not show up - CRM.ts got disconnected if infolog list got reloaded
This commit is contained in:
parent
87b1b05730
commit
ba0e1240c3
@ -46,6 +46,8 @@ var CRMView = /** @class */ (function (_super) {
|
||||
var _this =
|
||||
// call parent
|
||||
_super.call(this, 'addressbook') || this;
|
||||
// List ID
|
||||
_this.list_id = "";
|
||||
// Reference to the list
|
||||
_this.nm = null;
|
||||
// Which addressbook contact id(s) we are showing entries for
|
||||
@ -77,17 +79,19 @@ var CRMView = /** @class */ (function (_super) {
|
||||
CRMView.view_ready = function (et2, app_obj) {
|
||||
// Check to see if the template is for a CRM view
|
||||
if (et2.app == app_obj.appname) {
|
||||
return false;
|
||||
return CRMView.reconnect(app_obj);
|
||||
}
|
||||
// Make sure object is there, etemplate2 will pick it up and call our et2_ready
|
||||
var crm = undefined;
|
||||
// @ts-ignore
|
||||
if (typeof et2.app_obj.crm == "undefined" && app.classes.crm) {
|
||||
et2.app_obj.crm = new app.classes.crm();
|
||||
// @ts-ignore
|
||||
crm = et2.app_obj.crm = new app.classes.crm();
|
||||
}
|
||||
if (typeof et2.app_obj.crm == "undefined") {
|
||||
if (typeof crm == "undefined") {
|
||||
egw.debug("error", "CRMView object is missing");
|
||||
return false;
|
||||
}
|
||||
var crm = et2.app_obj.crm;
|
||||
// We can set this now
|
||||
crm.set_view_obj(app_obj);
|
||||
};
|
||||
@ -103,13 +107,50 @@ var CRMView = /** @class */ (function (_super) {
|
||||
// call parent
|
||||
_super.prototype.et2_ready.call(this, et2, name);
|
||||
};
|
||||
/**
|
||||
* Our CRM has become disconnected from its list, probably because something submitted.
|
||||
* Find it, and get things working again.
|
||||
*
|
||||
* @param app_obj
|
||||
*/
|
||||
CRMView.reconnect = function (app_obj) {
|
||||
var _a;
|
||||
// Check
|
||||
var contact_ids = app_obj.et2.getArrayMgr("content").getEntry("action_id") || "";
|
||||
debugger;
|
||||
if (!contact_ids)
|
||||
return;
|
||||
for (var _i = 0, _b = egw_app_1.EgwApp._instances; _i < _b.length; _i++) {
|
||||
var existing_app = _b[_i];
|
||||
if (existing_app instanceof CRMView && existing_app.list_id == app_obj.et2.getInstanceManager().uniqueId) {
|
||||
// List was reloaded. Rebind.
|
||||
existing_app.app_obj.destroy(existing_app.app_obj.appname);
|
||||
if (!((_a = existing_app.nm) === null || _a === void 0 ? void 0 : _a.getParent())) {
|
||||
try {
|
||||
// This will probably not die cleanly, we had a reference when it was destroyed
|
||||
existing_app.nm.destroy();
|
||||
}
|
||||
catch (e) { }
|
||||
}
|
||||
return existing_app.set_view_obj(app_obj);
|
||||
}
|
||||
}
|
||||
};
|
||||
/**
|
||||
* Set the associated private app JS
|
||||
* We try and pull the needed info here
|
||||
*/
|
||||
CRMView.prototype.set_view_obj = function (app_obj) {
|
||||
this.app_obj = app_obj;
|
||||
// Make sure object is there, etemplate2 will pick it up and call our et2_ready
|
||||
app_obj.et2.getInstanceManager().app_obj.crm = this;
|
||||
// Make _sure_ we get notified if the list is removed (actions, refresh) - this is not always a full
|
||||
// destruction
|
||||
jQuery(app_obj.et2.getDOMNode()).on('clear', function () {
|
||||
this.nm = null;
|
||||
}.bind(this));
|
||||
// For easy reference later
|
||||
this.list_id = app_obj.et2.getInstanceManager().uniqueId;
|
||||
this.nm = app_obj.et2.getDOMWidgetById('nm');
|
||||
var contact_ids = app_obj.et2.getArrayMgr("content").getEntry("action_id") || "";
|
||||
if (typeof contact_ids == "string") {
|
||||
|
@ -27,6 +27,9 @@ import {et2_nextmatch} from "../../api/js/etemplate/et2_extension_nextmatch";
|
||||
*/
|
||||
export class CRMView extends EgwApp
|
||||
{
|
||||
// List ID
|
||||
list_id: string = "";
|
||||
|
||||
// Reference to the list
|
||||
nm: et2_nextmatch = null;
|
||||
|
||||
@ -80,21 +83,23 @@ export class CRMView extends EgwApp
|
||||
// Check to see if the template is for a CRM view
|
||||
if(et2.app == app_obj.appname)
|
||||
{
|
||||
return false;
|
||||
return CRMView.reconnect(app_obj);
|
||||
}
|
||||
|
||||
// Make sure object is there, etemplate2 will pick it up and call our et2_ready
|
||||
let crm : CRMView = undefined;
|
||||
// @ts-ignore
|
||||
if(typeof et2.app_obj.crm == "undefined" && app.classes.crm)
|
||||
{
|
||||
et2.app_obj.crm = new app.classes.crm();
|
||||
// @ts-ignore
|
||||
crm = et2.app_obj.crm = new app.classes.crm();
|
||||
}
|
||||
if(typeof et2.app_obj.crm == "undefined")
|
||||
if(typeof crm == "undefined")
|
||||
{
|
||||
egw.debug("error", "CRMView object is missing");
|
||||
return false;
|
||||
}
|
||||
|
||||
let crm = et2.app_obj.crm;
|
||||
|
||||
// We can set this now
|
||||
crm.set_view_obj(app_obj);
|
||||
@ -115,6 +120,37 @@ export class CRMView extends EgwApp
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Our CRM has become disconnected from its list, probably because something submitted.
|
||||
* Find it, and get things working again.
|
||||
*
|
||||
* @param app_obj
|
||||
*/
|
||||
static reconnect(app_obj : EgwApp)
|
||||
{
|
||||
// Check
|
||||
let contact_ids = app_obj.et2.getArrayMgr("content").getEntry("action_id") || "";
|
||||
debugger;
|
||||
if(!contact_ids) return;
|
||||
|
||||
for (let existing_app of EgwApp._instances)
|
||||
{
|
||||
if(existing_app instanceof CRMView && existing_app.list_id == app_obj.et2.getInstanceManager().uniqueId)
|
||||
{
|
||||
// List was reloaded. Rebind.
|
||||
existing_app.app_obj.destroy(existing_app.app_obj.appname);
|
||||
if(!existing_app.nm?.getParent())
|
||||
{
|
||||
try
|
||||
{
|
||||
// This will probably not die cleanly, we had a reference when it was destroyed
|
||||
existing_app.nm.destroy();
|
||||
} catch (e) {}
|
||||
}
|
||||
return existing_app.set_view_obj(app_obj);
|
||||
}
|
||||
}
|
||||
}
|
||||
/**
|
||||
* Set the associated private app JS
|
||||
* We try and pull the needed info here
|
||||
@ -123,7 +159,17 @@ export class CRMView extends EgwApp
|
||||
{
|
||||
this.app_obj = app_obj;
|
||||
|
||||
// Make sure object is there, etemplate2 will pick it up and call our et2_ready
|
||||
app_obj.et2.getInstanceManager().app_obj.crm = this
|
||||
|
||||
// Make _sure_ we get notified if the list is removed (actions, refresh) - this is not always a full
|
||||
// destruction
|
||||
jQuery(app_obj.et2.getDOMNode()).on('clear', function() {
|
||||
this.nm = null;
|
||||
}.bind(this));
|
||||
|
||||
// For easy reference later
|
||||
this.list_id = app_obj.et2.getInstanceManager().uniqueId;
|
||||
this.nm = <et2_nextmatch>app_obj.et2.getDOMWidgetById('nm');
|
||||
|
||||
let contact_ids = app_obj.et2.getArrayMgr("content").getEntry("action_id") || "";
|
||||
|
@ -546,6 +546,10 @@ var et2_nextmatch = /** @class */ (function (_super) {
|
||||
// Pre-ask for the row data, and only proceed if we actually get it
|
||||
// need to send nextmatch filters too, as server-side will merge old version from request otherwise
|
||||
this_1.egw().dataFetch(this_1.getInstanceManager().etemplate_exec_id, { refresh: _row_ids }, this_1.controller._filters, this_1.id, function (data) {
|
||||
// In the event that the etemplate got removed before the data came back (Usually an action caused
|
||||
// a full submit) just stop here.
|
||||
if (!this.nm.getParent())
|
||||
return;
|
||||
if (data.total >= 1) {
|
||||
this.type == et2_nextmatch.ADD ? this.nm.refresh_add(this.uid, this.type)
|
||||
: this.nm.refresh_update(this.uid);
|
||||
@ -556,7 +560,7 @@ var et2_nextmatch = /** @class */ (function (_super) {
|
||||
// Adjust total rows, clean grid
|
||||
this.nm.controller._grid.setTotalCount(this.nm.controller._grid._total - _row_ids.length);
|
||||
}
|
||||
}, { type: _type, nm: this_1, uid: uid_1 }, [_row_ids]);
|
||||
}, { type: _type, nm: this_1, uid: uid_1, prefix: this_1.controller.dataStorePrefix }, [_row_ids]);
|
||||
return { value: void 0 };
|
||||
}
|
||||
switch (_type) {
|
||||
@ -635,32 +639,36 @@ var et2_nextmatch = /** @class */ (function (_super) {
|
||||
return false;
|
||||
}
|
||||
var time = new Date().valueOf();
|
||||
var callback = function (data) {
|
||||
if (data) {
|
||||
this.egw().dataRegisterUID(uid, this._push_add_callback, { nm: this, uid: uid, index: index }, this.getInstanceManager().etemplate_exec_id, this.id);
|
||||
return true;
|
||||
};
|
||||
/**
|
||||
* Callback for adding a new row via push
|
||||
*
|
||||
* Expected context: {nm: this, uid: string, index: number}
|
||||
*/
|
||||
et2_nextmatch.prototype._push_add_callback = function (data) {
|
||||
if (data && this.nm && this.nm.getParent()) {
|
||||
if (data.class) {
|
||||
data.class += " new_entry";
|
||||
}
|
||||
// Don't remove if new data has not arrived
|
||||
var stored = egw.dataGetUIDdata(uid);
|
||||
var stored = egw.dataGetUIDdata(this.uid);
|
||||
//if(stored?.timestamp >= time) return;
|
||||
// Increase displayed row count or we lose the last row when we add and the total is wrong
|
||||
this.controller._grid.setTotalCount(this.controller._grid.getTotalCount() + 1);
|
||||
this.nm.controller._grid.setTotalCount(this.nm.controller._grid.getTotalCount() + 1);
|
||||
// Insert at the top of the list, or where app said
|
||||
var entry = this.controller._selectionMgr._getRegisteredRowsEntry(uid);
|
||||
entry.idx = typeof index == "number" ? index : 0;
|
||||
this.controller._insertDataRow(entry, true);
|
||||
var entry = this.nm.controller._selectionMgr._getRegisteredRowsEntry(this.uid);
|
||||
entry.idx = typeof this.index == "number" ? this.index : 0;
|
||||
this.nm.controller._insertDataRow(entry, true);
|
||||
}
|
||||
else {
|
||||
debugger;
|
||||
else if (this.nm && this.nm.getParent()) {
|
||||
// Server didn't give us our row data
|
||||
// Delete from internal references
|
||||
this.controller.deleteRow(uid);
|
||||
this.controller._grid.setTotalCount(this.controller._grid.getTotalCount() - 1);
|
||||
this.nm.controller.deleteRow(this.uid);
|
||||
this.nm.controller._grid.setTotalCount(this.nm.controller._grid.getTotalCount() - 1);
|
||||
}
|
||||
this.egw().dataUnregisterUID(uid, callback, this);
|
||||
};
|
||||
this.egw().dataRegisterUID(uid, callback, this, this.getInstanceManager().etemplate_exec_id, this.id);
|
||||
return true;
|
||||
this.nm.egw().dataUnregisterUID(this.uid, this.nm._push_add_callback, this);
|
||||
};
|
||||
/**
|
||||
* Is this nextmatch currently sorted by "modified" date
|
||||
|
@ -844,6 +844,10 @@ export class et2_nextmatch extends et2_DOMWidget implements et2_IResizeable, et2
|
||||
this.controller._filters,
|
||||
this.id, function(data)
|
||||
{
|
||||
// In the event that the etemplate got removed before the data came back (Usually an action caused
|
||||
// a full submit) just stop here.
|
||||
if(!this.nm.getParent()) return;
|
||||
|
||||
if(data.total >= 1)
|
||||
{
|
||||
this.type == et2_nextmatch.ADD ? this.nm.refresh_add(this.uid, this.type)
|
||||
@ -857,7 +861,7 @@ export class et2_nextmatch extends et2_DOMWidget implements et2_IResizeable, et2
|
||||
// Adjust total rows, clean grid
|
||||
this.nm.controller._grid.setTotalCount(this.nm.controller._grid._total- _row_ids.length);
|
||||
}
|
||||
}, {type: _type, nm: this, uid: uid}, [_row_ids]
|
||||
}, {type: _type, nm: this, uid: uid, prefix: this.controller.dataStorePrefix}, [_row_ids]
|
||||
);
|
||||
return;
|
||||
}
|
||||
@ -942,37 +946,43 @@ export class et2_nextmatch extends et2_DOMWidget implements et2_IResizeable, et2
|
||||
|
||||
let time = new Date().valueOf();
|
||||
|
||||
let callback = function(data) {
|
||||
if(data)
|
||||
this.egw().dataRegisterUID(uid, this._push_add_callback, {nm: this, uid: uid, index: index}, this.getInstanceManager().etemplate_exec_id, this.id);
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback for adding a new row via push
|
||||
*
|
||||
* Expected context: {nm: this, uid: string, index: number}
|
||||
*/
|
||||
protected _push_add_callback(this: {nm: et2_nextmatch, uid: string, index: number}, data:any)
|
||||
{
|
||||
if(data && this.nm && this.nm.getParent())
|
||||
{
|
||||
if(data.class)
|
||||
{
|
||||
data.class += " new_entry";
|
||||
}
|
||||
// Don't remove if new data has not arrived
|
||||
let stored = egw.dataGetUIDdata(uid);
|
||||
let stored = egw.dataGetUIDdata(this.uid);
|
||||
//if(stored?.timestamp >= time) return;
|
||||
|
||||
// Increase displayed row count or we lose the last row when we add and the total is wrong
|
||||
this.controller._grid.setTotalCount(this.controller._grid.getTotalCount()+1);
|
||||
this.nm.controller._grid.setTotalCount(this.nm.controller._grid.getTotalCount()+1);
|
||||
|
||||
// Insert at the top of the list, or where app said
|
||||
var entry = this.controller._selectionMgr._getRegisteredRowsEntry(uid);
|
||||
entry.idx = typeof index == "number" ? index : 0;
|
||||
this.controller._insertDataRow(entry,true);
|
||||
var entry = this.nm.controller._selectionMgr._getRegisteredRowsEntry(this.uid);
|
||||
entry.idx = typeof this.index == "number" ? this.index : 0;
|
||||
this.nm.controller._insertDataRow(entry,true);
|
||||
}
|
||||
else
|
||||
else if (this.nm && this.nm.getParent())
|
||||
{
|
||||
debugger;
|
||||
// Server didn't give us our row data
|
||||
// Delete from internal references
|
||||
this.controller.deleteRow(uid);
|
||||
this.controller._grid.setTotalCount(this.controller._grid.getTotalCount()-1);
|
||||
this.nm.controller.deleteRow(this.uid);
|
||||
this.nm.controller._grid.setTotalCount(this.nm.controller._grid.getTotalCount()-1);
|
||||
}
|
||||
this.egw().dataUnregisterUID(uid, callback, this);
|
||||
};
|
||||
this.egw().dataRegisterUID(uid, callback, this, this.getInstanceManager().etemplate_exec_id, this.id);
|
||||
return true;
|
||||
this.nm.egw().dataUnregisterUID(this.uid, this.nm._push_add_callback, this);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -171,7 +171,6 @@ var InfologApp = /** @class */ (function (_super) {
|
||||
*/
|
||||
InfologApp.prototype.push = function (pushData) {
|
||||
var _this = this;
|
||||
var _a;
|
||||
if (pushData.app !== this.appname)
|
||||
return;
|
||||
// pushData does not contain everything, just the minimum.
|
||||
@ -235,14 +234,15 @@ var InfologApp = /** @class */ (function (_super) {
|
||||
}
|
||||
};
|
||||
// check filters against ACL data
|
||||
for (var _i = 0, _b = Object.values(filters); _i < _b.length; _i++) {
|
||||
var field_filter = _b[_i];
|
||||
for (var _i = 0, _a = Object.values(filters); _i < _a.length; _i++) {
|
||||
var field_filter = _a[_i];
|
||||
var state_1 = _loop_1(field_filter);
|
||||
if (typeof state_1 === "object")
|
||||
return state_1.value;
|
||||
}
|
||||
// Pass actual refresh on to just nextmatch
|
||||
(_a = this.et2.getDOMWidgetById('nm')) === null || _a === void 0 ? void 0 : _a.refresh(pushData.id, pushData.type);
|
||||
var nm = this.et2.getDOMWidgetById('nm');
|
||||
nm.refresh(pushData.id, pushData.type);
|
||||
};
|
||||
/**
|
||||
* Retrieve the current state of the application for future restoration
|
||||
|
@ -262,7 +262,8 @@ class InfologApp extends EgwApp
|
||||
}
|
||||
|
||||
// Pass actual refresh on to just nextmatch
|
||||
(<et2_nextmatch>this.et2.getDOMWidgetById('nm'))?.refresh(pushData.id, pushData.type);
|
||||
let nm = <et2_nextmatch>this.et2.getDOMWidgetById('nm');
|
||||
nm.refresh(pushData.id, pushData.type);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user