* [ 1661548 ] WAN: tab loading should be improved
- Improve loading of field meta data for wan profile - Added optional background loading of field meta data ( default to off )
This commit is contained in:
parent
2483cb5a4b
commit
1f6d8cbd0d
|
@ -67,15 +67,7 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
m_mTable.setReadOnly(m_vo.IsReadOnly || m_vo.IsView);
|
||||
m_mTable.setDeleteable(m_vo.IsDeleteable);
|
||||
// Load Tab
|
||||
// if (vo.TabNo == 0)
|
||||
//initTab(false);
|
||||
// else
|
||||
// {
|
||||
// m_loader = new Loader();
|
||||
// m_loader.setPriority(Thread.MIN_PRIORITY);
|
||||
// m_loader.start();
|
||||
// }
|
||||
// waitLoadCompete();
|
||||
} // GridTab
|
||||
|
||||
/** Value Object */
|
||||
|
@ -141,7 +133,7 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
*/
|
||||
public void run()
|
||||
{
|
||||
initTab (true);
|
||||
loadTab();
|
||||
} // run
|
||||
} // Loader
|
||||
|
||||
|
@ -179,10 +171,32 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
* @param async async
|
||||
* @return true, if correctly initialized (ignored)
|
||||
*/
|
||||
protected boolean initTab (boolean async)
|
||||
public boolean initTab (boolean async)
|
||||
{
|
||||
log.fine("#" + m_vo.TabNo + " - Async=" + async + " - Where=" + m_vo.WhereClause);
|
||||
if (isLoadComplete()) return true;
|
||||
|
||||
if (m_loader != null && m_loader.isAlive())
|
||||
{
|
||||
waitLoadCompete();
|
||||
if (isLoadComplete())
|
||||
return true;
|
||||
}
|
||||
|
||||
if (async)
|
||||
{
|
||||
m_loader = new Loader();
|
||||
m_loader.start();
|
||||
return false;
|
||||
}
|
||||
else
|
||||
{
|
||||
return loadTab();
|
||||
}
|
||||
} // initTab
|
||||
|
||||
protected boolean loadTab()
|
||||
{
|
||||
m_extendedWhere = m_vo.WhereClause;
|
||||
|
||||
// Get Field Data
|
||||
|
@ -195,11 +209,9 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
// Order By
|
||||
m_mTable.setOrderClause(getOrderByClause(m_vo.onlyCurrentRows));
|
||||
|
||||
if (async)
|
||||
log.fine("#" + m_vo.TabNo + " - Async=" + async + " - fini");
|
||||
m_loadComplete = true;
|
||||
return true;
|
||||
} // initTab
|
||||
}
|
||||
|
||||
/**
|
||||
* Dispose - clean up resources
|
||||
|
@ -227,6 +239,11 @@ public class GridTab implements DataStatusListener, Evaluatee, Serializable
|
|||
m_vo.getFields().clear();
|
||||
//m_vo.Fields = null;
|
||||
m_vo = null;
|
||||
if (m_loader != null)
|
||||
{
|
||||
if (m_loader.isAlive()) m_loader.interrupt();
|
||||
m_loader = null;
|
||||
}
|
||||
} // dispose
|
||||
|
||||
|
||||
|
|
|
@ -73,6 +73,8 @@ public class GridWindow implements Serializable
|
|||
/** Model last updated */
|
||||
private Timestamp m_modelUpdated = null;
|
||||
|
||||
private Set initTabs = new HashSet<GridTab>();
|
||||
|
||||
/** Logger */
|
||||
private static CLogger log = CLogger.getCLogger(GridWindow.class);
|
||||
|
||||
|
@ -129,7 +131,7 @@ public class GridWindow implements Serializable
|
|||
public void initTab(int index)
|
||||
{
|
||||
GridTab mTab = m_tabs.get(index);
|
||||
if (mTab.isLoadComplete()) return;
|
||||
if (initTabs.contains(mTab)) return;
|
||||
mTab.initTab(false);
|
||||
|
||||
// Set Link Column
|
||||
|
@ -175,6 +177,7 @@ public class GridWindow implements Serializable
|
|||
} // set Link column
|
||||
mTab.setLinkColumnName(null); // overwrites, if AD_Column_ID exists
|
||||
//
|
||||
initTabs.add(mTab);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue