crfPortal.html 6.4 KB

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