mirror of
https://github.com/hcengineering/platform.git
synced 2025-02-09 04:18:33 +00:00
dbca41afee
Signed-off-by: Dvinyanin Alexandr <dvinyanin.alexandr@gmail.com>
95 lines
2.9 KiB
Svelte
95 lines
2.9 KiB
Svelte
<script lang="ts">
|
|
import { DocumentQuery, WithLookup } from '@anticrm/core'
|
|
import { IntlString, translate } from '@anticrm/platform'
|
|
import { getClient } from '@anticrm/presentation'
|
|
import { Issue } from '@anticrm/tracker'
|
|
import { Button, IconDetails } from '@anticrm/ui'
|
|
import view, { Viewlet } from '@anticrm/view'
|
|
import { FilterBar } from '@anticrm/view-resources'
|
|
import { getActiveViewletId } from '@anticrm/view-resources/src/utils'
|
|
import tracker from '../../plugin'
|
|
import IssuesContent from './IssuesContent.svelte'
|
|
import IssuesHeader from './IssuesHeader.svelte'
|
|
|
|
export let query: DocumentQuery<Issue> = {}
|
|
export let title: IntlString | undefined = undefined
|
|
export let label: string = ''
|
|
|
|
export let panelWidth: number = 0
|
|
|
|
let viewlet: WithLookup<Viewlet> | undefined = undefined
|
|
let search = ''
|
|
let searchQuery: DocumentQuery<Issue> = { ...query }
|
|
function updateSearchQuery (search: string): void {
|
|
searchQuery = search === '' ? { ...query } : { ...query, $search: search }
|
|
}
|
|
$: updateSearchQuery(search)
|
|
$: if (query) updateSearchQuery(search)
|
|
let resultQuery: DocumentQuery<Issue> = { ...searchQuery }
|
|
|
|
const client = getClient()
|
|
|
|
let viewlets: WithLookup<Viewlet>[] = []
|
|
|
|
$: update()
|
|
|
|
async function update (): Promise<void> {
|
|
viewlets = await client.findAll(
|
|
view.class.Viewlet,
|
|
{ attachTo: tracker.class.Issue },
|
|
{
|
|
lookup: {
|
|
descriptor: view.class.ViewletDescriptor
|
|
}
|
|
}
|
|
)
|
|
const _id = getActiveViewletId()
|
|
viewlet = viewlets.find((viewlet) => viewlet._id === _id) || viewlets[0]
|
|
}
|
|
$: if (!label && title) {
|
|
translate(title, {}).then((res) => {
|
|
label = res
|
|
})
|
|
}
|
|
|
|
let asideFloat: boolean = false
|
|
let asideShown: boolean = true
|
|
$: if (panelWidth < 900 && !asideFloat) asideFloat = true
|
|
$: if (panelWidth >= 900 && asideFloat) {
|
|
asideFloat = false
|
|
asideShown = false
|
|
}
|
|
let docWidth: number
|
|
let docSize: boolean = false
|
|
$: if (docWidth <= 900 && !docSize) docSize = true
|
|
$: if (docWidth > 900 && docSize) docSize = false
|
|
</script>
|
|
|
|
<IssuesHeader {viewlets} {label} bind:viewlet bind:search>
|
|
<svelte:fragment slot="extra">
|
|
{#if asideFloat && $$slots.aside}
|
|
<Button
|
|
icon={IconDetails}
|
|
kind={'transparent'}
|
|
size={'medium'}
|
|
selected={asideShown}
|
|
on:click={() => {
|
|
asideShown = !asideShown
|
|
}}
|
|
/>
|
|
{/if}
|
|
</svelte:fragment>
|
|
</IssuesHeader>
|
|
<slot name="afterHeader" />
|
|
<FilterBar _class={tracker.class.Issue} query={searchQuery} on:change={(e) => (resultQuery = e.detail)} />
|
|
<div class="flex w-full h-full clear-mins">
|
|
{#if viewlet}
|
|
<IssuesContent {viewlet} query={resultQuery} />
|
|
{/if}
|
|
{#if $$slots.aside !== undefined && asideShown}
|
|
<div class="popupPanel-body__aside" class:float={asideFloat} class:shown={asideShown}>
|
|
<slot name="aside" />
|
|
</div>
|
|
{/if}
|
|
</div>
|