Minor Update

git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-expression-widget@91447 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Giancarlo Panichi 2014-02-12 12:15:42 +00:00
parent 910dcd7799
commit f8ed6f3a61
21 changed files with 401 additions and 6 deletions

View File

@ -87,6 +87,7 @@ public class ColumnExpressionDialog extends Window {
}
public void setExpression(Expression exp) {
Log.debug("New Expression set:"+exp.toString());
this.exp = exp;
}

View File

@ -373,8 +373,19 @@ public class ConditionWidget extends SimpleContainer {
ComboBox<Operation> comboOp = (ComboBox<Operation>) horiz
.getItemByItemId(itemIdCombo);
Log.debug("combo:" + comboOp.getCurrentValue().toString());
mapOperation
}
return exp;
}
protected Expression mapOperation(Operation op, firstArg, secondArg){
Expression single_exp=null;
if()op.getOperatorType().
}
}

View File

@ -53,19 +53,79 @@ public class OperationsStore {
add(new Operation(15,"NOT_IN","The value is not in",OperatorType.NOT_IN));
}};
static ArrayList<Operation> operationsBoolean = new ArrayList<Operation>() {
private static final long serialVersionUID = -1095217157799110522L;
{
add(new Operation(1,"EQUALS","The value is equal to",OperatorType.EQUALS));
add(new Operation(2,"NOT_EQUALS","The value is not equal to",OperatorType.NOT_EQUALS));
add(new Operation(3,"IS_NULL","The value is null",OperatorType.IS_NULL));
add(new Operation(4,"IS_NOT_NULL","The value is not null",OperatorType.IS_NOT_NULL));
}};
static ArrayList<Operation> operationsDate = new ArrayList<Operation>() {
private static final long serialVersionUID = -1095217157799110522L;
{
add(new Operation(1,"EQUALS","The value is equal to",OperatorType.EQUALS));
add(new Operation(2,"GREATER","The value is greater than",OperatorType.GREATER));
add(new Operation(3,"GREATER_OR_EQUALS","The value is greater than or equal to",OperatorType.GREATER_OR_EQUALS));
add(new Operation(4,"LESSER","The value is less than",OperatorType.LESSER));
add(new Operation(5,"LESSER_OR_EQUALS","The value is less than or equal to",OperatorType.LESSER_OR_EQUALS));
add(new Operation(6,"NOT_EQUALS","The value is not equal to",OperatorType.NOT_EQUALS));
add(new Operation(7,"NOT_GREATER","The value is not greater than",OperatorType.NOT_GREATER));
add(new Operation(8,"NOT_LESSER","The value is not less than",OperatorType.NOT_LESSER));
add(new Operation(9,"IS_NULL","The value is null",OperatorType.IS_NULL));
add(new Operation(10,"IS_NOT_NULL","The value is not null",OperatorType.IS_NOT_NULL));
add(new Operation(11,"BETWEEN","The value is between",OperatorType.BETWEEN));
add(new Operation(12,"NOT_BETWEEN","The value is not between",OperatorType.NOT_BETWEEN));
add(new Operation(13,"IN","The value is in",OperatorType.IN));
add(new Operation(14,"NOT_IN","The value is not in",OperatorType.NOT_IN));
}};
static ArrayList<Operation> operationsGeometry = new ArrayList<Operation>() {
private static final long serialVersionUID = -1095217157799110522L;
{
add(new Operation(1,"EQUALS","The value is equal to",OperatorType.EQUALS));
add(new Operation(2,"GREATER","The value is greater than",OperatorType.GREATER));
add(new Operation(3,"GREATER_OR_EQUALS","The value is greater than or equal to",OperatorType.GREATER_OR_EQUALS));
add(new Operation(4,"LESSER","The value is less than",OperatorType.LESSER));
add(new Operation(5,"LESSER_OR_EQUALS","The value is less than or equal to",OperatorType.LESSER_OR_EQUALS));
add(new Operation(6,"NOT_EQUALS","The value is not equal to",OperatorType.NOT_EQUALS));
add(new Operation(7,"NOT_GREATER","The value is not greater than",OperatorType.NOT_GREATER));
add(new Operation(8,"NOT_LESSER","The value is not less than",OperatorType.NOT_LESSER));
add(new Operation(9,"IS_NULL","The value is null",OperatorType.IS_NULL));
add(new Operation(10,"IS_NOT_NULL","The value is not null",OperatorType.IS_NOT_NULL));
add(new Operation(11,"BETWEEN","The value is between",OperatorType.BETWEEN));
add(new Operation(12,"NOT_BETWEEN","The value is not between",OperatorType.NOT_BETWEEN));
add(new Operation(13,"IN","The value is in",OperatorType.IN));
add(new Operation(14,"NOT_IN","The value is not in",OperatorType.NOT_IN));
}};
public static ArrayList<Operation> getAll(String dataTypeName){
if(dataTypeName.compareTo("Boolean")==0){
operations=operationsNumeric;
operations=operationsBoolean;
} else {
if(dataTypeName.compareTo("Date")==0){
operations=operationsNumeric;
operations=operationsDate;
} else {
if(dataTypeName.compareTo("Integer")==0){
operations=operationsNumeric;
} else {
if(dataTypeName.compareTo("Geometry")==0){
operations=operationsNumeric;
operations=operationsGeometry;
} else {
if(dataTypeName.compareTo("Numeric")==0){
operations=operationsNumeric;
@ -73,7 +133,7 @@ public class OperationsStore {
if(dataTypeName.compareTo("Text")==0){
operations=operationsText;
} else {
operations=operationsText;
operations=new ArrayList<Operation>();
}
}
}

View File

@ -7,6 +7,20 @@ public class Expression implements Serializable{
private static final long serialVersionUID = 7818512507606450235L;
protected String id="Expression";
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
@Override
public String toString() {
return "Expression [id=" + id + "]";
}
}

View File

@ -0,0 +1,105 @@
package org.gcube.portlets.user.td.expressionwidget.shared.model;
import java.util.List;
import net.sf.saxon.functions.Contains;
import org.gcube.portlets.user.td.expressionwidget.shared.model.composite.text.TextBeginsWith;
import org.gcube.portlets.user.td.expressionwidget.shared.model.composite.text.TextContains;
import org.gcube.portlets.user.td.expressionwidget.shared.model.logical.Between;
/**
*
* @author "Giancarlo Panichi"
* <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
public class OperatorTypeMap {
protected Expression exp=null;
OperatorTypeMap(OperatorType operatorType, String firstArg, String secondArg){
switch (operatorType) {
case ADDITION:
break;
case ALL:
break;
case AND:
break;
case ANY:
break;
case BEGINS_WITH:
exp=new TextBeginsWith(firstArg,secondArg);
break;
case BETWEEN:
exp=new Between(arguments.get(0),arguments.get(1));
break;
case CONTAINS:
exp=new TextContains(arguments.get(0),arguments.get(1));
break;
case DIVISION:
break;
case ENDS_WITH:
break;
case EQUALS:
break;
case EXISTS:
break;
case GREATER:
break;
case GREATER_OR_EQUALS:
break;
case IN:
break;
case IS_NOT_NULL:
break;
case IS_NULL:
break;
case LESSER:
break;
case LESSER_OR_EQUALS:
break;
case LIKE:
break;
case MATCH_REGEX:
break;
case MODULUS:
break;
case MULTIPLICATION:
break;
case NOT:
break;
case NOT_BEGINS_WITH:
break;
case NOT_BETWEEN:
break;
case NOT_CONTAINS:
break;
case NOT_ENDS_WITH:
break;
case NOT_EQUALS:
break;
case NOT_GREATER:
break;
case NOT_IN:
break;
case NOT_LESSER:
break;
case NOT_LIKE:
break;
case NOT_MATCH_REGEX:
break;
case OR:
break;
case SELECT_IN:
break;
case SUBTRACTION:
break;
case UNIQUE:
break;
default:
break;
}
}
}

View File

@ -10,6 +10,8 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*
*/
public class Equals extends Expression {
protected String id="Equals";
private static final long serialVersionUID = 3154667914317692836L;
Expression leftArgument;
Expression rightArgument;
@ -27,4 +29,12 @@ public class Equals extends Expression {
return "Boolean";
}
@Override
public String toString() {
return "Equals [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,8 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class GreaterOrEquals extends Expression {
private static final long serialVersionUID = -5441076239992740424L;
protected String id="GreaterOrEquals";
protected Expression leftArgument;
protected Expression rightArgument;
@ -27,4 +29,12 @@ public class GreaterOrEquals extends Expression {
return "Boolean";
}
@Override
public String toString() {
return "GreaterOrEquals [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class GreaterThan extends Expression {
private static final long serialVersionUID = -8878360512708863164L;
protected String id="GreaterThan";
protected Expression leftArgument;
protected Expression rightArgument;
@ -27,4 +28,12 @@ public class GreaterThan extends Expression {
return "Boolean";
}
@Override
public String toString() {
return "GreaterThan [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class LessOrEquals extends Expression {
private static final long serialVersionUID = 7693397481316523615L;
protected String id="LessOrEquals";
Expression leftArgument;
Expression rightArgument;
@ -26,4 +27,13 @@ public class LessOrEquals extends Expression {
public String getReturnedDataType() {
return "Boolean";
}
@Override
public String toString() {
return "LessOrEquals [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -12,6 +12,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class LessThan extends Expression {
private static final long serialVersionUID = 6420164520127827750L;
protected String id="LessThan";
Expression leftArgument;
Expression rightArgument;
@ -27,4 +28,13 @@ public class LessThan extends Expression {
public String getReturnedDataType() {
return "Boolean";
}
@Override
public String toString() {
return "LessThan [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class NotEquals extends Expression {
private static final long serialVersionUID = 7587723477959909679L;
protected String id="NotEquals";
Expression leftArgument;
Expression rightArgument;
@ -26,4 +27,12 @@ public class NotEquals extends Expression {
public String getReturnedDataType() {
return "Boolean";
}
@Override
public String toString() {
return "NotEquals [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class NotGreater extends Expression {
private static final long serialVersionUID = 6783019184437499833L;
protected String id="NotGreater";
Expression leftArgument;
Expression rightArgument;
@ -26,4 +27,13 @@ public class NotGreater extends Expression {
public String getReturnedDataType() {
return "Boolean";
}
@Override
public String toString() {
return "NotGreater [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class NotLess extends Expression {
private static final long serialVersionUID = 4497500830326659077L;
protected String id="NotLess";
Expression leftArgument;
Expression rightArgument;
@ -26,4 +27,13 @@ public class NotLess extends Expression {
public String getReturnedDataType() {
return "Boolean";
}
@Override
public String toString() {
return "NotLess [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class TextBeginsWith extends Expression {
private static final long serialVersionUID = 222662008523199480L;
protected String id="TextBeginsWith";
protected Expression leftArgument;
protected Expression rightArgument;
@ -27,4 +28,12 @@ public class TextBeginsWith extends Expression {
return "Boolean";
}
@Override
public String toString() {
return "TextBeginsWith [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class TextContains extends Expression {
private static final long serialVersionUID = 7951499429397693592L;
protected String id="TextContains";
protected Expression leftArgument;
protected Expression rightArgument;
@ -26,4 +27,13 @@ public class TextContains extends Expression {
public String getReturnedDataType() {
return "Boolean";
}
@Override
public String toString() {
return "TextContains [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class TextEndsWith extends Expression {
private static final long serialVersionUID = -5149428840566398839L;
protected String id="TextEndsWith";
protected Expression leftArgument;
protected Expression rightArgument;
@ -27,4 +28,12 @@ public class TextEndsWith extends Expression {
return "Boolean";
}
@Override
public String toString() {
return "TextEndsWith [id=" + id + ", leftArgument=" + leftArgument
+ ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.OperatorType;
*/
public class TextMatchSQLRegexp extends Expression {
private static final long serialVersionUID = -4097780009381262681L;
protected String id="TextMatchSQLRegexp";
protected Expression leftArgument;
protected Expression rightArgument;
@ -27,5 +28,13 @@ public class TextMatchSQLRegexp extends Expression {
return "Boolean";
}
@Override
public String toString() {
return "TextMatchSQLRegexp [id=" + id + ", leftArgument="
+ leftArgument + ", rightArgument=" + rightArgument + "]";
}
}

View File

@ -0,0 +1,17 @@
package org.gcube.portlets.user.td.expressionwidget.shared.model.leaf;
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnDataType;
public class ColumnReferencePlaceholder extends Leaf {
private static final long serialVersionUID = 275747262118236529L;
protected String id = "ConstantList";
protected String columnId;
protected ColumnDataType dataType;
ColumnReferencePlaceholder(ColumnDataType dataType, String columnId){
this.dataType=dataType;
this.columnId=columnId;
}
}

View File

@ -1,5 +1,22 @@
package org.gcube.portlets.user.td.expressionwidget.shared.model.leaf;
public class ConstantList {
import java.util.List;
public class ConstantList extends Leaf {
private static final long serialVersionUID = 222662008523199480L;
protected String id = "ConstantList";
List<TD_Value> arguments;
public ConstantList(List<TD_Value> arguments) {
this.arguments = arguments;
}
@Override
public String toString() {
return "ConstantList [id=" + id + ", arguments=" + arguments + "]";
}
}

View File

@ -0,0 +1,18 @@
package org.gcube.portlets.user.td.expressionwidget.shared.model.leaf;
import org.gcube.portlets.user.td.expressionwidget.shared.model.Expression;
public class Leaf extends Expression {
private static final long serialVersionUID = -2354159908167637688L;
protected String id="Leaf";
@Override
public String toString() {
return "Leaf [id=" + id + "]";
}
}

View File

@ -0,0 +1,37 @@
package org.gcube.portlets.user.td.expressionwidget.shared.model.leaf;
import java.io.Serializable;
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnDataType;
public class TD_Value implements Serializable {
private static final long serialVersionUID = 2802022467528178596L;
protected String id="TD_Value";
protected String value;
protected ColumnDataType valueType;
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public ColumnDataType getValueType() {
return valueType;
}
public void setValueType(ColumnDataType valueType) {
this.valueType = valueType;
}
@Override
public String toString() {
return "TD_Value [value=" + value + ", valueType=" + valueType + "]";
}
}