mirror of
https://github.com/hcengineering/platform.git
synced 2025-04-22 16:27:22 +00:00
Gmail public messages (#907)
Signed-off-by: Denis Bykhov <80476319+BykhovDenis@users.noreply.github.com>
This commit is contained in:
parent
a8fbdbecde
commit
a34150221b
@ -30,29 +30,31 @@
|
|||||||
export let channel: Channel
|
export let channel: Channel
|
||||||
export let newMessage: boolean
|
export let newMessage: boolean
|
||||||
|
|
||||||
|
const EMAIL_REGEX = /(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))/
|
||||||
|
|
||||||
let messages: Message[] = []
|
let messages: Message[] = []
|
||||||
let account: EmployeeAccount | undefined
|
let accounts: EmployeeAccount[] = []
|
||||||
let enabled: boolean
|
let enabled: boolean
|
||||||
let selected: Set<Ref<SharedMessage>> = new Set<Ref<SharedMessage>>()
|
let selected: Set<Ref<SharedMessage>> = new Set<Ref<SharedMessage>>()
|
||||||
let selectable = false
|
let selectable = false
|
||||||
let me = ''
|
|
||||||
|
|
||||||
const messagesQuery = createQuery()
|
const messagesQuery = createQuery()
|
||||||
const accauntQuery = createQuery()
|
const accauntsQuery = createQuery()
|
||||||
const settingsQuery = createQuery()
|
const settingsQuery = createQuery()
|
||||||
const accountId = getCurrentAccount()._id
|
const accountId = getCurrentAccount()._id
|
||||||
|
|
||||||
$: messagesQuery.query(
|
$: messagesQuery.query(
|
||||||
gmail.class.Message,
|
gmail.class.Message,
|
||||||
{ modifiedBy: accountId, attachedTo: channel._id },
|
{ attachedTo: channel._id },
|
||||||
(res) => {
|
(res) => {
|
||||||
messages = res
|
messages = res
|
||||||
},
|
},
|
||||||
{ sort: { modifiedOn: SortingOrder.Descending } }
|
{ sort: { modifiedOn: SortingOrder.Descending } }
|
||||||
)
|
)
|
||||||
|
|
||||||
$: accauntQuery.query(contact.class.EmployeeAccount, { _id: accountId as Ref<EmployeeAccount> }, (result) => {
|
$: accountsIds = messages.map((p) => p.modifiedBy as Ref<EmployeeAccount>)
|
||||||
account = result[0]
|
$: accauntsQuery.query(contact.class.EmployeeAccount, { _id: { $in: accountsIds }}, (result) => {
|
||||||
|
accounts = result
|
||||||
})
|
})
|
||||||
|
|
||||||
$: settingsQuery.query(
|
$: settingsQuery.query(
|
||||||
@ -60,7 +62,6 @@
|
|||||||
{ type: gmail.integrationType.Gmail, space: accountId as string as Ref<Space> },
|
{ type: gmail.integrationType.Gmail, space: accountId as string as Ref<Space> },
|
||||||
(res) => {
|
(res) => {
|
||||||
enabled = res.length > 0
|
enabled = res.length > 0
|
||||||
me = res[0].value
|
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
const client = getClient()
|
const client = getClient()
|
||||||
@ -68,7 +69,7 @@
|
|||||||
async function share (): Promise<void> {
|
async function share (): Promise<void> {
|
||||||
const selectedMessages = messages.filter((m) => selected.has(m._id as string as Ref<SharedMessage>))
|
const selectedMessages = messages.filter((m) => selected.has(m._id as string as Ref<SharedMessage>))
|
||||||
await client.addCollection(gmail.class.SharedMessages, object.space, object._id, object._class, 'gmailSharedMessages', {
|
await client.addCollection(gmail.class.SharedMessages, object.space, object._id, object._class, 'gmailSharedMessages', {
|
||||||
messages: convertMessages(selectedMessages)
|
messages: convertMessages(selectedMessages, accounts)
|
||||||
})
|
})
|
||||||
clear()
|
clear()
|
||||||
}
|
}
|
||||||
@ -79,21 +80,27 @@
|
|||||||
selected = selected
|
selected = selected
|
||||||
}
|
}
|
||||||
|
|
||||||
function convertMessages (messages: Message[]): SharedMessage[] {
|
function convertMessages (messages: Message[], accounts: EmployeeAccount[]): SharedMessage[] {
|
||||||
return messages.map((m) => {
|
return messages.map((m) => {
|
||||||
return {
|
return {
|
||||||
...m,
|
...m,
|
||||||
_id: m._id as string as Ref<SharedMessage>,
|
_id: m._id as string as Ref<SharedMessage>,
|
||||||
sender: account ? getName(m, account, true) : '',
|
sender: getName(m, accounts, true),
|
||||||
receiver: account ? getName(m, account, false) : ''
|
receiver: getName(m, accounts, false)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
function getName (message: Message, account: EmployeeAccount, sender: boolean): string {
|
|
||||||
return message.incoming === sender
|
function getName (message: Message, accounts: EmployeeAccount[], sender: boolean): string {
|
||||||
? `${formatName(object.name)} (${channel.value})`
|
if (message.incoming === sender) {
|
||||||
: `${formatName(account.name)} (${me})`
|
return `${formatName(object.name)} (${channel.value})`
|
||||||
|
} else {
|
||||||
|
const account = accounts.find((p) => p._id === message.modifiedBy)
|
||||||
|
const value = message.incoming ? message.to : message.from
|
||||||
|
const email = value.match(EMAIL_REGEX)
|
||||||
|
return account ? `${formatName(account.name)} (${email?.[0] ?? value})` : email?.[0] ?? value
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
@ -157,7 +164,7 @@
|
|||||||
<div class="h-full right-content">
|
<div class="h-full right-content">
|
||||||
<ScrollBox vertical stretch>
|
<ScrollBox vertical stretch>
|
||||||
{#if messages}
|
{#if messages}
|
||||||
<Messages messages={convertMessages(messages)} {selectable} bind:selected on:select />
|
<Messages messages={convertMessages(messages, accounts)} {selectable} bind:selected on:select />
|
||||||
{/if}
|
{/if}
|
||||||
</ScrollBox>
|
</ScrollBox>
|
||||||
</div>
|
</div>
|
||||||
|
@ -15,7 +15,6 @@
|
|||||||
-->
|
-->
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import type { SharedMessage } from '@anticrm/gmail'
|
import type { SharedMessage } from '@anticrm/gmail'
|
||||||
import { formatName } from '@anticrm/contact'
|
|
||||||
import { CheckBox } from '@anticrm/ui'
|
import { CheckBox } from '@anticrm/ui'
|
||||||
import { createEventDispatcher } from 'svelte'
|
import { createEventDispatcher } from 'svelte'
|
||||||
import { getTime } from '../utils'
|
import { getTime } from '../utils'
|
||||||
@ -37,10 +36,11 @@
|
|||||||
<div class="mr-4"><CheckBox circle primary bind:checked={selected} /></div>
|
<div class="mr-4"><CheckBox circle primary bind:checked={selected} /></div>
|
||||||
{/if}
|
{/if}
|
||||||
<div class="flex-col message" class:selected>
|
<div class="flex-col message" class:selected>
|
||||||
<div class="flex-between text-sm mb-4">
|
<div class="flex-between text-sm mb-1">
|
||||||
<div class="content-trans-color overflow-label mr-4">From: <span class="content-accent-color">{formatName(message.sender)}</span></div>
|
<div class="content-trans-color overflow-label mr-4">From: <span class="content-accent-color">{message.sender}</span></div>
|
||||||
<div class="content-trans-color">{getTime(message.modifiedOn)}</div>
|
<div class="content-trans-color">{getTime(message.modifiedOn)}</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="content-trans-color text-sm overflow-label mr-4 mb-4">To: <span class="content-accent-color">{message.receiver}</span></div>
|
||||||
<div class="fs-title overflow-label mb-1">
|
<div class="fs-title overflow-label mb-1">
|
||||||
{message.subject}
|
{message.subject}
|
||||||
</div>
|
</div>
|
||||||
@ -62,6 +62,7 @@
|
|||||||
background-color: var(--theme-incoming-msg);
|
background-color: var(--theme-incoming-msg);
|
||||||
border-radius: .75rem;
|
border-radius: .75rem;
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
|
flex-grow: 1;
|
||||||
|
|
||||||
&.selected { background-color: var(--primary-button-enabled); }
|
&.selected { background-color: var(--primary-button-enabled); }
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user