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 let editable: boolean = false
$: editable = hasAccountRole(me, AccountRole.Maintainer) $: editable = hasAccountRole(me, AccountRole.Maintainer)
let canViewMinutes: boolean = false
$: canViewMinutes = hasAccountRole(me, AccountRole.User)
</script> </script>
<div class="hulyComponent"> <div class="hulyComponent">
<Header adaptive={'disabled'}> <Header adaptive={'disabled'}>
<Breadcrumb title={selectedFloor?.name ?? ''} size={'large'} isCurrent /> <Breadcrumb title={selectedFloor?.name ?? ''} size={'large'} isCurrent />
<svelte:fragment slot="beforeTitle"> <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>
<svelte:fragment slot="actions"> <svelte:fragment slot="actions">
{#if editable} {#if editable}

View File

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