mirror of
https://github.com/hcengineering/platform.git
synced 2025-05-10 17:30:51 +00:00
Hide meeting minutes for guests (#8881)
Signed-off-by: Anton Alexeyev <alexeyev.anton@gmail.com>
This commit is contained in:
parent
9f94b06d6a
commit
d75d8604ec
@ -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}
|
||||
|
@ -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}
|
||||
|
Loading…
Reference in New Issue
Block a user