grnsight 3.0.0 → 5.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (489) hide show
  1. package/.eslintignore +1 -0
  2. package/.travis.yml +1 -1
  3. package/GRNsight - Beta.html +194 -0
  4. package/Gemfile.lock +259 -0
  5. package/README.md +1 -1
  6. package/_gh_pages/about.html +360 -45
  7. package/_gh_pages/assets/css/footer.css +3 -0
  8. package/_gh_pages/assets/css/main.css +28 -14
  9. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_estimation_output_binary-no-targetless-genes_sif.png +0 -0
  10. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_estimation_output_binary_sif.png +0 -0
  11. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_3-edges-and-footer.png +0 -0
  12. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_header-and-3-nodes.png +0 -0
  13. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_output_3-edges-and-footer.png +0 -0
  14. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_output_header-and-3-nodes.png +0 -0
  15. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_binary-no-targetless-genes_sif.png +0 -0
  16. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_binary_sif.png +0 -0
  17. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_concatenated-no-targetless-genes_sif.png +0 -0
  18. package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_concatenated_sif.png +0 -0
  19. package/_gh_pages/assets/images/Choe-Shin_CMSI402-poster-session_20180430.jpg +0 -0
  20. package/_gh_pages/assets/images/Choe_SCCUR_2017.jpg +0 -0
  21. package/_gh_pages/assets/images/Dahlquist-Choe-Shin_CMSI402-poster-session_20180430.jpg +0 -0
  22. package/_gh_pages/assets/images/Dionisio-Dahlquist_GRNsight-shades_20170506.jpg +0 -0
  23. package/_gh_pages/assets/images/Klein_Samdarshi_TriBeta_2018_20180317.jpg +0 -0
  24. package/_gh_pages/assets/images/Shin_SCCUR_2017.jpg +0 -0
  25. package/{documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure1_zoom145_900pix-wide.png → _gh_pages/assets/images/demo-3_network-sheet.png} +0 -0
  26. package/{documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure2_zoom145_900pix-wide.png → _gh_pages/assets/images/demo-4_network-optimized-weights-sheet.png} +0 -0
  27. package/_gh_pages/assets/images/gene-pages-0.png +0 -0
  28. package/_gh_pages/assets/images/gene-pages-1.png +0 -0
  29. package/_gh_pages/assets/images/gene-pages-2.png +0 -0
  30. package/_gh_pages/assets/images/gene-pages-3.png +0 -0
  31. package/_gh_pages/assets/images/grnsight2020.png +0 -0
  32. package/_gh_pages/assets/images/v3demo2-grid+nodecoloring.png +0 -0
  33. package/_gh_pages/assets/images/v3demo2-nodecoloring.png +0 -0
  34. package/_gh_pages/assets/images/v3demo2.png +0 -0
  35. package/_gh_pages/assets/js/ga-report.js +11 -11
  36. package/_gh_pages/assets/js/iframeResizer.min.js +9 -0
  37. package/_gh_pages/assets/js/main.js +43 -43
  38. package/_gh_pages/beta.html +29 -24
  39. package/_gh_pages/contact.html +31 -31
  40. package/_gh_pages/coverage/coverage.json +1 -0
  41. package/_gh_pages/coverage/coverage.raw.json +1 -0
  42. package/_gh_pages/coverage/lcov-report/base.css +223 -0
  43. package/_gh_pages/coverage/lcov-report/block-navigation.js +63 -0
  44. package/_gh_pages/coverage/lcov-report/controllers/additional-sheet-parser.js.html +330 -0
  45. package/_gh_pages/coverage/lcov-report/controllers/constants.js.html +243 -0
  46. package/_gh_pages/coverage/lcov-report/controllers/export-controller.js.html +285 -0
  47. package/_gh_pages/coverage/lcov-report/controllers/exporters/graphml.js.html +405 -0
  48. package/_gh_pages/coverage/lcov-report/controllers/exporters/index.html +110 -0
  49. package/_gh_pages/coverage/lcov-report/controllers/exporters/sif.js.html +150 -0
  50. package/_gh_pages/coverage/lcov-report/controllers/helpers.js.html +114 -0
  51. package/_gh_pages/coverage/lcov-report/controllers/import-controller.js.html +233 -0
  52. package/_gh_pages/coverage/lcov-report/controllers/importers/graphml.js.html +716 -0
  53. package/_gh_pages/coverage/lcov-report/controllers/importers/index.html +106 -0
  54. package/_gh_pages/coverage/lcov-report/controllers/importers/sif.js.html +488 -0
  55. package/_gh_pages/coverage/lcov-report/controllers/index.html +162 -0
  56. package/_gh_pages/coverage/lcov-report/controllers/semantic-checker.js.html +810 -0
  57. package/_gh_pages/coverage/lcov-report/controllers/spreadsheet-controller.js.html +1779 -0
  58. package/_gh_pages/coverage/lcov-report/index.html +136 -0
  59. package/_gh_pages/coverage/lcov-report/prettify.css +1 -0
  60. package/_gh_pages/coverage/lcov-report/prettify.js +1 -0
  61. package/_gh_pages/coverage/lcov-report/server/controllers/additional-sheet-parser.js.html +330 -0
  62. package/_gh_pages/coverage/lcov-report/server/controllers/constants.js.html +243 -0
  63. package/_gh_pages/coverage/lcov-report/server/controllers/export-controller.js.html +285 -0
  64. package/_gh_pages/coverage/lcov-report/server/controllers/exporters/graphml.js.html +405 -0
  65. package/_gh_pages/coverage/lcov-report/server/controllers/exporters/index.html +110 -0
  66. package/_gh_pages/coverage/lcov-report/server/controllers/exporters/sif.js.html +150 -0
  67. package/_gh_pages/coverage/lcov-report/server/controllers/graphml-constants.js.html +585 -0
  68. package/_gh_pages/coverage/lcov-report/server/controllers/helpers.js.html +114 -0
  69. package/_gh_pages/coverage/lcov-report/server/controllers/import-controller.js.html +237 -0
  70. package/_gh_pages/coverage/lcov-report/server/controllers/importers/graphml.js.html +585 -0
  71. package/_gh_pages/coverage/lcov-report/server/controllers/importers/index.html +110 -0
  72. package/_gh_pages/coverage/lcov-report/server/controllers/importers/sif.js.html +492 -0
  73. package/_gh_pages/coverage/lcov-report/server/controllers/index.html +188 -0
  74. package/_gh_pages/coverage/lcov-report/server/controllers/semantic-checker.js.html +810 -0
  75. package/_gh_pages/coverage/lcov-report/server/controllers/spreadsheet-controller.js.html +1779 -0
  76. package/_gh_pages/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  77. package/_gh_pages/coverage/lcov-report/sorter.js +158 -0
  78. package/_gh_pages/coverage/lcov-report/web-client/public/js/grnstate.js.html +225 -0
  79. package/_gh_pages/coverage/lcov-report/web-client/public/js/index.html +97 -0
  80. package/_gh_pages/coverage/lcov.info +49 -0
  81. package/_gh_pages/documentation.html +998 -320
  82. package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.aux +47 -0
  83. package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.bbl +73 -0
  84. package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.blg +52 -0
  85. package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.log +1056 -0
  86. package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.out +7 -0
  87. package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.synctex.gz +0 -0
  88. package/_gh_pages/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_text-only_revised-Dondi.docx +0 -0
  89. package/_gh_pages/encryption/server.cert +21 -0
  90. package/_gh_pages/encryption/server.key +28 -0
  91. package/_gh_pages/favicon.ico +0 -0
  92. package/_gh_pages/index.html +45 -22
  93. package/_gh_pages/links.html +47 -28
  94. package/_gh_pages/news.html +103 -21
  95. package/_gh_pages/onlyfooter.html +78 -0
  96. package/_gh_pages/onlyheader.html +64 -0
  97. package/_gh_pages/onlysidebar.html +73 -0
  98. package/_gh_pages/package-lock.json +14048 -0
  99. package/_gh_pages/people.html +129 -40
  100. package/_gh_pages/privacy.html +23 -17
  101. package/_gh_pages/publications.html +75 -33
  102. package/_gh_pages/robots.txt +1 -0
  103. package/_gh_pages/sitemap.xml +87 -74
  104. package/_gh_pages/test-files/import-samples/attributes.graphml +40 -0
  105. package/_gh_pages/test-files/import-samples/port.graphml +32 -0
  106. package/_gh_pages/test-files/import-samples/simple.graphml +31 -0
  107. package/_gh_pages/web-client/public/js/grnsight.min.js +2347 -0
  108. package/_gh_pages/web-client/public/stylesheets/grnsight.css +443 -0
  109. package/coverage/coverage.json +1 -1
  110. package/coverage/coverage.raw.json +1 -0
  111. package/coverage/lcov-report/base.css +18 -8
  112. package/coverage/lcov-report/block-navigation.js +63 -0
  113. package/coverage/lcov-report/controllers/additional-sheet-parser.js.html +330 -0
  114. package/coverage/lcov-report/controllers/constants.js.html +65 -61
  115. package/coverage/lcov-report/controllers/export-controller.js.html +96 -92
  116. package/coverage/lcov-report/controllers/exporters/graphml.js.html +168 -164
  117. package/coverage/lcov-report/controllers/exporters/index.html +36 -32
  118. package/coverage/lcov-report/controllers/exporters/sif.js.html +65 -61
  119. package/coverage/lcov-report/controllers/helpers.js.html +25 -21
  120. package/coverage/lcov-report/controllers/index.html +49 -45
  121. package/coverage/lcov-report/controllers/semantic-checker.js.html +403 -396
  122. package/coverage/lcov-report/controllers/spreadsheet-controller.js.html +973 -879
  123. package/coverage/lcov-report/index.html +45 -28
  124. package/coverage/lcov-report/server/controllers/additional-sheet-parser.js.html +330 -0
  125. package/coverage/lcov-report/server/controllers/constants.js.html +243 -0
  126. package/coverage/lcov-report/server/controllers/export-controller.js.html +285 -0
  127. package/coverage/lcov-report/server/controllers/exporters/graphml.js.html +405 -0
  128. package/coverage/lcov-report/server/controllers/exporters/index.html +110 -0
  129. package/coverage/lcov-report/server/controllers/exporters/sif.js.html +150 -0
  130. package/coverage/lcov-report/server/controllers/graphml-constants.js.html +585 -0
  131. package/coverage/lcov-report/server/controllers/helpers.js.html +114 -0
  132. package/coverage/lcov-report/server/controllers/import-controller.js.html +237 -0
  133. package/coverage/lcov-report/server/controllers/importers/graphml.js.html +585 -0
  134. package/coverage/lcov-report/server/controllers/importers/index.html +110 -0
  135. package/coverage/lcov-report/server/controllers/importers/sif.js.html +492 -0
  136. package/coverage/lcov-report/server/controllers/index.html +188 -0
  137. package/coverage/lcov-report/server/controllers/semantic-checker.js.html +810 -0
  138. package/coverage/lcov-report/server/controllers/spreadsheet-controller.js.html +1779 -0
  139. package/coverage/lcov-report/web-client/public/js/grnstate.js.html +225 -0
  140. package/coverage/lcov-report/web-client/public/js/index.html +97 -0
  141. package/coverage/lcov.info +1758 -876
  142. package/encryption/server.cert +21 -0
  143. package/encryption/server.key +28 -0
  144. package/package.json +46 -22
  145. package/server/app.js +6 -2
  146. package/server/config/config.js +16 -7
  147. package/server/controllers/additional-sheet-parser.js +292 -55
  148. package/server/controllers/api-controllers.js +36 -0
  149. package/server/controllers/constants.js +4 -37
  150. package/server/controllers/database-controller.js +129 -0
  151. package/server/controllers/demo-workbooks.js +5973 -0
  152. package/server/controllers/export-constants.js +78 -0
  153. package/server/controllers/export-controller.js +25 -3
  154. package/server/controllers/exporters/graphml.js +15 -15
  155. package/server/controllers/exporters/sif.js +7 -7
  156. package/server/controllers/exporters/xlsx.js +183 -0
  157. package/server/controllers/expression-sheet-parser.js +170 -0
  158. package/server/controllers/ga-controller.js +1 -1
  159. package/server/controllers/graphml-constants.js +0 -17
  160. package/server/controllers/helpers.js +25 -1
  161. package/server/controllers/import-controller.js +2 -2
  162. package/server/controllers/importers/graphml.js +17 -20
  163. package/server/controllers/importers/sif.js +22 -18
  164. package/server/controllers/network-sheet-parser.js +307 -0
  165. package/server/controllers/semantic-checker.js +30 -162
  166. package/server/controllers/sif-constants.js +36 -0
  167. package/server/controllers/spreadsheet-controller.js +277 -424
  168. package/server/controllers/workbook-constants.js +521 -0
  169. package/test/additional-sheet-parser-tests.js +147 -38
  170. package/test/api-tests.js +245 -0
  171. package/test/errors-adjacency-matrix-modifications.js +30 -29
  172. package/test/errors-gene-name-modifications.js +9 -0
  173. package/test/errors-graph-tests.js +4 -4
  174. package/test/errors-sheet-modifications.js +10 -2
  175. package/test/export-tests.js +431 -24
  176. package/test/expression-data-import-tests.js +113 -0
  177. package/test/grnstate-tests.js +29 -0
  178. package/test/import-graphml-tests.js +59 -40
  179. package/test/import-sif-tests.js +50 -37
  180. package/test/test.js +557 -93
  181. package/test/warnings-adjacency-matrix-modifications.js +8 -7
  182. package/test-files/additional-sheet-test-files/optimization-diagnostics-default.xlsx +0 -0
  183. package/test-files/additional-sheet-test-files/optimization-diagnostics-extraneous-data.xlsx +0 -0
  184. package/test-files/additional-sheet-test-files/optimization-diagnostics-incorrect-MSE-gene-header.xlsx +0 -0
  185. package/test-files/additional-sheet-test-files/optimization-diagnostics-incorrect-MSE-header.xlsx +0 -0
  186. package/test-files/additional-sheet-test-files/optimization-diagnostics-incorrect-column-headers.xlsx +0 -0
  187. package/test-files/additional-sheet-test-files/optimization-diagnostics-invalid-MSE-data.xlsx +0 -0
  188. package/test-files/additional-sheet-test-files/optimization-diagnostics-invalid-value.xlsx +0 -0
  189. package/test-files/additional-sheet-test-files/optimization-diagnostics-missing-MSE-data.xlsx +0 -0
  190. package/test-files/additional-sheet-test-files/optimization-diagnostics-missing-column-headers.xlsx +0 -0
  191. package/test-files/additional-sheet-test-files/optimization-diagnostics-missing-header.xlsx +0 -0
  192. package/test-files/additional-sheet-test-files/optimization-diagnostics-unknown-parameter.xlsx +0 -0
  193. package/test-files/additional-sheet-test-files/optimization-parameters-default.xlsx +0 -0
  194. package/test-files/additional-sheet-test-files/optimization-parameters-incorrect-headers.xlsx +0 -0
  195. package/test-files/additional-sheet-test-files/optimization-parameters-invalid-optimization-parameter.xlsx +0 -0
  196. package/test-files/additional-sheet-test-files/optimization-parameters-missing-headers.xlsx +0 -0
  197. package/test-files/additional-sheet-test-files/optimization-parameters-unknown-parameter.xlsx +0 -0
  198. package/test-files/additional-sheet-test-files/two-column-sheets-extraneous-data.xlsx +0 -0
  199. package/test-files/additional-sheet-test-files/two-column-sheets-incorrect-cell-A1.xlsx +0 -0
  200. package/test-files/additional-sheet-test-files/two-column-sheets-incorrect-column-header.xlsx +0 -0
  201. package/test-files/additional-sheet-test-files/two-column-sheets-invalid-gene-length.xlsx +0 -0
  202. package/test-files/additional-sheet-test-files/two-column-sheets-invalid-gene-type.xlsx +0 -0
  203. package/test-files/additional-sheet-test-files/two-column-sheets-invalid-value.xlsx +0 -0
  204. package/test-files/additional-sheet-test-files/two-column-sheets-missing-column-header.xlsx +0 -0
  205. package/test-files/additional-sheet-test-files/two-column-sheets-special-character.xlsx +0 -0
  206. package/test-files/adjacency-matrix-modifications/asymmetric-gene-order-input.xlsx +0 -0
  207. package/test-files/adjacency-matrix-modifications/asymmetric-gene-order-output.xlsx +0 -0
  208. package/test-files/adjacency-matrix-modifications/extra-column-adjacent-input.xlsx +0 -0
  209. package/test-files/adjacency-matrix-modifications/extra-column-adjacent-output.xlsx +0 -0
  210. package/test-files/adjacency-matrix-modifications/extra-column-end-of-sheet-input.xlsx +0 -0
  211. package/test-files/adjacency-matrix-modifications/extra-column-end-of-sheet-output.xlsx +0 -0
  212. package/test-files/adjacency-matrix-modifications/extra-data-random-cell-both-output.xlsx +0 -0
  213. package/test-files/adjacency-matrix-modifications/extra-data-random-cell-network-only-input.xlsx +0 -0
  214. package/test-files/adjacency-matrix-modifications/extra-data-random-cell-network-only-output.xlsx +0 -0
  215. package/test-files/adjacency-matrix-modifications/extra-data-random-cell-network-optimized-only-output.xlsx +0 -0
  216. package/test-files/adjacency-matrix-modifications/extra-row-end-of-sheet-input.xlsx +0 -0
  217. package/test-files/adjacency-matrix-modifications/extra-row-end-of-sheet-output.xlsx +0 -0
  218. package/test-files/adjacency-matrix-modifications/incorrect-network-cell-A1.xlsx +0 -0
  219. package/test-files/adjacency-matrix-modifications/missing-column-end-input.xlsx +0 -0
  220. package/test-files/adjacency-matrix-modifications/missing-column-end-output.xlsx +0 -0
  221. package/test-files/adjacency-matrix-modifications/missing-data-input.xlsx +0 -0
  222. package/test-files/adjacency-matrix-modifications/missing-data-output.xlsx +0 -0
  223. package/test-files/adjacency-matrix-modifications/missing-row-end-input.xlsx +0 -0
  224. package/test-files/adjacency-matrix-modifications/missing-row-end-output.xlsx +0 -0
  225. package/test-files/adjacency-matrix-modifications/missing-row-middle-input.xlsx +0 -0
  226. package/test-files/adjacency-matrix-modifications/missing-row-middle-output.xlsx +0 -0
  227. package/test-files/adjacency-matrix-modifications/missing-value-bottom-corner-input.xlsx +0 -0
  228. package/test-files/adjacency-matrix-modifications/missing-value-bottom-corner-output.xlsx +0 -0
  229. package/test-files/adjacency-matrix-modifications/value-replaced-w-spaces-both-output.xlsx +0 -0
  230. package/test-files/adjacency-matrix-modifications/value-replaced-w-spaces-net-only-input.xlsx +0 -0
  231. package/test-files/adjacency-matrix-modifications/value-replaced-w-spaces-net-op-only-output.xlsx +0 -0
  232. package/test-files/adjacency-matrix-modifications/value-replaced/342/200/223w-spaces-net-only-output.xlsx +0 -0
  233. package/test-files/demo-files/15-genes_28-edges_db5_Dahlquist-data_estimation_output.xlsx +0 -0
  234. package/test-files/demo-files/15-genes_28-edges_db5_Dahlquist-data_input.xlsx +0 -0
  235. package/test-files/expression-data-test-sheets/expression_sheet_correct_numbering.xlsx +0 -0
  236. package/test-files/expression-data-test-sheets/expression_sheet_different_number_of_columns.xlsx +0 -0
  237. package/test-files/expression-data-test-sheets/expression_sheet_empty_column.xlsx +0 -0
  238. package/test-files/expression-data-test-sheets/expression_sheet_empty_row.xlsx +0 -0
  239. package/test-files/expression-data-test-sheets/expression_sheet_erroneous_data.xlsx +0 -0
  240. package/test-files/expression-data-test-sheets/expression_sheet_extra_gene_name.xlsx +0 -0
  241. package/test-files/expression-data-test-sheets/expression_sheet_incorrectly_ordered_time_points.xlsx +0 -0
  242. package/test-files/expression-data-test-sheets/expression_sheet_mismatched_case_gene_names.xlsx +0 -0
  243. package/test-files/expression-data-test-sheets/expression_sheet_mismatched_gene_names.xlsx +0 -0
  244. package/test-files/expression-data-test-sheets/expression_sheet_missing_column_header.xlsx +0 -0
  245. package/test-files/expression-data-test-sheets/expression_sheet_missing_data_error.xlsx +0 -0
  246. package/test-files/expression-data-test-sheets/expression_sheet_missing_data_ok.xlsx +0 -0
  247. package/test-files/expression-data-test-sheets/expression_sheet_missing_data_ok_export_exact.xlsx +0 -0
  248. package/test-files/expression-data-test-sheets/expression_sheet_missing_gene_name.xlsx +0 -0
  249. package/test-files/expression-data-test-sheets/expression_sheet_name_not_in_optparams.xlsx +0 -0
  250. package/test-files/expression-data-test-sheets/expression_sheet_name_not_present.xlsx +0 -0
  251. package/test-files/expression-data-test-sheets/expression_sheet_negative_time_points.xlsx +0 -0
  252. package/test-files/expression-data-test-sheets/expression_sheet_non_numerical_time_points.xlsx +0 -0
  253. package/test-files/expression-data-test-sheets/expression_sheet_not_existing.xlsx +0 -0
  254. package/test-files/expression-data-test-sheets/expression_sheet_wrong_id_label.xlsx +0 -0
  255. package/test-files/expression-data-test-sheets/expression_sheet_wrong_order_gene_names.xlsx +0 -0
  256. package/test-files/expression-data-test-sheets/expression_sheet_wrong_sheet_name_case.xlsx +0 -0
  257. package/test-files/expression-data-test-sheets/expression_sheet_wrong_sheet_name_convention.xlsx +0 -0
  258. package/test-files/gene-name-modifications/NaN-as-gene-name-input.xlsx +0 -0
  259. package/test-files/gene-name-modifications/NaN-as-gene-name-output.xlsx +0 -0
  260. package/test-files/gene-name-modifications/mismatched-case-related-input.xlsx +0 -0
  261. package/test-files/gene-name-modifications/mismatched-case-related-output.xlsx +0 -0
  262. package/test-files/gene-name-modifications/mismatched-case-unrelated-input.xlsx +0 -0
  263. package/test-files/gene-name-modifications/mismatched-case-unrelated-output.xlsx +0 -0
  264. package/test-files/gene-name-modifications/numbers-as-gene-name-related-input.xlsx +0 -0
  265. package/test-files/gene-name-modifications/numbers-as-gene-name-related-output.xlsx +0 -0
  266. package/test-files/gene-name-modifications/numbers-as-gene-name-unrelated-input.xlsx +0 -0
  267. package/test-files/gene-name-modifications/numbers-as-gene-name-unrelated-output.xlsx +0 -0
  268. package/test-files/graph-tests/different-sized-networks/{80-genes-0-edges.xlsx → 134-genes-0-edges.xlsx} +0 -0
  269. package/test-files/graph-tests/different-sized-networks/{45-genes-max-edges.xlsx → 44-source-genes-45-target-genes-max-edges.xlsx} +0 -0
  270. package/test-files/graph-tests/different-sized-networks/{1-gene-0-edges.xlsx → unused-files/1-gene-0-edges.xlsx} +0 -0
  271. package/test-files/graph-tests/different-sized-networks/{1-gene-1-edges.xlsx → unused-files/1-gene-1-edges.xlsx} +0 -0
  272. package/test-files/graph-tests/different-sized-networks/{10-genes-50-edges.xlsx → unused-files/10-genes-50-edges.xlsx} +0 -0
  273. package/test-files/graph-tests/different-sized-networks/{10-genes-90-edges.xlsx → unused-files/10-genes-90-edges.xlsx} +0 -0
  274. package/test-files/graph-tests/different-sized-networks/{100-genes-0-edges.xlsx → unused-files/100-genes-0-edges.xlsx} +0 -0
  275. package/test-files/graph-tests/different-sized-networks/{110-genes-0-edges.xlsx → unused-files/110-genes-0-edges.xlsx} +0 -0
  276. package/test-files/graph-tests/different-sized-networks/{120-genes-0-edges.xlsx → unused-files/120-genes-0-edges.xlsx} +0 -0
  277. package/test-files/graph-tests/different-sized-networks/{130-genes-0-edges.xlsx → unused-files/130-genes-0-edges.xlsx} +0 -0
  278. package/test-files/graph-tests/different-sized-networks/{140-genes-0-edges.xlsx → unused-files/140-genes-0-edges.xlsx} +0 -0
  279. package/test-files/graph-tests/different-sized-networks/{150-genes-10000-edges.xlsx → unused-files/150-genes-10000-edges.xlsx} +0 -0
  280. package/test-files/graph-tests/different-sized-networks/{150-genes-20000-edges.xlsx → unused-files/150-genes-20000-edges.xlsx} +0 -0
  281. package/test-files/graph-tests/different-sized-networks/{150-genes-max-edges.xlsx → unused-files/150-genes-max-edges.xlsx} +0 -0
  282. package/test-files/graph-tests/different-sized-networks/{160-genes-max-edges.xlsx → unused-files/160-genes-max-edges.xlsx} +0 -0
  283. package/test-files/graph-tests/different-sized-networks/{20-genes-max-edges.xlsx → unused-files/20-genes-max-edges.xlsx} +0 -0
  284. package/test-files/graph-tests/different-sized-networks/{25-genes-max-edges.xlsx → unused-files/25-genes-max-edges.xlsx} +0 -0
  285. package/test-files/graph-tests/different-sized-networks/{30-genes-max-edges.xlsx → unused-files/30-genes-max-edges.xlsx} +0 -0
  286. package/test-files/graph-tests/different-sized-networks/{34-genes-0-edges.xlsx → unused-files/34-genes-0-edges.xlsx} +0 -0
  287. package/test-files/graph-tests/different-sized-networks/{34-genes-40-edges.xlsx → unused-files/34-genes-40-edges.xlsx} +0 -0
  288. package/test-files/graph-tests/different-sized-networks/{34-genes-65-edges.xlsx → unused-files/34-genes-65-edges.xlsx} +0 -0
  289. package/test-files/graph-tests/different-sized-networks/{34-genes-90-edges.xlsx → unused-files/34-genes-90-edges.xlsx} +0 -0
  290. package/test-files/graph-tests/different-sized-networks/{5-genes-max-edges.xlsx → unused-files/5-genes-max-edges.xlsx} +0 -0
  291. package/test-files/graph-tests/different-sized-networks/{51-genes-max-edges.xlsx → unused-files/51-genes-max-edges.xlsx} +0 -0
  292. package/test-files/graph-tests/different-sized-networks/{52-genes-max-edges.xlsx → unused-files/52-genes-max-edges.xlsx} +0 -0
  293. package/test-files/graph-tests/different-sized-networks/{55-genes-0-edges.xlsx → unused-files/55-genes-0-edges.xlsx} +0 -0
  294. package/test-files/graph-tests/different-sized-networks/{55-genes-max-edges.xlsx → unused-files/55-genes-max-edges.xlsx} +0 -0
  295. package/test-files/graph-tests/different-sized-networks/{65-genes-0-edges.xlsx → unused-files/65-genes-0-edges.xlsx} +0 -0
  296. package/test-files/graph-tests/different-sized-networks/{7-genes-max-edges.xlsx → unused-files/7-genes-max-edges.xlsx} +0 -0
  297. package/test-files/graph-tests/different-sized-networks/{70-genes-0-edges.xlsx → unused-files/70-genes-0-edges.xlsx} +0 -0
  298. package/test-files/graph-tests/different-sized-networks/{9-genes-max-edges.xlsx → unused-files/9-genes-max-edges.xlsx} +0 -0
  299. package/test-files/graph-tests/different-sized-networks/{90-genes-0-edges.xlsx → unused-files/90-genes-0-edges.xlsx} +0 -0
  300. package/test-files/graph-tests/different-sized-networks/{regulation-matrix-documented-20140709-AllTF-all-targets.xlsx → unused-files/regulation-matrix-documented-20140709-AllTF-all-targets.xlsx} +0 -0
  301. package/test-files/node-tests/long-gene-name-no-spaces-first.xlsx +0 -0
  302. package/test-files/node-tests/long-gene-name-no-spaces-second.xlsx +0 -0
  303. package/test-files/node-tests/long-gene-name-spaces.xlsx +0 -0
  304. package/test-files/species-test-data/15-genes_28-edges_db5_Dahlquist-data_input_no-species.xlsx +0 -0
  305. package/test-files/species-test-data/15-genes_28-edges_db5_Dahlquist-data_input_with-species.xlsx +0 -0
  306. package/test-files/species-test-data/3-gene_7-edge_elegans.xlsx +0 -0
  307. package/test-files/species-test-data/3-gene_7-edge_melanogaster.xlsx +0 -0
  308. package/test-files/species-test-data/3-gene_7-edge_musculus.xlsx +0 -0
  309. package/test-files/species-test-data/3-gene_7-edge_sapiens.xlsx +0 -0
  310. package/test-files/species-test-data/kev-fake-data-sapiens-no-exp-data.xlsx +0 -0
  311. package/test-files/spreadsheet-controller-test-files/sheet-name-capitalized-network-optimized-weights.xlsx +0 -0
  312. package/test-files/spreadsheet-controller-test-files/sheet-name-capitalized-network.xlsx +0 -0
  313. package/web-client/app.js +1 -1
  314. package/web-client/config/config.js +5 -5
  315. package/web-client/controllers/main.js +5 -1
  316. package/web-client/public/favicon.ico +0 -0
  317. package/web-client/public/gene/GRNSight.svg +689 -0
  318. package/web-client/public/gene/PageDesignREADME.md +1 -0
  319. package/web-client/public/gene/api.js +442 -0
  320. package/web-client/public/gene/info.css +181 -0
  321. package/web-client/public/gene/info.js +334 -0
  322. package/web-client/public/gene/integrationREADME.md +52 -0
  323. package/web-client/public/js/constants.js +182 -0
  324. package/web-client/public/js/getGeneInformationREADME.md +4 -0
  325. package/web-client/public/js/graph-statistics.js +7 -7
  326. package/web-client/public/js/graph.js +480 -476
  327. package/web-client/public/js/grnsight.js +10 -9
  328. package/web-client/public/js/grnsight.min.js +2335 -0
  329. package/web-client/public/js/grnstate.js +147 -0
  330. package/web-client/public/js/iframe-coordination.js +55 -0
  331. package/web-client/public/js/setup-handlers.js +617 -0
  332. package/web-client/public/js/setup-load-and-import-handlers.js +180 -0
  333. package/web-client/public/js/update-app.js +980 -0
  334. package/web-client/public/js/upload.js +352 -578
  335. package/web-client/public/js/warnings.js +60 -0
  336. package/web-client/public/lib/iframeSizer.contentWindow.min.js +10 -0
  337. package/{documents/SDF/CMSI_402/spring_2018/writtenStatusReport4 → web-client/public/lib/jaspar-front.html} +0 -0
  338. package/web-client/public/stylesheets/grnsight.styl +176 -26
  339. package/web-client/public/stylesheets/print.styl +10 -4
  340. package/web-client/views/{graph.jade → graph.pug} +1 -3
  341. package/web-client/views/info.pug +215 -0
  342. package/web-client/views/upload.pug +587 -0
  343. package/_gh_pages/Gemfile +0 -7
  344. package/_gh_pages/Gemfile.lock +0 -129
  345. package/documents/SDF/CMSI_402/spring_2014/Southwick_CMSI402_Spring2014_software-development-plan.md +0 -71
  346. package/documents/SDF/CMSI_402/spring_2014/Southwick_CMSI402_Spring2014_software-requirements-specification.md +0 -71
  347. package/documents/SDF/CMSI_402/spring_2014/use-case-diagram-spring-2014.jpg +0 -0
  348. package/documents/SDF/CMSI_402/spring_2017/Anguiano_402_Final_Presentation.pptx +0 -0
  349. package/documents/SDF/CMSI_402/spring_2017/Anguiano_402_Presentation_Final_Poster.pdf +0 -0
  350. package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_project-proposal-presentation.pptx +0 -0
  351. package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_project-proposal.docx +0 -0
  352. package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_software-development-plan.docx +0 -0
  353. package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_software-requirements-specification.docx +0 -0
  354. package/documents/SDF/CMSI_402/spring_2017/Design Review Presentation.pptx +0 -0
  355. package/documents/SDF/CMSI_402/spring_2018/0402report.docx +0 -0
  356. package/documents/SDF/CMSI_402/spring_2018/0409report.docx +0 -0
  357. package/documents/SDF/CMSI_402/spring_2018/402-gantt.png +0 -0
  358. package/documents/SDF/CMSI_402/spring_2018/402SRS_GRNSightFeedback01.txt +0 -28
  359. package/documents/SDF/CMSI_402/spring_2018/402_SPD.md +0 -223
  360. package/documents/SDF/CMSI_402/spring_2018/ChoeShinCMSI402_Final.pptx +0 -0
  361. package/documents/SDF/CMSI_402/spring_2018/ProjectProposal.md +0 -22
  362. package/documents/SDF/CMSI_402/spring_2018/SoftwareRequirementsSpecification.md +0 -88
  363. package/documents/SDF/CMSI_402/spring_2018/homework/choe_eileen/Choe_Eileen_CMSI 402_HW1.pdf +0 -0
  364. package/documents/SDF/CMSI_402/spring_2018/homework/choe_eileen/Choe_Eileen_CMSI402_HW2.pdf +0 -0
  365. package/documents/SDF/CMSI_402/spring_2018/homework/shin_jen/402hw2.docx +0 -0
  366. package/documents/SDF/CMSI_402/spring_2018/homework/shin_jen/Jen - 402Hw1.docx +0 -0
  367. package/documents/SDF/CMSI_402/spring_2018/homework/shin_jen/Jen - hw3.docx +0 -0
  368. package/documents/SDF/CMSI_402/spring_2018/writtenStatusReport.docx +0 -0
  369. package/documents/Varshneya_Samdarshi_LMU_Symposium_2016.pptx +0 -0
  370. package/documents/abstracts/Anguiano_Varshneya_Undergraduate-Research-Symposium_2017_abstract.pdf +0 -0
  371. package/documents/abstracts/SIGGRAPH 2017 Abstract/ACM-Reference-Format.bst +0 -3478
  372. package/documents/abstracts/SIGGRAPH 2017 Abstract/Figure1_zoom100.png +0 -0
  373. package/documents/abstracts/SIGGRAPH 2017 Abstract/acmart.cls +0 -2352
  374. package/documents/abstracts/SIGGRAPH 2017 Abstract/acmart.ins +0 -29
  375. package/documents/abstracts/SIGGRAPH 2017 Abstract/always-weights.png +0 -0
  376. package/documents/abstracts/SIGGRAPH 2017 Abstract/auto.png +0 -0
  377. package/documents/abstracts/SIGGRAPH 2017 Abstract/networkA.png +0 -0
  378. package/documents/abstracts/SIGGRAPH 2017 Abstract/networkB-normalized.png +0 -0
  379. package/documents/abstracts/SIGGRAPH 2017 Abstract/networkB.png +0 -0
  380. package/documents/abstracts/SIGGRAPH 2017 Abstract/never-weights.png +0 -0
  381. package/documents/abstracts/SIGGRAPH 2017 Abstract/representative-image/screenshot.jpg +0 -0
  382. package/documents/abstracts/SIGGRAPH 2017 Abstract/representative-image/screenshot3x2.png +0 -0
  383. package/documents/abstracts/SIGGRAPH 2017 Abstract/representative-image/withweights3x2.png +0 -0
  384. package/documents/abstracts/SIGGRAPH 2017 Abstract/screenshot-auto.png +0 -0
  385. package/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.bib +0 -85
  386. package/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.pdf +0 -0
  387. package/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.tex +0 -235
  388. package/documents/abstracts/SWE Collegiate Competition 2017.md +0 -9
  389. package/documents/abstracts/Varshneya_Samdarshi_Southern-California-Systems-Biology_2017_abstract.docx +0 -0
  390. package/documents/developer_documents/State Diagram.graphml +0 -3525
  391. package/documents/developer_documents/graphml/State Diagram.graphml +0 -3115
  392. package/documents/developer_documents/older_versions/GRNsight State Diagram old.png +0 -0
  393. package/documents/developer_documents/older_versions/GRNsight State Diagram.png +0 -0
  394. package/documents/developer_documents/testing_script_generator/GRNsightTestingDocument.md +0 -998
  395. package/documents/developer_documents/testing_script_generator/featureList.json +0 -486
  396. package/documents/developer_documents/testing_script_generator/testing-script-generator.js +0 -149
  397. package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_conference-presentations_2016.docx +0 -0
  398. package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016.docx +0 -0
  399. package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016_Table1.docx +0 -0
  400. package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016_references.rtf +0 -264
  401. package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016_text-only.docx +0 -0
  402. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/21-genes_31-edges_Schade-data_for-screenshots.xlsx +0 -0
  403. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom100.jpg +0 -0
  404. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom100.png +0 -0
  405. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom100.psd +0 -0
  406. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145.jpg +0 -0
  407. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145.png +0 -0
  408. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145.psd +0 -0
  409. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145_900pix-wide.psd +0 -0
  410. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom100.jpg +0 -0
  411. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom100.png +0 -0
  412. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom100.psd +0 -0
  413. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145.jpg +0 -0
  414. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145.png +0 -0
  415. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145.psd +0 -0
  416. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145_900pix-wide.psd +0 -0
  417. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5A.pdf +0 -0
  418. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5B.pdf +0 -0
  419. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5C.eps +0 -0
  420. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5D.pdf +0 -0
  421. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5E.pdf +0 -0
  422. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5F.eps +0 -0
  423. package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5_compiled.png +0 -0
  424. package/documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure3_GRNsight-Architecture.pdf +0 -0
  425. package/documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure4_GRNsight-Screenshot.pdf +0 -0
  426. package/documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure5_compiled.pdf +12 -5383
  427. package/documents/manuscripts/peerj-computerscience-2016/peerj-reviewing-10823-v0.pdf +0 -0
  428. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_conference-presentations_2016_revised.docx +0 -0
  429. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_cover-letter-and-response_2016.pdf +0 -0
  430. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_cover-letter_2016.docx +0 -0
  431. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_cover-letter_2016.pdf +0 -0
  432. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_Table1.docx +0 -0
  433. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_references_revised.rtf +0 -385
  434. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_text-only_revised.docx +0 -0
  435. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_text-only_revised_marked.docx +0 -0
  436. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_response-to-reviewers_2016.docx +0 -0
  437. package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_response-to-reviewers_2016.pdf +0 -0
  438. package/documents/manuscripts/peerj-computerscience-2016/revisions/figures/Figure3_GRNsight-Architecture.pdf +0 -0
  439. package/documents/manuscripts/peerj-computerscience-2016/revisions/figures/Figure4_GRNsight-Screenshot-auto.pdf +0 -0
  440. package/documents/manuscripts/peerj-computerscience-2016/revisions/figures/Figure4_GRNsight-Screenshot.pdf +0 -0
  441. package/documents/manuscripts/peerj-computerscience-2016/revisions/peerj-reviewing-10823-v1.pdf +0 -0
  442. package/documents/posters/Anguiano_402_Presentation_Draft_Poster.pdf +0 -0
  443. package/documents/posters/Anguiano_402_Presentation_Draft_Poster.pptx +0 -0
  444. package/documents/posters/Anguiano_Varshneya_LMU-Symposium_2015_poster.pptx +0 -0
  445. package/documents/posters/Anguiano_Varshneya_SCCUR-Poster_20141122_poster.pptx +0 -0
  446. package/documents/posters/ChoeShinCMSI402-2.pptx +0 -0
  447. package/documents/posters/ChoeShinCMSI402.pptx +0 -0
  448. package/documents/posters/ChoeShinCMSI402Final.pptx +0 -0
  449. package/documents/posters/Dahlquist-et-al_BOSC_ISMB_2016_poster.pptx +0 -0
  450. package/documents/posters/Samdarshi et al. LMU Symposium 2017-finalDraft.pptx +0 -0
  451. package/documents/posters/Samdarshi et al. LMU Symposium 2018-firstDraft.pptx +0 -0
  452. package/documents/posters/Shin et al. SCCUR 2017 FinalDraft.pptx +0 -0
  453. package/documents/posters/Southwick_CMSI402_2014_poster.pptx +0 -0
  454. package/documents/posters/Varshneya_Samdarshi_LMU-Symposium_2016_poster.pptx +0 -0
  455. package/documents/posters/Varshneya_Samdarshi_Southern-California-Systems-Biology-Conference_2017_poster.pptx +0 -0
  456. package/documents/posters/~$Samdarshi et al. LMU Symposium 2018-firstDraft.pptx +0 -0
  457. package/documents/presentations/Anguiano_402_Final_Presentation.pptx +0 -0
  458. package/documents/presentations/Choe_SCCUR2017.pptx +0 -0
  459. package/documents/presentations/Choe_SWERapidFire2017_final.pptx +0 -0
  460. package/documents/presentations/Dahlquist_BOSC_20160709.pptx +0 -0
  461. package/documents/presentations/Dahlquist_ExperimentalBiology_20160404_talk.pptx +0 -0
  462. package/documents/presentations/Dahlquist_SoCalSysBio_20150131_talk.pptx +0 -0
  463. package/documents/presentations/Samdarshi et al. LMU Symposium 2017-draft.pptx +0 -0
  464. package/documents/presentations/Southwick_Anguiano_LMU-Symposium_20140329_talk.pptx +0 -0
  465. package/documents/presentations/Southwick_CMSI402_Presentation_20140508_talk.pptx +0 -0
  466. package/documents/presentations/Varshneya-Anguiano-LMU Symposium-201703.pptx +0 -0
  467. package/documents/presentations/~$Choe_SWERapidFire2017_final.pptx +0 -0
  468. package/documents/reports/Varshneya-201701-AnnotatedBibliography.docx +0 -0
  469. package/documents/reports/Varshneya-201702-Introduction.docx +0 -0
  470. package/documents/reports/Varshneya-201702-Outline.docx +0 -0
  471. package/documents/reports/Varshneya-201703-Discussion.docx +0 -0
  472. package/documents/reports/Varshneya-201703-MMResults.docx +0 -0
  473. package/documents/reports/Varshneya-201704-Draft-1.docx +0 -0
  474. package/documents/reports/Varshneya-201704-Final.docx +0 -0
  475. package/test/graph-library-tests.js +0 -165
  476. package/test-files/demo-files/21-genes_50-edges_Dahlquist-data_estimation_output.xlsx +0 -0
  477. package/test-files/demo-files/21-genes_50-edges_Dahlquist-data_input.xlsx +0 -0
  478. package/test-files/graph-tests/different-sized-networks/10-genes-max-edges.xlsx +0 -0
  479. package/test-files/graph-tests/different-sized-networks/12-genes-max-edges.xlsx +0 -0
  480. package/test-files/graph-tests/different-sized-networks/35-genes-max-edges.xlsx +0 -0
  481. package/test-files/graph-tests/different-sized-networks/40-genes-0-edges.xlsx +0 -0
  482. package/test-files/graph-tests/different-sized-networks/40-genes-max-edges.xlsx +0 -0
  483. package/test-files/graph-tests/different-sized-networks/42-genes-max-edges.xlsx +0 -0
  484. package/test-files/graph-tests/different-sized-networks/50-genes-max-edges.xlsx +0 -0
  485. package/test-files/graph-tests/different-sized-networks/75-genes-150-edges.xlsx +0 -0
  486. package/web-client/public/js/container.js +0 -121
  487. package/web-client/public/js/node-coloring.js +0 -306
  488. package/web-client/public/js/sliders.js +0 -197
  489. package/web-client/views/upload.jade +0 -458
