-
Notifications
You must be signed in to change notification settings - Fork 19
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
545ae41
commit eb0c4da
Showing
10 changed files
with
347 additions
and
59 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
116 changes: 116 additions & 0 deletions
116
met-web/src/components/engagement/form/EngagementWidgets/Subscribe/SubscribeInfoBlock.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,116 @@ | ||
import React, { useContext, useRef } from 'react'; | ||
import { Grid, Skeleton } from '@mui/material'; | ||
import { DragDropContext, DropResult } from '@hello-pangea/dnd'; | ||
import { MetDraggable, MetDroppable } from 'components/common/Dragdrop'; | ||
import { reorder } from 'utils'; | ||
import SubscribeInfoPaper from './SubscribeInfoPaper'; | ||
import { When } from 'react-if'; | ||
import { debounce } from 'lodash'; | ||
import { deleteSubscribeForm } from 'services/subscriptionService'; | ||
import { useAppDispatch } from 'hooks'; | ||
import { openNotificationModal } from 'services/notificationModalService/notificationModalSlice'; | ||
import { openNotification } from 'services/notificationService/notificationSlice'; | ||
import { SubscribeContext } from './SubscribeContext'; | ||
import { Subscribe_TYPE, SubscribeForm } from 'models/subscription'; | ||
|
||
const SubscribeInfoBlock = () => { | ||
const { subscribe, setSubscribe, isLoadingSubscribe, updateWidgetSubscribeSorting, widget } = | ||
useContext(SubscribeContext); | ||
const dispatch = useAppDispatch(); | ||
const debounceUpdateWidgetSubscribeSorting = useRef( | ||
debounce((widgetSubscribeToSort: SubscribeForm[]) => { | ||
updateWidgetSubscribeSorting(widgetSubscribeToSort); | ||
}, 800), | ||
).current; | ||
|
||
const moveSubscribeForm = (result: DropResult) => { | ||
if (!result.destination) { | ||
return; | ||
} | ||
|
||
const items = reorder(subscribe, result.source.index, result.destination.index); | ||
|
||
setSubscribe(items); | ||
|
||
debounceUpdateWidgetSubscribeSorting(items); | ||
}; | ||
|
||
if (isLoadingSubscribe) { | ||
return ( | ||
<Grid container direction="row" alignItems={'flex-start'} justifyContent="flex-start" spacing={2}> | ||
<Grid item xs={12}> | ||
<Skeleton variant="rectangular" width="100%" height="12em" /> | ||
</Grid> | ||
</Grid> | ||
); | ||
} | ||
|
||
const handleRemoveSubscribeForm = (subscribeFormId: number) => { | ||
dispatch( | ||
openNotificationModal({ | ||
open: true, | ||
data: { | ||
header: 'Remove SubscribeForm', | ||
subText: [ | ||
{ | ||
text: 'You will be removing this subscribeForm from the engagement.', | ||
}, | ||
{ | ||
text: 'Do you want to remove this subscribeForm?', | ||
}, | ||
], | ||
handleConfirm: () => { | ||
removeSubscribeForm(subscribeFormId); | ||
}, | ||
}, | ||
type: 'confirm', | ||
}), | ||
); | ||
}; | ||
|
||
const removeSubscribeForm = async (subscribeFormId: number) => { | ||
try { | ||
if (widget) { | ||
await deleteSubscribeForm(widget.id, subscribeFormId); | ||
const newSubscribe = subscribe.filter((subscribeForm) => subscribeForm.id !== subscribeFormId); | ||
setSubscribe([...newSubscribe]); | ||
dispatch(openNotification({ severity: 'success', text: 'The subscribeForm was removed successfully' })); | ||
} | ||
} catch (error) { | ||
dispatch( | ||
openNotification({ severity: 'error', text: 'An error occurred while trying to remove subscribeForm' }), | ||
); | ||
} | ||
}; | ||
|
||
return ( | ||
<DragDropContext onDragEnd={moveSubscribeForm}> | ||
<MetDroppable droppableId="droppable"> | ||
<Grid container direction="row" alignItems={'flex-start'} justifyContent="flex-start" spacing={2}> | ||
{subscribe.map((subscribeForm: SubscribeForm, index) => { | ||
return ( | ||
<Grid item xs={12} key={`Grid-${subscribeForm.widget_id}`}> | ||
<MetDraggable draggableId={String(subscribeForm.widget_id)} index={index}> | ||
<When condition={subscribeForm.type === Subscribe_TYPE.EMAIL_LIST}> | ||
<SubscribeInfoPaper | ||
removeSubscribeForm={handleRemoveSubscribeForm} | ||
subscribeForm={subscribeForm} | ||
/> | ||
</When> | ||
<When condition={subscribeForm.type === Subscribe_TYPE.FORM}> | ||
<SubscribeInfoPaper | ||
removeSubscribeForm={handleRemoveSubscribeForm} | ||
subscribeForm={subscribeForm} | ||
/> | ||
</When> | ||
</MetDraggable> | ||
</Grid> | ||
); | ||
})} | ||
</Grid> | ||
</MetDroppable> | ||
</DragDropContext> | ||
); | ||
}; | ||
|
||
export default SubscribeInfoBlock; |
Oops, something went wrong.