crfPortal.html 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  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.source=new Object();
  79. par.source.queryName="StudyProperties";
  80. par.source.schemaName="study";
  81. par.source.vars=["eudraCTNumber","studyCoordinator","regulatoryNumber","studySponsor"];
  82. par.vars=new Object();
  83. //User
  84. let parUser=new Object();
  85. parUser.masterSelectVarName="UserId";
  86. parUser.callback=function(){};
  87. parUser.selectId="UserSelect";
  88. parUser.inputType="select";
  89. //only display users in crfEditors list
  90. parUser.filter=new Object();
  91. parUser.filter.queryName="crfEditors";
  92. parUser.filter.filterVarName="User";
  93. parUser.filter.filters=new Object();
  94. parUser.filter.filters["User"]=LABKEY.Security.currentUser.id;
  95. par.vars["User"]=parUser;
  96. //Crf
  97. let parCrf=new Object();
  98. parCrf.masterSelectVarName="entryId";
  99. //parCrf.callback=generateList;
  100. parCrf.selectId="crfSelect";
  101. parCrf.addSelect=true;
  102. parCrf.addNewFlag=-1;
  103. parCrf.inputType="select";
  104. par.vars["Crf"]=parCrf;
  105. //Site
  106. let parSite=new Object();
  107. parSite.masterSelectVarName="Site";
  108. //parSite.callback=generateListAndPopulateDaughterSelect;
  109. parSite.selectId="SiteSelect";
  110. parSite.daughterSelect="Crf";
  111. parSite.inputType="select";
  112. //apply additional filter to variable - specify
  113. //- queryName,
  114. //- name of variable in queryName
  115. // - list of filters with name of the variable associated targeted value
  116. parSite.filter=new Object();
  117. parSite.filter.queryName="crfEditors";
  118. parSite.filter.filterVarName="Site";
  119. parSite.filter.filters=new Object();
  120. parSite.filter.filters["User"]=LABKEY.Security.currentUser.id;
  121. par.vars["Site"]=parSite;
  122. //Form
  123. par.vars["Form"]=new Object();
  124. let parForm=par.vars["Form"];
  125. parForm.masterSelectVarName="Form";
  126. parForm.callback=function(){};
  127. parForm.selectId="FormSelect";
  128. parForm.selectAll=true;
  129. parForm.inputType="select";
  130. parForm.urlName="formUrl";
  131. //FormStatus;
  132. par.vars["FormStatus"]=new Object();
  133. let parFormStatus=par.vars["FormStatus"];
  134. parFormStatus.masterSelectVarName="FormStatus";
  135. //parFormStatus.callback=generateListAndPopulateDaughterSelect;
  136. parFormStatus.selectId="FormStatusSelect";
  137. parFormStatus.daughterSelect="Crf";
  138. parFormStatus.inputType="select";
  139. parFormStatus.filter=new Object();
  140. parFormStatus.filter.queryName="formStatusVisibility";
  141. parFormStatus.filter.filterVarName="formStatus";
  142. parFormStatus.filter.filters=new Object();
  143. parFormStatus.filter.filters["visibilityLevel"]="crfEditor";
  144. //par.vars["eudraCTNumber"]=sourceVar("EudraCTNumber","eudraCTNumber","EudraCTNumber");
  145. //par.vars["studyCoordinator"]=sourceVar("StudyCoordinator","studyCoordinator","StudyCoordinator");
  146. //par.vars["studySponsor"]=sourceVar("StudySponsor","studySponsor","StudySponsor");
  147. par.filters=["User","Site","FormStatus"];
  148. //par.filters=["User","Site"];
  149. //drawForm(par);
  150. }
  151. </script>