Project

General

Profile

1 4971 daigle
 /*
2
  *   '$RCSfile$'
3
  *     Purpose: Basic funtions to support searching workflows
4
  *   Copyright: 2009 Regents of the University of California and the
5
  *               National Center for Ecological Analysis and Synthesis
6
  *     Authors: Michael Daigle
7
  *
8
  *    '$Author: leinfelder $'
9
  *      '$Date: 2008-06-17 13:16:32 -0700 (Tue, 17 Jun 2008) $'
10
  *  '$Revision: 4006 $'
11
  *
12
  * This program is free software; you can redistribute it and/or modify
13
  * it under the terms of the GNU General Public License as published by
14
  * the Free Software Foundation; either version 2 of the License, or
15
  * (at your option) any later version.
16
  *
17
  * This program is distributed in the hope that it will be useful,
18
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
19
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20
  * GNU General Public License for more details.
21
  *
22
  * You should have received a copy of the GNU General Public License
23
  * along with this program; if not, write to the Free Software
24
  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
25
  */
26
27 4948 daigle
/*
28
 * Generate a workflow query string.  this assumes that search fields meet the
29
 * following criteria in the web page:
30 4971 daigle
 * -- search input fields have an ID that starts with sf-
31 4948 daigle
 * -- if there is a search mode dropdown for an input field in the form, it's ID
32 4971 daigle
 *    should use the same convention as the input field, but start with sm-
33
 *    (i.e. the search mode input for the sf-firstname input would be sm-firstname)
34 4948 daigle
 */
35
function setWorkflowQueryFormField(formId) {
36
	var queryString = "";
37
	queryString += "<pathquery version='1.2'>";
38
	queryString += "<returndoctype>entity</returndoctype>";
39
	queryString += "<returndoctype>-//UC Berkeley//DTD MoML 1//EN</returndoctype>";
40 4966 daigle
	queryString += "<returnfield>/entity/@name</returnfield>";
41 4976 daigle
	queryString += "<returnfield>/entity/property[@name=\'KeplerDocumentation\']/property[@name=\'author\']/configure</returnfield>";
42
	queryString += "<returnfield>/entity/property[@name=\'KeplerDocumentation\']/property[@name=\'description\']/configure</returnfield>";
43
	queryString += "<returnfield>/entity/property[@name=\'KeplerDocumentation\']/property[@name=\'createDate\']/configure</returnfield>";
44
	queryString += "<returnfield>/entity/property[@name=\'KeplerDocumentation\']/property[@name=\'workflowId\']/configure</returnfield>";
45 4966 daigle
	queryString += "<returnfield>/entity/property[@name=\'karLSID\']/@value</returnfield>";
46
	queryString += "<returnfield>/entity/property[@name=\'entityId\']/@value</returnfield>";
47 4948 daigle
48
	queryString += "<querygroup operator='INTERSECT'>";
49
50
	var elementList = document.getElementById(formId).elements;
51
	for(var i = 0; i < elementList.length; i++) {
52
	//alert("form element: " + elementList[i].id);
53
		if((elementList[i].id.indexOf("sf-") == 0) && (elementList[i].value != '')) {
54
			queryString += getQueryTerm(elementList[i]);
55
		}
56
	}
57
58
	queryString += "</querygroup>";
59
	queryString += "</pathquery>";
60
61
	//alert(queryString);
62
63
	var queryField = document.getElementById("query");
64
65
	queryField.value = queryString;
66
}
67
68 4971 daigle
/*
69
 * Generate individual query terms for all the search input fields in a search
70
 * form.  There must be a case for each search field handle explicitly below.
71
 * This assumes:
72
 * -- search input fields have an ID that starts with sf-
73
 * -- if there is a search mode dropdown for an input field in the form, it's ID
74
 *    should use the same convention as the input field, but start with sm-
75
 *    (i.e. the search mode input for the sf-firstname input would be sm-firstname)
76
 */
77 4948 daigle
function getQueryTerm(sfElement) {
78
	var baseId = sfElement.id.substring(3, sfElement.id.length);
79
	var searchMode = "contains";
80
	var selector = document.getElementById("sm-" + baseId);
81
	if (selector != null) {
82
		searchMode = selector.value;
83
	}
84
85
	var pathExpr = '';
86
	if (sfElement.name == 'name') {
87
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
88
		pathExpr += "<value>" + sfElement.value + "</value>";
89
		pathExpr += "<pathexpr>entity/@name</pathexpr>";
90
		pathExpr += "</queryterm>";
91
	} else if (sfElement.name == 'keyword') {
92
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
93
		pathExpr += "<value>" + sfElement.value + "</value>";
94
		pathExpr += "<pathexpr>property/@value</pathexpr>";
95
		pathExpr += "</queryterm>";
96
	} else if (sfElement.name == 'creator') {
97
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
98
		pathExpr += "<value>" + sfElement.value + "</value>";
99
		pathExpr += "<pathexpr>property/property/configure</pathexpr>";
100
		pathExpr += "</queryterm>";
101
	} else if (sfElement.name == 'description') {
102
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
103
		pathExpr += "<value>" + sfElement.value + "</value>";
104
		pathExpr += "<pathexpr>property/property/configure</pathexpr>";
105
		pathExpr += "</queryterm>";
106
	} else if (sfElement.name == 'date-created') {
107
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
108
		pathExpr += "<value>" + sfElement.value + "</value>";
109
		pathExpr += "<pathexpr>property/property/configure</pathexpr>";
110
		pathExpr += "</queryterm>";
111
	} else if (sfElement.name == 'date-executed') {
112
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
113
		pathExpr += "<value>" + sfElement.value + "</value>";
114
		pathExpr += "<pathexpr>property/property/configure</pathexpr>";
115 4984 daigle
		pathExpr += "</queryterm>";
116 4948 daigle
	} else if (sfElement.name == 'workflow-id') {
117
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
118 4984 daigle
		pathExpr += "<value>entityId</value>";
119
		pathExpr += "<pathexpr>/entity/property/@name</pathexpr>";
120 4966 daigle
		pathExpr += "</queryterm>";
121
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
122
		pathExpr += "<value>" + sfElement.value + "</value>";
123 4984 daigle
		pathExpr += "<pathexpr>/entity/property/@value</pathexpr>";
124 4966 daigle
		pathExpr += "</queryterm>";
125 4948 daigle
	} else if (sfElement.name == 'workflow-run-id') {
126
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
127
		pathExpr += "<value>" + sfElement.value + "</value>";
128
		pathExpr += "<pathexpr>property/property/configure</pathexpr>";
129
		pathExpr += "</queryterm>";
130
	} else if (sfElement.name == 'status') {
131
		pathExpr += "<queryterm casesensitive='false' searchmode='" + searchMode + "'>";
132
		pathExpr += "<value>" + sfElement.value + "</value>";
133
		pathExpr += "<pathexpr>property/property/configure</pathexpr>";
134
		pathExpr += "</queryterm>";
135
	}
136
137
	//alert("returning path expression: " + pathExpr);
138
	return pathExpr;
139
}
140