@@ -0,0 +1,21 @@
1
+ -----BEGIN CERTIFICATE-----
2
+ MIIDcjCCAloCCQCH8V5lU4wTmDANBgkqhkiG9w0BAQsFADB7MQswCQYDVQQGEwJV
3
+ UzETMBEGA1UECAwKQ2FsaWZvcm5pYTEUMBIGA1UEBwwLTG9zIEFuZ2VsZXMxJDAi
4
+ BgNVBAoMG0xveW9sYSBNYXJ5bW91bnQgVW5pdmVyc2l0eTEbMBkGA1UEAwwSZ3Ju
5
+ c2lnaHQubG9jYWxob3N0MB4XDTE5MDYwMjIyMjUxNVoXDTE5MDcwMjIyMjUxNVow
6
+ ezELMAkGA1UEBhMCVVMxEzARBgNVBAgMCkNhbGlmb3JuaWExFDASBgNVBAcMC0xv
7
+ cyBBbmdlbGVzMSQwIgYDVQQKDBtMb3lvbGEgTWFyeW1vdW50IFVuaXZlcnNpdHkx
8
+ GzAZBgNVBAMMEmdybnNpZ2h0LmxvY2FsaG9zdDCCASIwDQYJKoZIhvcNAQEBBQAD
9
+ ggEPADCCAQoCggEBAL+DUWtN2tbIJzI1HvvQ9bf/WJfW4cIp/vaFvmd5XhVH3O8+
10
+ /uRsqHF6IOyMV8xQPzC3TeUZLxFa1QZhgSZAayugALKf74dUOEk4TekedJIrDLLl
11
+ xOqRpn+r14zNVxyO+/4iEeozXkCjVSG5DcBtG/LYmb6Hlf3DAA/nn2qMcW7OxR/E
12
+ So9SXNQLH32PzRzF9q5MtULYWaCv4IVj0itrf8lvsCkmiDX/tbCSxSMNwqlWs7ip
13
+ 12hGzPjyYcrBbmsPxsMPmhcorwGw8bOMwJVBr0QAGWYXwXD9KYlOAERq39/XeQ5p
14
+ MfefBNaJHd9RsqkzQ1kzG9lqypiWyTuppJhhvb8CAwEAATANBgkqhkiG9w0BAQsF
15
+ AAOCAQEAusVE7Anl9seWn3okeuvZlo+Fso9RfGroMWkoyLDyzyeQvh1CgzRqMyi9
16
+ I3AEIPPbNDBBEO8yAkUMwt0aCFa5KEjfTgIOMqqHpf4voRFqdK/Tmt3GT71vwqLD
17
+ EGzEK4YsbprJ2xqXxxpajTebn8EvZJrw6zJzLxRils78tALL9keaD13XHQwe3NhE
18
+ JSbRVi0hytruXR/XcxNU4hHriRT0rh22I0w8kLIeuwoDWBAjFiIvqKIifxI6KWDV
19
+ vezkw7AB8oANJr6/n7XMADIwnANU7lSOXHTMfsqwtIyL9qZBNwWE2gOcvSLBmHud
20
+ XZouhmNnLs9UdZEBEocrxmHzXwtVIg==
21
+ -----END CERTIFICATE-----
@@ -0,0 +1,28 @@
1
+ -----BEGIN PRIVATE KEY-----
2
+ MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQC/g1FrTdrWyCcy
3
+ NR770PW3/1iX1uHCKf72hb5neV4VR9zvPv7kbKhxeiDsjFfMUD8wt03lGS8RWtUG
4
+ YYEmQGsroACyn++HVDhJOE3pHnSSKwyy5cTqkaZ/q9eMzVccjvv+IhHqM15Ao1Uh
5
+ uQ3AbRvy2Jm+h5X9wwAP559qjHFuzsUfxEqPUlzUCx99j80cxfauTLVC2Fmgr+CF
6
+ Y9Ira3/Jb7ApJog1/7WwksUjDcKpVrO4qddoRsz48mHKwW5rD8bDD5oXKK8BsPGz
7
+ jMCVQa9EABlmF8Fw/SmJTgBEat/f13kOaTH3nwTWiR3fUbKpM0NZMxvZasqYlsk7
8
+ qaSYYb2/AgMBAAECggEBAJ/sgeYQSomG9KxJjckM0tRGp+2L5FQmi6HDR5/Sys0M
9
+ iKNEwMdxMSwppyrBe2PDMzF0MNj6McLVTgSZEacmrhfs8gg35Gbm3mXOXckoxIF2
10
+ 75DIrKqQ3C/LCSGsK21OvYGXY8xl/vQNML8LcD9bHbaqR6DCSm9xEjE143qvMt4q
11
+ 3GqyVwFCvy44J0ZQ4DvgV3MZEkesMNIIH22nGXgsf0aeNKxjO0S2A6DHf3DL9l8l
12
+ 4y1DXYS4CodQFvx/EpQyGvVdwIo/Hb9de2syb/n92/BZ/aP3dCfLbUfTxKtCAptw
13
+ xQVD306GO6Tkb6wF9L201zBG7ELSVmd/46zpE5OPZHECgYEA517amlwnsMZFjf3t
14
+ Im0Ugxm7QelZP9PDmu7T97gdnuK1ieoE0p1sh/DaIIbkDYvYskD8QlSwr+pKEsts
15
+ 5OaHWwEmwfwaOUpQ/Kj9Wyo3TMMy/VI1z+0UKfhkm7aE6FdKVsEAU5BIJW/QAPTV
16
+ NGt7UQoCzXwAFiI9QO+7gvTEpxkCgYEA0+ZLQ15ut6s5RnSn7552V3vPncX/7JH0
17
+ jwVONuCHuL38eo5McT12+/blGEL9Iw+UTst/EoUMMD+bfEVN+7gpsNiIVnAliQdO
18
+ sUyjj6pqajhvwDrfDoHD16xDKVQ5FQK0ZaEYaJZv7j92VdGdymH0V3TBWzwQ9M91
19
+ s3pc46RIXpcCgYBVMfREypJC4X9THaFn/8qBy8PMLWSTwCJStoaOvNkLXGeEdQt5
20
+ kkYYeHOZbpIi+s+8M3mv4wd8f0TvTsC2OLy2oeHnpDDzz42qu38vRog+V9I6vT7b
21
+ ZWz7V1+UhszB0QKqlz7LhmFKh7WL5JttRfaOjKUjjPlrLQhpFN1zBzYyYQKBgEDk
22
+ V8wr0TBCKWogM4W4O3mTGwOwLS3fjMt3znoTzLyQwg8uIM7VCekjtQj3Ctp/3OU8
23
+ gI/FWvQzpoQqHTWnMm1MAoSmF3idWkYFuFk40Rnyapat8L1alAUqZe70Mf7zMxek
24
+ e/sbhu+pU634YaAm21MlGEm+XVr7ZYovQN8d4mPFAoGBAMlNevRguVVuFt//iu4z
25
+ nPF/6qzaTXMk97YHPK8A7RXbXamGb6/RELrmbfLnwD4sEJjRl1cMt08EKPpfFZ1n
26
+ xcR7UcbF2m86xLPQgCqgPMyR3xyYFr5G9DvmbgUCgdN69Q0sD3IW5SOjfwNtbtZi
27
+ M1O6nwbvDbHOFQ9PsCxV23hP
28
+ -----END PRIVATE KEY-----
package/package.json CHANGED
@@ -1,48 +1,72 @@
1
1
  {
2
2
  "name": "grnsight",
3
- "version": "3.0.0",
3
+ "version": "5.1.0",
4
4
  "description": "Web app and service for visualizing models of gene regulatory networks",
5
5
  "directories": {
6
6
  "test": "test"
7
7
  },
8
8
  "dependencies": {
9
- "body-parser": "^1.18.2",
9
+ "body-parser": "1.18.2",
10
+ "canvg": "2.0.0",
10
11
  "cors": "2.8.1",
11
12
  "cytoscape": "2.7.14",
12
- "d3-v4-grid": "^2.0.1",
13
- "errorhandler": "^1.5.0",
14
- "express": "^4.16.0",
13
+ "d3-v4-grid": "2.0.1",
14
+ "dotenv": "^8.2.0",
15
+ "errorhandler": "1.5.0",
16
+ "express": "4.16.0",
17
+ "fs": "0.0.1-security",
15
18
  "googleapis": "1.1.5",
16
- "jade": "1.11.0",
17
- "method-override": "^2.3.10",
18
- "moment": "2.17.1",
19
- "morgan": "^1.9.0",
20
- "multiparty": "4.1.3",
19
+ "http": "0.0.0",
20
+ "jspdf": "1.5.3",
21
+ "method-override": "2.3.10",
22
+ "moment": "2.24.0",
23
+ "morgan": "1.9.1",
24
+ "multiparty": "4.2.2",
21
25
  "node-xlsx": "0.7.2",
22
- "nodemon": "1.11.0",
23
- "parallelshell": "^3.0.1",
24
- "serve-static": "^1.13.1",
26
+ "nodemon": "1.19.1",
27
+ "parallelshell": "3.0.1",
28
+ "pg": "^8.0.0",
29
+ "pg-hstore": "^2.3.3",
30
+ "pug": "^3.0.2",
31
+ "querystring": "^0.2.0",
32
+ "save-svg-as-png": "1.4.14",
33
+ "sequelize": "^5.21.6",
34
+ "serve-static": "1.13.1",
25
35
  "should": "11.2.0",
26
- "stylus": "0.54.5",
36
+ "stylus": "^0.54.5",
27
37
  "supertest": "3.0.0",
28
- "webpack": "^4.0.0",
38
+ "url": "^0.11.0",
39
+ "webpack": "4.0.0",
29
40
  "xml2js": "0.4.17",
30
41
  "xmlbuilder": "8.2.2"
31
42
  },
32
43
  "devDependencies": {
33
- "chai": "1.10.0",
34
- "coveralls": "^2.13.1",
35
- "eslint": "^3.19.0",
44
+ "browser-env": "^3.3.0",
45
+ "chai": "4.1.2",
46
+ "coveralls": "2.13.1",
47
+ "eslint": "3.19.0",
48
+ "isomorphic-fetch": "2.2.1",
36
49
  "istanbul": "0.4.5",
50
+ "jquery": "^3.6.0",
37
51
  "jquery-extend": "2.0.3",
38
- "markdown-pdf": "^8.0.0",
52
+ "jsdom": "11.11.0",
53
+ "markdown-pdf": "8.0.0",
39
54
  "mocha": "2.5.3",
40
- "mocha-lcov-reporter": "^1.3.0",
41
- "webpack-cli": "^2.0.14"
55
+ "mocha-lcov-reporter": "1.3.0",
56
+ "nock": "10.0.6",
57
+ "sinon": "5.1.1",
58
+ "w3c-xmlserializer": "1.0.1",
59
+ "webpack-cli": "2.0.14",
60
+ "xmlserializer": "0.6.1"
61
+ },
62
+ "babel": {
63
+ "presets": [
64
+ "es2015"
65
+ ]
42
66
  },
43
67
  "scripts": {
44
68
  "webpack-start": "webpack --watch",
45
- "test": "mocha --reporter list",
69
+ "test": "mocha --reporter list --compilers js:babel-core/register",
46
70
  "start-dev": "parallelshell --wait \"nodemon web-client/app.js\" \"nodemon server/app.js\" \"webpack --watch --mode=development\"",
47
71
  "start-prod": "parallelshell --wait \"nodemon web-client/app.js\" \"nodemon server/app.js\" \"webpack --watch --mode=production\"",
48
72
  "coverage": "istanbul cover _mocha",
package/server/app.js CHANGED
@@ -15,8 +15,10 @@ var app = express();
15
15
  app.set("port", process.env.PORT || config.port || 3000);
16
16
  app.use(morgan("dev"));
17
17
  app.use(express.json());
18
- app.use(bodyParser.urlencoded({extended: true}));
19
- app.use(bodyParser.json());
18
+ // app.use(bodyParser.urlencoded({extended: true}));
19
+ // app.use(bodyParser.json());
20
+ app.use(bodyParser.json({limit: "50mb"}));
21
+ app.use(bodyParser.urlencoded({limit: "50mb", extended: true}));
20
22
  app.use(methodOverride());
21
23
  app.use(cors());
22
24
 
@@ -30,6 +32,8 @@ require(__dirname + "/controllers/spreadsheet-controller")(app);
30
32
  require(__dirname + "/controllers/export-controller")(app);
31
33
  require(__dirname + "/controllers/import-controller")(app);
32
34
  require(__dirname + "/controllers/ga-controller")(app);
35
+ require(__dirname + "/controllers/api-controllers")(app);
36
+ require(__dirname + "/controllers/database-controller")(app);
33
37
 
34
38
  // Don"t start the server if this app is run as a child process.
35
39
  if (!module.parent) {
@@ -10,28 +10,37 @@ module.exports = {
10
10
  root: rootPath,
11
11
  app: {
12
12
  name: "GRNsight"
13
- }
13
+ },
14
+ databaseHost: "localhost", // This will most likely stay as localhost due to tunneling.
15
+ databaseName: "postgres",
16
+ databaseDialect: "postgres"
14
17
  },
15
18
 
16
19
  production: {
17
20
  host: "grnsight.cs.lmu.edu",
18
21
  port: 3000,
19
- url: "http://" + this.host + "/server",
20
- corsOrigin: "http://grnsight.cs.lmu.edu",
22
+ url: "https://" + this.host + "/server",
23
+ corsOrigin: "//grnsight.cs.lmu.edu",
21
24
  root: rootPath,
22
25
  app: {
23
26
  name: "GRNsight"
24
- }
27
+ },
28
+ databaseHost: "grnsight2.cfimp3lu6uob.us-west-1.rds.amazonaws.com",
29
+ databaseName: "postgres",
30
+ databaseDialect: "postgres"
25
31
  },
26
32
 
27
33
  beta: {
28
34
  host: "grnsight.cs.lmu.edu",
29
35
  port: 4000,
30
- url: "http://" + this.host + "/beta/server/",
31
- corsOrigin: "http://grnsight.cs.lmu.edu",
36
+ url: "https://" + this.host + "/beta/server/",
37
+ corsOrigin: "//grnsight.cs.lmu.edu",
32
38
  root: rootPath,
33
39
  app: {
34
40
  name: "GRNsight"
35
- }
41
+ },
42
+ databaseHost: "grnsight2.cfimp3lu6uob.us-west-1.rds.amazonaws.com",
43
+ databaseName: "postgres",
44
+ databaseDialect: "postgres"
36
45
  }
