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