crfPortal.html 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  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. var config=new Object();
  46. config.document=document;
  47. config.debugId='formStatus';
  48. generateHead(config,"debugAreaHead","debugAreaDiv","Debug info");
  49. generateHead(config,"generalDataHead","generalDataDiv","General data");
  50. generateHead(config,"pickFormHead","pickFormDiv","Select CRF");
  51. return;
  52. //parameters should include
  53. //divName - place to render select entry table
  54. //masterQuery - the master query that will collect al the data
  55. //masterSelectVarName - variable that is going to fill the content of select.
  56. // Typically, the variable is a lookup in the master query
  57. //masterUserVarName - variable that stores the user id in the master query
  58. // only entries matching current user in the master query will be selected
  59. //authorization - additional data to check:
  60. // * if the current user is authorized to perform action and/or
  61. // * limit number of different queryVariable values user is entitled to use
  62. //authorization should contain:
  63. // * queryName - query of user/queryVariable pairs to check for authorized access
  64. // * authUserVarName - name of the variable in authorization.queryName that contain usesId
  65. // * authSelectVarName - name of the selectVar in authorization query
  66. //callback - function that executes when value of the select changes (onchange).
  67. // argument to callback are the parameters
  68. //selectId - id of the DOM element where select is rendered - to check for value in callback
  69. //dataDiv - div element to render potential output of the callback
  70. //rework to enable addNew
  71. let par=new Object();
  72. par.masterQuery="crfEntry";
  73. par.dataDiv="listDiv";
  74. par.masterUserVarName="UserId";
  75. par.formStatusName="FormStatus";
  76. par.formStatus=1;
  77. par.addDiv="selectFormDiv";
  78. par.config=config;
  79. par.source=new Object();
  80. par.source.queryName="StudyProperties";
  81. par.source.schemaName="study";
  82. par.source.vars=["eudraCTNumber","studyCoordinator","regulatoryNumber","studySponsor"];
  83. par.vars=new Object();
  84. //User
  85. let parUser=new Object();
  86. parUser.masterSelectVarName="UserId";
  87. parUser.callback=function(){};
  88. parUser.selectId="UserSelect";
  89. parUser.inputType="select";
  90. //only display users in crfEditors list
  91. parUser.filter=new Object();
  92. parUser.filter.queryName="crfEditors";
  93. parUser.filter.filterVarName="User";
  94. parUser.filter.filters=new Object();
  95. parUser.filter.filters["User"]=LABKEY.Security.currentUser.id;
  96. par.vars["User"]=parUser;
  97. //Crf
  98. let parCrf=new Object();
  99. parCrf.masterSelectVarName="entryId";
  100. parCrf.callback=generateList;
  101. parCrf.selectId="crfSelect";
  102. parCrf.addSelect=true;
  103. parCrf.addNewFlag=-1;
  104. parCrf.inputType="select";
  105. par.vars["Crf"]=parCrf;
  106. //Site
  107. let parSite=new Object();
  108. parSite.masterSelectVarName="Site";
  109. parSite.callback=generateListAndPopulateDaughterSelect;
  110. parSite.selectId="SiteSelect";
  111. parSite.daughterSelect="Crf";
  112. parSite.inputType="select";
  113. //apply additional filter to variable - specify
  114. //- queryName,
  115. //- name of variable in queryName
  116. // - list of filters with name of the variable associated targeted value
  117. parSite.filter=new Object();
  118. parSite.filter.queryName="crfEditors";
  119. parSite.filter.filterVarName="Site";
  120. parSite.filter.filters=new Object();
  121. parSite.filter.filters["User"]=LABKEY.Security.currentUser.id;
  122. par.vars["Site"]=parSite;
  123. //Form
  124. par.vars["Form"]=new Object();
  125. let parForm=par.vars["Form"];
  126. parForm.masterSelectVarName="Form";
  127. parForm.callback=function(){};
  128. parForm.selectId="FormSelect";
  129. parForm.selectAll=true;
  130. parForm.inputType="select";
  131. parForm.urlName="formUrl";
  132. //FormStatus;
  133. par.vars["FormStatus"]=new Object();
  134. let parFormStatus=par.vars["FormStatus"];
  135. parFormStatus.masterSelectVarName="FormStatus";
  136. parFormStatus.callback=generateListAndPopulateDaughterSelect;
  137. parFormStatus.selectId="FormStatusSelect";
  138. parFormStatus.daughterSelect="Crf";
  139. parFormStatus.inputType="select";
  140. parFormStatus.filter=new Object();
  141. parFormStatus.filter.queryName="formStatusVisibility";
  142. parFormStatus.filter.filterVarName="formStatus";
  143. parFormStatus.filter.filters=new Object();
  144. parFormStatus.filter.filters["visibilityLevel"]="crfEditor";
  145. par.vars["eudraCTNumber"]=sourceVar("EudraCTNumber","eudraCTNumber","EudraCTNumber");
  146. par.vars["studyCoordinator"]=sourceVar("StudyCoordinator","studyCoordinator","StudyCoordinator");
  147. par.vars["studySponsor"]=sourceVar("StudySponsor","studySponsor","StudySponsor");
  148. par.vars["regulatoryNumber"]=sourceVar("RegulatoryNumber","regulatoryNumber","RegulatoryNumber");
  149. par.filters=["User","Site","FormStatus"];
  150. //par.filters=["User","Site"];
  151. drawForm(par);
  152. }
  153. </script>