Skip to content

Commit

Permalink
Merge branch 'fix/like-causing-flashing-interp-panel' into feat/bundl…
Browse files Browse the repository at this point in the history
…e-26.4.0

Prepare analytics bundle
  • Loading branch information
edoardo committed Feb 20, 2024
2 parents 29898c8 + fe2a3d3 commit 6d1ceb4
Show file tree
Hide file tree
Showing 6 changed files with 58 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ const InterpretationModal = ({
})
const interpretation = data?.interpretation
const shouldRenderModalContent = !error && interpretation
const shouldCssHideModal = loading || isVisualizationLoading
const loadingInProgress = loading || isVisualizationLoading
const handleClose = () => {
if (isDirty) {
onInterpretationUpdate()
Expand All @@ -97,6 +97,13 @@ const InterpretationModal = ({
}
refetch({ id: interpretationId })
}

const onLikeToggled = ({ likedBy }) => {
setIsDirty(true)
interpretation.likedBy = likedBy
interpretation.likes = likedBy.length
}

const onInterpretationDeleted = () => {
setIsDirty(false)
onInterpretationUpdate()
Expand All @@ -111,7 +118,7 @@ const InterpretationModal = ({

return (
<>
{shouldCssHideModal && (
{loadingInProgress && (
<Layer>
<CenteredContent>
<CircularLoader />
Expand All @@ -122,7 +129,7 @@ const InterpretationModal = ({
fluid
onClose={handleClose}
className={cx(modalCSS.className, {
hidden: shouldCssHideModal,
hidden: loadingInProgress,
})}
dataTest="interpretation-modal"
>
Expand Down Expand Up @@ -183,6 +190,7 @@ const InterpretationModal = ({
downloadMenuComponent={
downloadMenuComponent
}
onLikeToggled={onLikeToggled}
/>
</div>
</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ const InterpretationThread = ({
fetching,
interpretation,
onInterpretationDeleted,
onLikeToggled,
initialFocus,
onThreadUpdated,
downloadMenuComponent: DownloadMenu,
Expand Down Expand Up @@ -46,6 +47,7 @@ const InterpretationThread = ({
<Interpretation
currentUser={currentUser}
interpretation={interpretation}
onLikeToggled={onLikeToggled}
onReplyIconClick={
interpretationAccess.comment
? () => focusRef.current?.focus()
Expand Down Expand Up @@ -151,6 +153,7 @@ InterpretationThread.propTypes = {
fetching: PropTypes.bool.isRequired,
interpretation: PropTypes.object.isRequired,
onInterpretationDeleted: PropTypes.func.isRequired,
onLikeToggled: PropTypes.func.isRequired,
downloadMenuComponent: PropTypes.oneOfType([
PropTypes.object,
PropTypes.func,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ export const InterpretationList = ({
currentUser,
interpretations,
onInterpretationClick,
onLikeToggled,
onReplyIconClick,
refresh,
disabled,
Expand Down Expand Up @@ -64,6 +65,7 @@ export const InterpretationList = ({
interpretation={interpretation}
currentUser={currentUser}
onClick={onInterpretationClick}
onLikeToggled={onLikeToggled}
onReplyIconClick={onReplyIconClick}
onDeleted={refresh}
onUpdated={refresh}
Expand Down Expand Up @@ -116,6 +118,7 @@ InterpretationList.propTypes = {
interpretations: PropTypes.array.isRequired,
refresh: PropTypes.func.isRequired,
onInterpretationClick: PropTypes.func.isRequired,
onLikeToggled: PropTypes.func.isRequired,
onReplyIconClick: PropTypes.func.isRequired,
disabled: PropTypes.bool,
}
Original file line number Diff line number Diff line change
Expand Up @@ -53,13 +53,16 @@ export const InterpretationsUnit = forwardRef(
ref
) => {
const [isExpanded, setIsExpanded] = useState(true)
const [interpretations, setInterpretations] = useState([])
const showNoTimeDimensionHelpText =
type === 'eventVisualization' && !visualizationHasTimeDimension

const { data, loading, fetching, refetch } = useDataQuery(
const { loading, fetching, refetch } = useDataQuery(
interpretationsQuery,
{
lazy: true,
onComplete: (data) =>
setInterpretations(data.interpretations.interpretations),
}
)

Expand All @@ -81,6 +84,14 @@ export const InterpretationsUnit = forwardRef(
}
}, [type, id, renderId, refetch])

const onLikeToggled = ({ id, likedBy }) => {
const interpretation = interpretations.find(
(interp) => interp.id === id
)
interpretation.likedBy = likedBy
interpretation.likes = likedBy.length
}

return (
<div
className={cx('container', {
Expand Down Expand Up @@ -110,7 +121,7 @@ export const InterpretationsUnit = forwardRef(
<CircularLoader small />
</div>
)}
{data && (
{interpretations && (
<>
<InterpretationForm
currentUser={currentUser}
Expand All @@ -124,12 +135,11 @@ export const InterpretationsUnit = forwardRef(
/>
<InterpretationList
currentUser={currentUser}
interpretations={
data.interpretations.interpretations
}
interpretations={interpretations}
onInterpretationClick={
onInterpretationClick
}
onLikeToggled={onLikeToggled}
onReplyIconClick={onReplyIconClick}
refresh={onCompleteAction}
disabled={disabled}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,13 +28,18 @@ export const Interpretation = ({
disabled,
onReplyIconClick,
isInThread,
onLikeToggled,
}) => {
const [isUpdateMode, setIsUpdateMode] = useState(false)
const [showSharingDialog, setShowSharingDialog] = useState(false)
const { toggleLike, isLikedByCurrentUser, toggleLikeInProgress } = useLike({
interpretation,
currentUser,
onComplete: onUpdated,
onComplete: (likedBy) =>
onLikeToggled({
id: interpretation.id,
likedBy,
}),
})
const shouldShowButton = !!onClick && !disabled

Expand Down Expand Up @@ -151,6 +156,7 @@ Interpretation.propTypes = {
currentUser: PropTypes.object.isRequired,
interpretation: PropTypes.object.isRequired,
onDeleted: PropTypes.func.isRequired,
onLikeToggled: PropTypes.func.isRequired,
onReplyIconClick: PropTypes.func.isRequired,
onUpdated: PropTypes.func.isRequired,
disabled: PropTypes.bool,
Expand Down
21 changes: 19 additions & 2 deletions src/components/Interpretations/common/Interpretation/useLike.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,28 @@ const useLike = ({ interpretation, currentUser, onComplete }) => {
const unlikeMutationRef = useRef({ resource, type: 'delete' })
const [like, { loading: likeLoading }] = useDataMutation(
likeMutationRef.current,
{ onComplete }
{
onComplete: () => {
const newLikedBy = interpretation.likedBy.concat({
id: currentUser.id,
})
setIsLikedByCurrentUser(true)
onComplete(newLikedBy)
},
}
)
const [unlike, { loading: unlikeLoading }] = useDataMutation(
unlikeMutationRef.current,
{ onComplete }
{
onComplete: () => {
const newLikedBy = interpretation.likedBy.filter(
(lb) => lb.id !== currentUser.id
)

setIsLikedByCurrentUser(false)
onComplete(newLikedBy)
},
}
)
const [isLikedByCurrentUser, setIsLikedByCurrentUser] = useState(false)
const toggleLike = () => {
Expand Down

0 comments on commit 6d1ceb4

Please sign in to comment.