@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,3 +1,3 @@
|
|
|
1
|
-
import { config } from
|
|
1
|
+
import { config } from "../config"
|
|
2
2
|
|
|
3
|
-
export const getDatasetUrl = dataset => `${config.url}/datasets/${dataset.id}`
|
|
3
|
+
export const getDatasetUrl = (dataset) => `${config.url}/datasets/${dataset.id}`
|
|
@@ -2,5 +2,5 @@
|
|
|
2
2
|
* Return an equivalent to moment(date).format('L') without moment
|
|
3
3
|
* @param {*} dateObject
|
|
4
4
|
*/
|
|
5
|
-
export const formatDate = dateObject =>
|
|
6
|
-
new Date(dateObject).toISOString().split(
|
|
5
|
+
export const formatDate = (dateObject) =>
|
|
6
|
+
new Date(dateObject).toISOString().split("T")[0]
|
|
@@ -5,8 +5,8 @@ interface Object {
|
|
|
5
5
|
}
|
|
6
6
|
|
|
7
7
|
function polyfillGlobal(): void {
|
|
8
|
-
if (typeof global ===
|
|
9
|
-
Object.defineProperty(Object.prototype,
|
|
8
|
+
if (typeof global === "object") return
|
|
9
|
+
Object.defineProperty(Object.prototype, "global", {
|
|
10
10
|
get: () => globalThis,
|
|
11
11
|
configurable: true,
|
|
12
12
|
})
|
|
@@ -5,18 +5,18 @@ function gtag() {
|
|
|
5
5
|
globalThis.dataLayer.push(arguments)
|
|
6
6
|
}
|
|
7
7
|
|
|
8
|
-
gtag(
|
|
8
|
+
gtag("js", new Date())
|
|
9
9
|
|
|
10
|
-
export const initialize = trackingIds =>
|
|
11
|
-
trackingIds?.forEach(trackingId => gtag(
|
|
10
|
+
export const initialize = (trackingIds) =>
|
|
11
|
+
trackingIds?.forEach((trackingId) => gtag("config", trackingId))
|
|
12
12
|
|
|
13
|
-
export const pageview = path =>
|
|
14
|
-
gtag(
|
|
13
|
+
export const pageview = (path) =>
|
|
14
|
+
gtag("event", "page_view", {
|
|
15
15
|
page_path: path,
|
|
16
16
|
})
|
|
17
17
|
|
|
18
18
|
export const event = ({ category, action, label }) =>
|
|
19
|
-
gtag(
|
|
19
|
+
gtag("event", action, {
|
|
20
20
|
event_category: category,
|
|
21
21
|
event_label: label,
|
|
22
22
|
})
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
const formatAuthors = authorList => {
|
|
1
|
+
const formatAuthors = (authorList) => {
|
|
2
2
|
if (authorList.length) {
|
|
3
3
|
const authorsArray = []
|
|
4
4
|
for (const author of authorList) {
|
|
5
5
|
const authorObj = {
|
|
6
|
-
|
|
6
|
+
"@type": "Person",
|
|
7
7
|
name: author,
|
|
8
8
|
}
|
|
9
9
|
// Attempt to handle common "Poldrack, R.A." format
|
|
10
|
-
if (author.includes(
|
|
11
|
-
const [familyName, givenName] = author.split(
|
|
10
|
+
if (author.includes(",")) {
|
|
11
|
+
const [familyName, givenName] = author.split(",")
|
|
12
12
|
authorObj.familyName = familyName
|
|
13
13
|
authorObj.givenName = givenName
|
|
14
14
|
} else {
|
|
15
15
|
// Probably "Russ Poldrack" name?
|
|
16
|
-
const nameTokens = author.split(
|
|
16
|
+
const nameTokens = author.split(" ") || []
|
|
17
17
|
authorObj.givenName = nameTokens
|
|
18
18
|
.slice(0, nameTokens.length - 1)
|
|
19
|
-
.join(
|
|
19
|
+
.join(" ")
|
|
20
20
|
authorObj.familyName = nameTokens[nameTokens.length - 1]
|
|
21
21
|
}
|
|
22
22
|
authorsArray.push(authorObj)
|
|
@@ -27,24 +27,24 @@ const formatAuthors = authorList => {
|
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
29
|
|
|
30
|
-
const schemaGenerator = snapshot => {
|
|
30
|
+
const schemaGenerator = (snapshot) => {
|
|
31
31
|
try {
|
|
32
32
|
const schema = {
|
|
33
|
-
|
|
34
|
-
|
|
33
|
+
"@context": "http://schema.org",
|
|
34
|
+
"@type": "Dataset",
|
|
35
35
|
name: snapshot.description.Name,
|
|
36
36
|
author: formatAuthors(snapshot.description.Authors),
|
|
37
37
|
datePublished: snapshot.created,
|
|
38
38
|
dateModified: snapshot.created,
|
|
39
|
-
license:
|
|
39
|
+
license: "https://creativecommons.org/publicdomain/zero/1.0/",
|
|
40
40
|
publisher: {
|
|
41
|
-
|
|
42
|
-
name:
|
|
41
|
+
"@type": "Organization",
|
|
42
|
+
name: "OpenNeuro",
|
|
43
43
|
},
|
|
44
44
|
description: snapshot.readme,
|
|
45
45
|
version: snapshot.tag,
|
|
46
46
|
url: `https://openneuro.org/datasets/${
|
|
47
|
-
snapshot.id.split(
|
|
47
|
+
snapshot.id.split(":")[0]
|
|
48
48
|
}/versions/${snapshot.tag}`,
|
|
49
49
|
}
|
|
50
50
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import React, { createContext,
|
|
2
|
-
import { UserLoginModal } from
|
|
3
|
-
import loginUrls from
|
|
1
|
+
import React, { createContext, FC, ReactNode, useState } from "react"
|
|
2
|
+
import { UserLoginModal } from "@openneuro/components/modal"
|
|
3
|
+
import loginUrls from "../authentication/loginUrls"
|
|
4
4
|
|
|
5
5
|
export const UserModalOpenCtx = createContext(null)
|
|
6
6
|
|
|
@@ -13,7 +13,7 @@ export const UserModalOpenProvider: FC<UserModalOpenProviderProps> = ({
|
|
|
13
13
|
}) => {
|
|
14
14
|
const [userModalOpen, setUserModalOpen] = useState(false)
|
|
15
15
|
const toggle = (): void => {
|
|
16
|
-
setUserModalOpen(prevState => !prevState)
|
|
16
|
+
setUserModalOpen((prevState) => !prevState)
|
|
17
17
|
}
|
|
18
18
|
return (
|
|
19
19
|
<UserModalOpenCtx.Provider value={{ userModalOpen, setUserModalOpen }}>
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import { AccordionTab, AccordionWrap } from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import { AccordionTab, AccordionWrap } from "@openneuro/components/accordion"
|
|
4
4
|
|
|
5
5
|
class ValidationPanel extends React.Component {
|
|
6
6
|
constructor(props) {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// dependencies -------------------------------------------------------
|
|
2
2
|
|
|
3
|
-
import React from
|
|
4
|
-
import PropTypes from
|
|
3
|
+
import React from "react"
|
|
4
|
+
import PropTypes from "prop-types"
|
|
5
5
|
|
|
6
6
|
// component setup ----------------------------------------------------
|
|
7
7
|
|
|
@@ -12,16 +12,16 @@ class Issue extends React.Component {
|
|
|
12
12
|
const error = this.props.error
|
|
13
13
|
let fileInfo
|
|
14
14
|
// build error location string
|
|
15
|
-
let errLocation =
|
|
15
|
+
let errLocation = ""
|
|
16
16
|
let errorLocationMeta
|
|
17
17
|
if (error.line) {
|
|
18
|
-
errLocation +=
|
|
18
|
+
errLocation += "Line: " + error.line + " "
|
|
19
19
|
}
|
|
20
20
|
if (error.character) {
|
|
21
|
-
errLocation +=
|
|
21
|
+
errLocation += "Character: " + error.character + ""
|
|
22
22
|
}
|
|
23
|
-
if (errLocation ===
|
|
24
|
-
errLocation =
|
|
23
|
+
if (errLocation === "" && error.evidence) {
|
|
24
|
+
errLocation = "Evidence: "
|
|
25
25
|
}
|
|
26
26
|
if (errLocation) {
|
|
27
27
|
errorLocationMeta = (
|
|
@@ -46,7 +46,7 @@ class Issue extends React.Component {
|
|
|
46
46
|
<div className="em-body">
|
|
47
47
|
{fileInfo}
|
|
48
48
|
<span className="e-meta">
|
|
49
|
-
<label>Reason
|
|
49
|
+
<label>Reason:</label>
|
|
50
50
|
<p>{error.reason}</p>
|
|
51
51
|
</span>
|
|
52
52
|
{errorLocationMeta}
|
|
@@ -60,7 +60,7 @@ class Issue extends React.Component {
|
|
|
60
60
|
if (file && file.relativePath) {
|
|
61
61
|
return (
|
|
62
62
|
<span>
|
|
63
|
-
<label>Location
|
|
63
|
+
<label>Location:</label>
|
|
64
64
|
<p>{file.relativePath}</p>
|
|
65
65
|
</span>
|
|
66
66
|
)
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
// dependencies -----------------------------------------------------------
|
|
2
2
|
|
|
3
|
-
import React from
|
|
4
|
-
import PropTypes from
|
|
5
|
-
import { AccordionTab, AccordionWrap } from
|
|
3
|
+
import React from "react"
|
|
4
|
+
import PropTypes from "prop-types"
|
|
5
|
+
import { AccordionTab, AccordionWrap } from "@openneuro/components/accordion"
|
|
6
6
|
|
|
7
|
-
import pluralize from
|
|
8
|
-
import Issue from
|
|
7
|
+
import pluralize from "pluralize"
|
|
8
|
+
import Issue from "./validation-results.issues.issue.jsx"
|
|
9
9
|
|
|
10
10
|
class Issues extends React.Component {
|
|
11
11
|
render() {
|
|
@@ -15,7 +15,7 @@ class Issues extends React.Component {
|
|
|
15
15
|
if (issue.additionalFileCount) {
|
|
16
16
|
totalFiles += issue.additionalFileCount
|
|
17
17
|
}
|
|
18
|
-
const issueCount = pluralize(
|
|
18
|
+
const issueCount = pluralize("files", totalFiles)
|
|
19
19
|
|
|
20
20
|
const header = (
|
|
21
21
|
<span className="file-header">
|
|
@@ -48,15 +48,17 @@ class Issues extends React.Component {
|
|
|
48
48
|
)
|
|
49
49
|
})
|
|
50
50
|
} else {
|
|
51
|
-
return error
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
51
|
+
return error
|
|
52
|
+
? (
|
|
53
|
+
<Issue
|
|
54
|
+
type={this.props.issueType}
|
|
55
|
+
file={issue.file}
|
|
56
|
+
error={error}
|
|
57
|
+
index={index2}
|
|
58
|
+
key={index2}
|
|
59
|
+
/>
|
|
60
|
+
)
|
|
61
|
+
: null
|
|
60
62
|
}
|
|
61
63
|
})
|
|
62
64
|
|
|
@@ -64,8 +66,8 @@ class Issues extends React.Component {
|
|
|
64
66
|
subErrors.push(
|
|
65
67
|
<div className="em-body" key="additional-file-count">
|
|
66
68
|
<span className="e-meta">
|
|
67
|
-
and {issue.additionalFileCount} more{
|
|
68
|
-
{pluralize(
|
|
69
|
+
and {issue.additionalFileCount} more{" "}
|
|
70
|
+
{pluralize("files", issue.additionalFileCount)}
|
|
69
71
|
</span>
|
|
70
72
|
</div>,
|
|
71
73
|
)
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
// dependencies -----------------------------------------------------------
|
|
2
2
|
|
|
3
|
-
import React from
|
|
4
|
-
import PropTypes from
|
|
5
|
-
import pluralize from
|
|
6
|
-
import { AccordionTab, AccordionWrap } from
|
|
3
|
+
import React from "react"
|
|
4
|
+
import PropTypes from "prop-types"
|
|
5
|
+
import pluralize from "pluralize"
|
|
6
|
+
import { AccordionTab, AccordionWrap } from "@openneuro/components/accordion"
|
|
7
7
|
|
|
8
|
-
import Issues from
|
|
8
|
+
import Issues from "./validation-results.issues.jsx"
|
|
9
9
|
|
|
10
10
|
// component setup --------------------------------------------------------
|
|
11
11
|
|
|
@@ -16,7 +16,7 @@ class ValidationResults extends React.Component {
|
|
|
16
16
|
const errors = this.props.errors
|
|
17
17
|
const warnings = this.props.warnings
|
|
18
18
|
|
|
19
|
-
if (errors ===
|
|
19
|
+
if (errors === "Invalid") {
|
|
20
20
|
return false
|
|
21
21
|
}
|
|
22
22
|
|
|
@@ -26,8 +26,8 @@ class ValidationResults extends React.Component {
|
|
|
26
26
|
const fileCount = this._countFiles(errors)
|
|
27
27
|
const errorHeader = (
|
|
28
28
|
<span>
|
|
29
|
-
view {errors.length} {pluralize(
|
|
30
|
-
{fileCount} {pluralize(
|
|
29
|
+
view {errors.length} {pluralize("error", errors.length)} in{" "}
|
|
30
|
+
{fileCount} {pluralize("files", fileCount)}
|
|
31
31
|
</span>
|
|
32
32
|
)
|
|
33
33
|
errorsWrap = (
|
|
@@ -48,8 +48,8 @@ class ValidationResults extends React.Component {
|
|
|
48
48
|
const fileCount = this._countFiles(warnings)
|
|
49
49
|
const warningHeader = (
|
|
50
50
|
<span>
|
|
51
|
-
view {warnings.length} {pluralize(
|
|
52
|
-
{fileCount} {pluralize(
|
|
51
|
+
view {warnings.length} {pluralize("warning", warnings.length)} in{" "}
|
|
52
|
+
{fileCount} {pluralize("files", fileCount)}
|
|
53
53
|
</span>
|
|
54
54
|
)
|
|
55
55
|
warningWrap = (
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import pluralize from
|
|
4
|
-
import ValidationPanel from
|
|
5
|
-
import Results from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import pluralize from "pluralize"
|
|
4
|
+
import ValidationPanel from "./validation-panel.jsx"
|
|
5
|
+
import Results from "./validation-results.jsx"
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* These can't be React components due to legacy react-bootstrap
|
|
@@ -18,12 +18,12 @@ const validHeader = () => (
|
|
|
18
18
|
</div>
|
|
19
19
|
)
|
|
20
20
|
|
|
21
|
-
const warningHeader = count => (
|
|
21
|
+
const warningHeader = (count) => (
|
|
22
22
|
<div>
|
|
23
23
|
<h3 className="metaheader">BIDS Validation</h3>
|
|
24
24
|
|
|
25
25
|
<span className="label text-warning pull-right">
|
|
26
|
-
{count} {pluralize(
|
|
26
|
+
{count} {pluralize("Warning", count)}
|
|
27
27
|
</span>
|
|
28
28
|
<span className="dataset-status ds-success">
|
|
29
29
|
<i className="fa fa-check-circle" /> Valid
|
|
@@ -31,12 +31,12 @@ const warningHeader = count => (
|
|
|
31
31
|
</div>
|
|
32
32
|
)
|
|
33
33
|
|
|
34
|
-
const errorHeader = count => (
|
|
34
|
+
const errorHeader = (count) => (
|
|
35
35
|
<div>
|
|
36
36
|
<h3 className="metaheader">BIDS Validation</h3>
|
|
37
37
|
|
|
38
38
|
<span className="label text-warning pull-right">
|
|
39
|
-
{count} {pluralize(
|
|
39
|
+
{count} {pluralize("Error", count)}
|
|
40
40
|
</span>
|
|
41
41
|
<span className="dataset-status ds-danger">
|
|
42
42
|
<i className="fa fa-exclamation-circle" /> Invalid
|
|
@@ -56,10 +56,10 @@ const Warnings = ({ errors, warnings }) => (
|
|
|
56
56
|
<ValidationPanel heading={warningHeader(warnings.length)}>
|
|
57
57
|
<div>
|
|
58
58
|
<span className="message error fade-in">
|
|
59
|
-
We found{
|
|
59
|
+
We found{" "}
|
|
60
60
|
<strong>
|
|
61
|
-
{warnings.length +
|
|
62
|
-
</strong>{
|
|
61
|
+
{warnings.length + " " + pluralize("Warning", warnings.length)}
|
|
62
|
+
</strong>{" "}
|
|
63
63
|
in your dataset. You are not required to fix warnings, but doing so will
|
|
64
64
|
make your dataset more BIDS compliant.
|
|
65
65
|
</span>
|
|
@@ -77,8 +77,9 @@ Warnings.propTypes = {
|
|
|
77
77
|
const Errors = ({ errors, warnings }) => (
|
|
78
78
|
<ValidationPanel heading={errorHeader(errors.length)}>
|
|
79
79
|
<span className="message error fade-in">
|
|
80
|
-
Your dataset is no longer valid. You must fix the{
|
|
81
|
-
<strong>{errors.length +
|
|
80
|
+
Your dataset is no longer valid. You must fix the{" "}
|
|
81
|
+
<strong>{errors.length + " " + pluralize("Error", errors.length)}</strong>
|
|
82
|
+
{" "}
|
|
82
83
|
to use all of the site features.
|
|
83
84
|
</span>
|
|
84
85
|
<br />
|
|
@@ -93,8 +94,8 @@ Errors.propTypes = {
|
|
|
93
94
|
|
|
94
95
|
const ValidationStatus = ({ issues }) => {
|
|
95
96
|
if (issues) {
|
|
96
|
-
const warnings = issues.filter(issue => issue.severity ===
|
|
97
|
-
const errors = issues.filter(issue => issue.severity ===
|
|
97
|
+
const warnings = issues.filter((issue) => issue.severity === "warning")
|
|
98
|
+
const errors = issues.filter((issue) => issue.severity === "error")
|
|
98
99
|
if (errors.length) {
|
|
99
100
|
return <Errors errors={errors} warnings={warnings} />
|
|
100
101
|
} else if (warnings.length) {
|
|
@@ -112,7 +113,8 @@ const ValidationStatus = ({ issues }) => {
|
|
|
112
113
|
Validation Pending
|
|
113
114
|
</span>
|
|
114
115
|
</div>
|
|
115
|
-
}
|
|
116
|
+
}
|
|
117
|
+
>
|
|
116
118
|
<br />
|
|
117
119
|
<p className="ds-validation-pending-message">
|
|
118
120
|
The BIDS validator is running. This may take several minutes.
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import React from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import ValidationStatus from
|
|
4
|
-
import ErrorBoundary from
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import ValidationStatus from "./validation-status.jsx"
|
|
4
|
+
import ErrorBoundary from "../errors/errorBoundary.jsx"
|
|
5
5
|
|
|
6
6
|
const Validation = ({ issues }) => (
|
|
7
7
|
<>
|
|
8
|
-
<ErrorBoundary subject={
|
|
8
|
+
<ErrorBoundary subject={"error in dataset validation component"}>
|
|
9
9
|
<ValidationStatus issues={issues} />
|
|
10
10
|
</ErrorBoundary>
|
|
11
11
|
</>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { runValidator } from
|
|
2
|
-
import { BIDSValidatorIssues } from
|
|
1
|
+
import { runValidator } from "./schema.worker" // eslint-disable-line import/no-unresolved
|
|
2
|
+
import { BIDSValidatorIssues } from "./worker-interface"
|
|
3
3
|
|
|
4
4
|
function init(files, options): Promise<BIDSValidatorIssues> {
|
|
5
5
|
return new Promise((resolve, reject) => {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* eslint-env worker */
|
|
2
|
-
import {
|
|
3
|
-
import { BIDSValidatorIssues } from
|
|
2
|
+
import { fileListToTree, validate } from "../utils/schema-validator.js"
|
|
3
|
+
import { BIDSValidatorIssues } from "./worker-interface"
|
|
4
4
|
|
|
5
5
|
export async function runValidator(
|
|
6
6
|
files,
|
|
@@ -17,9 +17,9 @@ export async function runValidator(
|
|
|
17
17
|
const result = await validate(tree, { json: true })
|
|
18
18
|
const issues = Array.from(result.issues, ([key, value]) => value)
|
|
19
19
|
output.issues.warnings = issues.filter(
|
|
20
|
-
issue => issue.severity ===
|
|
20
|
+
(issue) => issue.severity === "warning",
|
|
21
21
|
)
|
|
22
|
-
output.issues.errors = issues.filter(issue => issue.severity ===
|
|
22
|
+
output.issues.errors = issues.filter((issue) => issue.severity === "error")
|
|
23
23
|
output.summary = result.summary
|
|
24
24
|
} catch (err) {
|
|
25
25
|
error = err
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { runValidator } from
|
|
2
|
-
import { BIDSValidatorIssues } from
|
|
1
|
+
import { runValidator } from "./validate.worker" // eslint-disable-line import/no-unresolved
|
|
2
|
+
import { BIDSValidatorIssues } from "./worker-interface"
|
|
3
3
|
|
|
4
4
|
function init(files, options): Promise<BIDSValidatorIssues> {
|
|
5
5
|
return new Promise((resolve, reject) => {
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
/* eslint-env worker */
|
|
2
|
-
import validate from
|
|
3
|
-
import { BIDSValidatorIssues } from
|
|
2
|
+
import validate from "bids-validator"
|
|
3
|
+
import { BIDSValidatorIssues } from "./worker-interface"
|
|
4
4
|
|
|
5
5
|
const asyncValidateBIDS = (files, options): Promise<BIDSValidatorIssues> =>
|
|
6
|
-
new Promise(resolve => {
|
|
7
|
-
validate.BIDS(
|
|
8
|
-
|
|
6
|
+
new Promise((resolve) => {
|
|
7
|
+
validate.BIDS(
|
|
8
|
+
files,
|
|
9
|
+
options,
|
|
10
|
+
(issues, summary) => resolve({ issues, summary }),
|
|
9
11
|
)
|
|
10
12
|
})
|
|
11
13
|
|
package/vite.config.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import path from
|
|
2
|
-
import { defineConfig } from
|
|
3
|
-
import nodePolyfills from
|
|
1
|
+
import path from "path"
|
|
2
|
+
import { defineConfig } from "vite"
|
|
3
|
+
import nodePolyfills from "rollup-plugin-polyfill-node"
|
|
4
4
|
|
|
5
5
|
export default defineConfig({
|
|
6
|
-
root:
|
|
6
|
+
root: "src",
|
|
7
7
|
server: {
|
|
8
8
|
port: 80,
|
|
9
|
-
host:
|
|
9
|
+
host: "0.0.0.0",
|
|
10
10
|
cors: true,
|
|
11
11
|
},
|
|
12
12
|
build: {
|
|
@@ -14,29 +14,29 @@ export default defineConfig({
|
|
|
14
14
|
},
|
|
15
15
|
optimizeDeps: {
|
|
16
16
|
include: [
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
17
|
+
"@apollo/client/react/components",
|
|
18
|
+
"@apollo/client/link/schema",
|
|
19
|
+
"@apollo/client/link/context",
|
|
20
|
+
"@apollo/client/link/ws",
|
|
21
|
+
"@apollo/client/utilities",
|
|
22
22
|
],
|
|
23
|
-
exclude: [
|
|
23
|
+
exclude: ["buffer", "stream-browserify"],
|
|
24
24
|
},
|
|
25
25
|
resolve: {
|
|
26
26
|
alias: [
|
|
27
27
|
// Workaround for `'request' is not exported by __vite-browser-external`
|
|
28
28
|
{
|
|
29
|
-
find:
|
|
30
|
-
replacement:
|
|
29
|
+
find: "./runtimeConfig",
|
|
30
|
+
replacement: "./runtimeConfig.browser",
|
|
31
31
|
},
|
|
32
32
|
// Workaround for bids-validator -> hed-validator -> xml2js -> sax -> Stream shim
|
|
33
|
-
{ find:
|
|
33
|
+
{ find: "stream", replacement: "stream-browserify" },
|
|
34
34
|
// sax -> Buffer shim
|
|
35
|
-
{ find:
|
|
35
|
+
{ find: "buffer", replacement: "buffer/" },
|
|
36
36
|
// Workaround UMD -> ESM issues in pluralize
|
|
37
37
|
{
|
|
38
|
-
find:
|
|
39
|
-
replacement: path.resolve(__dirname,
|
|
38
|
+
find: "pluralize",
|
|
39
|
+
replacement: path.resolve(__dirname, "./pluralize-esm.js"),
|
|
40
40
|
},
|
|
41
41
|
],
|
|
42
42
|
},
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|