37
46
  };
@@ -1,87 +1,324 @@
1
- // Parses "optimization_paramters," expression data sheets, and 2-column sheets
1
+ // Parses "optimization_paramters" and 2-column sheets
2
2
  // from GRNmap input or output workbook
3
3
 
4
- var TWO_COL_SHEET_NAMES = [
4
+ var constants = require(__dirname + "/workbook-constants");
5
+
6
+ const getSheetHeader = (sheetName, column, row) => {
7
+ if (row === 0) {
8
+ if (sheetName === "production_rates" || sheetName === "optimized_production_rates") {
9
+ return "production_rate";
10
+ } else if (sheetName === "degradation_rates") {
11
+ return "degradation_rate";
12
+ } else if (sheetName === "threshold_b" || sheetName === "optimized_threshold_b") {
13
+ return "threshold_b";
14
+ } else if (sheetName === "optimization_parameters") {
15
+ return (column === 0) ? "optimization_parameter" : "value";
16
+ } else if (sheetName === "optimization_diagnostics") {
17
+ return (column === 0) ? "Parameter" : "Value";
18
+ }
19
+ }
20
+ };
21
+
22
+ const optimizationParametersTypeKey = {
23
+ alpha: "number", "kk_max": "number", MaxIter: "number", TolFun: "number", MaxFunEval: "number",
24
+ TolX: "number", "production_function": "string", "L_curve": "number", "estimate_params": "number",
25
+ "make_graphs": "number", "fix_P": "number", "fix_b": "number", "expression_timepoints": "object",
26
+ Strain: "object", species: "string", "taxon_id": "number", "simulation_timepoints": "object", "b_or_tau" : "number"
27
+
28
+ };
29
+
30
+ const optimizationDiagnosticsParameters = ["LSE", "Penalty", "min LSE", "iteration count"];
31
+
32
+ const optimizationParametersObectKey = {
33
+ "expression_timepoints": "number", Strain: "string", "simulation_timepoints": "number"
34
+ };
35
+
36
+ const addWarning = (workbook, message) => {
37
+ let warningsCount;
38
+ if (!Object.keys(workbook).includes("warnings")) {
39
+ warningsCount = 0;
40
+ workbook.warnings = [];
41
+ } else {
42
+ warningsCount = workbook.warnings.length;
43
+ }
44
+ const MAX_WARNINGS = 75;
45
+ if (warningsCount < MAX_WARNINGS) {
46
+ workbook.warnings.push(message);
47
+ } else {
48
+ workbook.errors.push(constants.errors.warningsCountError);
49
+ return false;
50
+ }
51
+ };
52
+
53
+ const addError = (output, message) => {
54
+ const errorsCount = output.errors.length;
55
+ const MAX_ERRORS = 20;
56
+ if (errorsCount < MAX_ERRORS) {
57
+ output.errors.push(message);
58
+ } else {
59
+ output.errors.push(constants.errors.errorsCountError);
60
+ return false;
61
+ }
62
+ };
63
+
64
+ const TWO_COL_SHEET_NAMES = [
5
65
  "production_rates",
6
66
  "degradation_rates",
7
67
  "threshold_b",
8
68
  "optimized_production_rates",
9
- "optimized_threshold_b"];
10
-
11
- var EXPRESSION_SHEET_SUFFIXES = ["_expression", "_optimized_expression", "_sigmas"];
12
-
13
- var isExpressionSheet = function (sheetName) {
14
- return EXPRESSION_SHEET_SUFFIXES.some(function (suffix) {
15
- return sheetName.includes(suffix);
16
- });
17
- };
69
+ "optimized_threshold_b"
70
+ ];
18
71
 
