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.
- package/.eslintignore +1 -0
- package/.travis.yml +1 -1
- package/GRNsight - Beta.html +194 -0
- package/Gemfile.lock +259 -0
- package/README.md +1 -1
- package/_gh_pages/about.html +360 -45
- package/_gh_pages/assets/css/footer.css +3 -0
- package/_gh_pages/assets/css/main.css +28 -14
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_estimation_output_binary-no-targetless-genes_sif.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_estimation_output_binary_sif.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_3-edges-and-footer.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_header-and-3-nodes.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_output_3-edges-and-footer.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_graphml_output_header-and-3-nodes.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_binary-no-targetless-genes_sif.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_binary_sif.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_concatenated-no-targetless-genes_sif.png +0 -0
- package/_gh_pages/assets/images/21-genes_31-edges_Schade-data_input_concatenated_sif.png +0 -0
- package/_gh_pages/assets/images/Choe-Shin_CMSI402-poster-session_20180430.jpg +0 -0
- package/_gh_pages/assets/images/Choe_SCCUR_2017.jpg +0 -0
- package/_gh_pages/assets/images/Dahlquist-Choe-Shin_CMSI402-poster-session_20180430.jpg +0 -0
- package/_gh_pages/assets/images/Dionisio-Dahlquist_GRNsight-shades_20170506.jpg +0 -0
- package/_gh_pages/assets/images/Klein_Samdarshi_TriBeta_2018_20180317.jpg +0 -0
- package/_gh_pages/assets/images/Shin_SCCUR_2017.jpg +0 -0
- 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
- 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
- package/_gh_pages/assets/images/gene-pages-0.png +0 -0
- package/_gh_pages/assets/images/gene-pages-1.png +0 -0
- package/_gh_pages/assets/images/gene-pages-2.png +0 -0
- package/_gh_pages/assets/images/gene-pages-3.png +0 -0
- package/_gh_pages/assets/images/grnsight2020.png +0 -0
- package/_gh_pages/assets/images/v3demo2-grid+nodecoloring.png +0 -0
- package/_gh_pages/assets/images/v3demo2-nodecoloring.png +0 -0
- package/_gh_pages/assets/images/v3demo2.png +0 -0
- package/_gh_pages/assets/js/ga-report.js +11 -11
- package/_gh_pages/assets/js/iframeResizer.min.js +9 -0
- package/_gh_pages/assets/js/main.js +43 -43
- package/_gh_pages/beta.html +29 -24
- package/_gh_pages/contact.html +31 -31
- package/_gh_pages/coverage/coverage.json +1 -0
- package/_gh_pages/coverage/coverage.raw.json +1 -0
- package/_gh_pages/coverage/lcov-report/base.css +223 -0
- package/_gh_pages/coverage/lcov-report/block-navigation.js +63 -0
- package/_gh_pages/coverage/lcov-report/controllers/additional-sheet-parser.js.html +330 -0
- package/_gh_pages/coverage/lcov-report/controllers/constants.js.html +243 -0
- package/_gh_pages/coverage/lcov-report/controllers/export-controller.js.html +285 -0
- package/_gh_pages/coverage/lcov-report/controllers/exporters/graphml.js.html +405 -0
- package/_gh_pages/coverage/lcov-report/controllers/exporters/index.html +110 -0
- package/_gh_pages/coverage/lcov-report/controllers/exporters/sif.js.html +150 -0
- package/_gh_pages/coverage/lcov-report/controllers/helpers.js.html +114 -0
- package/_gh_pages/coverage/lcov-report/controllers/import-controller.js.html +233 -0
- package/_gh_pages/coverage/lcov-report/controllers/importers/graphml.js.html +716 -0
- package/_gh_pages/coverage/lcov-report/controllers/importers/index.html +106 -0
- package/_gh_pages/coverage/lcov-report/controllers/importers/sif.js.html +488 -0
- package/_gh_pages/coverage/lcov-report/controllers/index.html +162 -0
- package/_gh_pages/coverage/lcov-report/controllers/semantic-checker.js.html +810 -0
- package/_gh_pages/coverage/lcov-report/controllers/spreadsheet-controller.js.html +1779 -0
- package/_gh_pages/coverage/lcov-report/index.html +136 -0
- package/_gh_pages/coverage/lcov-report/prettify.css +1 -0
- package/_gh_pages/coverage/lcov-report/prettify.js +1 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/additional-sheet-parser.js.html +330 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/constants.js.html +243 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/export-controller.js.html +285 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/exporters/graphml.js.html +405 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/exporters/index.html +110 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/exporters/sif.js.html +150 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/graphml-constants.js.html +585 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/helpers.js.html +114 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/import-controller.js.html +237 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/importers/graphml.js.html +585 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/importers/index.html +110 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/importers/sif.js.html +492 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/index.html +188 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/semantic-checker.js.html +810 -0
- package/_gh_pages/coverage/lcov-report/server/controllers/spreadsheet-controller.js.html +1779 -0
- package/_gh_pages/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/_gh_pages/coverage/lcov-report/sorter.js +158 -0
- package/_gh_pages/coverage/lcov-report/web-client/public/js/grnstate.js.html +225 -0
- package/_gh_pages/coverage/lcov-report/web-client/public/js/index.html +97 -0
- package/_gh_pages/coverage/lcov.info +49 -0
- package/_gh_pages/documentation.html +998 -320
- package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.aux +47 -0
- package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.bbl +73 -0
- package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.blg +52 -0
- package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.log +1056 -0
- package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.out +7 -0
- package/_gh_pages/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.synctex.gz +0 -0
- package/_gh_pages/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_text-only_revised-Dondi.docx +0 -0
- package/_gh_pages/encryption/server.cert +21 -0
- package/_gh_pages/encryption/server.key +28 -0
- package/_gh_pages/favicon.ico +0 -0
- package/_gh_pages/index.html +45 -22
- package/_gh_pages/links.html +47 -28
- package/_gh_pages/news.html +103 -21
- package/_gh_pages/onlyfooter.html +78 -0
- package/_gh_pages/onlyheader.html +64 -0
- package/_gh_pages/onlysidebar.html +73 -0
- package/_gh_pages/package-lock.json +14048 -0
- package/_gh_pages/people.html +129 -40
- package/_gh_pages/privacy.html +23 -17
- package/_gh_pages/publications.html +75 -33
- package/_gh_pages/robots.txt +1 -0
- package/_gh_pages/sitemap.xml +87 -74
- package/_gh_pages/test-files/import-samples/attributes.graphml +40 -0
- package/_gh_pages/test-files/import-samples/port.graphml +32 -0
- package/_gh_pages/test-files/import-samples/simple.graphml +31 -0
- package/_gh_pages/web-client/public/js/grnsight.min.js +2347 -0
- package/_gh_pages/web-client/public/stylesheets/grnsight.css +443 -0
- package/coverage/coverage.json +1 -1
- package/coverage/coverage.raw.json +1 -0
- package/coverage/lcov-report/base.css +18 -8
- package/coverage/lcov-report/block-navigation.js +63 -0
- package/coverage/lcov-report/controllers/additional-sheet-parser.js.html +330 -0
- package/coverage/lcov-report/controllers/constants.js.html +65 -61
- package/coverage/lcov-report/controllers/export-controller.js.html +96 -92
- package/coverage/lcov-report/controllers/exporters/graphml.js.html +168 -164
- package/coverage/lcov-report/controllers/exporters/index.html +36 -32
- package/coverage/lcov-report/controllers/exporters/sif.js.html +65 -61
- package/coverage/lcov-report/controllers/helpers.js.html +25 -21
- package/coverage/lcov-report/controllers/index.html +49 -45
- package/coverage/lcov-report/controllers/semantic-checker.js.html +403 -396
- package/coverage/lcov-report/controllers/spreadsheet-controller.js.html +973 -879
- package/coverage/lcov-report/index.html +45 -28
- package/coverage/lcov-report/server/controllers/additional-sheet-parser.js.html +330 -0
- package/coverage/lcov-report/server/controllers/constants.js.html +243 -0
- package/coverage/lcov-report/server/controllers/export-controller.js.html +285 -0
- package/coverage/lcov-report/server/controllers/exporters/graphml.js.html +405 -0
- package/coverage/lcov-report/server/controllers/exporters/index.html +110 -0
- package/coverage/lcov-report/server/controllers/exporters/sif.js.html +150 -0
- package/coverage/lcov-report/server/controllers/graphml-constants.js.html +585 -0
- package/coverage/lcov-report/server/controllers/helpers.js.html +114 -0
- package/coverage/lcov-report/server/controllers/import-controller.js.html +237 -0
- package/coverage/lcov-report/server/controllers/importers/graphml.js.html +585 -0
- package/coverage/lcov-report/server/controllers/importers/index.html +110 -0
- package/coverage/lcov-report/server/controllers/importers/sif.js.html +492 -0
- package/coverage/lcov-report/server/controllers/index.html +188 -0
- package/coverage/lcov-report/server/controllers/semantic-checker.js.html +810 -0
- package/coverage/lcov-report/server/controllers/spreadsheet-controller.js.html +1779 -0
- package/coverage/lcov-report/web-client/public/js/grnstate.js.html +225 -0
- package/coverage/lcov-report/web-client/public/js/index.html +97 -0
- package/coverage/lcov.info +1758 -876
- package/encryption/server.cert +21 -0
- package/encryption/server.key +28 -0
- package/package.json +46 -22
- package/server/app.js +6 -2
- package/server/config/config.js +16 -7
- package/server/controllers/additional-sheet-parser.js +292 -55
- package/server/controllers/api-controllers.js +36 -0
- package/server/controllers/constants.js +4 -37
- package/server/controllers/database-controller.js +129 -0
- package/server/controllers/demo-workbooks.js +5973 -0
- package/server/controllers/export-constants.js +78 -0
- package/server/controllers/export-controller.js +25 -3
- package/server/controllers/exporters/graphml.js +15 -15
- package/server/controllers/exporters/sif.js +7 -7
- package/server/controllers/exporters/xlsx.js +183 -0
- package/server/controllers/expression-sheet-parser.js +170 -0
- package/server/controllers/ga-controller.js +1 -1
- package/server/controllers/graphml-constants.js +0 -17
- package/server/controllers/helpers.js +25 -1
- package/server/controllers/import-controller.js +2 -2
- package/server/controllers/importers/graphml.js +17 -20
- package/server/controllers/importers/sif.js +22 -18
- package/server/controllers/network-sheet-parser.js +307 -0
- package/server/controllers/semantic-checker.js +30 -162
- package/server/controllers/sif-constants.js +36 -0
- package/server/controllers/spreadsheet-controller.js +277 -424
- package/server/controllers/workbook-constants.js +521 -0
- package/test/additional-sheet-parser-tests.js +147 -38
- package/test/api-tests.js +245 -0
- package/test/errors-adjacency-matrix-modifications.js +30 -29
- package/test/errors-gene-name-modifications.js +9 -0
- package/test/errors-graph-tests.js +4 -4
- package/test/errors-sheet-modifications.js +10 -2
- package/test/export-tests.js +431 -24
- package/test/expression-data-import-tests.js +113 -0
- package/test/grnstate-tests.js +29 -0
- package/test/import-graphml-tests.js +59 -40
- package/test/import-sif-tests.js +50 -37
- package/test/test.js +557 -93
- package/test/warnings-adjacency-matrix-modifications.js +8 -7
- package/test-files/additional-sheet-test-files/optimization-diagnostics-default.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-extraneous-data.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-incorrect-MSE-gene-header.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-incorrect-MSE-header.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-incorrect-column-headers.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-invalid-MSE-data.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-invalid-value.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-missing-MSE-data.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-missing-column-headers.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-missing-header.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-diagnostics-unknown-parameter.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-parameters-default.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-parameters-incorrect-headers.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-parameters-invalid-optimization-parameter.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-parameters-missing-headers.xlsx +0 -0
- package/test-files/additional-sheet-test-files/optimization-parameters-unknown-parameter.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-extraneous-data.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-incorrect-cell-A1.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-incorrect-column-header.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-invalid-gene-length.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-invalid-gene-type.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-invalid-value.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-missing-column-header.xlsx +0 -0
- package/test-files/additional-sheet-test-files/two-column-sheets-special-character.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/asymmetric-gene-order-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/asymmetric-gene-order-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-column-adjacent-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-column-adjacent-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-column-end-of-sheet-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-column-end-of-sheet-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-data-random-cell-both-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-data-random-cell-network-only-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-data-random-cell-network-only-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-data-random-cell-network-optimized-only-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-row-end-of-sheet-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/extra-row-end-of-sheet-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/incorrect-network-cell-A1.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-column-end-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-column-end-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-data-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-data-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-row-end-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-row-end-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-row-middle-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-row-middle-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-value-bottom-corner-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/missing-value-bottom-corner-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/value-replaced-w-spaces-both-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/value-replaced-w-spaces-net-only-input.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/value-replaced-w-spaces-net-op-only-output.xlsx +0 -0
- package/test-files/adjacency-matrix-modifications/value-replaced/342/200/223w-spaces-net-only-output.xlsx +0 -0
- package/test-files/demo-files/15-genes_28-edges_db5_Dahlquist-data_estimation_output.xlsx +0 -0
- package/test-files/demo-files/15-genes_28-edges_db5_Dahlquist-data_input.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_correct_numbering.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_different_number_of_columns.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_empty_column.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_empty_row.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_erroneous_data.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_extra_gene_name.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_incorrectly_ordered_time_points.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_mismatched_case_gene_names.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_mismatched_gene_names.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_missing_column_header.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_missing_data_error.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_missing_data_ok.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_missing_data_ok_export_exact.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_missing_gene_name.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_name_not_in_optparams.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_name_not_present.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_negative_time_points.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_non_numerical_time_points.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_not_existing.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_wrong_id_label.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_wrong_order_gene_names.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_wrong_sheet_name_case.xlsx +0 -0
- package/test-files/expression-data-test-sheets/expression_sheet_wrong_sheet_name_convention.xlsx +0 -0
- package/test-files/gene-name-modifications/NaN-as-gene-name-input.xlsx +0 -0
- package/test-files/gene-name-modifications/NaN-as-gene-name-output.xlsx +0 -0
- package/test-files/gene-name-modifications/mismatched-case-related-input.xlsx +0 -0
- package/test-files/gene-name-modifications/mismatched-case-related-output.xlsx +0 -0
- package/test-files/gene-name-modifications/mismatched-case-unrelated-input.xlsx +0 -0
- package/test-files/gene-name-modifications/mismatched-case-unrelated-output.xlsx +0 -0
- package/test-files/gene-name-modifications/numbers-as-gene-name-related-input.xlsx +0 -0
- package/test-files/gene-name-modifications/numbers-as-gene-name-related-output.xlsx +0 -0
- package/test-files/gene-name-modifications/numbers-as-gene-name-unrelated-input.xlsx +0 -0
- package/test-files/gene-name-modifications/numbers-as-gene-name-unrelated-output.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/{80-genes-0-edges.xlsx → 134-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{45-genes-max-edges.xlsx → 44-source-genes-45-target-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{1-gene-0-edges.xlsx → unused-files/1-gene-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{1-gene-1-edges.xlsx → unused-files/1-gene-1-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{10-genes-50-edges.xlsx → unused-files/10-genes-50-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{10-genes-90-edges.xlsx → unused-files/10-genes-90-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{100-genes-0-edges.xlsx → unused-files/100-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{110-genes-0-edges.xlsx → unused-files/110-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{120-genes-0-edges.xlsx → unused-files/120-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{130-genes-0-edges.xlsx → unused-files/130-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{140-genes-0-edges.xlsx → unused-files/140-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{150-genes-10000-edges.xlsx → unused-files/150-genes-10000-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{150-genes-20000-edges.xlsx → unused-files/150-genes-20000-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{150-genes-max-edges.xlsx → unused-files/150-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{160-genes-max-edges.xlsx → unused-files/160-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{20-genes-max-edges.xlsx → unused-files/20-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{25-genes-max-edges.xlsx → unused-files/25-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{30-genes-max-edges.xlsx → unused-files/30-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{34-genes-0-edges.xlsx → unused-files/34-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{34-genes-40-edges.xlsx → unused-files/34-genes-40-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{34-genes-65-edges.xlsx → unused-files/34-genes-65-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{34-genes-90-edges.xlsx → unused-files/34-genes-90-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{5-genes-max-edges.xlsx → unused-files/5-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{51-genes-max-edges.xlsx → unused-files/51-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{52-genes-max-edges.xlsx → unused-files/52-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{55-genes-0-edges.xlsx → unused-files/55-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{55-genes-max-edges.xlsx → unused-files/55-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{65-genes-0-edges.xlsx → unused-files/65-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{7-genes-max-edges.xlsx → unused-files/7-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{70-genes-0-edges.xlsx → unused-files/70-genes-0-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{9-genes-max-edges.xlsx → unused-files/9-genes-max-edges.xlsx} +0 -0
- package/test-files/graph-tests/different-sized-networks/{90-genes-0-edges.xlsx → unused-files/90-genes-0-edges.xlsx} +0 -0
- 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
- package/test-files/node-tests/long-gene-name-no-spaces-first.xlsx +0 -0
- package/test-files/node-tests/long-gene-name-no-spaces-second.xlsx +0 -0
- package/test-files/node-tests/long-gene-name-spaces.xlsx +0 -0
- package/test-files/species-test-data/15-genes_28-edges_db5_Dahlquist-data_input_no-species.xlsx +0 -0
- package/test-files/species-test-data/15-genes_28-edges_db5_Dahlquist-data_input_with-species.xlsx +0 -0
- package/test-files/species-test-data/3-gene_7-edge_elegans.xlsx +0 -0
- package/test-files/species-test-data/3-gene_7-edge_melanogaster.xlsx +0 -0
- package/test-files/species-test-data/3-gene_7-edge_musculus.xlsx +0 -0
- package/test-files/species-test-data/3-gene_7-edge_sapiens.xlsx +0 -0
- package/test-files/species-test-data/kev-fake-data-sapiens-no-exp-data.xlsx +0 -0
- package/test-files/spreadsheet-controller-test-files/sheet-name-capitalized-network-optimized-weights.xlsx +0 -0
- package/test-files/spreadsheet-controller-test-files/sheet-name-capitalized-network.xlsx +0 -0
- package/web-client/app.js +1 -1
- package/web-client/config/config.js +5 -5
- package/web-client/controllers/main.js +5 -1
- package/web-client/public/favicon.ico +0 -0
- package/web-client/public/gene/GRNSight.svg +689 -0
- package/web-client/public/gene/PageDesignREADME.md +1 -0
- package/web-client/public/gene/api.js +442 -0
- package/web-client/public/gene/info.css +181 -0
- package/web-client/public/gene/info.js +334 -0
- package/web-client/public/gene/integrationREADME.md +52 -0
- package/web-client/public/js/constants.js +182 -0
- package/web-client/public/js/getGeneInformationREADME.md +4 -0
- package/web-client/public/js/graph-statistics.js +7 -7
- package/web-client/public/js/graph.js +480 -476
- package/web-client/public/js/grnsight.js +10 -9
- package/web-client/public/js/grnsight.min.js +2335 -0
- package/web-client/public/js/grnstate.js +147 -0
- package/web-client/public/js/iframe-coordination.js +55 -0
- package/web-client/public/js/setup-handlers.js +617 -0
- package/web-client/public/js/setup-load-and-import-handlers.js +180 -0
- package/web-client/public/js/update-app.js +980 -0
- package/web-client/public/js/upload.js +352 -578
- package/web-client/public/js/warnings.js +60 -0
- package/web-client/public/lib/iframeSizer.contentWindow.min.js +10 -0
- package/{documents/SDF/CMSI_402/spring_2018/writtenStatusReport4 → web-client/public/lib/jaspar-front.html} +0 -0
- package/web-client/public/stylesheets/grnsight.styl +176 -26
- package/web-client/public/stylesheets/print.styl +10 -4
- package/web-client/views/{graph.jade → graph.pug} +1 -3
- package/web-client/views/info.pug +215 -0
- package/web-client/views/upload.pug +587 -0
- package/_gh_pages/Gemfile +0 -7
- package/_gh_pages/Gemfile.lock +0 -129
- package/documents/SDF/CMSI_402/spring_2014/Southwick_CMSI402_Spring2014_software-development-plan.md +0 -71
- package/documents/SDF/CMSI_402/spring_2014/Southwick_CMSI402_Spring2014_software-requirements-specification.md +0 -71
- package/documents/SDF/CMSI_402/spring_2014/use-case-diagram-spring-2014.jpg +0 -0
- package/documents/SDF/CMSI_402/spring_2017/Anguiano_402_Final_Presentation.pptx +0 -0
- package/documents/SDF/CMSI_402/spring_2017/Anguiano_402_Presentation_Final_Poster.pdf +0 -0
- package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_project-proposal-presentation.pptx +0 -0
- package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_project-proposal.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_software-development-plan.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2017/Anguiano_CMSI402_Spring2017_software-requirements-specification.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2017/Design Review Presentation.pptx +0 -0
- package/documents/SDF/CMSI_402/spring_2018/0402report.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2018/0409report.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2018/402-gantt.png +0 -0
- package/documents/SDF/CMSI_402/spring_2018/402SRS_GRNSightFeedback01.txt +0 -28
- package/documents/SDF/CMSI_402/spring_2018/402_SPD.md +0 -223
- package/documents/SDF/CMSI_402/spring_2018/ChoeShinCMSI402_Final.pptx +0 -0
- package/documents/SDF/CMSI_402/spring_2018/ProjectProposal.md +0 -22
- package/documents/SDF/CMSI_402/spring_2018/SoftwareRequirementsSpecification.md +0 -88
- package/documents/SDF/CMSI_402/spring_2018/homework/choe_eileen/Choe_Eileen_CMSI 402_HW1.pdf +0 -0
- package/documents/SDF/CMSI_402/spring_2018/homework/choe_eileen/Choe_Eileen_CMSI402_HW2.pdf +0 -0
- package/documents/SDF/CMSI_402/spring_2018/homework/shin_jen/402hw2.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2018/homework/shin_jen/Jen - 402Hw1.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2018/homework/shin_jen/Jen - hw3.docx +0 -0
- package/documents/SDF/CMSI_402/spring_2018/writtenStatusReport.docx +0 -0
- package/documents/Varshneya_Samdarshi_LMU_Symposium_2016.pptx +0 -0
- package/documents/abstracts/Anguiano_Varshneya_Undergraduate-Research-Symposium_2017_abstract.pdf +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/ACM-Reference-Format.bst +0 -3478
- package/documents/abstracts/SIGGRAPH 2017 Abstract/Figure1_zoom100.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/acmart.cls +0 -2352
- package/documents/abstracts/SIGGRAPH 2017 Abstract/acmart.ins +0 -29
- package/documents/abstracts/SIGGRAPH 2017 Abstract/always-weights.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/auto.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/networkA.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/networkB-normalized.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/networkB.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/never-weights.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/representative-image/screenshot.jpg +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/representative-image/screenshot3x2.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/representative-image/withweights3x2.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/screenshot-auto.png +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.bib +0 -85
- package/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.pdf +0 -0
- package/documents/abstracts/SIGGRAPH 2017 Abstract/siggraph-abstract-review.tex +0 -235
- package/documents/abstracts/SWE Collegiate Competition 2017.md +0 -9
- package/documents/abstracts/Varshneya_Samdarshi_Southern-California-Systems-Biology_2017_abstract.docx +0 -0
- package/documents/developer_documents/State Diagram.graphml +0 -3525
- package/documents/developer_documents/graphml/State Diagram.graphml +0 -3115
- package/documents/developer_documents/older_versions/GRNsight State Diagram old.png +0 -0
- package/documents/developer_documents/older_versions/GRNsight State Diagram.png +0 -0
- package/documents/developer_documents/testing_script_generator/GRNsightTestingDocument.md +0 -998
- package/documents/developer_documents/testing_script_generator/featureList.json +0 -486
- package/documents/developer_documents/testing_script_generator/testing-script-generator.js +0 -149
- package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_conference-presentations_2016.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016_Table1.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016_references.rtf +0 -264
- package/documents/manuscripts/peerj-computerscience-2016/GRNsight_PeerJ-CS_manuscript_2016_text-only.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/21-genes_31-edges_Schade-data_for-screenshots.xlsx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom100.jpg +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom100.png +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom100.psd +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145.jpg +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145.png +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145.psd +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure1_zoom145_900pix-wide.psd +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom100.jpg +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom100.png +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom100.psd +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145.jpg +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145.png +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145.psd +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure2_zoom145_900pix-wide.psd +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5A.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5B.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5C.eps +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5D.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5E.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5F.eps +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/other-versions/Figure5_compiled.png +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure3_GRNsight-Architecture.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure4_GRNsight-Screenshot.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/figures/submitted-versions/Figure5_compiled.pdf +12 -5383
- package/documents/manuscripts/peerj-computerscience-2016/peerj-reviewing-10823-v0.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_conference-presentations_2016_revised.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_cover-letter-and-response_2016.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_cover-letter_2016.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_cover-letter_2016.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_Table1.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_references_revised.rtf +0 -385
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_text-only_revised.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_manuscript_2016_text-only_revised_marked.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_response-to-reviewers_2016.docx +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/GRNsight_PeerJ-CS_response-to-reviewers_2016.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/figures/Figure3_GRNsight-Architecture.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/figures/Figure4_GRNsight-Screenshot-auto.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/figures/Figure4_GRNsight-Screenshot.pdf +0 -0
- package/documents/manuscripts/peerj-computerscience-2016/revisions/peerj-reviewing-10823-v1.pdf +0 -0
- package/documents/posters/Anguiano_402_Presentation_Draft_Poster.pdf +0 -0
- package/documents/posters/Anguiano_402_Presentation_Draft_Poster.pptx +0 -0
- package/documents/posters/Anguiano_Varshneya_LMU-Symposium_2015_poster.pptx +0 -0
- package/documents/posters/Anguiano_Varshneya_SCCUR-Poster_20141122_poster.pptx +0 -0
- package/documents/posters/ChoeShinCMSI402-2.pptx +0 -0
- package/documents/posters/ChoeShinCMSI402.pptx +0 -0
- package/documents/posters/ChoeShinCMSI402Final.pptx +0 -0
- package/documents/posters/Dahlquist-et-al_BOSC_ISMB_2016_poster.pptx +0 -0
- package/documents/posters/Samdarshi et al. LMU Symposium 2017-finalDraft.pptx +0 -0
- package/documents/posters/Samdarshi et al. LMU Symposium 2018-firstDraft.pptx +0 -0
- package/documents/posters/Shin et al. SCCUR 2017 FinalDraft.pptx +0 -0
- package/documents/posters/Southwick_CMSI402_2014_poster.pptx +0 -0
- package/documents/posters/Varshneya_Samdarshi_LMU-Symposium_2016_poster.pptx +0 -0
- package/documents/posters/Varshneya_Samdarshi_Southern-California-Systems-Biology-Conference_2017_poster.pptx +0 -0
- package/documents/posters/~$Samdarshi et al. LMU Symposium 2018-firstDraft.pptx +0 -0
- package/documents/presentations/Anguiano_402_Final_Presentation.pptx +0 -0
- package/documents/presentations/Choe_SCCUR2017.pptx +0 -0
- package/documents/presentations/Choe_SWERapidFire2017_final.pptx +0 -0
- package/documents/presentations/Dahlquist_BOSC_20160709.pptx +0 -0
- package/documents/presentations/Dahlquist_ExperimentalBiology_20160404_talk.pptx +0 -0
- package/documents/presentations/Dahlquist_SoCalSysBio_20150131_talk.pptx +0 -0
- package/documents/presentations/Samdarshi et al. LMU Symposium 2017-draft.pptx +0 -0
- package/documents/presentations/Southwick_Anguiano_LMU-Symposium_20140329_talk.pptx +0 -0
- package/documents/presentations/Southwick_CMSI402_Presentation_20140508_talk.pptx +0 -0
- package/documents/presentations/Varshneya-Anguiano-LMU Symposium-201703.pptx +0 -0
- package/documents/presentations/~$Choe_SWERapidFire2017_final.pptx +0 -0
- package/documents/reports/Varshneya-201701-AnnotatedBibliography.docx +0 -0
- package/documents/reports/Varshneya-201702-Introduction.docx +0 -0
- package/documents/reports/Varshneya-201702-Outline.docx +0 -0
- package/documents/reports/Varshneya-201703-Discussion.docx +0 -0
- package/documents/reports/Varshneya-201703-MMResults.docx +0 -0
- package/documents/reports/Varshneya-201704-Draft-1.docx +0 -0
- package/documents/reports/Varshneya-201704-Final.docx +0 -0
- package/test/graph-library-tests.js +0 -165
- package/test-files/demo-files/21-genes_50-edges_Dahlquist-data_estimation_output.xlsx +0 -0
- package/test-files/demo-files/21-genes_50-edges_Dahlquist-data_input.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/10-genes-max-edges.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/12-genes-max-edges.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/35-genes-max-edges.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/40-genes-0-edges.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/40-genes-max-edges.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/42-genes-max-edges.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/50-genes-max-edges.xlsx +0 -0
- package/test-files/graph-tests/different-sized-networks/75-genes-150-edges.xlsx +0 -0
- package/web-client/public/js/container.js +0 -121
- package/web-client/public/js/node-coloring.js +0 -306
- package/web-client/public/js/sliders.js +0 -197
- 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
|
+
"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": "
|
|
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": "
|
|
13
|
-
"
|
|
14
|
-
"
|
|
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
|
-
"
|
|
17
|
-
"
|
|
18
|
-
"
|
|
19
|
-
"
|
|
20
|
-
"
|
|
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.
|
|
23
|
-
"parallelshell": "
|
|
24
|
-
"
|
|
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
|
-
"
|
|
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
|
-
"
|
|
34
|
-
"
|
|
35
|
-
"
|
|
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
|
-
"
|
|
52
|
+
"jsdom": "11.11.0",
|
|
53
|
+
"markdown-pdf": "8.0.0",
|
|
39
54
|
"mocha": "2.5.3",
|
|
40
|
-
"mocha-lcov-reporter": "
|
|
41
|
-
"
|
|
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) {
|
package/server/config/config.js
CHANGED
|
@@ -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: "
|
|
20
|
-
corsOrigin: "
|
|
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: "
|
|
31
|
-
corsOrigin: "
|
|
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
|
|
1
|
+
// Parses "optimization_paramters" and 2-column sheets
|
|
2
2
|
// from GRNmap input or output workbook
|
|
3
3
|
|
|
4
|
-
var
|
|
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
|
-
|
|
20
|
-
|
|
21
|
-
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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
|
-
|
|
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
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
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
|
-
|
|
66
|
-
return
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
return output;
|
|
67
300
|
};
|
|
68
301
|
|
|
69
|
-
module.exports = function (
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
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
|
-
|
|
312
|
+
workbookFile.forEach(function (sheet) {
|
|
76
313
|
if (sheet.name === "optimization_parameters") {
|
|
77
|
-
output
|
|
78
|
-
|
|
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
|
-
|
|
82
|
-
|
|
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
|
+
};
|