-
Notifications
You must be signed in to change notification settings - Fork 2.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #476 from gitroomhq/feat/customer
Add customers seperation
- Loading branch information
Showing
11 changed files
with
616 additions
and
131 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
import { TopTitle } from '@gitroom/frontend/components/launches/helpers/top.title.component'; | ||
import React, { FC, useCallback, useEffect, useState } from 'react'; | ||
import { useModals } from '@mantine/modals'; | ||
import { Integration } from '@prisma/client'; | ||
import { Autocomplete } from '@mantine/core'; | ||
import useSWR from 'swr'; | ||
import { useFetch } from '@gitroom/helpers/utils/custom.fetch'; | ||
import { Button } from '@gitroom/react/form/button'; | ||
|
||
export const CustomerModal: FC<{ | ||
integration: Integration & { customer?: { id: string; name: string } }; | ||
onClose: () => void; | ||
}> = (props) => { | ||
const fetch = useFetch(); | ||
const { onClose, integration } = props; | ||
const [customer, setCustomer] = useState( | ||
integration.customer?.name || undefined | ||
); | ||
const modal = useModals(); | ||
|
||
const loadCustomers = useCallback(async () => { | ||
return (await fetch('/integrations/customers')).json(); | ||
}, []); | ||
|
||
const removeFromCustomer = useCallback(async () => { | ||
saveCustomer(true); | ||
}, []); | ||
|
||
const saveCustomer = useCallback(async (removeCustomer?: boolean) => { | ||
if (!customer) { | ||
return; | ||
} | ||
|
||
await fetch(`/integrations/${integration.id}/customer-name`, { | ||
method: 'PUT', | ||
body: JSON.stringify({ name: removeCustomer ? '' : customer }), | ||
}); | ||
|
||
modal.closeAll(); | ||
onClose(); | ||
}, [customer]); | ||
|
||
const { data } = useSWR('/customers', loadCustomers); | ||
|
||
return ( | ||
<div className="rounded-[4px] border border-customColor6 bg-sixth px-[16px] pb-[16px] relative w-full"> | ||
<TopTitle title={`Move / Add to customer`} /> | ||
<button | ||
className="outline-none absolute right-[20px] top-[20px] mantine-UnstyledButton-root mantine-ActionIcon-root hover:bg-tableBorder cursor-pointer mantine-Modal-close mantine-1dcetaa" | ||
type="button" | ||
onClick={() => modal.closeAll()} | ||
> | ||
<svg | ||
viewBox="0 0 15 15" | ||
fill="none" | ||
xmlns="http://www.w3.org/2000/svg" | ||
width="16" | ||
height="16" | ||
> | ||
<path | ||
d="M11.7816 4.03157C12.0062 3.80702 12.0062 3.44295 11.7816 3.2184C11.5571 2.99385 11.193 2.99385 10.9685 3.2184L7.50005 6.68682L4.03164 3.2184C3.80708 2.99385 3.44301 2.99385 3.21846 3.2184C2.99391 3.44295 2.99391 3.80702 3.21846 4.03157L6.68688 7.49999L3.21846 10.9684C2.99391 11.193 2.99391 11.557 3.21846 11.7816C3.44301 12.0061 3.80708 12.0061 4.03164 11.7816L7.50005 8.31316L10.9685 11.7816C11.193 12.0061 11.5571 12.0061 11.7816 11.7816C12.0062 11.557 12.0062 11.193 11.7816 10.9684L8.31322 7.49999L11.7816 4.03157Z" | ||
fill="currentColor" | ||
fillRule="evenodd" | ||
clipRule="evenodd" | ||
></path> | ||
</svg> | ||
</button> | ||
|
||
<div className="mt-[16px]"> | ||
<Autocomplete | ||
value={customer} | ||
onChange={setCustomer} | ||
classNames={{ | ||
label: 'text-white', | ||
}} | ||
label="Select Customer" | ||
placeholder="Start typing..." | ||
data={data?.map((p: any) => p.name) || []} | ||
/> | ||
</div> | ||
|
||
<div className="my-[16px] flex gap-[10px]"> | ||
<Button onClick={() => saveCustomer()}>Save</Button> | ||
{!!integration?.customer?.name && <Button className="bg-red-700" onClick={removeFromCustomer}>Remove from customer</Button>} | ||
</div> | ||
</div> | ||
); | ||
}; |
Oops, something went wrong.