crfPortal.html 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <style>
  2. p.hidden{
  3. display:none;
  4. }
  5. table {margin-bottom:20px;table-layout:fixed; border-collapse:collapse; border-spacing:10px}
  6. table.t1 {width:400px; border:1px solid black}
  7. table.t1 th {border:1px solid black;padding:4px;background-color:#e0e0e0}
  8. table.t1 td {text-align:center}
  9. table.t2 {width:800px; border:1px solid black;}
  10. table.t2 th {border:1px solid black;padding:4px;background-color:#e0e0e0}
  11. table.t2 td {border:1px solid black; text-align:center}
  12. table.headTable {width:800px}
  13. table.headTable th {font-size:20px,text-align:center,background-color:#e0e0e0}
  14. table.headTable td {font-size:20px,text-align:center}
  15. div.d1 {text-align:center; width=400px; background-color:#e0e0e0;
  16. font-size: 20px; margin-bottom:20px}
  17. </style>
  18. <div class="d1">Clinical Report Form Portal</div>
  19. <div id="generalDataHead"></div>
  20. <div id="generalDataDiv" style="display:none">
  21. <table id="generalDataTable" cellspacing="2" cellpadding="5" border="0">
  22. <tr><td>Eudra CT Number: </td><td><strong id="eudraCTNumber">Loading</strong></td></tr>
  23. <tr><td>Study Sponsor: </td><td><strong id="studySponsor">Loading</strong></td></tr>
  24. <tr><td>Study Coordinator: </td><td><strong id="studyCoordinator">Loading</strong></td></tr>
  25. <tr><td>Regulatory authority Entry Number:</td><td><strong id="regulatoryNumber">Loading</strong></td></tr>
  26. </table>
  27. </div>
  28. <div id="pickFormHead"></div>
  29. <div id="pickFormDiv" style="display:none">
  30. <div id="formDiv"></div>
  31. <div id="selectFormDiv" style="display:block"></div>
  32. <div id="listDiv"></div>
  33. </div>
  34. <div id="startDiv"></div>
  35. <div id="debugAreaHead"></div>
  36. <div id="debugAreaDiv" style="display:none">
  37. <textarea cols="95" rows="5" name="formStatus" id="formStatus">Entering data</textarea>
  38. </div>
  39. <script type="text/javascript">
  40. document.getElementById("formStatus").value+="\nStarting";
  41. window.onload = init();
  42. // Initialize the form by populating the Reagent drop-down list and
  43. // entering data associated with the current user.
  44. function init() {
  45. generateHead("debugAreaHead","debugAreaDiv","Debug info");
  46. generateHead("generalDataHead","generalDataDiv","General data");
  47. generateHead("pickFormHead","pickFormDiv","Select CRF");
  48. //parameters should include
  49. //divName - place to render select entry table
  50. //masterQuery - the master query that will collect al the data
  51. //masterSelectVarName - variable that is going to fill the content of select.
  52. // Typically, the variable is a lookup in the master query
  53. //masterUserVarName - variable that stores the user id in the master query
  54. // only entries matching current user in the master query will be selected
  55. //authorization - additional data to check:
  56. // * if the current user is authorized to perform action and/or
  57. // * limit number of different queryVariable values user is entitled to use
  58. //authorization should contain:
  59. // * queryName - query of user/queryVariable pairs to check for authorized access
  60. // * authUserVarName - name of the variable in authorization.queryName that contain usesId
  61. // * authSelectVarName - name of the selectVar in authorization query
  62. //callback - function that executes when value of the select changes (onchange).
  63. // argument to callback are the parameters
  64. //selectId - id of the DOM element where select is rendered - to check for value in callback
  65. //dataDiv - div element to render potential output of the callback
  66. //rework to enable addNew
  67. let par=new Object();
  68. par.masterQuery="crfEntry";
  69. par.dataDiv="listDiv";
  70. par.masterUserVarName="UserId";
  71. par.formStatusName="FormStatus";
  72. par.formStatus=1;
  73. par.addDiv="selectFormDiv";
  74. par.source=new Object();
  75. par.source.queryName="StudyProperties";
  76. par.source.schemaName="study";
  77. par.source.vars=["eudraCTNumber","studyCoordinator","regulatoryNumber","studySponsor"];
  78. par.vars=new Object();
  79. //User
  80. let parUser=new Object();
  81. parUser.masterSelectVarName="UserId";
  82. parUser.callback=function(){};
  83. parUser.selectId="UserSelect";
  84. parUser.inputType="select";
  85. //only display users in crfEditors list
  86. parUser.filter=new Object();
  87. parUser.filter.queryName="crfEditors";
  88. parUser.filter.filterVarName="User";
  89. parUser.filter.filters=new Object();
  90. parUser.filter.filters["User"]=LABKEY.Security.currentUser.id;
  91. par.vars["User"]=parUser;
  92. //Crf
  93. let parCrf=new Object();
  94. parCrf.masterSelectVarName="entryId";
  95. parCrf.callback=generateList;
  96. parCrf.selectId="crfSelect";
  97. parCrf.addSelect=true;
  98. parCrf.addNewFlag=-1;
  99. parCrf.inputType="select";
  100. par.vars["Crf"]=parCrf;
  101. //Site
  102. let parSite=new Object();
  103. parSite.masterSelectVarName="Site";
  104. parSite.callback=generateListAndPopulateDaughterSelect;
  105. parSite.selectId="SiteSelect";
  106. parSite.daughterSelect="Crf";
  107. parSite.inputType="select";
  108. //apply additional filter to variable - specify
  109. //- queryName,
  110. //- name of variable in queryName
  111. // - list of filters with name of the variable associated targeted value
  112. parSite.filter=new Object();
  113. parSite.filter.queryName="crfEditors";
  114. parSite.filter.filterVarName="Site";
  115. parSite.filter.filters=new Object();
  116. parSite.filter.filters["User"]=LABKEY.Security.currentUser.id;
  117. par.vars["Site"]=parSite;
  118. //Form
  119. par.vars["Form"]=new Object();
  120. let parForm=par.vars["Form"];
  121. parForm.masterSelectVarName="Form";
  122. parForm.callback=function(){};
  123. parForm.selectId="FormSelect";
  124. parForm.selectAll=true;
  125. parForm.inputType="select";
  126. parForm.urlName="formUrl";
  127. //FormStatus;
  128. par.vars["FormStatus"]=new Object();
  129. let parFormStatus=par.vars["FormStatus"];
  130. parFormStatus.masterSelectVarName="FormStatus";
  131. parFormStatus.callback=generateListAndPopulateDaughterSelect;
  132. parFormStatus.selectId="FormStatusSelect";
  133. parFormStatus.daughterSelect="Crf";
  134. parFormStatus.inputType="select";
  135. parFormStatus.filter=new Object();
  136. parFormStatus.filter.queryName="formStatusVisibility";
  137. parFormStatus.filter.filterVarName="formStatus";
  138. parFormStatus.filter.filters=new Object();
  139. parFormStatus.filter.filters["visibilityLevel"]="crfEditor";
  140. par.vars["eudraCTNumber"]=sourceVar("EudraCTNumber","eudraCTNumber","EudraCTNumber");
  141. par.vars["studyCoordinator"]=sourceVar("StudyCoordinator","studyCoordinator","StudyCoordinator");
  142. par.vars["studySponsor"]=sourceVar("StudySponsor","studySponsor","StudySponsor");
  143. par.vars["regulatoryNumber"]=sourceVar("RegulatoryNumber","regulatoryNumber","RegulatoryNumber");
  144. par.filters=["User","Site","FormStatus"];
  145. //par.filters=["User","Site"];
  146. generateForm(par)
  147. </script>