Hide meeting minutes for guests

Signed-off-by: Anton Alexeyev <alexeyev.anton@gmail.com>
This commit is contained in:
Anton Alexeyev 2025-05-08 07:52:11 +07:00
parent 9f94b06d6a
commit 8c2275c484
2 changed files with 48 additions and 32 deletions

View File

@ -39,13 +39,21 @@
let editable: boolean = false
$: editable = hasAccountRole(me, AccountRole.Maintainer)
let canViewMinutes: boolean = false
$: canViewMinutes = hasAccountRole(me, AccountRole.User)
</script>
<div class="hulyComponent">
<Header adaptive={'disabled'}>
<Breadcrumb title={selectedFloor?.name ?? ''} size={'large'} isCurrent />
<svelte:fragment slot="beforeTitle">
<ViewletSelector bind:viewlet bind:preference bind:loading viewletQuery={{ attachTo: lovePlg.class.Floor }} />
<ViewletSelector
bind:viewlet
bind:preference
bind:loading
hidden={!canViewMinutes}
viewletQuery={{ attachTo: lovePlg.class.Floor }}
/>
</svelte:fragment>
<svelte:fragment slot="actions">
{#if editable}

View File

@ -14,6 +14,7 @@
-->
<script lang="ts">
import type { Class, Doc, Ref, Space } from '@hcengineering/core'
import { AccountRole, getCurrentAccount, hasAccountRole } from '@hcengineering/core'
import { Label, Section, Scroller } from '@hcengineering/ui'
import { Table, ViewletsSettingButton } from '@hcengineering/view-resources'
import { Viewlet, ViewletPreference } from '@hcengineering/view'
@ -26,40 +27,47 @@
export let readonly: boolean = false
export let meetings: number
const me = getCurrentAccount()
let viewlet: Viewlet | undefined
let preference: ViewletPreference | undefined
let loading = true
let canViewMinutes: boolean = false
$: canViewMinutes = hasAccountRole(me, AccountRole.User)
</script>
<Section label={love.string.MeetingMinutes} icon={love.icon.Cam}>
<svelte:fragment slot="header">
<ViewletsSettingButton
viewletQuery={{ _id: love.viewlet.TableMeetingMinutesEmbedded }}
kind={'tertiary'}
bind:viewlet
bind:loading
bind:preference
/>
</svelte:fragment>
{#if canViewMinutes}
<Section label={love.string.MeetingMinutes} icon={love.icon.Cam}>
<svelte:fragment slot="header">
<ViewletsSettingButton
viewletQuery={{ _id: love.viewlet.TableMeetingMinutesEmbedded }}
kind={'tertiary'}
bind:viewlet
bind:loading
bind:preference
/>
</svelte:fragment>
<svelte:fragment slot="content">
{#if meetings > 0 && viewlet}
<Scroller horizontal>
<Table
_class={love.class.MeetingMinutes}
config={preference?.config ?? viewlet.config}
query={{ attachedTo: objectId }}
loadingProps={{ length: meetings }}
prefferedSorting="createdOn"
{readonly}
/>
</Scroller>
{:else}
<div class="antiSection-empty solid flex-col mt-3">
<span class="content-dark-color">
<Label label={love.string.NoMeetingMinutes} />
</span>
</div>
{/if}
</svelte:fragment>
</Section>
<svelte:fragment slot="content">
{#if meetings > 0 && viewlet}
<Scroller horizontal>
<Table
_class={love.class.MeetingMinutes}
config={preference?.config ?? viewlet.config}
query={{ attachedTo: objectId }}
loadingProps={{ length: meetings }}
prefferedSorting="createdOn"
{readonly}
/>
</Scroller>
{:else}
<div class="antiSection-empty solid flex-col mt-3">
<span class="content-dark-color">
<Label label={love.string.NoMeetingMinutes} />
</span>
</div>
{/if}
</svelte:fragment>
</Section>
{/if}