platform/packages/presentation/src/components/UserBoxList.svelte

96 lines
3.0 KiB
Svelte
Raw Normal View History

<!--
// Copyright © 2022 Hardcore Engineering Inc.
//
// Licensed under the Eclipse Public License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License. You may
// obtain a copy of the License at https://www.eclipse.org/legal/epl-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
//
// See the License for the specific language governing permissions and
// limitations under the License.
-->
<script lang="ts">
import contact, { Employee } from '@hcengineering/contact'
import type { Class, DocumentQuery, Ref } from '@hcengineering/core'
import type { IntlString } from '@hcengineering/platform'
import { Button, ButtonKind, ButtonSize, Label, showPopup, TooltipAlignment } from '@hcengineering/ui'
import { createEventDispatcher } from 'svelte'
import presentation, { CombineAvatars, UsersPopup } from '..'
import { createQuery } from '../utils'
import Members from './icons/Members.svelte'
export let items: Ref<Employee>[] = []
export let _class: Ref<Class<Employee>> = contact.class.Employee
export let label: IntlString
export let docQuery: DocumentQuery<Employee> | undefined = {
active: true
}
export let kind: ButtonKind = 'no-border'
export let size: ButtonSize = 'small'
export let justify: 'left' | 'center' = 'center'
export let width: string | undefined = undefined
export let labelDirection: TooltipAlignment | undefined = undefined
export let emptyLabel = presentation.string.Members
export let readonly: boolean = false
let persons: Employee[] = []
const query = createQuery()
$: query.query<Employee>(_class, { _id: { $in: items } }, (result) => {
persons = result
})
const dispatch = createEventDispatcher()
async function addPerson (evt: Event): Promise<void> {
showPopup(
UsersPopup,
{
_class,
label,
docQuery,
multiSelect: true,
allowDeselect: false,
selectedUsers: items
},
evt.target as HTMLElement,
undefined,
(result) => {
if (result != null) {
items = result
dispatch('update', items)
}
}
)
}
</script>
<Button
icon={persons.length === 0 ? Members : undefined}
label={persons.length === 0 ? emptyLabel : undefined}
2022-12-29 02:57:46 +00:00
notSelected={persons.length === 0}
width={width ?? 'min-content'}
{kind}
{size}
{justify}
showTooltip={{ label, direction: labelDirection }}
on:click={addPerson}
disabled={readonly}
>
<svelte:fragment slot="content">
{#if persons.length > 0}
<div class="flex-row-center flex-nowrap pointer-events-none">
<CombineAvatars {_class} bind:items size={'inline'} />
<span class="overflow-label ml-1-5">
<Label label={presentation.string.NumberMembers} params={{ count: persons.length }} />
</span>
</div>
{/if}
</svelte:fragment>
</Button>