19
- var fillArray = function (value, array, length) { // mutator
20
- while (array.length < length) {
21
- array.push(value);
72
+ const validGeneName = (output, sheetName, gene, row) => {
73
+ var maxGeneLength = 12;
74
+ var regex = /[^a-z0-9\_\-]/gi;
75
+ if (typeof gene !== "string") {
76
+ addError(output, constants.errors.invalidGeneTypeError(sheetName, gene, row));
77
+ return false;
78
+ } else if (gene.length > maxGeneLength) {
79
+ addError(output, constants.errors.invalidGeneLengthError(sheetName, gene, row));
80
+ return false;
81
+ } else if (gene.match(regex) !== null) {
82
+ addError(output, constants.errors.specialCharacterError(sheetName, gene, row));
83
+ return false;
22
84
  }
23
- return array;
85
+ return true;
24
86
  };
87
+ // Optimization Parameters Parser
88
+ const parseMetaDataSheet = (sheet) => {
89
+ let meta = {
90
+ data: {},
91
+ errors: [],
92
+ warnings: []
93
+ };
94
+ let paramType;
95
+ if (sheet.data[0][0] === undefined) {
96
+ addError(meta, constants.errors.missingColumnHeaderError(sheet.name, constants.numbersToLetters[0],
97
+ getSheetHeader(sheet.name, 0, 0)));
98
+ } else if (sheet.data[0][0] !== getSheetHeader(sheet.name, 0, 0)) {
99
+ addError(meta, constants.errors.incorrectColumnHeaderError(sheet.name, constants.numbersToLetters[0],
100
+ getSheetHeader(sheet.name, 0, 0)));
101
+ }
102
+ if (sheet.data[0][1] === undefined) {
103
+ addError(meta, constants.errors.missingColumnHeaderError(sheet.name, constants.numbersToLetters[1],
104
+ getSheetHeader(sheet.name, 1, 0)));
105
+ } else if (sheet.data[0][1] !== getSheetHeader(sheet.name, 1, 0)) {
106
+ addError(meta, constants.errors.incorrectColumnHeaderError(sheet.name, constants.numbersToLetters[1],
107
+ getSheetHeader(sheet.name, 1, 0)));
108
+ }
25
109
 
26
- var parseMetaDataSheet = function (sheet) {
27
- var meta = {};
28
110
  sheet.data.forEach(function (element, index) {
29
111
  if (index !== 0) {
30
- var value = element.slice(1);
112
+ const value = element.slice(1);
31
113
  // Extract element from array if array contains only 1 value
32
- meta[element[0]] = value.length > 1 ? value : value[0];
114
+ meta.data[element[0]] = value.length > 1 ? value : value[0];
33
115
  }
34
116
  });
117
+ for (let key in meta.data) {
118
+ paramType = optimizationParametersTypeKey[key];
119
+ if (paramType === "object") {
120
+ paramType = `list of ${optimizationParametersObectKey[key]}s`;
121
+ }
122
+ if (meta.data[key] === undefined) {
123
+ addWarning(meta, constants.warnings.unknownOptimizationParameter(sheet.name, key));
124
+ } else if (typeof meta.data[key] !== optimizationParametersTypeKey[key]) {
125
+ if (optimizationParametersTypeKey[key] !== "object" ||
126
+ typeof meta.data[key] !== optimizationParametersObectKey[key]) {
127
+ addWarning(meta, constants.warnings.invalidOptimizationParameter(sheet.name, key, paramType));
128
+ }
129
+ } else if (optimizationParametersTypeKey[key] === "object") {
130
+ for (let val of meta.data[key]) {
131
+ if (typeof val !== optimizationParametersObectKey[key]) {
132
+ // throw error once per object. Makes sure that errors list is not flooded
133
+ addWarning(meta, constants.warnings.invalidOptimizationParameter(sheet.name, key, paramType));
134
+ break;
135
+ }
136
+ }
137
+ }
138
+ }
35
139
  return meta;
36
140
  };
37
141
 
38
- var parseTwoColumnSheet = function (sheet) {
39
- var data = {};
40
- sheet.data.forEach(function (element, index) {
41
- if (index !== 0) {
42
- data[element[0]] = element[1];
142
+ const parseOptimizationDiagnosticsSheet = (sheet) => {
143
+ let output = {
144
+ data: {
145
+ Parameters: {},
146
+ MSE: {
147
+ "column-headers": [],
148
+ Genes: {}
149
+ },
150
+ },
151
+ errors: [],
152
+ warnings: [],
153
+ };
154
+ let currentParameter;
155
+ let currentValue;
156
+ let currentGene;
157
+ let currentMSE = [];
158
+ // Check Headers
159
+ if (sheet.data[0].length > 1) {
160
+ if (sheet.data[0][0] !== getSheetHeader(sheet.name, 0, 0)) {
161
+ addError(output, constants.errors.incorrectColumnHeaderError(sheet.name, constants.numbersToLetters[0],
162
+ getSheetHeader(sheet.name, 0, 0)));
43
163
  }
44
- });
45
- return data;
164
+ if (sheet.data[0][1] !== getSheetHeader(sheet.name, 1, 0)) {
165
+ addError(output, constants.errors.incorrectColumnHeaderError(sheet.name, constants.numbersToLetters[1],
166
+ getSheetHeader(sheet.name, 1, 0)));
167
+ }
168
+ } else {
169
+ // seems a bit sus, but we'll see if this works properly during testing :\
170
+ for (let col = 1; col >= sheet.data[0].length; col--) {
171
+ addError(output, constants.errors.missingColumnHeaderError(sheet.name, constants.numbersToLetters[col],
172
+ getSheetHeader(sheet.name, col, 0)));
173
+ }
174
+ }
175
+ // Check Parameter Section
176
+ let row = 1;
177
+ // a missing row is the indicator to move onto the MSE
178
+ while (sheet.data[row].length > 0) {
179
+ currentParameter = sheet.data[row][0];
180
+ currentValue = sheet.data[row][1];
181
+ if (currentParameter === undefined || currentParameter.replace(/\s+/g, "") === "") {
182
+ if (currentValue === undefined || currentValue.replace(/\s+/g, "") === "") {
183
+ // if there is no parameter or value assume that its time to move on
184
+ row++;
185
+ break;
186
+ }
187
+ }
188
+ if (sheet.data[row].length > 2) {
189
+ addWarning(output, constants.warnings.extraneousDataWarning(sheet.name, row + 1));
190
+ }
191
+ if (! optimizationDiagnosticsParameters.includes(currentParameter)) {
192
+ if (currentParameter === "Gene") {
193
+ row--;
194
+ break;
195
+ }
196
+ addWarning(output, constants.warnings.unknownOptimizationDiagnosticsParameter(sheet.name,
197
+ currentParameter));
198
+ } else if (typeof currentValue !== "number") {
199
+ addWarning(output, constants.warnings.invalidOptimizationDiagnosticsValue(sheet.name, currentParameter));
200
+ } else {
201
+ output.data.Parameters[currentParameter] = currentValue;
202
+ }
203
+ row++;
204
+ }
205
+ // Skip until Gene section
206
+ while (sheet.data[row] !== undefined && sheet.data[row].length < 1) {
207
+ row++;
208
+ }
209
+ // Check Gene section MSE's
210
+ if (sheet.data[row].length > 1) {
211
+ if (sheet.data[row][0] !== "Gene") {
212
+ addWarning(output, constants.warnings.incorrectMSEGeneHeaderWarning(sheet.name, row + 1));
213
+ }
214
+ for (let col = 1; col < sheet.data[row].length; col++) {
215
+ if (!sheet.data[row][col].includes("MSE")) {
216
+ addWarning(output, constants.warnings.incorrectMSEHeaderWarning(sheet.name, sheet.data[row][col],
217
+ row + 1, constants.numbersToLetters[col]));
218
+ }
219
+ // we still push the header (even tho it's sus) because the gene MSE's are
220
+ // dependent on the order of the column headers
221
+ output.data.MSE["column-headers"].push(sheet.data[row][col]);
222
+ }
223
+ row++;
224
+ // on to the actual genes
225
+ while (row < sheet.data.length) {
226
+ if (sheet.data[row].length > output.data.MSE["column-headers"].length + 1) {
227
+ addWarning(output, constants.warnings.extraneousDataWarning(sheet.name, row + 1));
228
+ }
229
+ currentGene = sheet.data[row][0];
230
+ // if it's a valid gene set the key = MSE value
231
+ if (validGeneName(output, sheet.name, currentGene, row)) {
232
+ for (let col = 1; col <= output.data.MSE["column-headers"].length; col++) {
233
+ if (typeof sheet.data[row][col] === "number") {
234
+ currentMSE.push(sheet.data[row][col]);
235
+ } else if (sheet.data[row][col] === undefined) {
236
+ addWarning(output, constants.warnings.missingMSEDataWarning(sheet.name, row + 1,
237
+ constants.numbersToLetters[col]));
238
+ } else {
239
+ addWarning(output, constants.warnings.invalidMSEDataWarning(sheet.name, row + 1,
240
+ constants.numbersToLetters[col]));
241
+ }
242
+ }
243
+ output.data.MSE.Genes[currentGene] = currentMSE;
244
+ currentMSE = [];
245
+ }
246
+ row++;
247
+ }
248
+ }
249
+ return output;
46
250
  };
47
251
 
48
- var parseExpressionSheet = function (sheet) {
49
- var expressionData = {};
50
- var geneData = {};
51
- expressionData["time_points"] = sheet.data[0].slice(1);
52
- var numberOfDataPoints = expressionData["time_points"].length;
53
- sheet.data.forEach(function (sheet) {
54
- var geneName = sheet[0];
55
- if (geneName) {
56
- var rowData = sheet.slice(1);
57
- // Sometimes, missing data is at the end of the row. In this case, pad the
58
- // array with nulls
59
- if (rowData.length < numberOfDataPoints) {
60
- fillArray(null, rowData, numberOfDataPoints);
252
+ const parseTwoColumnSheet = (sheet) => {
253
+ let output = {
254
+ data : {},
255
+ errors: [],
256
+ warnings: [],
257
+ };
258
+
259
+ let currentGene;
260
+ let currentValue;
261
+
262
+ // check to see if the genes are strings and the values are numbers
263
+
264
+ for (let row = 0; row < sheet.data.length; row++) {
265
+ if (sheet.data[row].length > 2) {
266
+ addWarning(output, constants.warnings.extraneousDataWarning(sheet.name, row + 1));
267
+ }
268
+ if (row === 0) {
269
+ if (sheet.data[row].length > 0) {
270
+ if (sheet.data[row][0] !== "id") {
271
+ addError(output, constants.errors.idLabelError(sheet.name));
272
+ }
273
+ }
274
+ if (sheet.data[row].length > 1) {
275
+ if (sheet.data[row][1] !== getSheetHeader(sheet.name, 1, row)) {
276
+ addError(output, constants.errors.incorrectColumnHeaderError(sheet.name,
277
+ constants.numbersToLetters[1],
278
+ getSheetHeader(sheet.name, 1, row)));
279
+ }
280
+ } else {
281
+ addError(output, constants.errors.missingColumnHeaderError(sheet.name, constants.numbersToLetters[1],
282
+ getSheetHeader(sheet.name, 1, row)));
283
+ }
284
+ } else {
285
+ currentGene = sheet.data[row][0];
286
+ currentValue = sheet.data[row][1];
287
+
288
+ if (validGeneName(output, sheet.name, currentGene, row + 1)) {
289
+ if (typeof currentValue === "number") {
290
+ output.data[currentGene] = currentValue;
291
+ } else {
292
+ addError(output, constants.errors.invalidValueError(sheet.name, currentValue, row + 1,
293
+ getSheetHeader(sheet.name, 1, row)));
294
+ }
61
295
  }
62
- geneData[geneName] = rowData;
63
296
  }
64
- });
65
- expressionData["data"] = geneData;
66
- return expressionData;
297
+ }
298
+
299
+ return output;
67
300
  };
68
301
 
69
- module.exports = function (workbook) {
70
- var output = {
71
- expression: {}, // expression data
72
- meta: {},
73
- test: {} // 2-column data
302
+ module.exports = function (workbookFile) {
303
+ let output = {
304
+ meta: {
305
+ data: {},
306
+ errors: [],
307
+ warnings: []
308
+ }, // optimization_parameters only
309
+ test: {}, // 2-column data
310
+ meta2: {} // optimation_diagnostics only //temporary until where it goes is decided
74
311
  };
75
- workbook.forEach(function (sheet) {
312
+ workbookFile.forEach(function (sheet) {
76
313
  if (sheet.name === "optimization_parameters") {
77
- output["meta"] = parseMetaDataSheet(sheet);
78
- // Parse 2-column sheets
314
+ output.meta = parseMetaDataSheet(sheet);
315
+ // above line creates an object from the optimization paramerters sheet
316
+ // these are part of the "meta" property
79
317
  } else if (TWO_COL_SHEET_NAMES.includes(sheet.name)) {
80
318
  output["test"][sheet.name] = parseTwoColumnSheet(sheet);
81
- // Parse expression sheets
82
- } else if (isExpressionSheet(sheet.name)) {
83
- output["expression"][sheet.name] = parseExpressionSheet(sheet);
319
+ } else if (sheet.name === "optimization_diagnostics") {
320
+ output.meta2 = parseOptimizationDiagnosticsSheet(sheet);
84
321
  }
85
322
  });
86
323
  return output;
87
- };
324
+ };
@@ -0,0 +1,36 @@
1
+ module.exports = function (app) {
2
+ const request = require("request");
3
+
4
+ const UNIPROT_HOST = " http://www.uniprot.org";
5
+ const JASPAR_HOST = "http://jaspar.genereg.net";
6
+ const YEASTMINE_HOST = "https://www.yeastgenome.org";
7
+ const NCBI_HOST = "https://eutils.ncbi.nlm.nih.gov";
8
+ const ENSEMBL_HOST = "http://rest.ensembl.org";
9
+
10
+ const relay = (req, res, host) => {
11
+ const url = host + req.url;
12
+ res.header("Access-Control-Allow-Origin", "*");
13
+ res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
14
+ req.pipe(request(url)).pipe(res);
15
+ };
16
+
17
+ app.use("/uniprot/", (req, res) => {
18
+ relay(req, res, UNIPROT_HOST);
19
+ });
20
+
21
+ app.use("/jaspar/", (req, res) => {
22
+ relay(req, res, JASPAR_HOST);
23
+ });
24
+
25
+ app.use("/yeastmine/", (req, res) => {
26
+ relay(req, res, YEASTMINE_HOST);
27
+ });
28
+
29
+ app.use("/ncbi/", (req, res) => {
30
+ relay(req, res, NCBI_HOST);
31
+ });
32
+
33
+ app.use("/ensembl/", (req, res) => {
34
+ relay(req, res, ENSEMBL_HOST);
35
+ });
36
+ };