Skip to content

Commit

Permalink
feat: add deletion functionality
Browse files Browse the repository at this point in the history
- use context for Side Panel components
- add delete modal to handle deletion of namespaces and keys
- add context menu button on every rendered link
`
  • Loading branch information
d-rita committed Dec 20, 2024
1 parent 26867e5 commit b603eb3
Show file tree
Hide file tree
Showing 13 changed files with 359 additions and 98 deletions.
56 changes: 37 additions & 19 deletions i18n/en.pot
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@ msgstr ""
"Content-Type: text/plain; charset=utf-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Plural-Forms: nplurals=2; plural=(n != 1)\n"
"POT-Creation-Date: 2024-12-11T00:48:22.223Z\n"
"PO-Revision-Date: 2024-12-11T00:48:22.223Z\n"
"POT-Creation-Date: 2024-12-20T17:43:52.507Z\n"
"PO-Revision-Date: 2024-12-20T17:43:52.508Z\n"

msgid "View keys"
msgstr "View keys"
Expand All @@ -23,6 +23,18 @@ msgstr "An error occurred"
msgid "Error"
msgstr "Error"

msgid "Add New Namespace"
msgstr "Add New Namespace"

msgid "Add New Key"
msgstr "Add New Key"

msgid "Add Namespace"
msgstr "Add Namespace"

msgid "Add Key"
msgstr "Add Key"

msgid "Namespace"
msgstr "Namespace"

Expand All @@ -32,6 +44,18 @@ msgstr "Key"
msgid "Cancel"
msgstr "Cancel"

msgid "Delete Namespace"
msgstr "Delete Namespace"

msgid "Delete Key"
msgstr "Delete Key"

msgid "This will delete all the keys in this namespace"
msgstr "This will delete all the keys in this namespace"

msgid "Delete"
msgstr "Delete"

msgid "Key successfully updated"
msgstr "Key successfully updated"

Expand All @@ -44,6 +68,15 @@ msgstr "Loading"
msgid "Save changes"
msgstr "Save changes"

msgid "delete"
msgstr "delete"

msgid "New namespace"
msgstr "New namespace"

msgid "New key"
msgstr "New key"

msgid "create"
msgstr "create"

Expand All @@ -59,20 +92,5 @@ msgstr "Search"
msgid "Key created successfully"
msgstr "Key created successfully"

msgid "Add New Namespace"
msgstr "Add New Namespace"

msgid "Add New Key"
msgstr "Add New Key"

msgid "Add Namespace"
msgstr "Add Namespace"

msgid "Add Key"
msgstr "Add Key"

msgid "New namespace"
msgstr "New namespace"

msgid "New key"
msgstr "New key"
msgid "There was an error creating the key"
msgstr "There was an error creating the key"
9 changes: 9 additions & 0 deletions src/components/Panel.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
margin: 0.5em 0 0.3em 0;
width: 100%;
border: none;
justify-content: start;
}

.sidebarList ul {
Expand Down Expand Up @@ -97,3 +98,11 @@
.navLink.active:hover {
background: var(--colors-teal050);
}

/* context menu */
.contextMenu button {
background-color: transparent;
border: none;
width: 100%;
justify-content: start;
}
18 changes: 11 additions & 7 deletions src/components/modals/CreateModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import {
InputField,
} from '@dhis2/ui'
import React from 'react'
import { useSidePanelContext } from '../../context/SidePanelContext'
import i18n from '../../locales'
import { CreateFieldValues } from '../sidepanel/SidePanel'

Expand All @@ -16,22 +17,25 @@ type CreateModalProps = {
values: CreateFieldValues
setValues: (values) => void
closeModal: () => void
title: string
type: string
buttonLabel: string
}

const CreateModal = ({
createFn,
values,
setValues,
closeModal,
title,
type,
buttonLabel,
}: CreateModalProps) => {
const { panelType: type } = useSidePanelContext()

const title =
type === 'namespace'
? i18n.t('Add New Namespace')
: i18n.t('Add New Key')
const buttonLabel =
type === 'namespace' ? i18n.t('Add Namespace') : i18n.t('Add Key')

return (
<Modal>
<Modal position="middle">
<ModalTitle>{title}</ModalTitle>
<ModalContent>
{type === 'namespace' && (
Expand Down
84 changes: 84 additions & 0 deletions src/components/modals/DeleteModal.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
import {
Modal,
ModalContent,
ModalActions,
ModalTitle,
Button,
ButtonStrip,
} from '@dhis2/ui'
import React from 'react'
import { useParams } from 'react-router-dom'
import { useSidePanelContext } from '../../context/SidePanelContext'
import i18n from '../../locales'

const DeleteModal = ({
handleDeleteAction,
}: {
handleDeleteAction: () => void
}) => {
const {
panelType: type,
totalItems,
selectedLinkItem: value,
setOpenDeleteModal,
} = useSidePanelContext()
const { namespace: currentNamespace } = useParams()

const title =
type === 'namespace' ? i18n.t('Delete Namespace') : i18n.t('Delete Key')

return (
<Modal position="middle">
<ModalTitle>{title}</ModalTitle>
<ModalContent>
{type === 'namespace' && (
<>
<p>
{i18n.t(
`Are you sure you want to delete '${value}'?`
)}
</p>
<p>
{i18n.t(
`This will delete all the keys in this namespace`
)}
</p>
</>
)}
{type === 'keys' && (
<>
<p>
{i18n.t(
`Are you sure you want to delete '${value}' in ${currentNamespace}?`
)}
</p>
{totalItems < 2 && (
<p>
{i18n.t(
`This will also delete the namespace '${currentNamespace}'`
)}
</p>
)}
</>
)}
</ModalContent>
<ModalActions>
<ButtonStrip end>
<Button secondary onClick={() => setOpenDeleteModal(false)}>
{i18n.t('Cancel')}
</Button>
<Button
destructive
onClick={() => {
handleDeleteAction()
setOpenDeleteModal(false)
}}
>
{i18n.t('Delete')}
</Button>
</ButtonStrip>
</ModalActions>
</Modal>
)
}
export default DeleteModal
1 change: 1 addition & 0 deletions src/components/panels/EditPanel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ const EditPanel = () => {
})
} catch (error) {
// setUpdateError(error.message)
console.error(error.message)
const message = i18n.t('There was an error updating the key')
showError(message)
}
Expand Down
62 changes: 62 additions & 0 deletions src/components/sidepanel/ContextButton.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
import { Button, IconMore16, Popover, IconDelete16 } from '@dhis2/ui'
import React, { useRef } from 'react'
import { useSidePanelContext } from '../../context/SidePanelContext'
import i18n from '../../locales'
import classes from '../Panel.module.css'

type ContextMenuButtonProps = {
handleContextMenu: () => void
openContextMenu: boolean
setOpenContextMenu: (boolean) => void
}

const ContextMenuButton = ({
handleContextMenu,
openContextMenu,
setOpenContextMenu,
}: ContextMenuButtonProps) => {
const ref = useRef(null)
const { setOpenDeleteModal } = useSidePanelContext()

return (
<div ref={ref}>
<Button
aria-label="More"
icon={<IconMore16 />}
name="more"
onClick={handleContextMenu}
title="More"
/>
{openContextMenu && (
<Popover
reference={ref}
placement="right-start"
onClickOutside={() => setOpenContextMenu(false)}
>
<div
className={classes.contextMenu}
style={{
width: '150px',
padding: 6,
}}
>
<Button
aria-label={i18n.t('delete')}
icon={<IconDelete16 />}
name={i18n.t('delete')}
onClick={() => {
setOpenContextMenu(false)
setOpenDeleteModal(true)
}}
title={i18n.t('delete')}
>
{i18n.t('Delete')}
</Button>
</div>
</Popover>
)}
</div>
)
}

export default ContextMenuButton
7 changes: 5 additions & 2 deletions src/components/sidepanel/CreateButton.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,18 @@
import { Button } from '@dhis2/ui'
import { IconAdd16 } from '@dhis2/ui-icons'
import React from 'react'
import { useSidePanelContext } from '../../context/SidePanelContext'
import i18n from '../../locales'
import classes from '../Panel.module.css'

type CreateButtonProps = {
label: string
handleClick: () => void
}

const CreateButton = ({ label, handleClick }: CreateButtonProps) => {
const CreateButton = ({ handleClick }: CreateButtonProps) => {
const { panelType: type } = useSidePanelContext()
const label =
type === 'namespace' ? i18n.t('New namespace') : i18n.t('New key')
return (
<div className={classes.createButton}>
<Button
Expand Down
31 changes: 16 additions & 15 deletions src/components/sidepanel/PanelLink.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,9 @@
import { Button } from '@dhis2/ui'
import {
IconFile16,
IconMore16,
IconFolder16,
IconFolderOpen16,
} from '@dhis2/ui-icons'
import React from 'react'
import { IconFile16, IconFolder16, IconFolderOpen16 } from '@dhis2/ui-icons'
import React, { useState } from 'react'
import { NavLink } from 'react-router-dom'
import { useSidePanelContext } from '../../context/SidePanelContext'
import classes from '../Panel.module.css'
import ContextMenuButton from './ContextButton'

type SidePanelLinkProps = {
label: string
Expand All @@ -16,6 +12,13 @@ type SidePanelLinkProps = {
}

const SidePanelLink = ({ to, label, type }: SidePanelLinkProps) => {
const { setSelectedLinkItem } = useSidePanelContext()
const [openContextMenu, setOpenContextMenu] = useState(false)

const handleContextMenu = () => {
setSelectedLinkItem(label)
setOpenContextMenu((prev) => !prev)
}
const renderIcon = ({ isActive }) =>
type === 'namespace' ? (
isActive ? (
Expand All @@ -38,16 +41,14 @@ const SidePanelLink = ({ to, label, type }: SidePanelLinkProps) => {
<>
{renderIcon({ isActive })}
<span>{label}</span>
<Button
aria-label="More"
icon={<IconMore16 />}
name="more"
// onClick={}
title="More"
/>
</>
)}
</NavLink>
<ContextMenuButton
handleContextMenu={handleContextMenu}
openContextMenu={openContextMenu}
setOpenContextMenu={setOpenContextMenu}
/>
</li>
)
}
Expand Down
Loading

0 comments on commit b603eb3

Please sign in to comment.