123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703 |
- function drawForm(par){
-
- populateSourceTable(par);
- let tableId="entryTable";
- generateTable("formDiv",tableId);
- generateRow(tableId, par,"User");
- populateSelectTableEntry(par,"User");
-
- generateRow(tableId, par,"Site");
- generateRow(tableId, par, "FormStatus");
- generateRow(tableId, par,"Crf");
- populateSelectTableEntry(par,"Site");
- populateSelectTableEntry(par,"FormStatus");
- let formTableId="selectFormTable";
- generateTable("selectFormDiv",formTableId);
- generateRow(formTableId,par,"Form");
- generateButtonRow(formTableId,"Add new CRF","Add", par, addNewEntry);
- populateSelectTableEntry(par,"Form");
- generateTable("startDiv","startTable");
- generateButtonRow("startTable","Start filling the selected form","Start", par, startForm);
-
-
- }
- function sourceVar(crfEntryName,elementId,sourceName){
- let f=new Object();
- f.masterSelectVarName=crfEntryName;
- f.selectId=elementId;
- f.inputType="innerHTML";
- f.sourceSelectVarName=sourceName;
- return f;
- }
- function generateHead(headDivName,divName,title){
- document.getElementById("formStatus").value+="\ngenerateHead";
- let tb=document.createElement('table');
- tb.className='t2';
- let row=tb.insertRow();
- let cell=document.createElement('th');
- row.appendChild(cell);
- cell.setAttribute("colspan","4");
- cell.style.fontSize="20px";
- cell.style.textAlign="center";
- let cellData=document.createTextNode(title);
- cell.appendChild(cellData);
- cell=row.insertCell();
- cell.style.fontSize="20px";
- let input=document.createElement("input");
- input.type="button";
- input.value="Show";
- input.id="toggle"+divName+"VisbilityButton";
- input.onclick=function(){toggleVisibility(divName,input.id)};
- cell.appendChild(input);
- document.getElementById(headDivName).appendChild(tb);
- document.getElementById("formStatus").value+="\ngenerateHead: Done";
- }
- function toggleVisibility(divName,buttonName){
- let x = document.getElementById(divName);
- if (x.style.display === "none") {
- x.style.display = "block";
- document.getElementById(buttonName).value="Hide";
- } else {
- x.style.display = "none";
- document.getElementById(buttonName).value="Show";
- }
- }
- function populateSourceTable(par){
- let debug=true;
- if (debug){
- document.getElementById('formStatus').value +=
- "\npopulateSourceTable: Starting";
- }
- let config=new Object();
- if (!("source" in par)) return;
- if (debug){
- print("populateSourceTable ["+par.source.queryName+"]");
- }
- config.schemaName=par.source.schemaName;
- config.queryName=par.source.queryName;
- config.success=function(data){populateSourceTableData(data,par)};
- config.failure=function(errorTxt){print("populateSourceData:fail")};
- LABKEY.Query.selectRows(config);
- }
- function print(msg){
- document.getElementById('formStatus').value +="\n"+msg;
- }
- function populateSourceTableData(data,par){
- let debug=true;
- if (debug){
- document.getElementById('formStatus').value +=
- "\npopulateSourceTableData: nrow: "+data.rows.length;
- }
- let entry=data.rows[0];
- for (let i=0;i < par.source.vars.length;i++){
- let srcVarName=par.source.vars[i];
- if (debug){
- document.getElementById('formStatus').value +=
- "\npopulateSourceTable ["+srcVarName+"]";
- }
- let row=par.vars[srcVarName];
- let el=document.getElementById(row.selectId);
- if (debug){
- document.getElementById('formStatus').value +=
- "\nElement: "+el;
- }
- el.innerHTML=entry[row.sourceSelectVarName];
- }
- }
- function populateSelectNotLookup(data,parameters,rowId, entry){
- //selectId
- //masterSelectVarName
- let debug=true;
- if (debug)
- print("populateSelectNonLookup on "+data.queryName);
-
- let row=parameters.vars[rowId];
- let varName=row.masterSelectVarName;
- if (debug) print("var "+varName+" rows "+data.rows.length);
- if (debug) print("Getting element "+row.selectId);
- let el=document.getElementById(row.selectId);
- if (!el) {
- print("Element not found");
- return;
- }
- if (debug) print("Element "+el);
- if (debug) print("Clearing entries");
- //remove previous options
- for(i = el.options.length; i >= 0; i--) {
- el.remove(i);
- }
-
- if (debug)
- print("Adding entries");
- if ("addSelect" in row){
- if (debug)
- print("adding <Select>");
- let opt = document.createElement("option");
- opt.text = "<Select>";
- opt.value = -2;
- el.options[0] = opt;
- }
- if ("addNewFlag" in row){
- if (debug) print("adding Add new");
- let opt = document.createElement("option");
- opt.text = "Add New";
- opt.value = row.addNewFlag;
- el.options[el.options.length] = opt;
- }
- for (let i=0;i< data.rows.length;i++){
- let valEntry=data.rows[i];
- if (debug)
- print("adding "+valEntry[varName]);
- let opt = document.createElement("option");
- opt.text = valEntry[varName];
- opt.value = valEntry[varName];
- if (entry){
- if (opt.value==entry[varName])
- el.selectedIndex=el.options.length-1;
- }
- el.options[el.options.length] = opt;
- }
- if (entry)
- row.callback(parameters,rowId);
- }
- function populateSelect(data,selectedData, parameters, rowId){
- //data is the set of lookup entries, selectedData is a subset of entries valued at lookup.keyColumn
- let debug=true;
- if (debug)
- print("populateSelect Data: "+data.queryName+" selectedData:"+selectedData.queryName);
- let row=parameters.vars[rowId];
- let selectId=row.selectId;
-
- let varName=row.masterSelectVarName;
- if ("filter" in row){
- varName=row.filter.filterVarName;
- }
- let field=getField(selectedData,varName);
- let displayColumn=field.lookup.displayColumn;
- let keyColumn=field.lookup.keyColumn;
- if (debug){
- document.getElementById('formStatus').value+="\n Query: "+data.queryName;
- document.getElementById('formStatus').value+="\n ElementId: "+selectId;
- document.getElementById('formStatus').value+="\n keyColumn: "+keyColumn;
- document.getElementById('formStatus').value+="\n displayColumn: "+displayColumn;
-
- }
- let el = document.getElementById(selectId);
-
- if (debug)
- document.getElementById('formStatus').value+="\n Element: "+el;
-
- for(i = el.options.length; i >= 0; i--) {
- el.remove(i);
- }
- if ("addSelect" in row){
- let opt = document.createElement("option");
- opt.text = "<Select>";
- opt.value = -1;
- el.options[0] = opt;
- }
- if ("addNewFlag" in row){
- let opt = document.createElement("option");
- opt.text = "Add New"
- opt.value = row.addNewFlag;
- el.options[el.options.length] = opt;
- }
- for (var i = 0; i < data.rows.length; i++) {
- let key=data.rows[i][keyColumn];
- let skip=true;
- if (row.selectAll){
- skip=false;
- }
- else{
- if (debug)
- print("Selecting from: "+selectedData.rows.length);
- for (let j=0; j< selectedData.rows.length; j++){
- let entry=selectedData.rows[j];
- if (debug)
- print("Comparing: "+entry[varName]+"/"+key);
- if (key!=entry[varName]) continue;
- skip=false;
- break;
- }
- }
- if (skip) continue;
- let opt = document.createElement("option");
- opt.text = data.rows[i][displayColumn];
- opt.value = data.rows[i][keyColumn];
- if (debug)
- print("Adding: "+opt.value+" : "+opt.text);
-
- el.options[el.options.length] = opt;
-
- if ("selectedKey" in row){
- if (debug)
- print("Comparing: " + opt.value + "/" + row["selectedKey"]);
-
- if (opt.value==row["selectedKey"]){
- el.selectedIndex=el.options.length-1;
- if (debug)
- print("Equal; "+el.selectedIndex);
- }
- }
- }
- if (debug)
- print("Running callback");
- row.callback(parameters,rowId);
- }
- function saveData(queryName){
- document.getElementById('formStatus').value+="\n saveData: "+queryName;
-
- }
- function populateSelectTableEntry(parameters,rowId){
- //parameters should include
- //tableId - update this table (unused)
- //masterQuery - the master query that will collect al the data
- //masterSelectVarName - variable that is going to fill the content of select.
- // Typically, the variable is a lookup in the master query
- //masterUserVarName - variable that stores the user id in the master query
- // only entries matching current user in the master query will be selected
- //authorization - additional data to check:
- // * if the current user is authorized to perform action and/or
- // * limit number of different queryVariable values user is entitled to use
- //authorization should contain:
- // * queryName - query of user/queryVariable pairs to check for authorized access
- // * authUserVarName - name of the variable in authorization.queryName that contain usesId
- // * authSelectVarName - name of the selectVar in authorization query
- //callback - function that executes when value of the select changes (onchange).
- // argument to callback are the parameters
- //selectId - id of the DOM element where select is rendered - to check for value in callback
- //dataDiv - div element to render potential output of the callback
- let debug=true;
- let row=parameters.vars[rowId];
- if (debug)
- document.getElementById('formStatus').value+="\n populateSelectTableEntry:"
- +parameters.masterQuery+"/"+row.masterSelectVarName;
-
-
- let config=new Object();
- config.schemaName='lists';
- if ("filter" in row){
- //populateSelect on authorizationQuery with authSelectVarName
- let filter=row.filter;
- if (debug){
- print("Filter:"+filter.queryName);
- print("FilterVar "+filter.filterVarName);
- }
- config.queryName=filter.queryName;
- config.filterArray=[];
- for (f in filter.filters){
- if (debug) print("Adding filter: "+f+" val "+filter.filters[f]);
- config.filterArray.push(LABKEY.Filter.create(f,filter.filters[f]));
- }
- }
- else{
- config.queryName=parameters.masterQuery;
- }
-
- config.success=function(data){populateTableRow(data,parameters,rowId)};
- LABKEY.Query.selectRows(config);
- if (debug)
- print("generateSelect: End");
- return;
-
- }
- function getField(data, varName){
- let debug=false;
- if (debug) print("getField");
- let fields=data.metaData.fields;
- for (f in fields){
- if (debug) print("Checking "+f+": name "+fields[f].name+"/"+varName);
- if (fields[f].name!=varName) continue;
- return fields[f];
- }
- return null;
- }
- function getCaption(data, varName){
- let field=getField(data,varName);
- if (field) return field.shortCaption;
- return "NONE";
- }
- function generateTable(divName,elementId){
- let debug=true;
- if (debug)
- document.getElementById('formStatus').value+="\n generateTable";
- let tb=document.createElement('table');
- tb.className="t2";
- tb.id=elementId;
- document.getElementById(divName).appendChild(tb);
- if (debug)
- document.getElementById('formStatus').value+="\n generateTable: Done";
- }
- function generateRow(tableId, parameters,rowId){
- let debug=true;
- if (debug)
- document.getElementById('formStatus').value+="\n generateRow: Start";
- let config=new Object();
- config.schemaName='lists';
- config.queryName=parameters.masterQuery;
- config.success=function(data){generateTableRow(data,tableId, parameters,rowId)};
- LABKEY.Query.selectRows(config);
- if (debug)
- document.getElementById('formStatus').value+="\n generateRow: End";
- return;
- }
- function generateTableRow(data,tableId, parameters,rowId){
- let tb=document.getElementById(tableId);
- let row=parameters.vars[rowId];
- let field=getField(data,row.masterSelectVarName);
- let trow=tb.insertRow();
- let cell=document.createElement('th');
- trow.appendChild(cell);
- let text = document.createTextNode(field.shortCaption);
- cell.appendChild(text);
- cell=trow.insertCell();
- let input = document.createElement("select");
- input.id = row.selectId;
- input.onchange=function(){row.callback(parameters,rowId)};
- cell.appendChild(input);
- }
- function populateTableRow(data,parameters,rowId){
- //data is output of selectRows on either
- // * masterQuery looking at masterSelectVarName or
- // * authQuery looking at authSelectVarName
- //in both cases, query[varName] is a lookup variable, so do populateSelect with lookupData,queryData and parameters
- let debug=true;
- let row=parameters.vars[rowId];
- let varName=row.masterSelectVarName;
- if ("filter" in row){
- if (row.filter.queryName==data.queryName){
- varName=row.filter.filterVarName;
- }
- }
- if (debug)
- print("generateSelectVar: "+data.queryName+"/"+varName+" size "+data.rows.length);
- let field=getField(data,varName);
-
- if (!field) {
- print("Field "+varName+" not found");
- return;
- }
- if (!("lookup" in field)){
- let entry=data.rows[0];
- print("Field "+varName+" not a lookup");
- populateSelectNotLookup(data,parameters,rowId, entry);
- return;
- }
-
- let config=new Object();
- config.schemaName=field.lookup.schemaName;
- config.queryName=field.lookup.queryName;
- config.success=function(lookupData){populateSelect(lookupData,data,parameters,rowId)};
- LABKEY.Query.selectRows(config);
-
- if (debug)
- print("generateSelectVar: End");
-
- }
- function generateButtonRow(tableId,caption,label,parameters,callback){
- let tb=document.getElementById(tableId);
- let trow=tb.insertRow();
- let cell=document.createElement('th');
- trow.appendChild(cell);
- let text = document.createTextNode(caption);
- cell.appendChild(text);
- cell=trow.insertCell();
- let input = document.createElement("input");
- input.type="button";
- input.value=label;
- input.onclick=function(){callback(parameters)};
- cell.appendChild(input);
- }
- function generateListAndPopulateDaughterSelect(parameters,rowId){
- let debug=true;
- if (debug){
- print("generateListAndPopulateDaughter");
-
- }
-
- generateList(parameters,rowId);
- let row=parameters.vars[rowId];
- if ("daughterSelect" in row){
- populateDaughterSelect(parameters,rowId,row["daughterSelect"],null);
- }
- }
- function populateDaughterSelect(parameters,rowId,daughterRowId,entry){
- let debug=true;
- if (debug)
- print("populateDaughterSelect: "+rowId+" "+daughterRowId);
- let row=parameters.vars[rowId];
- if (debug)
- print("row["+rowId+"]:"+row);
- let daughterRow=parameters.vars[daughterRowId];
- if (debug)
- print("daughterRow["+daughterRowId+"]:"+daughterRow);
- let el=document.getElementById(row.selectId);
- if (debug)
- print("\n Element:"+el);
- let varValue=el.options[el.selectedIndex].value;
- if (debug)
- print("\nAdding filter ["+row.masterSelectVarName+"]:"+varValue);
- let config=new Object();
- config.schemaName='lists';
- config.queryName=parameters.masterQuery;
- config.filterArray=[];
- for (let i=0;i < parameters.filters.length;i++){
- let filterRowId=parameters.filters[i];
- let filterRow=parameters.vars[filterRowId];
- let filterValue=document.getElementById(filterRow.selectId).value;
- config.filterArray.push(LABKEY.Filter.create(filterRow.masterSelectVarName,filterValue));
- }
- config.success=function(data){populateSelectNotLookup(data,parameters,daughterRowId,entry)};
- LABKEY.Query.selectRows(config);
- }
- function generateList(parameters,rowId){
- let row=parameters.vars[rowId];
- let debug=true;
- if (debug)
- print("generateList: "+parameters.masterQuery);
-
- //ignore authorization, just select on select variable
- let el=document.getElementById(row.selectId);
- let varValue=el.options[el.selectedIndex].value;
- if (debug)
- print("Using value "+varValue+" from "+row.selectId);
-
- let iValue=parseInt(varValue);
- let div=document.getElementById(parameters.addDiv);
- div.style.display="none";
- //add new crf entry
- if ("addNewFlag" in row){
- if (debug)
- print("Comparing " + iValue + "/" + row.addNewFlag);
- if (iValue==row.addNewFlag) {
- addNew(parameters);
- return;
- }
- }
-
- //do filtering
- let filterArray=[];
- for (let i=0;i < parameters.filters.length;i++){
- let filterRowId=parameters.filters[i];
- let filterRow=parameters.vars[filterRowId];
- let filterValue=document.getElementById(filterRow.selectId).value;
- filterArray.push(LABKEY.Filter.create(filterRow.masterSelectVarName,filterValue));
- }
-
- //show all for system entries (Select, Add New)
- if (debug)
- print("Using iValue "+iValue);
- if (iValue<0) {
- if (debug)
- print("Ignoring ["+row.masterSelectVarName+ "]: "+varValue);
- }
- else{
- if (debug)
- print("Filtering ["+row.masterSelectVarName+"]: "+varValue);
- if (rowId==="Crf"){
- filterArray.push(LABKEY.Filter.create(row.masterSelectVarName,varValue));
- if (debug)
- print("Filtering ["+row.masterSelectVarName+"]: "+varValue);
- }
-
- }
- LABKEY.QueryWebPart({renderTo: parameters.dataDiv, schemaName: 'lists',
- queryName: parameters.masterQuery,
- buttonBarPosition: 'top',filters: filterArray, viewName:"sparseView",
- success:updateSuccess, failure:updateFailure });
-
- }
- function updateSuccess(){
- document.getElementById('formStatus').value+="\n Update success";
- }
- function updateFailure(json){
- document.getElementById('formStatus').value+="\n Update failed";
- }
- function addNewEntry(parameters){
- print("Add new, npar ");
- let entry=new Object();
- for (vv in parameters.vars){
- let f=parameters.vars[vv];
- print("New: Adding "+f.masterSelectVarName);
- setValue(entry,f);
- }
- for (f in entry){
- print("entry ["+f+"]="+entry[f]);
- }
- entry.entryId=Date.now();
- entry.Date=new Date();
- entry.formStatus=1;//In Progress
- let config=new Object();
- config.schemaName='lists';
- config.queryName=parameters.masterQuery;
- config.rows=[entry];
- config.success=function(data){
- populateDaughterSelect(parameters,"Site","Crf",data.rows[0]);
- selectEntry(data,parameters.vars["Crf"]);
- generateList(parameters,"Crf");};
- LABKEY.Query.insertRows(config);
- }
- function selectEntry(data,row){
- let entry=data.rows[0];
- let varName=row.masterSelectVarName;
- let el=document.getElementById(row.selectId);
- for (let i=0;i< el.options.length;i++){
- print("selectEntry: "+el.options[i].value+"/"+entry[varName]);
- if (el.options[i].value!=entry[varName]) continue;
- el.selectedIndex=i;
- return;
- }
- }
- function setValue(entry,f){
- let el=document.getElementById(f.selectId);
- print("setValue: Element: "+el);
- if (f.inputType=="select"){
- entry[f.masterSelectVarName]=el.value;
- }
- if (f.inputType=="innerHTML"){
- entry[f.masterSelectVarName]=el.innerHTML;
- }
- }
- function addNew(parameters){
- print("Show Add new");
- let div=document.getElementById(parameters.addDiv);
- div.style.display="block";
- }
- function startForm(parameters){
- let crfVar=parameters.vars["Crf"];
- let el=document.getElementById(crfVar.selectId);
- let config=new Object();
- config.schemaName='lists';
- config.queryName=parameters.masterQuery;
- config.filterArray=[LABKEY.Filter.create(crfVar.masterSelectVarName,el.value)]
- config.success=function(data){findURL(data,parameters)};
- LABKEY.Query.selectRows(config);
- // The set of URL parameters.
- }
- function findURL(data,parameters){
- let entry=data.rows[0];
-
- let fields=data.metaData.fields;
- let formVar=parameters.vars["Form"];
- let formVarName=formVar.masterSelectVarName;
- let lookup;
- for (f in fields){
- if (fields[f].name!=formVarName) continue;
- lookup=fields[f].lookup;
- break;
- }
- let config=new Object();
- config.schemaName=lookup.schemaName;
- config.queryName=lookup.queryName;
- config.filterArray=[LABKEY.Filter.create(lookup.keyColumn,entry[formVarName])];
- config.success=function(data){finalRedirect(data,entry,parameters)};
- LABKEY.Query.selectRows(config);
- }
- function finalRedirect(data,entry,parameters){
- let formEntry=data.rows[0];
- let formVar=parameters.vars["Form"];
- let formUrl=formEntry[formVar.urlName];
- var params = {
- "name": formUrl, // The destination wiki page. The name of this parameter is not arbitrary.
- "userid": entry[parameters.vars["User"].masterSelectVarName],
- "entryId": entry[parameters.vars["Crf"].masterSelectVarName]
- };
- // This changes the page after building the URL.
- //Note that the wiki page destination name is set in params.
- var wikiURL = LABKEY.ActionURL.buildURL("wiki", "page", LABKEY.ActionURL.getContainer(), params);
- print("Redirecting to "+wikiURL);
-
- window.location = wikiURL;
- }
- </script>
|