added dynamic getMessages query
This commit is contained in:
parent
5e3631c49d
commit
19674310e7
@ -4,12 +4,12 @@ import axios from 'axios';
|
|||||||
|
|
||||||
export default createOperation.query({
|
export default createOperation.query({
|
||||||
input: z.object({
|
input: z.object({
|
||||||
page: z.number().optional(),
|
|
||||||
}),
|
}),
|
||||||
handler: async ({ page = 1 }) => {
|
handler: async () => {
|
||||||
console.log('Making request to Chatwoot API');
|
console.log('Making request to Chatwoot API');
|
||||||
|
|
||||||
const { data } = await axios.get(`https://chatwoot.andert.me/api/v1/accounts/1/contacts?page=${page}`, {
|
const { data } = await axios.get(`https://chatwoot.andert.me/api/v1/accounts/1/contacts`, {
|
||||||
headers: {
|
headers: {
|
||||||
api_access_token: process.env.CHATWOOT_API_ACCESS_TOKEN
|
api_access_token: process.env.CHATWOOT_API_ACCESS_TOKEN
|
||||||
},
|
},
|
||||||
|
20
.wundergraph/operations/getChatwootMessages.ts
Normal file
20
.wundergraph/operations/getChatwootMessages.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
// .wundergraph/operations/getChatwootMessages.ts
|
||||||
|
import { createOperation, z } from '../generated/wundergraph.factory';
|
||||||
|
import axios from 'axios';
|
||||||
|
|
||||||
|
export default createOperation.query({
|
||||||
|
input: z.object({
|
||||||
|
conversationId: z.string(),
|
||||||
|
}),
|
||||||
|
handler: async ({ input }) => {
|
||||||
|
console.log('Making request to Chatwoot API');
|
||||||
|
|
||||||
|
const { data } = await axios.get(`https://chatwoot.andert.me/api/v1/accounts/1/conversations/${input.conversationId}/messages`, {
|
||||||
|
headers: {
|
||||||
|
api_access_token: process.env.CHATWOOT_API_ACCESS_TOKEN
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
return data;
|
||||||
|
},
|
||||||
|
});
|
@ -5,7 +5,6 @@
|
|||||||
|
|
||||||
const contactsQuery = createQuery({
|
const contactsQuery = createQuery({
|
||||||
operationName: "getChatwootContacts",
|
operationName: "getChatwootContacts",
|
||||||
variables: { page: 2 },
|
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
let selectedConversation = null;
|
let selectedConversation = null;
|
||||||
|
let messagesQuery;
|
||||||
|
|
||||||
function selectConversation(conversation) {
|
function selectConversation(conversation) {
|
||||||
selectedConversation = conversation;
|
selectedConversation = conversation;
|
||||||
}
|
}
|
||||||
@ -15,6 +17,13 @@
|
|||||||
$: if ($conversationsQuery.data && !selectedConversation) {
|
$: if ($conversationsQuery.data && !selectedConversation) {
|
||||||
selectedConversation = $conversationsQuery.data.data.payload[0];
|
selectedConversation = $conversationsQuery.data.data.payload[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$: if (selectedConversation) {
|
||||||
|
messagesQuery = createQuery({
|
||||||
|
operationName: "getChatwootMessages",
|
||||||
|
input: { conversationId: selectedConversation.id },
|
||||||
|
});
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="h-full w-full overflow-scroll flex">
|
<div class="h-full w-full overflow-scroll flex">
|
||||||
@ -49,24 +58,21 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="space-y-4 px-4">
|
<div class="space-y-4 px-4">
|
||||||
{#each selectedConversation.messages as message (message.id)}
|
{#if $messagesQuery && $messagesQuery.data}
|
||||||
{#if message.content_type == "incoming_email"}
|
{#each $messagesQuery.data.payload as message (message.id)}
|
||||||
{#if selectedConversation.last_non_activity_message.content != message.content}
|
{#if message.content_attributes.email && (message.content_attributes.email.content_type.includes("text/html") || message.content_attributes.email.content_type.includes("multipart/alternative"))}
|
||||||
<MailViewer
|
|
||||||
html={selectedConversation.last_non_activity_message
|
|
||||||
.content_attributes.email.html_content.full}
|
|
||||||
/>{/if}
|
|
||||||
<MailViewer
|
<MailViewer
|
||||||
html={message.content_attributes.email.html_content.full}
|
html={message.content_attributes.email.html_content.full}
|
||||||
/>
|
/>
|
||||||
{:else}
|
{:else}
|
||||||
{#if selectedConversation.last_non_activity_message.content != message.content}{selectedConversation
|
<div
|
||||||
.last_non_activity_message.content}{/if}
|
class="p-4 max-w-xs mx-auto bg-blue-100 rounded-xl shadow-md flex items-center space-x-4"
|
||||||
<p class="bg-slate-400 py-1 px-2 rounded-sm my-2">
|
>
|
||||||
{message.content}
|
<p class="text-black">{message.content}</p>
|
||||||
</p>
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
{/each}
|
{/each}
|
||||||
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
{:else}
|
{:else}
|
||||||
<p>Select a conversation to view its details.</p>
|
<p>Select a conversation to view its details.</p>
|
||||||
|
Loading…
Reference in New Issue
Block a user