Skip to content

Commit

Permalink
refactor: Add useQuery in ContactCardModal
Browse files Browse the repository at this point in the history
  • Loading branch information
JF-Cozy committed Aug 20, 2020
1 parent 11a4320 commit f1a892b
Show file tree
Hide file tree
Showing 3 changed files with 98 additions and 71 deletions.
122 changes: 53 additions & 69 deletions src/components/Modals/ContactCardModal.jsx
Original file line number Diff line number Diff line change
@@ -1,96 +1,80 @@
import React from 'react'
import React, { useState } from 'react'
import { PropTypes } from 'prop-types'
import { flow } from 'lodash'

import { useQuery, isQueryLoading, hasQueryBeenLoaded } from 'cozy-client'
import Button from 'cozy-ui/transpiled/react/Button'
import { translate } from 'cozy-ui/transpiled/react/I18n'
import Modal, {
ModalHeader,
ModalContent
} from 'cozy-ui/transpiled/react/Modal'
import { DOCTYPE_CONTACTS } from '../../helpers/doctypes'
import { getConnectedAccounts } from '../../helpers/contacts'

import { getConnectedAccounts } from '../../helpers/contacts'
import withContactsMutations from '../../connections/allContacts'
import ContactCard from '../ContactCard/ContactCard'
import SpinnerContact from '../Components/Spinner'
import ContactFormModal from './ContactFormModal'
import ContactGroups from '../ContactCard/ContactGroups'
import Button from 'cozy-ui/transpiled/react/Button'
import { Query } from 'cozy-client'
import { flow } from 'lodash'
import { buildContactQuery, queryAllGroups } from '../../helpers/queries'

export class ContactCardModal extends React.Component {
state = {
editMode: false,
shouldDisplayConfirmDeleteModal: false
}
const ContactCardModal = props => {
const [editMode, setEditMode] = useState(false)
const [
shouldDisplayConfirmDeleteModal,
setShouldDisplayConfirmDeleteModal
] = useState(false)

toggleConfirmDeleteModal = () => {
this.setState(state => ({
shouldDisplayConfirmDeleteModal: !state.shouldDisplayConfirmDeleteModal
}))
const toggleConfirmDeleteModal = () => {
setShouldDisplayConfirmDeleteModal(!shouldDisplayConfirmDeleteModal)
}

deleteContact = async (contactParam = null) => {
const { contact, deleteContact, onDeleteContact, onClose } = this.props
const deleteContact = async (contactParam = null) => {
const { contact, deleteContact, onDeleteContact, onClose } = props
onClose && onClose()
await deleteContact(contactParam ? contactParam : contact)
onDeleteContact && onDeleteContact(contactParam ? contactParam : contact)
}

toggleEditMode = () => {
this.setState(state => ({
editMode: !state.editMode
}))
const toggleEditMode = () => {
setEditMode(!editMode)
}

render() {
const { onClose, t, id } = this.props
const { editMode, shouldDisplayConfirmDeleteModal } = this.state
const { onClose, t, id } = props

return (
<Modal into="body" dismissAction={onClose} size="xlarge" mobileFullscreen>
<Query query={client => client.get(DOCTYPE_CONTACTS, id)}>
{({ data: contact, fetchStatus: fetchContactStatus }) => {
return (
<Query
query={client =>
client
.find('io.cozy.contacts.groups')
.where({
trashed: { $exists: false }
})
.sortBy([{ name: 'asc' }])
.indexFields(['name'])
}
>
{({ data: allGroups, fetchStatus: allGroupsContactStatus }) => {
if (
fetchContactStatus !== 'loaded' ||
allGroupsContactStatus !== 'loaded'
) {
return <SpinnerContact size="xxlarge" />
}
return (
<DumbContactCardModal
editMode={editMode}
contact={contact}
allGroups={allGroups}
t={t}
toggleConfirmDeleteModal={this.toggleConfirmDeleteModal}
toggleEditMode={this.toggleEditMode}
shouldDisplayConfirmDeleteModal={
shouldDisplayConfirmDeleteModal
}
deleteContact={this.deleteContact}
/>
)
}}
</Query>
)
}}
</Query>
</Modal>
)
}
const queryContactById = buildContactQuery(id)
const resultContactById = useQuery(
queryContactById.definition,
queryContactById.options
)
const resultAllGroups = useQuery(
queryAllGroups.definition,
queryAllGroups.options
)

const dataHaveBeenLoaded =
(!isQueryLoading(resultContactById) ||
hasQueryBeenLoaded(resultContactById)) &&
(!isQueryLoading(resultAllGroups) || hasQueryBeenLoaded(resultAllGroups))

return (
<Modal into="body" dismissAction={onClose} size="xlarge" mobileFullscreen>
{dataHaveBeenLoaded ? (
<DumbContactCardModal
editMode={editMode}
contact={resultContactById.data[0]}
allGroups={resultAllGroups.data}
t={t}
toggleConfirmDeleteModal={toggleConfirmDeleteModal}
toggleEditMode={toggleEditMode}
shouldDisplayConfirmDeleteModal={shouldDisplayConfirmDeleteModal}
deleteContact={deleteContact}
/>
) : (
<SpinnerContact size="xxlarge" />
)}
</Modal>
)
}

export const DumbContactCardModal = ({
Expand Down
13 changes: 11 additions & 2 deletions src/components/Modals/ContactCardModal.spec.jsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
import React from 'react'
import { ContactCardModal, DumbContactCardModal } from './ContactCardModal'
import ContactCardModal, { DumbContactCardModal } from './ContactCardModal'
import { render } from '@testing-library/react'
import { createMockClient } from 'cozy-client'
import AppLike from '../../tests/Applike'
import { contactWithGroup as contact, groups } from '../../helpers/testData'
import { createMockClient, useQuery } from 'cozy-client'

jest.mock('cozy-client/dist/hooks/useQuery', () => jest.fn())

const client = createMockClient({})
const setup = ({
Expand Down Expand Up @@ -31,6 +33,13 @@ describe('ContactCardModal', () => {
onClose: jest.fn,
deleteContact: jest.fn
}
useQuery.mockReturnValue({
data: [],
fetchStatus: 'pending',
hasMore: true,
fetchMore: jest.fn()
})

const jsx = (
<AppLike client={client}>
<ContactCardModal {...props} />
Expand Down
34 changes: 34 additions & 0 deletions src/helpers/queries.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
import { Q, fetchPolicies } from 'cozy-client'
import { DOCTYPE_CONTACTS } from './doctypes'

const olderThan30sec = fetchPolicies.olderThan(30 * 1000)

export const buildContactQuery = id => ({
definition: () => Q(DOCTYPE_CONTACTS).getById(id),
options: {
as: `contactById-${id}`,
fetchPolicy: olderThan30sec
}
})

export const queryAllGroups = {
definition: () =>
Q('io.cozy.contacts.groups')
.where({
$or: [
{
trashed: {
$exists: false
}
},
{
trashed: false
}
]
})
.sortBy([{ name: 'asc' }]),
options: {
as: 'allGroups',
fetchPolicy: olderThan30sec
}
}

0 comments on commit f1a892b

Please sign in to comment.