diff --git a/src/client/components/Task/TaskButton.jsx b/src/client/components/Task/TaskButton.jsx new file mode 100644 index 00000000000..44db1ac492e --- /dev/null +++ b/src/client/components/Task/TaskButton.jsx @@ -0,0 +1,47 @@ +import React from 'react' +import Button from '@govuk-react/button' + +import ProgressIndicator from '../ProgressIndicator' +import Task from '.' + +/** + * The TaskButton component starts a Task and renders a progress indicator whilst loading. + * @param {Object} props + * @param {string} props.id - The _task_ id + * @param {string} props.name - The _task_ name + * @param {object} [props.startOptions=] - The _task_ start options + * @param {string} [props.children=] - the _button_ text + * @example usage within a list item + + Resend export win + + */ +export const TaskButton = ({ id, name, startOptions, children }) => { + return ( + + {(getTask) => { + const task = getTask(name, id) + return ( + + {() => ( + + )} + + ) + }} + + ) +} diff --git a/src/client/components/Task/__stories__/TaskButton.stories.jsx b/src/client/components/Task/__stories__/TaskButton.stories.jsx new file mode 100644 index 00000000000..ade516f2ac9 --- /dev/null +++ b/src/client/components/Task/__stories__/TaskButton.stories.jsx @@ -0,0 +1,28 @@ +import React from 'react' +import styled from 'styled-components' + +import { TaskButton } from '../TaskButton' + +export default { + title: 'Task/TaskButton', +} + +const StyledList = styled('ul')({ + listStyleType: 'none', +}) + +export const List = () => ( + + {[{ id: 1 }, { id: 2 }, { id: 3 }].map((item) => ( +
  • + + Do Something + +
  • + ))} +
    +) diff --git a/src/client/modules/ExportWins/Status/WinsSentList.jsx b/src/client/modules/ExportWins/Status/WinsSentList.jsx index d88e1b7b8fe..e32d9b6eeec 100644 --- a/src/client/modules/ExportWins/Status/WinsSentList.jsx +++ b/src/client/modules/ExportWins/Status/WinsSentList.jsx @@ -1,16 +1,16 @@ import React from 'react' -import { Link as ReactRouterLink } from 'react-router-dom' -import { Button } from 'govuk-react' import styled from 'styled-components' import ExportWinsResource from '../../../components/Resource/ExportWins' +import { TaskButton } from '../../../components/Task/TaskButton' import { currencyGBP } from '../../../utils/number-utils' import { formatMediumDate } from '../../../utils/date' import { CollectionItem } from '../../../components' +import { TASK_RESEND_EXPORT_WIN } from './state' import { WIN_FILTERS } from './constants' import urls from '../../../../lib/urls' -const ButtonContainer = styled('div')({ +const TaskButtonContainer = styled('div')({ marginTop: 10, }) @@ -38,16 +38,23 @@ export default () => ( label: 'Total value: ', value: currencyGBP(item.total_expected_export_value), }, - { label: 'Date won: ', value: formatMediumDate(item.date) }, + { + label: 'Date won: ', + value: formatMediumDate(item.date), + }, { label: 'First sent: ', value: '???' }, { label: 'Last sent: ', value: '???' }, ]} buttonRenderer={() => ( - - - + + )} /> diff --git a/src/client/modules/ExportWins/Status/state.js b/src/client/modules/ExportWins/Status/state.js new file mode 100644 index 00000000000..183638e99ec --- /dev/null +++ b/src/client/modules/ExportWins/Status/state.js @@ -0,0 +1 @@ +export const TASK_RESEND_EXPORT_WIN = 'TASK_RESEND_EXPORT_WIN' diff --git a/src/client/modules/ExportWins/Status/tasks.js b/src/client/modules/ExportWins/Status/tasks.js new file mode 100644 index 00000000000..0563fb8c0b9 --- /dev/null +++ b/src/client/modules/ExportWins/Status/tasks.js @@ -0,0 +1,4 @@ +import { apiProxyAxios } from '../../../components/Task/utils' + +export const resendExportWin = (id) => + apiProxyAxios.post(`/v4/export-win/${id}/resend-win`) diff --git a/src/client/tasks.js b/src/client/tasks.js index b0fa0fae350..0e370c1af95 100644 --- a/src/client/tasks.js +++ b/src/client/tasks.js @@ -444,6 +444,9 @@ import { getExportWin, } from '../client/modules/ExportWins/Form/tasks' +import { resendExportWin } from '../client/modules/ExportWins/Status/tasks' +import { TASK_RESEND_EXPORT_WIN } from './modules/ExportWins/Status/state' + export const tasks = { 'Create list': createList, 'Edit company': editCompany, @@ -697,4 +700,5 @@ export const tasks = { [TASK_PREVIEW_QUOTE]: previewQuote, [TASK_CREATE_QUOTE]: createQuote, [TASK_CANCEL_QUOTE]: cancelQuote, + [TASK_RESEND_EXPORT_WIN]: resendExportWin, }