crfPortal.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568
  1. function print(config,msg){
  2. config.document.getElementById(config.debugId).value+="\n"+msg;
  3. }
  4. function drawForm(par){
  5. populateSourceTable(par); //populateSourceTableData
  6. let tableId="entryTable";
  7. generateTable(par,"formDiv",tableId);
  8. generateRow(par,tableId,"User");//generateTableRow
  9. populateSelectTableEntry(par,"User");//populateTableRow , populateSelect
  10. generateRow(par, tableId,"Site");
  11. generateRow(par, tableId, "FormStatus");
  12. generateRow(par, tableId,"Crf");
  13. populateSelectTableEntry(par,"Site");
  14. populateSelectTableEntry(par,"FormStatus");
  15. let formTableId="selectFormTable";
  16. generateTable(par,"selectFormDiv",formTableId);
  17. generateRow(par,formTableId,par,"Form");
  18. }
  19. function generateQConfig(listName){
  20. let qConfig=new Object();
  21. qConfig.containerPath="TECANT/Data";
  22. qConfig.schemaName="lists";
  23. qConfig.queryName=listName;
  24. return qConfig;
  25. }
  26. function sourceVar(crfEntryName,elementId,sourceName){
  27. let f=new Object();
  28. f.masterSelectVarName=crfEntryName;
  29. f.selectId=elementId;
  30. f.inputType="innerHTML";
  31. f.sourceSelectVarName=sourceName;
  32. return f;
  33. }
  34. function getField(config, data, varName){
  35. let debug=false;
  36. if (debug) print(config, "getField");
  37. let fields=data.metaData.fields;
  38. for (f in fields){
  39. if (debug) print(config,"Checking "+f+": name "+fields[f].name+"/"+varName);
  40. if (fields[f].name!=varName) continue;
  41. return fields[f];
  42. }
  43. return null;
  44. }
  45. function generateHead(config, headDivName,divName,title){
  46. print(config,"generateHead");
  47. let tb=config.document.createElement('table');
  48. tb.className='t2';
  49. let row=tb.insertRow();
  50. let cell=config.document.createElement('th');
  51. row.appendChild(cell);
  52. cell.setAttribute("colspan","4");
  53. cell.style.fontSize="20px";
  54. cell.style.textAlign="center";
  55. let cellData=config.document.createTextNode(title);
  56. cell.appendChild(cellData);
  57. cell=row.insertCell();
  58. cell.style.fontSize="20px";
  59. let input=config.document.createElement("input");
  60. input.type="button";
  61. input.value="Show";
  62. input.id="toggle"+divName+"VisbilityButton";
  63. input.onclick=function(){toggleVisibility(config,divName,input.id)};
  64. cell.appendChild(input);
  65. config.document.getElementById(headDivName).appendChild(tb);
  66. print(config,"generateHead: Done");
  67. }
  68. function toggleVisibility(config,divName,buttonName){
  69. let x = config.document.getElementById(divName);
  70. if (x.style.display === "none") {
  71. x.style.display = "block";
  72. config.document.getElementById(buttonName).value="Hide";
  73. } else {
  74. x.style.display = "none";
  75. config.document.getElementById(buttonName).value="Show";
  76. }
  77. }
  78. function selectRowsSuccess(config,data){
  79. print(config,"Select rows on "+data.queryName+" got "+data.rows.length+" rows.");
  80. }
  81. function selectRowsFailure(config,errorObj){
  82. print(config,"selectRowsFail: "+errorObj.exception)
  83. }
  84. function populateSourceTable(par){
  85. let debug=true;
  86. if (debug){
  87. print(par.config,"populateSourceTable: Starting");
  88. }
  89. let config=generateQConfig(par.source.queryName);
  90. config.schemaName=par.source.schemaName;
  91. if (!("source" in par)) return;
  92. if (debug){
  93. print(par.config,"populateSourceTable ["+par.source.queryName+"]");
  94. }
  95. config.success=function(data){populateSourceTableData(data,par)};
  96. //config.success=function(data){selectRowsSuccess(par.config,data)};
  97. config.failure=function(errorObj){selectRowsFailure(par.config,errorObj)};
  98. LABKEY.Query.selectRows(config);
  99. }
  100. function populateSourceTableData(data,par){
  101. let debug=true;
  102. if (debug){
  103. print(par.config, "populateSourceTableData: nrow: "+data.rows.length);
  104. }
  105. let entry=data.rows[0];
  106. for (let i=0;i < par.source.vars.length;i++){
  107. let srcVarName=par.source.vars[i];
  108. if (debug){
  109. print(par.config, "populateSourceTable ["+srcVarName+"]");
  110. }
  111. let row=par.vars[srcVarName];
  112. let el=par.config.document.getElementById(row.selectId);
  113. if (debug){
  114. print(par.config, "Element: "+el);
  115. }
  116. el.innerHTML=entry[row.sourceSelectVarName];
  117. }
  118. }
  119. function generateTable(par,divName,elementId){
  120. let debug=true;
  121. if (debug)
  122. print(par.config,"generateTable");
  123. let tb=par.config.document.createElement('table');
  124. tb.className="t2";
  125. tb.id=elementId;
  126. par.config.document.getElementById(divName).appendChild(tb);
  127. if (debug)
  128. print(par.config,"generateTable: Done");
  129. }
  130. function generateRow(par, tableId, rowId){
  131. let debug=true;
  132. if (debug)
  133. print(par.config,"generateRow: Start");
  134. let config=generateQConfig(par.masterQuery);
  135. config.success=function(data){generateTableRow(data, par, tableId, rowId)};
  136. LABKEY.Query.selectRows(config);
  137. if (debug)
  138. print(par.config,"generateRow: End");
  139. return;
  140. }
  141. function generateTableRow(data, par, tableId, rowId){
  142. let debug=true;
  143. if (debug)
  144. print(par.config,"generateTableRow: start");
  145. let tb=par.config.document.getElementById(tableId);
  146. let row=par.vars[rowId];
  147. if (debug)
  148. print(par.config,"getField for "+row.masterSelectVarName);
  149. let field=getField(par.config,data,row.masterSelectVarName);
  150. let trow=tb.insertRow();
  151. let cell=par.config.document.createElement('th');
  152. trow.appendChild(cell);
  153. let text = par.config.document.createTextNode(field.shortCaption);
  154. cell.appendChild(text);
  155. cell=trow.insertCell();
  156. let input = par.config.document.createElement("select");
  157. input.id = row.selectId;
  158. input.onchange=function(){row.callback(par,rowId)};
  159. cell.appendChild(input);
  160. if (debug)
  161. print(par.config,"generateTableRow: end");
  162. }
  163. function populateSelectTableEntry(par,rowId){
  164. let debug=true;
  165. let row=par.vars[rowId];
  166. if (debug)
  167. print(par.config,"populateSelectTableEntry:"+par.masterQuery+"/"+row.masterSelectVarName);
  168. let config=generateQConfig(par.masterQuery);
  169. if ("filter" in row){
  170. //populateSelect on authorizationQuery with authSelectVarName
  171. let filter=row.filter;
  172. if (debug){
  173. print(par.config,"Filter:"+filter.queryName);
  174. print(par.config,"FilterVar "+filter.filterVarName);
  175. }
  176. config.queryName=filter.queryName;
  177. config.filterArray=[];
  178. for (f in filter.filters){
  179. if (debug) print(par.config,"Adding filter: "+f+" val "+filter.filters[f]);
  180. config.filterArray.push(LABKEY.Filter.create(f,filter.filters[f]));
  181. }
  182. }
  183. else{
  184. config.queryName=par.masterQuery;
  185. }
  186. config.success=function(data){populateTableRow(data,par,rowId)};
  187. LABKEY.Query.selectRows(config);
  188. if (debug)
  189. print(par.config,"generateSelect: End");
  190. return;
  191. }
  192. function populateTableRow(data,par,rowId){
  193. //data is output of selectRows on either
  194. // * masterQuery looking at masterSelectVarName or
  195. // * authQuery looking at authSelectVarName
  196. //in both cases, query[varName] is a lookup variable, so do populateSelect with lookupData,queryData and par
  197. let debug=true;
  198. let row=par.vars[rowId];
  199. let varName=row.masterSelectVarName;
  200. if ("filter" in row){
  201. if (row.filter.queryName==data.queryName){
  202. varName=row.filter.filterVarName;
  203. }
  204. }
  205. if (debug)
  206. print(par.config,"generateSelectVar: "+data.queryName+"/"+varName+" size "+data.rows.length);
  207. let field=getField(par.config,data,varName);
  208. if (!field) {
  209. print(par.config,"Field "+varName+" not found");
  210. return;
  211. }
  212. if (debug)
  213. print(par.config,"Using field "+field.name);
  214. if (!("lookup" in field)){
  215. let entry=data.rows[0];
  216. print(par.config,"Field "+varName+" not a lookup");
  217. //populateSelectNotLookup(data,par,rowId, entry);
  218. return;
  219. }
  220. let config=generateQConfig(field.lookup.queryName);
  221. config.schemaName=field.lookup.schemaName;
  222. config.success=function(lookupData){populateSelect(lookupData,data,par,rowId)};
  223. //config.success=function(data){selectRowsSuccess(par.config,data)};
  224. config.failure=function(errorObj){selectRowsFailure(par.config,errorObj)};
  225. LABKEY.Query.selectRows(config);
  226. if (debug)
  227. print(par.config,"generateSelectVar: End");
  228. }
  229. function populateSelect(data,selectedData, par, rowId){
  230. //data is the set of lookup entries, selectedData is a subset of entries valued at lookup.keyColumn
  231. let debug=true;
  232. if (debug)
  233. print(par.config,"populateSelect Data: "+data.queryName+" selectedData:"+selectedData.queryName);
  234. let row=par.vars[rowId];
  235. let selectId=row.selectId;
  236. let varName=row.masterSelectVarName;
  237. if ("filter" in row){
  238. varName=row.filter.filterVarName;
  239. }
  240. let field=getField(par.config,selectedData,varName);
  241. let displayColumn=field.lookup.displayColumn;
  242. let keyColumn=field.lookup.keyColumn;
  243. if (debug){
  244. print(par.config,"Query: "+data.queryName);
  245. print(par.config,"ElementId: "+selectId);
  246. print(par.config,"keyColumn: "+keyColumn);
  247. print(par.config,"displayColumn: "+displayColumn);
  248. }
  249. let el = document.getElementById(selectId);
  250. if (debug)
  251. print(par.config,"Element: "+el);
  252. for(i = el.options.length; i >= 0; i--) {
  253. el.remove(i);
  254. }
  255. if ("addSelect" in row){
  256. let opt = par.config.document.createElement("option");
  257. opt.text = "<Select>";
  258. opt.value = -1;
  259. el.options[0] = opt;
  260. }
  261. if ("addNewFlag" in row){
  262. let opt = par.config.document.createElement("option");
  263. opt.text = "Add New"
  264. opt.value = row.addNewFlag;
  265. el.options[el.options.length] = opt;
  266. }
  267. for (var i = 0; i < data.rows.length; i++) {
  268. let key=data.rows[i][keyColumn];
  269. let skip=true;
  270. if (row.selectAll){
  271. skip=false;
  272. }
  273. else{
  274. if (debug)
  275. print(par.config,"Selecting from: "+selectedData.rows.length);
  276. for (let j=0; j< selectedData.rows.length; j++){
  277. let entry=selectedData.rows[j];
  278. if (debug)
  279. print(par.config,"Comparing: "+entry[varName]+"/"+key);
  280. if (key!=entry[varName]) continue;
  281. skip=false;
  282. break;
  283. }
  284. }
  285. if (skip) continue;
  286. let opt = par.config.document.createElement("option");
  287. opt.text = data.rows[i][displayColumn];
  288. opt.value = data.rows[i][keyColumn];
  289. if (debug)
  290. print(par.config,"Adding: "+opt.value+" : "+opt.text);
  291. el.options[el.options.length] = opt;
  292. if ("selectedKey" in row){
  293. if (debug)
  294. print(par.config,"Comparing: " + opt.value + "/" + row["selectedKey"]);
  295. if (opt.value==row["selectedKey"]){
  296. el.selectedIndex=el.options.length-1;
  297. if (debug)
  298. print(par.config,"Equal; "+el.selectedIndex);
  299. }
  300. }
  301. }
  302. if (debug)
  303. print(par.config,"Running callback");
  304. row.callback(par,rowId);
  305. }
  306. function generateListAndPopulateDaughterSelect(par,rowId){
  307. let debug=true;
  308. if (debug){
  309. print(par.config,"generateListAndPopulateDaughter");
  310. }
  311. generateList(par,rowId);
  312. let row=par.vars[rowId];
  313. if ("daughterSelect" in row){
  314. populateDaughterSelect(par,rowId,row["daughterSelect"],null);
  315. }
  316. }
  317. function populateDaughterSelect(par,rowId,daughterRowId,entry){//populateSelectNotLookup
  318. let debug=true;
  319. if (debug)
  320. print(par.config,"populateDaughterSelect: "+rowId+" "+daughterRowId);
  321. let row=par.vars[rowId];
  322. if (debug)
  323. print(par.config,"row["+rowId+"]:"+row);
  324. let daughterRow=par.vars[daughterRowId];
  325. if (debug)
  326. print(par.config,"daughterRow["+daughterRowId+"]:"+daughterRow);
  327. let el=par.config.document.getElementById(row.selectId);
  328. if (debug)
  329. print(par.config,"\n Element:"+el);
  330. let varValue=el.options[el.selectedIndex].value;
  331. if (debug)
  332. print(par.config,"\nAdding filter ["+row.masterSelectVarName+"]:"+varValue);
  333. let config=generateQConfig(par.masterQuery)
  334. config.filterArray=[];
  335. for (let i=0;i < par.filters.length;i++){
  336. let filterRowId=par.filters[i];
  337. let filterRow=par.vars[filterRowId];
  338. let filterValue=par.config.document.getElementById(filterRow.selectId).value;
  339. config.filterArray.push(LABKEY.Filter.create(filterRow.masterSelectVarName,filterValue));
  340. }
  341. config.success=function(data){populateSelectNotLookup(data,par,daughterRowId,entry)};
  342. LABKEY.Query.selectRows(config);
  343. }
  344. function populateSelectNotLookup(data,par,rowId, entry){
  345. //selectId
  346. //masterSelectVarName
  347. let debug=true;
  348. if (debug)
  349. print(par.config,"populateSelectNonLookup on "+data.queryName);
  350. let row=par.vars[rowId];
  351. let varName=row.masterSelectVarName;
  352. if (debug) print(par.config,"var "+varName+" rows "+data.rows.length);
  353. if (debug) print(par.config,"Getting element "+row.selectId);
  354. let el=par.config.document.getElementById(row.selectId);
  355. if (!el) {
  356. print(par.config,"Element not found");
  357. return;
  358. }
  359. if (debug) print(par.config,"Element "+el);
  360. if (debug) print(par.config,"Clearing entries");
  361. //remove previous options
  362. for(i = el.options.length; i >= 0; i--) {
  363. el.remove(i);
  364. }
  365. if (debug)
  366. print(par.config,"Adding entries");
  367. if ("addSelect" in row){
  368. if (debug)
  369. print(par.config,"adding <Select>");
  370. let opt = par.config.document.createElement("option");
  371. opt.text = "<Select>";
  372. opt.value = -2;
  373. el.options[0] = opt;
  374. }
  375. if ("addNewFlag" in row){
  376. if (debug) print(par.config,"adding Add new");
  377. let opt = par.config.document.createElement("option");
  378. opt.text = "Add New";
  379. opt.value = row.addNewFlag;
  380. el.options[el.options.length] = opt;
  381. }
  382. for (let i=0;i< data.rows.length;i++){
  383. let valEntry=data.rows[i];
  384. if (debug)
  385. print(par.config,"adding "+valEntry[varName]);
  386. let opt = par.config.document.createElement("option");
  387. opt.text = valEntry[varName];
  388. opt.value = valEntry[varName];
  389. if (entry){
  390. if (opt.value==entry[varName])
  391. el.selectedIndex=el.options.length-1;
  392. }
  393. el.options[el.options.length] = opt;
  394. }
  395. if (entry)
  396. row.callback(par,rowId);
  397. }
  398. function generateList(par,rowId){
  399. let row=par.vars[rowId];
  400. let debug=true;
  401. if (debug)
  402. print(par.config,"generateList: "+par.masterQuery);
  403. //ignore authorization, just select on select variable
  404. let el=par.config.document.getElementById(row.selectId);
  405. let varValue=el.options[el.selectedIndex].value;
  406. if (debug)
  407. print(par.config,"Using value "+varValue+" from "+row.selectId);
  408. let iValue=parseInt(varValue);
  409. let div=par.config.document.getElementById(par.addDiv);
  410. div.style.display="none";
  411. //add new crf entry
  412. if ("addNewFlag" in row){
  413. if (debug)
  414. print(par.config,"Comparing " + iValue + "/" + row.addNewFlag);
  415. if (iValue==row.addNewFlag) {
  416. addNew(par);
  417. return;
  418. }
  419. }
  420. //do filtering
  421. let filterArray=[];
  422. for (let i=0;i < par.filters.length;i++){
  423. let filterRowId=par.filters[i];
  424. let filterRow=par.vars[filterRowId];
  425. let filterValue=par.config.document.getElementById(filterRow.selectId).value;
  426. filterArray.push(LABKEY.Filter.create(filterRow.masterSelectVarName,filterValue));
  427. }
  428. //show all for system entries (Select, Add New)
  429. if (debug)
  430. print(par.config,"Using iValue "+iValue);
  431. if (iValue<0) {
  432. if (debug)
  433. print(par.config,"Ignoring ["+row.masterSelectVarName+ "]: "+varValue);
  434. }
  435. else{
  436. if (debug)
  437. print(par.config,"Filtering ["+row.masterSelectVarName+"]: "+varValue);
  438. if (rowId==="Crf"){
  439. filterArray.push(LABKEY.Filter.create(row.masterSelectVarName,varValue));
  440. if (debug)
  441. print(par.config,"Filtering ["+row.masterSelectVarName+"]: "+varValue);
  442. }
  443. }
  444. var config=generateQConfig(par.masterQuery);
  445. config.renderTo=par.dataDiv;
  446. config.buttonBarPosition='top';
  447. config.filters=filterArray;
  448. config.viewName="sparseView";
  449. config.success=function(data){updateSuccess(data,par)};
  450. config.failure=function(json){updateFailure(json,par)};
  451. LABKEY.QueryWebPart(config);
  452. }
  453. function updateSuccess(data,par){
  454. print(par.config,"Update success");
  455. }
  456. function updateFailure(json,par){
  457. print(par.config,"Update failed");
  458. }