Skip to content

Commit

Permalink
fix: update successful save redirects [DHIS2-15431] (#1218)
Browse files Browse the repository at this point in the history
  • Loading branch information
tomzemp committed Sep 25, 2023
1 parent 4bc5e88 commit c0e7782
Show file tree
Hide file tree
Showing 16 changed files with 99 additions and 20 deletions.
7 changes: 5 additions & 2 deletions src/AppWrapper.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,14 @@ import { CssVariables } from '@dhis2/ui'
import React from 'react'
import App from './App.js'
import { CurrentUserProvider } from './components/CurrentUserProvider.js'
import { ReferrerProvider } from './providers/index.js'

const AppWrapper = () => (
<CurrentUserProvider>
<CssVariables spacers colors theme />
<App />
<ReferrerProvider>
<CssVariables spacers colors theme />
<App />
</ReferrerProvider>
</CurrentUserProvider>
)

Expand Down
8 changes: 3 additions & 5 deletions src/components/Form.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ import {
import cx from 'classnames'
import PropTypes from 'prop-types'
import React, { useState, useCallback, useMemo } from 'react'
import { useHistory } from 'react-router-dom'
import styles from './Form.module.css'
import SearchableOrgUnitTree from './SearchableOrgUnitTree/index.js'

Expand Down Expand Up @@ -288,10 +287,8 @@ const Form = ({
submitButtonLabel,
cancelButtonLabel,
onSubmit,
onCancel,
}) => {
const history = useHistory()
const handleCancel = () => history.goBack()

if (loading) {
return (
<CenteredContent>
Expand Down Expand Up @@ -337,7 +334,7 @@ const Form = ({
>
{submitButtonLabel}
</Button>
<Button onClick={handleCancel} disabled={submitting}>
<Button onClick={onCancel} disabled={submitting}>
{cancelButtonLabel}
</Button>
</ButtonStrip>
Expand All @@ -354,6 +351,7 @@ Form.defaultProps = {
Form.propTypes = {
children: PropTypes.func.isRequired,
submitButtonLabel: PropTypes.string.isRequired,
onCancel: PropTypes.func.isRequired,
onSubmit: PropTypes.func.isRequired,
cancelButtonLabel: PropTypes.string,
error: PropTypes.instanceOf(Error),
Expand Down
14 changes: 12 additions & 2 deletions src/components/GroupForm/GroupForm.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ import PropTypes from 'prop-types'
import React from 'react'
import { useHistory } from 'react-router-dom'
import { useCurrentUser } from '../../hooks/useCurrentUser.js'
import { useReferrerInfo } from '../../providers/index.js'
import navigateTo from '../../utils/navigateTo.js'
import Attributes from '../Attributes/index.js'
import Form, { FormSection } from '../Form.js'
import BasicInformationSection from './BasicInformationSection.js'
Expand All @@ -18,10 +20,11 @@ import UserGroupManagementSection from './UserGroupManagementSection.js'
import UserManagementSection from './UserManagementSection.js'

const GroupForm = ({ submitButtonLabel, group }) => {
const history = useHistory()
const engine = useDataEngine()
const { loading, error, userGroupOptions, attributes } = useFormData()
const currentUser = useCurrentUser()
const { referrer } = useReferrerInfo()
const history = useHistory()
const handleSubmit = async (values, form) => {
try {
if (group) {
Expand All @@ -43,7 +46,7 @@ const GroupForm = ({ submitButtonLabel, group }) => {
})
}

history.goBack()
navigateTo('/user-groups')
if (group && currentUser.userGroupIds.includes(group.id)) {
currentUser.refresh()
}
Expand All @@ -68,6 +71,13 @@ const GroupForm = ({ submitButtonLabel, group }) => {
error={error}
submitButtonLabel={submitButtonLabel}
onSubmit={handleSubmit}
onCancel={() => {
if (referrer === 'user-groups') {
history.goBack()
} else {
navigateTo('/user-groups')
}
}}
>
{({ submitError }) => (
<>
Expand Down
14 changes: 12 additions & 2 deletions src/components/RoleForm/RoleForm.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import PropTypes from 'prop-types'
import React from 'react'
import { useHistory } from 'react-router-dom'
import { useCurrentUser } from '../../hooks/useCurrentUser.js'
import { useReferrerInfo } from '../../providers/index.js'
import navigateTo from '../../utils/navigateTo.js'
import Form, { FormSection, TextField, TransferField } from '../Form.js'
import { getJsonPatch } from './getJsonPatch.js'
import { getRoleData } from './getRoleData.js'
Expand Down Expand Up @@ -49,7 +51,6 @@ const getRoleAuthorityIDs = ({
}

const RoleForm = ({ submitButtonLabel, role }) => {
const history = useHistory()
const engine = useDataEngine()
const debouncedUniqueRoleNameValidator =
useDebouncedUniqueRoleNameValidator({ engine, roleName: role?.name })
Expand All @@ -75,6 +76,8 @@ const RoleForm = ({ submitButtonLabel, role }) => {
systemAuthorityOptions,
})
const currentUser = useCurrentUser()
const { referrer } = useReferrerInfo()
const history = useHistory()
const handleSubmit = async (values, form) => {
const roleData = getRoleData({ values })

Expand All @@ -100,7 +103,7 @@ const RoleForm = ({ submitButtonLabel, role }) => {
})
}

history.goBack()
navigateTo('/user-roles')
if (role && currentUser.userRoleIds.includes(role.id)) {
currentUser.refresh()
}
Expand All @@ -125,6 +128,13 @@ const RoleForm = ({ submitButtonLabel, role }) => {
error={error}
submitButtonLabel={submitButtonLabel}
onSubmit={handleSubmit}
onCancel={() => {
if (referrer === 'user-roles') {
history.goBack()
} else {
navigateTo('/user-roles')
}
}}
>
{({ submitError }) => (
<>
Expand Down
14 changes: 12 additions & 2 deletions src/components/UserForm/UserForm.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import PropTypes from 'prop-types'
import React, { useState } from 'react'
import { useHistory } from 'react-router-dom'
import { useCurrentUser } from '../../hooks/useCurrentUser.js'
import { useReferrerInfo } from '../../providers/index.js'
import navigateTo from '../../utils/navigateTo.js'
import Attributes from '../Attributes/index.js'
import Form, { FormSection } from '../Form.js'
import AnalyticsDimensionsRestrictionsSection from './AnalyticsDimensionRestrictionsSection.js'
Expand All @@ -30,7 +32,6 @@ const UserForm = ({
systemInfo: { emailConfigured },
} = useConfig()
const [isInvite, setIsInvite] = useState(false)
const history = useHistory()
const engine = useDataEngine()
const {
loading,
Expand All @@ -45,6 +46,8 @@ const UserForm = ({
attributes,
} = useFormData()
const currentUser = useCurrentUser()
const { referrer } = useReferrerInfo()
const history = useHistory()
const handleSubmit = async (values, form) => {
const userData = getUserData({
values,
Expand Down Expand Up @@ -107,7 +110,7 @@ const UserForm = ({
}
}

history.goBack()
navigateTo('/users')
if (user && user.id === currentUser.id) {
currentUser.refresh()
}
Expand Down Expand Up @@ -151,6 +154,13 @@ const UserForm = ({
: i18n.t('Cancel without saving')
}
onSubmit={handleSubmit}
onCancel={() => {
if (referrer === 'users') {
history.goBack()
} else {
navigateTo('/users')
}
}}
>
{({ values, submitError }) => (
<>
Expand Down
7 changes: 5 additions & 2 deletions src/pages/GroupList/ContextMenu/ContextMenu.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import {
import PropTypes from 'prop-types'
import React, { useState } from 'react'
import { useCurrentUser } from '../../../hooks/useCurrentUser.js'
import { useReferrerInfo } from '../../../providers/index.js'
import navigateTo from '../../../utils/navigateTo.js'
import DeleteModal from './Modals/DeleteModal.js'
import JoinModal from './Modals/JoinModal.js'
Expand All @@ -37,6 +38,7 @@ const ContextMenu = ({ group, anchorRef, refetchGroups, onClose }) => {
const currentUserIsMember = currentUser.userGroupIds.includes(group.id)
const [CurrentModal, setCurrentModal] = useCurrentModal()
const { access } = group
const { setReferrer } = useReferrerInfo()

return (
<>
Expand Down Expand Up @@ -67,9 +69,10 @@ const ContextMenu = ({ group, anchorRef, refetchGroups, onClose }) => {
<MenuItem
label={i18n.t('Edit')}
icon={<IconEdit16 color={colors.grey600} />}
onClick={() =>
onClick={() => {
setReferrer('user-groups')
navigateTo(`/user-groups/edit/${group.id}`)
}
}}
dense
/>
)}
Expand Down
3 changes: 3 additions & 0 deletions src/pages/GroupList/GroupTable.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import React from 'react'
import DataTableInfoWrapper from '../../components/DataTableInfoWrapper.js'
import EmptyTableInfo from '../../components/EmptyTableInfo.js'
import { useCurrentUser } from '../../hooks/useCurrentUser.js'
import { useReferrerInfo } from '../../providers/useReferrer.js'
import navigateTo from '../../utils/navigateTo.js'
import ContextMenuButton from './ContextMenu/ContextMenuButton.js'

Expand All @@ -28,6 +29,7 @@ const GroupTable = ({
onNameSortDirectionToggle,
}) => {
const currentUser = useCurrentUser()
const { setReferrer } = useReferrerInfo()

if (loading && !groups) {
return (
Expand Down Expand Up @@ -93,6 +95,7 @@ const GroupTable = ({
{groups.map((group) => {
const { id, displayName, access } = group
const handleClick = () => {
setReferrer('user-groups')
if (access.update) {
navigateTo(`/user-groups/edit/${id}`)
} else if (access.read) {
Expand Down
7 changes: 5 additions & 2 deletions src/pages/RoleList/ContextMenu/ContextMenu.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import {
} from '@dhis2/ui'
import PropTypes from 'prop-types'
import React, { useState } from 'react'
import { useReferrerInfo } from '../../../providers/index.js'
import navigateTo from '../../../utils/navigateTo.js'
import DeleteModal from './Modals/DeleteModal.js'
import SharingSettingsModal from './Modals/SharingSettingsModal.js'
Expand All @@ -32,6 +33,7 @@ const useCurrentModal = () => {
const ContextMenu = ({ role, anchorRef, refetchRoles, onClose }) => {
const [CurrentModal, setCurrentModal] = useCurrentModal()
const { access } = role
const { setReferrer } = useReferrerInfo()

return (
<>
Expand Down Expand Up @@ -62,9 +64,10 @@ const ContextMenu = ({ role, anchorRef, refetchRoles, onClose }) => {
<MenuItem
label={i18n.t('Edit')}
icon={<IconEdit16 color={colors.grey600} />}
onClick={() =>
onClick={() => {
setReferrer('user-roles')
navigateTo(`/user-roles/edit/${role.id}`)
}
}}
dense
/>
)}
Expand Down
3 changes: 3 additions & 0 deletions src/pages/RoleList/RoleTable.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import PropTypes from 'prop-types'
import React from 'react'
import DataTableInfoWrapper from '../../components/DataTableInfoWrapper.js'
import EmptyTableInfo from '../../components/EmptyTableInfo.js'
import { useReferrerInfo } from '../../providers/useReferrer.js'
import navigateTo from '../../utils/navigateTo.js'
import ContextMenuButton from './ContextMenu/ContextMenuButton.js'

Expand All @@ -26,6 +27,7 @@ const RoleTable = ({
nameSortDirection,
onNameSortDirectionToggle,
}) => {
const { setReferrer } = useReferrerInfo()
if (loading && !roles) {
return (
<DataTableInfoWrapper columns={3}>
Expand Down Expand Up @@ -90,6 +92,7 @@ const RoleTable = ({
{roles.map((role) => {
const { id, displayName, access, description } = role
const handleClick = () => {
setReferrer('user-roles')
if (access.update) {
navigateTo(`/user-roles/edit/${id}`)
} else if (access.read) {
Expand Down
7 changes: 5 additions & 2 deletions src/pages/UserList/ContextMenu/ContextMenu.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import {
import PropTypes from 'prop-types'
import React, { useState } from 'react'
import { useCurrentUser } from '../../../hooks/useCurrentUser.js'
import { useReferrerInfo } from '../../../providers/useReferrer.js'
import navigateTo from '../../../utils/navigateTo.js'
import DeleteModal from './Modals/DeleteModal.js'
import Disable2FaModal from './Modals/Disable2FaModal.js'
Expand Down Expand Up @@ -67,6 +68,7 @@ const ContextMenu = ({ user, anchorRef, refetchUsers, onClose }) => {
)
const canDisable = currentUser.id !== user.id && access.update && !disabled
const canDelete = currentUser.id !== user.id && access.delete
const { setReferrer } = useReferrerInfo()

return (
<>
Expand All @@ -87,9 +89,10 @@ const ContextMenu = ({ user, anchorRef, refetchUsers, onClose }) => {
<MenuItem
label={i18n.t('Edit')}
icon={<IconEdit16 color={colors.grey600} />}
onClick={() =>
onClick={() => {
setReferrer('users')
navigateTo(`/users/edit/${user.id}`)
}
}}
dense
/>
)}
Expand Down
3 changes: 3 additions & 0 deletions src/pages/UserList/UserTable.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import PropTypes from 'prop-types'
import React from 'react'
import DataTableInfoWrapper from '../../components/DataTableInfoWrapper.js'
import EmptyTableInfo from '../../components/EmptyTableInfo.js'
import { useReferrerInfo } from '../../providers/useReferrer.js'
import navigateTo from '../../utils/navigateTo.js'
import ContextMenuButton from './ContextMenu/ContextMenuButton.js'

Expand All @@ -29,6 +30,7 @@ const UserTable = ({
onNameSortDirectionToggle,
}) => {
const { fromServerDate } = useTimeZoneConversion()
const { setReferrer } = useReferrerInfo()
if (loading && !users) {
return (
<DataTableInfoWrapper columns={5}>
Expand Down Expand Up @@ -102,6 +104,7 @@ const UserTable = ({
const lastLoginClient = fromServerDate(lastLogin)

const handleClick = () => {
setReferrer('users')
if (access.update) {
navigateTo(`/users/edit/${id}`)
} else if (access.read) {
Expand Down
6 changes: 6 additions & 0 deletions src/providers/ReferrerContext.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import React from 'react'

export const ReferrerContext = React.createContext({
referrer: '',
setReferrer: () => {},
})
17 changes: 17 additions & 0 deletions src/providers/ReferrerProvider.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import PropTypes from 'prop-types'
import React, { useState } from 'react'
import { ReferrerContext } from './ReferrerContext.js'

export const ReferrerProvider = ({ children }) => {
const [referrer, setReferrer] = useState('')
const providerValue = { referrer, setReferrer }
return (
<ReferrerContext.Provider value={providerValue}>
{children}
</ReferrerContext.Provider>
)
}

ReferrerProvider.propTypes = {
children: PropTypes.node.isRequired,
}
2 changes: 2 additions & 0 deletions src/providers/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
export { useReferrerInfo } from './useReferrer.js'
export { ReferrerProvider } from './ReferrerProvider.js'
4 changes: 4 additions & 0 deletions src/providers/useReferrer.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
import { useContext } from 'react'
import { ReferrerContext } from './ReferrerContext.js'

export const useReferrerInfo = () => useContext(ReferrerContext)
3 changes: 2 additions & 1 deletion src/utils/navigateTo.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,8 @@ import history from './history.js'
* @function
*/
const navigateTo = (path) => {
history.push(path)
// window.history.pushState({ prevUrl: window.location.href },null)
history.push(path, { search: 'bAH!' })
}

export default navigateTo

0 comments on commit c0e7782

Please sign in to comment.