/*!
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html
* or from the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
*
* Copyright (c) 2002-2013 Pentaho Corporation.. All rights reserved.
*/
package org.pentaho.pms.ui.tree;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import org.eclipse.swt.graphics.Image;
import org.pentaho.di.core.database.DatabaseMeta;
import org.pentaho.di.core.dnd.DragAndDropContainer;
import org.pentaho.pms.schema.PhysicalTable;
import org.pentaho.pms.schema.SchemaMeta;
import org.pentaho.pms.ui.jface.tree.ITreeNode;
import org.pentaho.pms.ui.util.GUIResource;
/**
* @author wseyler
*
*/
public class DatabaseMetaTreeNode extends ConceptTreeNode {
protected SchemaMeta schemaMeta = null;
protected DatabaseMeta databaseMeta = null;
/**
* @param connectionsLabel
* @param database
* @param activeLocale
*/
public DatabaseMetaTreeNode(ITreeNode parent, SchemaMeta schemaMeta, DatabaseMeta databaseMeta) {
super(parent);
this.schemaMeta = schemaMeta;
this.databaseMeta = databaseMeta;
}
/* (non-Javadoc)
* @see org.pentaho.pms.ui.tree.ConceptTreeNode#createChildren(java.util.List)
*/
protected void createChildren(List children) {
PhysicalTable[] physicalTables = schemaMeta.getTablesOnDatabase(databaseMeta);
for(int i=0; i<physicalTables.length; i++) {
PhysicalTable physicalTable = physicalTables[i];
addDomainChild(physicalTable);
}
}
public void addDomainChild(Object domainObject){
if (domainObject instanceof PhysicalTable){
addChild(new PhysicalTableTreeNode(this, (PhysicalTable) domainObject, schemaMeta.getActiveLocale()));
}
}
public void removeDomainChild(Object domainObject){
List<ITreeNode> children = new ArrayList<ITreeNode>();
// make copy of list so removals doesn't cause a problem
Iterator<ITreeNode> childIter = fChildren.iterator();
while ( childIter.hasNext() )
children.add(childIter.next());
if (domainObject instanceof PhysicalTable){
for (Iterator iter = children.iterator(); iter.hasNext();) {
PhysicalTableTreeNode element = (PhysicalTableTreeNode) iter.next();
if (element.physicalTable.equals(domainObject))
removeChild(element);
}
}
}
public void sync(){
// TODO: GEM - Because all physical tables are held in a single list in the
// schemaMeta, we can't persist the sort order of physical tables, so sort is not
// in the Connection tree; hence, the logic for preserving indexes is absent from this
// ConceptTreeNode subclass. We should probably fix up the model so that we
// can overcome this limitation in the future.
if (fChildren == null){
getChildren();
}
// make copy of list so removals doesn't cause a problem
Iterator<ITreeNode> childIter = fChildren.iterator();
List<ITreeNode> children = new ArrayList<ITreeNode>();
while ( childIter.hasNext() )
children.add(childIter.next());
PhysicalTable[] physicalTables = schemaMeta.getTablesOnDatabase(databaseMeta);
List tables = Arrays.asList(physicalTables);
for (int c = 0; c < tables.size(); c++) {
boolean found = false;
for (Iterator iter = children.iterator(); iter.hasNext();) {
PhysicalTableTreeNode element = (PhysicalTableTreeNode) iter.next();
if (element.getDomainObject().equals(tables.get(c)))
found = true;
}
if (!found){
addDomainChild(tables.get(c));
}
}
for (int c = 0; c < children.size(); c++) {
ConceptTreeNode node = (ConceptTreeNode)children.get(c);
if (!tables.contains(node.getDomainObject())){
removeChild(node);
}else{
node.sync();
}
}
// update this node
fireTreeNodeUpdated();
}
public DatabaseMeta getDatabaseMeta(){
return databaseMeta;
}
public String getId() {
// DatabaseMeta names are unique, and PME searches them by name
return databaseMeta.getName();
}
public int getDragAndDropType() {
return DragAndDropContainer.TYPE_DATABASE_CONNECTION;
}
/* (non-Javadoc)
* @see org.pentaho.pms.jface.tree.ITreeNode#getName()
*/
public String getName() {
return databaseMeta.getName();
}
public Object getDomainObject(){
return databaseMeta;
}
public Image getImage() {
return GUIResource.getInstance().getImageConnection();
}
}