Skip to content

Commit

Permalink
Merge pull request #354 from IQSS/339-add-alerts-for-create-dataset
Browse files Browse the repository at this point in the history
339 add alerts for create dataset
  • Loading branch information
GPortas authored Apr 4, 2024
2 parents 75fe4fb + ede4738 commit c0f2d0b
Show file tree
Hide file tree
Showing 11 changed files with 45 additions and 12 deletions.
4 changes: 4 additions & 0 deletions public/locales/en/createDataset.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,10 @@
"content": "After adding the dataset, click the Edit Dataset button to add more metadata."
},
"requiredFields": "Asterisks indicate required fields",
"validationAlert": {
"title": "Validation Error",
"content": "Required fields were missed or there was a validation error. Please scroll down to see details."
},
"datasetForm": {
"fields": {
"title": {
Expand Down
4 changes: 4 additions & 0 deletions public/locales/en/dataset.json
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,10 @@
"heading": "Success!",
"alertText": "This dataset draft has been deleted."
},
"datasetCreated": {
"heading": "Success!",
"alertText": "This dataset has been created."
},
"metadataUpdated": {
"heading": "Success!",
"alertText": "The metadata for this dataset has been updated."
Expand Down
1 change: 1 addition & 0 deletions src/alert/domain/models/Alert.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ export enum AlertMessageKey {
TERMS_UPDATED = 'termsUpdated',
THUMBNAIL_UPDATED = 'thumbnailUpdated',
DATASET_DELETED = 'datasetDeleted',
DATASET_CREATED = 'datasetCreated',
PUBLISH_IN_PROGRESS = 'publishInProgress'
}

Expand Down
6 changes: 5 additions & 1 deletion src/sections/create-dataset/CreateDatasetForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,11 @@ export function CreateDatasetForm({ repository }: CreateDatasetFormProps) {
{submissionStatus === SubmissionStatus.SubmitComplete && (
<p>{t('datasetForm.status.success')}</p>
)}
{submissionStatus === SubmissionStatus.Errored && <p>{t('datasetForm.status.failed')}</p>}
{submissionStatus === SubmissionStatus.Errored && (
<Alert variant={'danger'} customHeading={t('validationAlert.title')} dismissible={false}>
{t('validationAlert.content')}
</Alert>
)}
<Form
onSubmit={(event: FormEvent<HTMLFormElement>) => {
handleSubmit(event)
Expand Down
4 changes: 3 additions & 1 deletion src/sections/create-dataset/useCreateDatasetForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,9 @@ export function useCreateDatasetForm(
createDataset(repository, formData)
.then(({ persistentId }) => {
setSubmissionStatus(SubmissionStatus.SubmitComplete)
navigate(`${Route.DATASETS}?persistentId=${persistentId}`)
navigate(`${Route.DATASETS}?persistentId=${persistentId}`, {
state: { created: true }
})
return
})
.catch(() => {
Expand Down
11 changes: 9 additions & 2 deletions src/sections/dataset/Dataset.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Tabs, Col, Row } from '@iqss/dataverse-design-system'
import { Col, Row, Tabs } from '@iqss/dataverse-design-system'
import styles from './Dataset.module.scss'
import { DatasetLabels } from './dataset-labels/DatasetLabels'
import { useLoading } from '../loading/LoadingContext'
Expand All @@ -18,17 +18,24 @@ import { useNotImplementedModal } from '../not-implemented/NotImplementedModalCo
import { NotImplementedModal } from '../not-implemented/NotImplementedModal'
import { SeparationLine } from '../shared/layout/SeparationLine/SeparationLine'
import { BreadcrumbsGenerator } from '../shared/hierarchy/BreadcrumbsGenerator'
import { useAlertContext } from '../alerts/AlertContext'
import { AlertMessageKey } from '../../alert/domain/models/Alert'

interface DatasetProps {
fileRepository: FileRepository
created?: boolean
}

export function Dataset({ fileRepository }: DatasetProps) {
export function Dataset({ fileRepository, created }: DatasetProps) {
const { setIsLoading } = useLoading()
const { dataset, isLoading } = useDataset()
const { t } = useTranslation('dataset')
const { hideModal, isModalOpen } = useNotImplementedModal()
const { addDatasetAlert } = useAlertContext()

if (created) {
addDatasetAlert({ messageKey: AlertMessageKey.DATASET_CREATED, variant: 'success' })
}
useEffect(() => {
setIsLoading(isLoading)
}, [isLoading])
Expand Down
6 changes: 5 additions & 1 deletion src/sections/dataset/DatasetFactory.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { ReactElement, useEffect } from 'react'
import { useSearchParams } from 'react-router-dom'
import { useLocation } from 'react-router-dom'
import { Dataset } from './Dataset'
import { DatasetJSDataverseRepository } from '../../dataset/infrastructure/repositories/DatasetJSDataverseRepository'
import { useAnonymized } from './anonymized/AnonymizedContext'
Expand Down Expand Up @@ -47,6 +48,9 @@ function DatasetWithSearchParams() {
const privateUrlToken = searchParams.get('privateUrlToken')
const searchParamVersion = searchParams.get('version') ?? undefined
const version = searchParamVersionToDomainVersion(searchParamVersion)
const location = useLocation()
const state = location.state as { created: boolean } | undefined
const created = state?.created ?? false

useEffect(() => {
if (privateUrlToken) setAnonymizedView(true)
Expand All @@ -66,7 +70,7 @@ function DatasetWithSearchParams() {
<DatasetProvider
repository={datasetRepository}
searchParams={{ persistentId: persistentId, version: version }}>
<Dataset fileRepository={fileRepository} />
<Dataset fileRepository={fileRepository} created={created} />
</DatasetProvider>
)
}
4 changes: 4 additions & 0 deletions src/stories/dataset/Dataset.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@ export const Default: Story = {
render: () => <Dataset fileRepository={new FileMockRepository()} />
}

export const Created: Story = {
decorators: [WithLayout, WithDatasetDraftAsOwner, WithLoggedInUser, WithNotImplementedModal],
render: () => <Dataset fileRepository={new FileMockRepository()} created={true} />
}
export const DraftWithAllDatasetPermissions: Story = {
decorators: [WithLayout, WithDatasetDraftAsOwner, WithLoggedInUser, WithNotImplementedModal],
render: () => <Dataset fileRepository={new FileMockRepository()} />
Expand Down
14 changes: 7 additions & 7 deletions tests/component/create-dataset/CreateDatasetForm.spec.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ describe('Create Dataset', () => {

cy.findByText('Title is required.').should('exist')

cy.findByText('Error: Submission failed.').should('exist')
cy.findByText('Validation Error').should('exist')
})

it('shows an error message when the author name is not provided', () => {
Expand All @@ -63,7 +63,7 @@ describe('Create Dataset', () => {

cy.findByText('Author name is required.').should('exist')

cy.findByText('Error: Submission failed.').should('exist')
cy.findByText('Validation Error').should('exist')
})

it('shows an error message when the point of contact email is not provided', () => {
Expand All @@ -73,7 +73,7 @@ describe('Create Dataset', () => {

cy.findByText('Point of Contact E-mail is required.').should('exist')

cy.findByText('Error: Submission failed.').should('exist')
cy.findByText('Validation Error').should('exist')
})

it('shows an error message when the point of contact email is not a valid email', () => {
Expand All @@ -87,7 +87,7 @@ describe('Create Dataset', () => {

cy.findByText('Point of Contact E-mail is required.').should('exist')

cy.findByText('Error: Submission failed.').should('exist')
cy.findByText('Validation Error').should('exist')
})

it('shows an error message when the description text is not provided', () => {
Expand All @@ -97,7 +97,7 @@ describe('Create Dataset', () => {

cy.findByText('Description Text is required.').should('exist')

cy.findByText('Error: Submission failed.').should('exist')
cy.findByText('Validation Error').should('exist')
})

it('shows an error message when the subject is not provided', () => {
Expand All @@ -107,7 +107,7 @@ describe('Create Dataset', () => {

cy.findByText('Subject is required.').should('exist')

cy.findByText('Error: Submission failed.').should('exist')
cy.findByText('Validation Error').should('exist')
})

it('can submit a valid form', () => {
Expand Down Expand Up @@ -146,6 +146,6 @@ describe('Create Dataset', () => {
cy.findByLabelText(/Arts and Humanities/i).check()

cy.findByText(/Save Dataset/i).click()
cy.findByText('Error: Submission failed.').should('exist')
cy.contains('Validation Error').should('exist')
})
})
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ interface DatasetTranslation {
[AlertMessageKey.TERMS_UPDATED]: AlertTranslation
[AlertMessageKey.DATASET_DELETED]: AlertTranslation
[AlertMessageKey.THUMBNAIL_UPDATED]: AlertTranslation
[AlertMessageKey.DATASET_CREATED]: AlertTranslation
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@ describe('Create Dataset', () => {
cy.findByText(/Save Dataset/i).click()

cy.findByRole('heading', { name: 'Test Dataset Title' }).should('exist')
cy.findByText('Success!').should('exist')
cy.contains('This dataset has been created.').should('exist')
cy.findByText(DatasetLabelValue.DRAFT).should('exist')
cy.findByText(DatasetLabelValue.UNPUBLISHED).should('exist')
})
Expand Down

0 comments on commit c0f2d0b

Please sign in to comment.