// ============================================================================
//
// Copyright (C) 2006-2016 Talend Inc. - www.talend.com
//
// This source code is available under agreement available at
// %InstallDIR%\features\org.talend.rcp.branding.%PRODUCTNAME%\%PRODUCTNAME%license.txt
//
// You should have received a copy of the agreement
// along with this program; if not, write to Talend SA
// 9 rue Pages 92150 Suresnes, France
//
// ============================================================================
package org.talend.dataprofiler.core.ui.action.actions.predefined;
import java.util.Arrays;
import org.eclipse.jface.action.Action;
import org.eclipse.jface.dialogs.MessageDialogWithToggle;
import org.talend.core.model.metadata.builder.connection.Connection;
import org.talend.cwm.helper.ColumnHelper;
import org.talend.cwm.helper.ConnectionHelper;
import org.talend.cwm.relational.TdColumn;
import org.talend.dataprofiler.core.ImageLib;
import org.talend.dataprofiler.core.i18n.internal.DefaultMessagesImpl;
import org.talend.dq.dbms.DbmsLanguage;
import org.talend.dq.dbms.DbmsLanguageFactory;
import org.talend.dq.helper.SqlExplorerUtils;
import orgomg.cwm.objectmodel.core.ModelElement;
import orgomg.cwm.resource.relational.ColumnSet;
/**
* DOC Zqin class global comment. Detailled comment
*/
public class PreviewColumnAction extends Action {
private ModelElement[] modelElements;
public PreviewColumnAction(ModelElement[] modelElements) {
super(DefaultMessagesImpl.getString("PreviewColumnAction.Preview")); //$NON-NLS-1$
setImageDescriptor(ImageLib.getImageDescriptor(ImageLib.EXPLORE_IMAGE));
this.modelElements = modelElements;
}
@Override
public void run() {
if (modelElements[0] instanceof TdColumn) {
TdColumn[] columns = new TdColumn[modelElements.length];
int i = 0;
for (ModelElement me : modelElements) {
columns[i] = (TdColumn) me;
++i;
}
if (ColumnHelper.isFromSameTable(Arrays.asList(columns))) {
TdColumn oneColumn = columns[0];
Connection dataprovider = ConnectionHelper.getTdDataProvider(oneColumn);
ColumnSet columnSetOwner = ColumnHelper.getColumnOwnerAsColumnSet(oneColumn);
DbmsLanguage language = DbmsLanguageFactory.createDbmsLanguage(dataprovider);
String columnsWithPrefix = language.getQueryColumnsWithPrefix(columns);
String columnSetName = language.getQueryColumnSetWithPrefix(columnSetOwner);
String query = "select " + columnsWithPrefix + " from " + columnSetName; //$NON-NLS-1$ //$NON-NLS-2$
SqlExplorerUtils.getDefault().runInDQViewer(dataprovider, query, columnSetName);
} else {
MessageDialogWithToggle
.openWarning(
null,
DefaultMessagesImpl.getString("PreviewColumnAction.Warning"), DefaultMessagesImpl.getString("PreviewColumnAction.previewColumns")); //$NON-NLS-1$ //$NON-NLS-2$
}
}
}
}