@openneuro/app 4.20.5 → 4.20.6-alpha.2
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/__mocks__/fileMock.js +1 -1
- package/package.json +5 -5
- package/pluralize-esm.js +204 -211
- package/src/@types/custom.d.ts +3 -3
- package/src/@types/react.d.ts +3 -4
- package/src/client.jsx +17 -16
- package/src/scripts/__mocks__/config.ts +6 -6
- package/src/scripts/__utils__/mock-app-shell.tsx +9 -8
- package/src/scripts/apm.js +6 -6
- package/src/scripts/app.tsx +7 -7
- package/src/scripts/authentication/__tests__/profile.spec.js +10 -10
- package/src/scripts/authentication/admin-user.jsx +2 -2
- package/src/scripts/authentication/logged-in.jsx +2 -2
- package/src/scripts/authentication/logged-out.jsx +2 -2
- package/src/scripts/authentication/loginCheck.js +2 -2
- package/src/scripts/authentication/loginUrls.ts +1 -1
- package/src/scripts/authentication/profile.ts +7 -7
- package/src/scripts/authentication/regular-user.tsx +3 -3
- package/src/scripts/authentication/signOut.ts +2 -2
- package/src/scripts/authentication/withProfile.jsx +6 -6
- package/src/scripts/common/block-navigation.jsx +3 -4
- package/src/scripts/common/containers/__tests__/header.spec.tsx +16 -16
- package/src/scripts/common/containers/footer.tsx +3 -3
- package/src/scripts/common/containers/header.tsx +30 -30
- package/src/scripts/common/forms/__tests__/warn-button.spec.jsx +6 -6
- package/src/scripts/common/forms/warn-button.jsx +21 -17
- package/src/scripts/common/partials/block-navigation.jsx +3 -4
- package/src/scripts/common/partials/freshdesk-widget.jsx +17 -20
- package/src/scripts/common/partials/toast-content.jsx +2 -2
- package/src/scripts/components/__tests__/data-table.spec.tsx +7 -7
- package/src/scripts/components/data-table.tsx +23 -22
- package/src/scripts/config.ts +2 -2
- package/src/scripts/datalad/dataset/comments-fragments.js +1 -1
- package/src/scripts/datalad/dataset/dataset-context.js +1 -1
- package/src/scripts/datalad/dataset/dataset-query-context.js +1 -1
- package/src/scripts/datalad/dataset/dataset-query-fragments.js +1 -1
- package/src/scripts/datalad/mutations/cache-clear.jsx +7 -6
- package/src/scripts/datalad/mutations/cache-id.js +2 -2
- package/src/scripts/datalad/mutations/delete-comment.jsx +13 -11
- package/src/scripts/datalad/mutations/delete.jsx +10 -9
- package/src/scripts/datalad/mutations/follow.jsx +12 -11
- package/src/scripts/datalad/mutations/publish.jsx +13 -12
- package/src/scripts/datalad/mutations/remove-permissions.jsx +8 -8
- package/src/scripts/datalad/mutations/revalidate.jsx +7 -6
- package/src/scripts/datalad/mutations/snapshot.tsx +7 -7
- package/src/scripts/datalad/mutations/star.jsx +12 -11
- package/src/scripts/datalad/mutations/submit-metadata.jsx +14 -12
- package/src/scripts/datalad/mutations/update-permissions.jsx +14 -13
- package/src/scripts/datalad/mutations/update-ref.jsx +7 -6
- package/src/scripts/datalad/routes/dataset-redirect.tsx +49 -49
- package/src/scripts/datalad/subscriptions/__tests__/files-subscription.spec.jsx +32 -32
- package/src/scripts/datalad/subscriptions/files-subscription.jsx +16 -16
- package/src/scripts/datalad/subscriptions/useDatasetDeletedSubscription.jsx +4 -4
- package/src/scripts/datalad/subscriptions/useDraftSubscription.js +4 -4
- package/src/scripts/datalad/subscriptions/usePermissionsSubscription.js +4 -4
- package/src/scripts/datalad/subscriptions/useSnapshotsUpdatedSubscriptions.js +3 -3
- package/src/scripts/dataset/__tests__/__snapshots__/snapshot-container.spec.tsx.snap +2 -2
- package/src/scripts/dataset/__tests__/snapshot-container.spec.tsx +12 -12
- package/src/scripts/dataset/comments/__tests__/comment.spec.jsx +21 -21
- package/src/scripts/dataset/comments/__tests__/comments.spec.jsx +10 -10
- package/src/scripts/dataset/comments/block-style-controls.jsx +15 -15
- package/src/scripts/dataset/comments/comment-editor.jsx +31 -31
- package/src/scripts/dataset/comments/comment.jsx +50 -50
- package/src/scripts/dataset/comments/comments.jsx +24 -22
- package/src/scripts/dataset/comments/inline-style-controls.jsx +9 -9
- package/src/scripts/dataset/comments/style-button.jsx +8 -9
- package/src/scripts/dataset/common/follow-toggles.tsx +3 -3
- package/src/scripts/dataset/dataset-query-context.js +1 -1
- package/src/scripts/dataset/dataset-query.jsx +34 -31
- package/src/scripts/dataset/dataset-routes.jsx +5 -5
- package/src/scripts/dataset/download/__tests__/download-command-line.spec.jsx +13 -13
- package/src/scripts/dataset/download/__tests__/download-link.spec.jsx +10 -10
- package/src/scripts/dataset/download/__tests__/download-native.spec.js +7 -7
- package/src/scripts/dataset/download/__tests__/shell-example.spec.jsx +5 -5
- package/src/scripts/dataset/download/download-command-line.jsx +9 -7
- package/src/scripts/dataset/download/download-datalad.jsx +22 -20
- package/src/scripts/dataset/download/download-derivative-datalad.tsx +2 -2
- package/src/scripts/dataset/download/download-derivative-s3.tsx +2 -2
- package/src/scripts/dataset/download/download-link.jsx +6 -6
- package/src/scripts/dataset/download/download-native.js +20 -19
- package/src/scripts/dataset/download/download-query.js +2 -3
- package/src/scripts/dataset/download/download-s3.jsx +8 -8
- package/src/scripts/dataset/download/download-script.tsx +23 -20
- package/src/scripts/dataset/download/native-file-toast.jsx +13 -11
- package/src/scripts/dataset/download/shell-example.jsx +1 -1
- package/src/scripts/dataset/download/track-download.js +5 -5
- package/src/scripts/dataset/draft-container.tsx +104 -102
- package/src/scripts/dataset/draft-snapshot-routes.tsx +3 -3
- package/src/scripts/dataset/files/__tests__/file-tree-unloaded-directory.spec.jsx +23 -23
- package/src/scripts/dataset/files/__tests__/file-tree.spec.jsx +57 -58
- package/src/scripts/dataset/files/__tests__/file-viewer-type.spec.jsx +6 -6
- package/src/scripts/dataset/files/__tests__/file.spec.jsx +15 -15
- package/src/scripts/dataset/files/file-display.jsx +11 -11
- package/src/scripts/dataset/files/file-tree-unloaded-directory.jsx +10 -10
- package/src/scripts/dataset/files/file-tree.tsx +27 -27
- package/src/scripts/dataset/files/file-view.jsx +4 -4
- package/src/scripts/dataset/files/file-viewer-type.jsx +21 -21
- package/src/scripts/dataset/files/file.tsx +85 -80
- package/src/scripts/dataset/files/files.tsx +41 -40
- package/src/scripts/dataset/files/index.tsx +2 -2
- package/src/scripts/dataset/files/viewers/__tests__/__snapshots__/file-viewer-json.spec.jsx.snap +0 -24
- package/src/scripts/dataset/files/viewers/__tests__/file-viewer-json.spec.jsx +9 -9
- package/src/scripts/dataset/files/viewers/__tests__/parse-tabular.spec.js +8 -8
- package/src/scripts/dataset/files/viewers/file-viewer-csv.jsx +5 -5
- package/src/scripts/dataset/files/viewers/file-viewer-html.jsx +3 -3
- package/src/scripts/dataset/files/viewers/file-viewer-json.jsx +4 -4
- package/src/scripts/dataset/files/viewers/file-viewer-nifti.tsx +4 -4
- package/src/scripts/dataset/files/viewers/file-viewer-table.tsx +3 -3
- package/src/scripts/dataset/files/viewers/file-viewer-text.jsx +3 -3
- package/src/scripts/dataset/files/viewers/file-viewer-tsv.jsx +5 -5
- package/src/scripts/dataset/files/viewers/parse-tabular.js +4 -4
- package/src/scripts/dataset/fragments/__tests__/cancel-button.spec.tsx +5 -5
- package/src/scripts/dataset/fragments/__tests__/dataset-alert-draft.spec.tsx +9 -9
- package/src/scripts/dataset/fragments/__tests__/dataset-citation.spec.jsx +10 -10
- package/src/scripts/dataset/fragments/__tests__/doi-link.spec.tsx +29 -29
- package/src/scripts/dataset/fragments/__tests__/edit-button.spec.tsx +5 -5
- package/src/scripts/dataset/fragments/__tests__/edit-list.spec.jsx +13 -13
- package/src/scripts/dataset/fragments/__tests__/save-button.spec.tsx +5 -5
- package/src/scripts/dataset/fragments/__tests__/select-input.spec.tsx +26 -26
- package/src/scripts/dataset/fragments/cancel-button.tsx +2 -2
- package/src/scripts/dataset/fragments/comments-fragments.js +1 -1
- package/src/scripts/dataset/fragments/copyable-tooltip.jsx +14 -13
- package/src/scripts/dataset/fragments/dataset-alert-draft.tsx +17 -13
- package/src/scripts/dataset/fragments/dataset-alert-version.tsx +5 -4
- package/src/scripts/dataset/fragments/dataset-citation.jsx +23 -21
- package/src/scripts/dataset/fragments/dataset-history.jsx +12 -12
- package/src/scripts/dataset/fragments/dataset-reviewers.ts +1 -1
- package/src/scripts/dataset/fragments/doi-link.tsx +6 -6
- package/src/scripts/dataset/fragments/edit-button.tsx +2 -2
- package/src/scripts/dataset/fragments/edit-description-field.jsx +23 -21
- package/src/scripts/dataset/fragments/edit-description-list.jsx +8 -8
- package/src/scripts/dataset/fragments/edit-list.jsx +8 -8
- package/src/scripts/dataset/fragments/number-input.tsx +36 -35
- package/src/scripts/dataset/fragments/save-button.tsx +2 -2
- package/src/scripts/dataset/fragments/select-input.tsx +87 -86
- package/src/scripts/dataset/fragments/text-array-input.tsx +38 -37
- package/src/scripts/dataset/fragments/text-input.tsx +79 -78
- package/src/scripts/dataset/mutations/__tests__/cache-id.spec.js +5 -5
- package/src/scripts/dataset/mutations/__tests__/delete-file.spec.jsx +85 -83
- package/src/scripts/dataset/mutations/__tests__/delete.spec.jsx +8 -8
- package/src/scripts/dataset/mutations/__tests__/deprecate-snapshot.spec.tsx +17 -17
- package/src/scripts/dataset/mutations/__tests__/deprecate-version.spec.tsx +19 -19
- package/src/scripts/dataset/mutations/__tests__/description.spec.jsx +51 -51
- package/src/scripts/dataset/mutations/__tests__/remove-permissions.spec.tsx +9 -9
- package/src/scripts/dataset/mutations/__tests__/update-permissions.spec.jsx +7 -7
- package/src/scripts/dataset/mutations/admin-exports.jsx +13 -12
- package/src/scripts/dataset/mutations/cache-clear.jsx +6 -6
- package/src/scripts/dataset/mutations/cache-id.js +2 -2
- package/src/scripts/dataset/mutations/comment.jsx +25 -23
- package/src/scripts/dataset/mutations/create-anonymous-reviewer.tsx +36 -30
- package/src/scripts/dataset/mutations/dataset-relations.tsx +28 -29
- package/src/scripts/dataset/mutations/delete-anonymous-reviewer.tsx +7 -8
- package/src/scripts/dataset/mutations/delete-comment.jsx +14 -12
- package/src/scripts/dataset/mutations/delete-dataset-form.jsx +20 -22
- package/src/scripts/dataset/mutations/delete-file.jsx +8 -8
- package/src/scripts/dataset/mutations/delete.jsx +10 -9
- package/src/scripts/dataset/mutations/deprecate-version.tsx +5 -6
- package/src/scripts/dataset/mutations/description.jsx +21 -20
- package/src/scripts/dataset/mutations/flag-annex-object.jsx +10 -9
- package/src/scripts/dataset/mutations/follow.tsx +15 -14
- package/src/scripts/dataset/mutations/import-dataset.tsx +5 -5
- package/src/scripts/dataset/mutations/metadata-form.jsx +94 -97
- package/src/scripts/dataset/mutations/publish.jsx +13 -13
- package/src/scripts/dataset/mutations/readme.jsx +12 -11
- package/src/scripts/dataset/mutations/remove-annex-object.jsx +10 -9
- package/src/scripts/dataset/mutations/remove-permissions.tsx +5 -6
- package/src/scripts/dataset/mutations/revalidate.jsx +7 -7
- package/src/scripts/dataset/mutations/snapshot.tsx +8 -8
- package/src/scripts/dataset/mutations/star.tsx +14 -13
- package/src/scripts/dataset/mutations/submit-metadata.jsx +12 -11
- package/src/scripts/dataset/mutations/undo-deprecate-version.tsx +5 -6
- package/src/scripts/dataset/mutations/update-file.jsx +6 -6
- package/src/scripts/dataset/mutations/update-permissions.tsx +9 -9
- package/src/scripts/dataset/mutations/update-ref.jsx +7 -7
- package/src/scripts/dataset/routes/__tests__/deprecate-snapshot-page.spec.tsx +5 -5
- package/src/scripts/dataset/routes/add-metadata.jsx +19 -20
- package/src/scripts/dataset/routes/admin-datalad.jsx +7 -7
- package/src/scripts/dataset/routes/dataset-default.tsx +12 -10
- package/src/scripts/dataset/routes/delete-page.tsx +12 -12
- package/src/scripts/dataset/routes/deprecate-snapshot-page.tsx +8 -8
- package/src/scripts/dataset/routes/derivatives.tsx +10 -10
- package/src/scripts/dataset/routes/download-dataset.tsx +20 -20
- package/src/scripts/dataset/routes/manage-anonymous-reviewers.tsx +37 -35
- package/src/scripts/dataset/routes/manage-permissions.jsx +22 -22
- package/src/scripts/dataset/routes/publish.jsx +32 -30
- package/src/scripts/dataset/routes/snapshot-default.tsx +7 -7
- package/src/scripts/dataset/routes/snapshot.tsx +44 -43
- package/src/scripts/dataset/routes/styles/dataset-page-border.tsx +3 -3
- package/src/scripts/dataset/routes/styles/dataset-page-tab-container.tsx +3 -3
- package/src/scripts/dataset/routes/styles/header-row.tsx +3 -3
- package/src/scripts/dataset/routes/tab-routes-draft.tsx +12 -12
- package/src/scripts/dataset/routes/tab-routes-snapshot.tsx +8 -8
- package/src/scripts/dataset/snapshot-container.tsx +78 -86
- package/src/scripts/errors/403page.tsx +11 -11
- package/src/scripts/errors/404page.tsx +12 -12
- package/src/scripts/errors/errorBoundary.jsx +13 -12
- package/src/scripts/errors/errorRoute.jsx +6 -6
- package/src/scripts/errors/freshdesk-widget.jsx +17 -20
- package/src/scripts/errors/freshdeskInterface.jsx +9 -9
- package/src/scripts/errors/orcid/email.jsx +3 -3
- package/src/scripts/errors/orcid/family.jsx +4 -4
- package/src/scripts/errors/orcid/general.jsx +1 -1
- package/src/scripts/errors/orcid/given.jsx +4 -4
- package/src/scripts/fixtures/dataset-query.ts +119 -119
- package/src/scripts/fixtures/mock-app-wrapper.tsx +4 -4
- package/src/scripts/index.tsx +9 -9
- package/src/scripts/pages/admin/admin.jsx +5 -5
- package/src/scripts/pages/admin/flagged-files.jsx +33 -31
- package/src/scripts/pages/admin/user-fragment.ts +1 -1
- package/src/scripts/pages/admin/user-tools.tsx +13 -11
- package/src/scripts/pages/admin/users.jsx +38 -39
- package/src/scripts/pages/api.jsx +20 -19
- package/src/scripts/pages/citation-page.tsx +4 -4
- package/src/scripts/pages/faq/faq.tsx +2 -2
- package/src/scripts/pages/front-page/aggregate-queries/aggregate-counts-container.tsx +6 -5
- package/src/scripts/pages/front-page/aggregate-queries/use-participant-count.ts +2 -2
- package/src/scripts/pages/front-page/aggregate-queries/use-publicDatasets-count.ts +2 -2
- package/src/scripts/pages/front-page/front-page-content.ts +42 -42
- package/src/scripts/pages/front-page/front-page.tsx +18 -14
- package/src/scripts/pages/front-page-comp.tsx +3 -3
- package/src/scripts/pages/import-dataset.tsx +10 -10
- package/src/scripts/pages/metadata/dataset-metadata.tsx +15 -14
- package/src/scripts/pages/pet-redirect.tsx +2 -2
- package/src/scripts/queries/dataset.ts +3 -3
- package/src/scripts/resources/__tests__/kibana.spec.js +9 -9
- package/src/scripts/resources/kibana.js +3 -3
- package/src/scripts/resources/strings.js +2 -2
- package/src/scripts/routes.tsx +14 -14
- package/src/scripts/search/__helpers__/search-render.tsx +3 -3
- package/src/scripts/search/__tests__/search-container.spec.tsx +22 -22
- package/src/scripts/search/__tests__/search-params-ctx.spec.tsx +20 -20
- package/src/scripts/search/es-query-builders.ts +21 -5
- package/src/scripts/search/filters-block-container.tsx +14 -16
- package/src/scripts/search/initial-search-params.tsx +45 -45
- package/src/scripts/search/inputs/__tests__/sort-by-select.spec.tsx +23 -23
- package/src/scripts/search/inputs/admin-allDatasets-toggle.tsx +12 -12
- package/src/scripts/search/inputs/age-range-input.tsx +9 -8
- package/src/scripts/search/inputs/author-input.tsx +14 -11
- package/src/scripts/search/inputs/date-radios.tsx +8 -7
- package/src/scripts/search/inputs/diagnosis-select.tsx +6 -6
- package/src/scripts/search/inputs/index.ts +33 -33
- package/src/scripts/search/inputs/keyword-input.tsx +13 -13
- package/src/scripts/search/inputs/modality-select.tsx +33 -30
- package/src/scripts/search/inputs/pet/bodyParts_input.tsx +18 -16
- package/src/scripts/search/inputs/pet/scannerManufacturersModelNames_input.tsx +18 -16
- package/src/scripts/search/inputs/pet/scannerManufacturers_input.tsx +18 -16
- package/src/scripts/search/inputs/pet/tracerNames_input.tsx +16 -15
- package/src/scripts/search/inputs/pet/tracerRadionuclides_input.tsx +18 -16
- package/src/scripts/search/inputs/section-select.tsx +6 -6
- package/src/scripts/search/inputs/sex-radios.tsx +6 -6
- package/src/scripts/search/inputs/show-datasets-radios.tsx +31 -29
- package/src/scripts/search/inputs/sort-by-select.tsx +10 -11
- package/src/scripts/search/inputs/species-select.tsx +6 -6
- package/src/scripts/search/inputs/study-domain-input.tsx +18 -16
- package/src/scripts/search/inputs/subject-count-range-input.tsx +8 -7
- package/src/scripts/search/inputs/task-input.tsx +18 -16
- package/src/scripts/search/search-container.tsx +83 -85
- package/src/scripts/search/search-params-ctx.tsx +40 -38
- package/src/scripts/search/search-routes.tsx +4 -4
- package/src/scripts/search/use-search-results.tsx +125 -99
- package/src/scripts/styles/media.tsx +3 -3
- package/src/scripts/styles/support-modal.jsx +2 -2
- package/src/scripts/sw.ts +12 -11
- package/src/scripts/test-utils.js +4 -4
- package/src/scripts/uploader/add-path-to-files.js +7 -7
- package/src/scripts/uploader/file-select.tsx +3 -3
- package/src/scripts/uploader/file-upload.js +13 -12
- package/src/scripts/uploader/input.jsx +8 -7
- package/src/scripts/uploader/upload-button.jsx +3 -3
- package/src/scripts/uploader/upload-disclaimer-input.tsx +66 -66
- package/src/scripts/uploader/upload-disclaimer.jsx +6 -5
- package/src/scripts/uploader/upload-file-status.jsx +4 -4
- package/src/scripts/uploader/upload-issues.jsx +32 -29
- package/src/scripts/uploader/upload-metadata.jsx +18 -17
- package/src/scripts/uploader/upload-mutation.js +17 -20
- package/src/scripts/uploader/upload-progress-button.jsx +5 -4
- package/src/scripts/uploader/upload-progress.jsx +3 -3
- package/src/scripts/uploader/upload-rename.jsx +6 -5
- package/src/scripts/uploader/upload-resume.jsx +26 -24
- package/src/scripts/uploader/upload-select.jsx +10 -9
- package/src/scripts/uploader/upload-status.jsx +5 -5
- package/src/scripts/uploader/upload-step.jsx +9 -9
- package/src/scripts/uploader/uploader-context.js +1 -1
- package/src/scripts/uploader/uploader-location.js +1 -1
- package/src/scripts/uploader/uploader-modal.jsx +8 -7
- package/src/scripts/uploader/uploader-setup-routes.jsx +10 -10
- package/src/scripts/uploader/uploader-status-routes.jsx +6 -6
- package/src/scripts/uploader/uploader-view.jsx +4 -4
- package/src/scripts/uploader/uploader.jsx +50 -48
- package/src/scripts/users/username.tsx +3 -3
- package/src/scripts/utils/__tests__/csv.spec.ts +16 -16
- package/src/scripts/utils/__tests__/date.spec.js +4 -4
- package/src/scripts/utils/__tests__/json-ld.spec.js +12 -12
- package/src/scripts/utils/__tests__/newid.spec.js +9 -9
- package/src/scripts/utils/__tests__/userNotify.spec.js +10 -10
- package/src/scripts/utils/analytics.tsx +3 -3
- package/src/scripts/utils/cookies.js +1 -1
- package/src/scripts/utils/csv.ts +13 -15
- package/src/scripts/utils/datalad.js +1 -1
- package/src/scripts/utils/dataset-url.js +2 -2
- package/src/scripts/utils/date.js +2 -2
- package/src/scripts/utils/global-polyfill.ts +2 -2
- package/src/scripts/utils/gtag.js +6 -6
- package/src/scripts/utils/json-ld.js +13 -13
- package/src/scripts/utils/newid.js +1 -1
- package/src/scripts/utils/user-login-modal-ctx.tsx +4 -4
- package/src/scripts/utils/userNotify.js +2 -2
- package/src/scripts/validation/validation-panel.jsx +3 -3
- package/src/scripts/validation/validation-results.issues.issue.jsx +9 -9
- package/src/scripts/validation/validation-results.issues.jsx +19 -17
- package/src/scripts/validation/validation-results.jsx +10 -10
- package/src/scripts/validation/validation-status.jsx +19 -17
- package/src/scripts/validation/validation.jsx +5 -5
- package/src/scripts/workers/schema.ts +2 -2
- package/src/scripts/workers/schema.worker.ts +4 -4
- package/src/scripts/workers/validate.ts +2 -2
- package/src/scripts/workers/validate.worker.ts +7 -5
- package/vite.config.js +17 -17
- package/src/dist/assets/activity-icon.9ab0c828.png +0 -0
- package/src/dist/assets/bids.da8810b3.jpg +0 -0
- package/src/dist/assets/brand_mark.28e7645d.png +0 -0
- package/src/dist/assets/close-button.21e700a6.png +0 -0
- package/src/dist/assets/cube-get.39ed5636.png +0 -0
- package/src/dist/assets/cube-share.9b558c29.png +0 -0
- package/src/dist/assets/cube-use.ccf2ddc5.png +0 -0
- package/src/dist/assets/datalad.a35b15b8.jpg +0 -0
- package/src/dist/assets/eeg.1dc1dc54.jpg +0 -0
- package/src/dist/assets/email-header.1cb8bf76.png +0 -0
- package/src/dist/assets/ieeg.f91deb0a.jpg +0 -0
- package/src/dist/assets/index.3db805fb.js +0 -23127
- package/src/dist/assets/index.3db805fb.js.map +0 -1
- package/src/dist/assets/index.5eb79d2c.css +0 -1
- package/src/dist/assets/ljaf.567e9566.png +0 -0
- package/src/dist/assets/logo_app.8c986cf9.png +0 -0
- package/src/dist/assets/logo_cube.5224b745.png +0 -0
- package/src/dist/assets/logo_data.3e1d5743.png +0 -0
- package/src/dist/assets/logo_users.a84a265a.png +0 -0
- package/src/dist/assets/meg.1e1928f8.jpg +0 -0
- package/src/dist/assets/mri.b01e4f42.jpg +0 -0
- package/src/dist/assets/nih-bi-logo.80d76e1d.png +0 -0
- package/src/dist/assets/nih-stanford.2a7c496e.jpg +0 -0
- package/src/dist/assets/nih.78a64d38.png +0 -0
- package/src/dist/assets/nimh.0ec775d8.png +0 -0
- package/src/dist/assets/nru-logo.f3097dc5.png +0 -0
- package/src/dist/assets/nsf.eee1d3f7.png +0 -0
- package/src/dist/assets/nsf.f87e96e7.png +0 -0
- package/src/dist/assets/on-dark-horz.e1f213d0.svg +0 -1
- package/src/dist/assets/on-dark.12f4e2ce.svg +0 -1
- package/src/dist/assets/on-light-horz.23ff22c3.svg +0 -1
- package/src/dist/assets/on-light.50592f7f.svg +0 -1
- package/src/dist/assets/pet-scan.21d98a3d.jpg +0 -0
- package/src/dist/assets/revicons.4ca02b8a.ttf +0 -0
- package/src/dist/assets/revicons.9e4d4c68.eot +0 -0
- package/src/dist/assets/revicons.f7b9c306.woff +0 -0
- package/src/dist/assets/sqm-logo.9cd0cca5.png +0 -0
- package/src/dist/assets/squishymedia.fa3c5919.png +0 -0
- package/src/dist/assets/stanford.5f245936.png +0 -0
- package/src/dist/index.html +0 -25
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import { gql } from
|
|
4
|
-
import { Mutation } from
|
|
5
|
-
import { DATASET_METADATA } from
|
|
6
|
-
import { datasetCacheId } from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import { gql } from "@apollo/client"
|
|
4
|
+
import { Mutation } from "@apollo/client/react/components"
|
|
5
|
+
import { DATASET_METADATA } from "../dataset/dataset-query-fragments.js"
|
|
6
|
+
import { datasetCacheId } from "./cache-id.js"
|
|
7
7
|
|
|
8
8
|
export const SUBMIT_METADATA = gql`
|
|
9
9
|
mutation addMetadata($datasetId: ID!, $metadata: MetadataInput!) {
|
|
@@ -43,25 +43,27 @@ const SubmitMetadata = ({ datasetId, metadata, done, disabled }) => (
|
|
|
43
43
|
id: datasetCacheId(datasetId),
|
|
44
44
|
fragment: DATASET_METADATA,
|
|
45
45
|
data: {
|
|
46
|
-
__typename:
|
|
46
|
+
__typename: "Dataset",
|
|
47
47
|
id: datasetId,
|
|
48
48
|
metadata: addMetadata,
|
|
49
49
|
},
|
|
50
50
|
})
|
|
51
|
-
}}
|
|
52
|
-
|
|
51
|
+
}}
|
|
52
|
+
>
|
|
53
|
+
{(submitMetadata) => (
|
|
53
54
|
<button
|
|
54
55
|
type="submit"
|
|
55
56
|
form="metadata-form"
|
|
56
|
-
className={`btn-modal-action${disabled ?
|
|
57
|
+
className={`btn-modal-action${disabled ? " btn-modal-danger" : ""}`}
|
|
57
58
|
disabled={disabled}
|
|
58
|
-
onClick={async e => {
|
|
59
|
+
onClick={async (e) => {
|
|
59
60
|
e.preventDefault()
|
|
60
61
|
await submitMetadata({
|
|
61
62
|
variables: { datasetId, metadata },
|
|
62
63
|
})
|
|
63
64
|
done()
|
|
64
|
-
}}
|
|
65
|
+
}}
|
|
66
|
+
>
|
|
65
67
|
Submit Metadata
|
|
66
68
|
</button>
|
|
67
69
|
)}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import { gql } from
|
|
4
|
-
import { Mutation } from
|
|
5
|
-
import { toast } from
|
|
6
|
-
import ToastContent from
|
|
7
|
-
import { validate as isValidEmail } from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import { gql } from "@apollo/client"
|
|
4
|
+
import { Mutation } from "@apollo/client/react/components"
|
|
5
|
+
import { toast } from "react-toastify"
|
|
6
|
+
import ToastContent from "../../common/partials/toast-content.jsx"
|
|
7
|
+
import { validate as isValidEmail } from "email-validator"
|
|
8
8
|
|
|
9
9
|
const UPDATE_PERMISSIONS = gql`
|
|
10
10
|
mutation updatePermissions(
|
|
@@ -30,15 +30,15 @@ export const mergeNewPermission = (
|
|
|
30
30
|
metadata,
|
|
31
31
|
) => {
|
|
32
32
|
return {
|
|
33
|
-
__typename:
|
|
33
|
+
__typename: "Dataset",
|
|
34
34
|
id: datasetId,
|
|
35
35
|
permissions: {
|
|
36
36
|
...oldPermissions,
|
|
37
37
|
userPermissions: [
|
|
38
38
|
...oldPermissions.userPermissions,
|
|
39
39
|
{
|
|
40
|
-
__typename:
|
|
41
|
-
user: { __typename:
|
|
40
|
+
__typename: "Permission",
|
|
41
|
+
user: { __typename: "User", ...userInfo },
|
|
42
42
|
level: metadata,
|
|
43
43
|
},
|
|
44
44
|
],
|
|
@@ -48,7 +48,7 @@ export const mergeNewPermission = (
|
|
|
48
48
|
|
|
49
49
|
const UpdateDatasetPermissions = ({ datasetId, userEmail, metadata, done }) => (
|
|
50
50
|
<Mutation mutation={UPDATE_PERMISSIONS}>
|
|
51
|
-
{UpdateDatasetPermissions => (
|
|
51
|
+
{(UpdateDatasetPermissions) => (
|
|
52
52
|
<button
|
|
53
53
|
className="btn-modal-action"
|
|
54
54
|
onClick={async () => {
|
|
@@ -68,7 +68,8 @@ const UpdateDatasetPermissions = ({ datasetId, userEmail, metadata, done }) => (
|
|
|
68
68
|
<ToastContent body="Please enter a valid email address" />,
|
|
69
69
|
)
|
|
70
70
|
}
|
|
71
|
-
}}
|
|
71
|
+
}}
|
|
72
|
+
>
|
|
72
73
|
Share
|
|
73
74
|
</button>
|
|
74
75
|
)}
|
|
@@ -78,7 +79,7 @@ const UpdateDatasetPermissions = ({ datasetId, userEmail, metadata, done }) => (
|
|
|
78
79
|
UpdateDatasetPermissions.propTypes = {
|
|
79
80
|
datasetId: PropTypes.string,
|
|
80
81
|
userEmail: PropTypes.string,
|
|
81
|
-
metadata: PropTypes.oneOf([
|
|
82
|
+
metadata: PropTypes.oneOf(["ro", "rw", "admin"]),
|
|
82
83
|
done: PropTypes.func,
|
|
83
84
|
}
|
|
84
85
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import { gql } from
|
|
4
|
-
import { Mutation } from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import { gql } from "@apollo/client"
|
|
4
|
+
import { Mutation } from "@apollo/client/react/components"
|
|
5
5
|
|
|
6
6
|
const RESET_DRAFT = gql`
|
|
7
7
|
mutation resetDraft($datasetId: ID!, $ref: String!) {
|
|
@@ -11,7 +11,7 @@ const RESET_DRAFT = gql`
|
|
|
11
11
|
|
|
12
12
|
const UpdateRef = ({ datasetId, revision }) => (
|
|
13
13
|
<Mutation mutation={RESET_DRAFT}>
|
|
14
|
-
{resetDraft => (
|
|
14
|
+
{(resetDraft) => (
|
|
15
15
|
<span>
|
|
16
16
|
<button
|
|
17
17
|
className="btn-admin-blue"
|
|
@@ -22,7 +22,8 @@ const UpdateRef = ({ datasetId, revision }) => (
|
|
|
22
22
|
ref: revision,
|
|
23
23
|
},
|
|
24
24
|
})
|
|
25
|
-
}}
|
|
25
|
+
}}
|
|
26
|
+
>
|
|
26
27
|
<i className="fa fa-history" /> Reset Draft Head
|
|
27
28
|
</button>
|
|
28
29
|
</span>
|
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import { Navigate,
|
|
1
|
+
import React from "react"
|
|
2
|
+
import { Navigate, useLocation, useParams } from "react-router-dom"
|
|
3
3
|
|
|
4
4
|
const redirectLib = {
|
|
5
|
-
ds001167:
|
|
6
|
-
ds002777:
|
|
7
|
-
ds001482:
|
|
8
|
-
ds002895:
|
|
9
|
-
ds003023:
|
|
10
|
-
ds003028:
|
|
11
|
-
ds002844:
|
|
12
|
-
ds002941:
|
|
13
|
-
ds001966:
|
|
14
|
-
ds002683:
|
|
15
|
-
ds001919:
|
|
16
|
-
ds002393:
|
|
17
|
-
ds001868:
|
|
18
|
-
ds002355:
|
|
19
|
-
ds001569:
|
|
20
|
-
ds002221:
|
|
21
|
-
ds001493:
|
|
22
|
-
ds001505:
|
|
23
|
-
ds001512:
|
|
24
|
-
ds001544:
|
|
25
|
-
ds001568:
|
|
26
|
-
ds001611:
|
|
27
|
-
ds001650:
|
|
28
|
-
ds001996:
|
|
29
|
-
ds002509:
|
|
30
|
-
ds001219:
|
|
31
|
-
ds002653:
|
|
32
|
-
ds001165:
|
|
33
|
-
ds001393:
|
|
34
|
-
ds001934:
|
|
35
|
-
ds002070:
|
|
36
|
-
ds001985:
|
|
37
|
-
ds002572:
|
|
38
|
-
ds001782:
|
|
39
|
-
ds002337:
|
|
40
|
-
ds002319:
|
|
41
|
-
ds001900:
|
|
42
|
-
ds002317:
|
|
43
|
-
ds002036:
|
|
44
|
-
ds001851:
|
|
45
|
-
ds001750:
|
|
46
|
-
ds002068:
|
|
47
|
-
ds002171:
|
|
48
|
-
ds002078:
|
|
49
|
-
ds002222:
|
|
50
|
-
ds002245:
|
|
51
|
-
ds001988:
|
|
5
|
+
ds001167: "ds003782",
|
|
6
|
+
ds002777: "ds003424",
|
|
7
|
+
ds001482: "ds003146",
|
|
8
|
+
ds002895: "ds003097",
|
|
9
|
+
ds003023: "ds003085",
|
|
10
|
+
ds003028: "ds003083",
|
|
11
|
+
ds002844: "ds003078",
|
|
12
|
+
ds002941: "ds003028",
|
|
13
|
+
ds001966: "ds003012",
|
|
14
|
+
ds002683: "ds002938",
|
|
15
|
+
ds001919: "ds002902",
|
|
16
|
+
ds002393: "ds002900",
|
|
17
|
+
ds001868: "ds002904",
|
|
18
|
+
ds002355: "ds002841",
|
|
19
|
+
ds001569: "ds002848",
|
|
20
|
+
ds002221: "ds002842",
|
|
21
|
+
ds001493: "ds002797",
|
|
22
|
+
ds001505: "ds002743",
|
|
23
|
+
ds001512: "ds002739",
|
|
24
|
+
ds001544: "ds002737",
|
|
25
|
+
ds001568: "ds002735",
|
|
26
|
+
ds001611: "ds002733",
|
|
27
|
+
ds001650: "ds002731",
|
|
28
|
+
ds001996: "ds002726",
|
|
29
|
+
ds002509: "ds002741",
|
|
30
|
+
ds001219: "ds002734",
|
|
31
|
+
ds002653: "ds002728",
|
|
32
|
+
ds001165: "ds002750",
|
|
33
|
+
ds001393: "ds002738",
|
|
34
|
+
ds001934: "ds002727",
|
|
35
|
+
ds002070: "ds002711",
|
|
36
|
+
ds001985: "ds002712",
|
|
37
|
+
ds002572: "ds002647",
|
|
38
|
+
ds001782: "ds002614",
|
|
39
|
+
ds002337: "ds002606",
|
|
40
|
+
ds002319: "ds002609",
|
|
41
|
+
ds001900: "ds002608",
|
|
42
|
+
ds002317: "ds002602",
|
|
43
|
+
ds002036: "ds002596",
|
|
44
|
+
ds001851: "ds002574",
|
|
45
|
+
ds001750: "ds002550",
|
|
46
|
+
ds002068: "ds002543",
|
|
47
|
+
ds002171: "ds002380",
|
|
48
|
+
ds002078: "ds002149",
|
|
49
|
+
ds002222: "ds002250",
|
|
50
|
+
ds002245: "ds002345",
|
|
51
|
+
ds001988: "ds001996",
|
|
52
52
|
}
|
|
53
53
|
|
|
54
54
|
const datasetIdPattern = /ds\d{6}/gim
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import { render } from
|
|
3
|
-
import { MockedProvider } from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import { render } from "@testing-library/react"
|
|
3
|
+
import { MockedProvider } from "@apollo/client/testing"
|
|
4
4
|
import FilesSubscription, {
|
|
5
5
|
deleteFilesReducer,
|
|
6
6
|
updateFilesReducer,
|
|
7
|
-
} from
|
|
7
|
+
} from "../files-subscription.jsx"
|
|
8
8
|
|
|
9
|
-
describe(
|
|
10
|
-
it(
|
|
9
|
+
describe("FilesSubscription", () => {
|
|
10
|
+
it("renders with common props", () => {
|
|
11
11
|
const { asFragment } = render(<FilesSubscription datasetId="ds001" />, {
|
|
12
12
|
wrapper: MockedProvider,
|
|
13
13
|
})
|
|
@@ -15,64 +15,64 @@ describe('FilesSubscription', () => {
|
|
|
15
15
|
})
|
|
16
16
|
})
|
|
17
17
|
|
|
18
|
-
describe(
|
|
18
|
+
describe("deleteFilesReducer", () => {
|
|
19
19
|
let draft, filesToDelete
|
|
20
20
|
beforeEach(() => {
|
|
21
21
|
draft = {
|
|
22
22
|
a: 1,
|
|
23
23
|
files: [
|
|
24
|
-
{ filename:
|
|
25
|
-
{ filename:
|
|
26
|
-
{ filename:
|
|
27
|
-
{ filename:
|
|
24
|
+
{ filename: "deleted/file.txt" },
|
|
25
|
+
{ filename: "another_deleted_file.txt" },
|
|
26
|
+
{ filename: "path/to/file.txt" },
|
|
27
|
+
{ filename: "deleted/file/again/here" },
|
|
28
28
|
],
|
|
29
|
-
steak:
|
|
29
|
+
steak: "sauce",
|
|
30
30
|
}
|
|
31
31
|
filesToDelete = [
|
|
32
|
-
{ filename:
|
|
33
|
-
{ filename:
|
|
32
|
+
{ filename: "deleted" },
|
|
33
|
+
{ filename: "another_deleted_file.txt" },
|
|
34
34
|
]
|
|
35
35
|
})
|
|
36
|
-
it(
|
|
36
|
+
it("removes files from draft", () => {
|
|
37
37
|
const output = deleteFilesReducer(filesToDelete, draft)
|
|
38
38
|
expect(output).toEqual({
|
|
39
39
|
a: 1,
|
|
40
|
-
files: [{ filename:
|
|
41
|
-
steak:
|
|
40
|
+
files: [{ filename: "path/to/file.txt" }],
|
|
41
|
+
steak: "sauce",
|
|
42
42
|
})
|
|
43
43
|
})
|
|
44
44
|
})
|
|
45
45
|
|
|
46
|
-
describe(
|
|
46
|
+
describe("updateFilesReducer", () => {
|
|
47
47
|
let draft, filesToUpdate
|
|
48
48
|
beforeEach(() => {
|
|
49
49
|
draft = {
|
|
50
50
|
a: 1,
|
|
51
51
|
files: [
|
|
52
|
-
{ filename:
|
|
53
|
-
{ filename:
|
|
54
|
-
{ filename:
|
|
52
|
+
{ filename: "updated/file.txt", id: "something" },
|
|
53
|
+
{ filename: "a.txt" },
|
|
54
|
+
{ filename: "b" },
|
|
55
55
|
],
|
|
56
|
-
steak:
|
|
56
|
+
steak: "sauce",
|
|
57
57
|
}
|
|
58
58
|
filesToUpdate = [
|
|
59
|
-
{ filename:
|
|
60
|
-
{ filename:
|
|
61
|
-
{ filename:
|
|
59
|
+
{ filename: "updated:file.txt", id: "somethingelse" },
|
|
60
|
+
{ filename: "new:file.txt", id: "x" },
|
|
61
|
+
{ filename: "another:new:file", id: "y" },
|
|
62
62
|
]
|
|
63
63
|
})
|
|
64
|
-
it(
|
|
64
|
+
it("removes files from draft", () => {
|
|
65
65
|
const output = updateFilesReducer(filesToUpdate, draft)
|
|
66
66
|
expect(output).toEqual({
|
|
67
67
|
a: 1,
|
|
68
68
|
files: [
|
|
69
|
-
{ filename:
|
|
70
|
-
{ filename:
|
|
71
|
-
{ filename:
|
|
72
|
-
{ filename:
|
|
73
|
-
{ filename:
|
|
69
|
+
{ filename: "updated/file.txt", id: "somethingelse" },
|
|
70
|
+
{ filename: "a.txt" },
|
|
71
|
+
{ filename: "b" },
|
|
72
|
+
{ filename: "new/file.txt", id: "x" },
|
|
73
|
+
{ filename: "another/new/file", id: "y" },
|
|
74
74
|
],
|
|
75
|
-
steak:
|
|
75
|
+
steak: "sauce",
|
|
76
76
|
})
|
|
77
77
|
})
|
|
78
78
|
})
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import { Subscription } from
|
|
4
|
-
import { gql } from
|
|
5
|
-
import { DRAFT_FILES_FRAGMENT } from
|
|
6
|
-
import { datasetCacheId } from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import { Subscription } from "@apollo/client/react/components"
|
|
4
|
+
import { gql } from "@apollo/client"
|
|
5
|
+
import { DRAFT_FILES_FRAGMENT } from "../dataset/dataset-query-fragments.js"
|
|
6
|
+
import { datasetCacheId } from "../mutations/cache-id.js"
|
|
7
7
|
// import { datasetCacheId } from '../mutations/cache-id.js'
|
|
8
8
|
|
|
9
9
|
const FILES_SUBSCRIPTION = gql`
|
|
@@ -28,24 +28,24 @@ const FILES_SUBSCRIPTION = gql`
|
|
|
28
28
|
*/
|
|
29
29
|
export const deleteFilesReducer = (files, draft) => {
|
|
30
30
|
const pathMatch = files
|
|
31
|
-
.map(({ filename }) => filename.split(
|
|
32
|
-
.join(
|
|
31
|
+
.map(({ filename }) => filename.split(":").join("\\/"))
|
|
32
|
+
.join("|")
|
|
33
33
|
return {
|
|
34
34
|
...draft,
|
|
35
|
-
files: draft.files.filter(file => !file.filename.match(pathMatch)),
|
|
35
|
+
files: draft.files.filter((file) => !file.filename.match(pathMatch)),
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
export const updateFilesReducer = (files, draft) => {
|
|
40
|
-
files = files.map(file => ({
|
|
40
|
+
files = files.map((file) => ({
|
|
41
41
|
...file,
|
|
42
|
-
filename: file.filename.split(
|
|
42
|
+
filename: file.filename.split(":").join("/"),
|
|
43
43
|
}))
|
|
44
44
|
const newFiles = []
|
|
45
45
|
const draftFiles = [...draft.files]
|
|
46
|
-
files.forEach(file => {
|
|
46
|
+
files.forEach((file) => {
|
|
47
47
|
const updatedFileIndex = draftFiles.findIndex(
|
|
48
|
-
draftFile =>
|
|
48
|
+
(draftFile) =>
|
|
49
49
|
draftFile.filename === file.filename || draftFile.id === file.id,
|
|
50
50
|
)
|
|
51
51
|
if (updatedFileIndex === -1) newFiles.push(file)
|
|
@@ -59,9 +59,9 @@ export const updateFilesReducer = (files, draft) => {
|
|
|
59
59
|
|
|
60
60
|
export const draftReducer = (draft, action, payload) => {
|
|
61
61
|
switch (action) {
|
|
62
|
-
case
|
|
62
|
+
case "DELETE":
|
|
63
63
|
return deleteFilesReducer(payload, draft)
|
|
64
|
-
case
|
|
64
|
+
case "UPDATE":
|
|
65
65
|
return updateFilesReducer(payload, draft)
|
|
66
66
|
default:
|
|
67
67
|
return { ...draft }
|
|
@@ -87,7 +87,7 @@ const FilesSubscription = ({ datasetId }) => (
|
|
|
87
87
|
id,
|
|
88
88
|
fragment: DRAFT_FILES_FRAGMENT,
|
|
89
89
|
data: {
|
|
90
|
-
__typename:
|
|
90
|
+
__typename: "Dataset",
|
|
91
91
|
id: datasetId,
|
|
92
92
|
draft: updatedDraft,
|
|
93
93
|
},
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import {
|
|
1
|
+
import React from "react"
|
|
2
|
+
import { gql, useSubscription } from "@apollo/client"
|
|
3
3
|
|
|
4
|
-
import { toast } from
|
|
5
|
-
import ToastContent from
|
|
4
|
+
import { toast } from "react-toastify"
|
|
5
|
+
import ToastContent from "../../common/partials/toast-content.jsx"
|
|
6
6
|
|
|
7
7
|
const DATASET_DELETED_SUBSCRIPTION = gql`
|
|
8
8
|
subscription datasetDeleted($datasetIds: [ID!]) {
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { gql, useSubscription } from "@apollo/client"
|
|
2
2
|
|
|
3
3
|
import {
|
|
4
|
-
DRAFT_FRAGMENT,
|
|
5
4
|
DATASET_ISSUES,
|
|
6
|
-
|
|
5
|
+
DRAFT_FRAGMENT,
|
|
6
|
+
} from "../dataset/dataset-query-fragments.js"
|
|
7
7
|
|
|
8
8
|
const DRAFT_SUBSCRIPTION = gql`
|
|
9
9
|
subscription draftUpdated($datasetId: ID!) {
|
|
@@ -17,7 +17,7 @@ const DRAFT_SUBSCRIPTION = gql`
|
|
|
17
17
|
${DATASET_ISSUES}
|
|
18
18
|
`
|
|
19
19
|
|
|
20
|
-
const useDraftSubscription = datasetId =>
|
|
20
|
+
const useDraftSubscription = (datasetId) =>
|
|
21
21
|
useSubscription(DRAFT_SUBSCRIPTION, {
|
|
22
22
|
variables: { datasetId },
|
|
23
23
|
shouldResubscribe: true,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { gql, useSubscription } from "@apollo/client"
|
|
2
2
|
|
|
3
|
-
import { PERMISSION_FRAGMENT } from
|
|
3
|
+
import { PERMISSION_FRAGMENT } from "../dataset/dataset-query-fragments.js"
|
|
4
4
|
|
|
5
5
|
const PERMISSIONS_SUBSCRIPTION = gql`
|
|
6
6
|
subscription permissionsUpdated($datasetIds: [ID!]) {
|
|
@@ -12,9 +12,9 @@ const PERMISSIONS_SUBSCRIPTION = gql`
|
|
|
12
12
|
${PERMISSION_FRAGMENT}
|
|
13
13
|
`
|
|
14
14
|
|
|
15
|
-
const usePermissionsSubscription = datasetIds =>
|
|
15
|
+
const usePermissionsSubscription = (datasetIds) =>
|
|
16
16
|
useSubscription(PERMISSIONS_SUBSCRIPTION, {
|
|
17
|
-
variables: { datasetIds: datasetIds || [
|
|
17
|
+
variables: { datasetIds: datasetIds || ["NULL_ID"] },
|
|
18
18
|
shouldResubscribe: true,
|
|
19
19
|
})
|
|
20
20
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { gql, useSubscription } from "@apollo/client"
|
|
2
2
|
|
|
3
|
-
import { DATASET_SNAPSHOTS } from
|
|
3
|
+
import { DATASET_SNAPSHOTS } from "../dataset/dataset-query-fragments.js"
|
|
4
4
|
|
|
5
5
|
export const SNAPSHOTS_UPDATED_SUBSCRIPTION = gql`
|
|
6
6
|
subscription snapshotsUpdated($datasetId: ID!) {
|
|
@@ -12,7 +12,7 @@ export const SNAPSHOTS_UPDATED_SUBSCRIPTION = gql`
|
|
|
12
12
|
${DATASET_SNAPSHOTS}
|
|
13
13
|
`
|
|
14
14
|
|
|
15
|
-
const useSnapshotsUpdatedSubscription = datasetId =>
|
|
15
|
+
const useSnapshotsUpdatedSubscription = (datasetId) =>
|
|
16
16
|
useSubscription(SNAPSHOTS_UPDATED_SUBSCRIPTION, {
|
|
17
17
|
variables: { datasetId },
|
|
18
18
|
shouldResubscribe: true,
|
|
@@ -258,7 +258,7 @@ exports[`SnapshotContainer component > renders successfully 1`] = `
|
|
|
258
258
|
>
|
|
259
259
|
<span>
|
|
260
260
|
<label>
|
|
261
|
-
Location:
|
|
261
|
+
Location:
|
|
262
262
|
</label>
|
|
263
263
|
<p>
|
|
264
264
|
/participants.tsv
|
|
@@ -269,7 +269,7 @@ exports[`SnapshotContainer component > renders successfully 1`] = `
|
|
|
269
269
|
class="e-meta"
|
|
270
270
|
>
|
|
271
271
|
<label>
|
|
272
|
-
Reason:
|
|
272
|
+
Reason:
|
|
273
273
|
</label>
|
|
274
274
|
<p>
|
|
275
275
|
Tabular file contains custom columns not described in a data dictionary
|
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import { render } from
|
|
3
|
-
import Helmet from
|
|
4
|
-
import { SnapshotContainer } from
|
|
5
|
-
import { MockAppWrapper } from
|
|
6
|
-
import { dataset, snapshot } from
|
|
7
|
-
import { vi } from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import { render } from "@testing-library/react"
|
|
3
|
+
import Helmet from "react-helmet"
|
|
4
|
+
import { SnapshotContainer } from "../snapshot-container"
|
|
5
|
+
import { MockAppWrapper } from "../../fixtures/mock-app-wrapper"
|
|
6
|
+
import { dataset, snapshot } from "../../fixtures/dataset-query"
|
|
7
|
+
import { vi } from "vitest"
|
|
8
8
|
|
|
9
|
-
vi.mock(
|
|
9
|
+
vi.mock("../../config.ts")
|
|
10
10
|
|
|
11
11
|
const defProps = {
|
|
12
12
|
dataset,
|
|
13
13
|
snapshot,
|
|
14
|
-
tag:
|
|
14
|
+
tag: "1.0.0",
|
|
15
15
|
}
|
|
16
16
|
|
|
17
|
-
describe(
|
|
18
|
-
it(
|
|
17
|
+
describe("SnapshotContainer component", () => {
|
|
18
|
+
it("renders successfully", () => {
|
|
19
19
|
const { asFragment } = render(<SnapshotContainer {...defProps} />, {
|
|
20
20
|
wrapper: MockAppWrapper,
|
|
21
21
|
})
|
|
22
22
|
expect(asFragment()).toMatchSnapshot()
|
|
23
23
|
})
|
|
24
|
-
it(
|
|
24
|
+
it("includes JSON-LD data in the header", () => {
|
|
25
25
|
render(<SnapshotContainer {...defProps} />, {
|
|
26
26
|
wrapper: MockAppWrapper,
|
|
27
27
|
})
|
|
@@ -1,48 +1,48 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import { render } from
|
|
3
|
-
import Comment from
|
|
4
|
-
import formatDistanceToNow from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import { render } from "@testing-library/react"
|
|
3
|
+
import Comment from "../comment.jsx"
|
|
4
|
+
import formatDistanceToNow from "date-fns/formatDistanceToNow"
|
|
5
5
|
|
|
6
|
-
vi.mock(
|
|
6
|
+
vi.mock("date-fns/formatDistanceToNow")
|
|
7
7
|
|
|
8
8
|
const emptyState =
|
|
9
9
|
'{"blocks":[{"key":"3sm42","text":"","type":"unstyled","depth":0,"inlineStyleRanges":[],"entityRanges":[],"data":{}}],"entityMap":{}}'
|
|
10
10
|
|
|
11
|
-
describe(
|
|
12
|
-
it(
|
|
13
|
-
formatDistanceToNow.mockReturnValueOnce(
|
|
11
|
+
describe("Comment component", () => {
|
|
12
|
+
it("renders with an empty comment", () => {
|
|
13
|
+
formatDistanceToNow.mockReturnValueOnce("almost 2 years")
|
|
14
14
|
|
|
15
15
|
const wrapper = render(
|
|
16
16
|
<Comment
|
|
17
17
|
data={{
|
|
18
|
-
id:
|
|
18
|
+
id: "9001",
|
|
19
19
|
text: emptyState,
|
|
20
20
|
user: {
|
|
21
|
-
id:
|
|
22
|
-
email:
|
|
23
|
-
name:
|
|
21
|
+
id: "1234",
|
|
22
|
+
email: "example@example.com",
|
|
23
|
+
name: "Example Exampler",
|
|
24
24
|
},
|
|
25
|
-
createDate: new Date(
|
|
25
|
+
createDate: new Date("2019-04-02T19:56:41.222Z").toISOString(),
|
|
26
26
|
}}
|
|
27
27
|
/>,
|
|
28
28
|
)
|
|
29
29
|
expect(wrapper).toMatchSnapshot()
|
|
30
30
|
})
|
|
31
|
-
it(
|
|
32
|
-
formatDistanceToNow.mockReturnValueOnce(
|
|
31
|
+
it("renders an ORCID user comment", () => {
|
|
32
|
+
formatDistanceToNow.mockReturnValueOnce("almost 2 years")
|
|
33
33
|
|
|
34
34
|
const wrapper = render(
|
|
35
35
|
<Comment
|
|
36
36
|
data={{
|
|
37
|
-
id:
|
|
37
|
+
id: "9001",
|
|
38
38
|
text: emptyState,
|
|
39
39
|
user: {
|
|
40
|
-
id:
|
|
41
|
-
email:
|
|
42
|
-
name:
|
|
43
|
-
orcid:
|
|
40
|
+
id: "1234",
|
|
41
|
+
email: "example@example.com",
|
|
42
|
+
name: "Example Exampler",
|
|
43
|
+
orcid: "1234-5678-9101",
|
|
44
44
|
},
|
|
45
|
-
createDate: new Date(
|
|
45
|
+
createDate: new Date("2019-04-02T19:56:41.222Z").toISOString(),
|
|
46
46
|
}}
|
|
47
47
|
/>,
|
|
48
48
|
)
|