UBER-205: more info to Kanban card (due date, assignee, Lead number) (#3251)

Signed-off-by: Vyacheslav Tumanov <me@slavatumanov.me>
This commit is contained in:
Vyacheslav Tumanov 2023-05-24 22:14:55 +05:00 committed by GitHub
parent 3776137a52
commit bc1db861c3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 42 additions and 15 deletions

View File

@ -41,6 +41,7 @@
"@hcengineering/contact": "^0.6.16", "@hcengineering/contact": "^0.6.16",
"@hcengineering/view": "^0.6.6", "@hcengineering/view": "^0.6.6",
"@hcengineering/task": "^0.6.8", "@hcengineering/task": "^0.6.8",
"@hcengineering/task-resources": "^0.6.0",
"@hcengineering/login": "^0.6.5", "@hcengineering/login": "^0.6.5",
"@hcengineering/workbench": "^0.6.6", "@hcengineering/workbench": "^0.6.6",
"@hcengineering/view-resources": "^0.6.0", "@hcengineering/view-resources": "^0.6.0",

View File

@ -16,16 +16,22 @@
<script lang="ts"> <script lang="ts">
import { AttachmentsPresenter } from '@hcengineering/attachment-resources' import { AttachmentsPresenter } from '@hcengineering/attachment-resources'
import { CommentsPresenter } from '@hcengineering/chunter-resources' import { CommentsPresenter } from '@hcengineering/chunter-resources'
import contact from '@hcengineering/contact'
import { ContactPresenter } from '@hcengineering/contact-resources' import { ContactPresenter } from '@hcengineering/contact-resources'
import type { WithLookup } from '@hcengineering/core' import type { WithLookup } from '@hcengineering/core'
import type { Lead } from '@hcengineering/lead' import type { Lead } from '@hcengineering/lead'
import { ActionIcon, Component, IconMoreH, showPanel, showPopup } from '@hcengineering/ui' import { ActionIcon, Component, DueDatePresenter, IconMoreH, showPanel, showPopup } from '@hcengineering/ui'
import view from '@hcengineering/view' import view from '@hcengineering/view'
import { ContextMenu } from '@hcengineering/view-resources' import { ContextMenu } from '@hcengineering/view-resources'
import lead from '../plugin' import lead from '../plugin'
import notification from '@hcengineering/notification' import notification from '@hcengineering/notification'
import { getClient } from '@hcengineering/presentation'
import { AssigneePresenter } from '@hcengineering/task-resources'
import LeadPresenter from './LeadPresenter.svelte'
export let object: WithLookup<Lead> export let object: WithLookup<Lead>
const client = getClient()
const assigneeAttribute = client.getHierarchy().getAttribute(lead.class.Lead, 'assignee')
function showMenu (ev?: Event): void { function showMenu (ev?: Event): void {
showPopup(ContextMenu, { object }, (ev as MouseEvent).target as HTMLElement) showPopup(ContextMenu, { object }, (ev as MouseEvent).target as HTMLElement)
@ -55,21 +61,41 @@
/> />
</div> </div>
</div> </div>
<div class="flex-between"> <div class="flex-col">
{#if object.$lookup?.attachedTo} <div class="flex-between">
<ContactPresenter value={object.$lookup.attachedTo} /> {#if object.$lookup?.attachedTo}
{/if} <ContactPresenter value={object.$lookup.attachedTo} />
<div class="flex-row-center">
{#if (object.attachments ?? 0) > 0}
<div class="step-lr75">
<AttachmentsPresenter value={object.attachments} {object} />
</div>
{/if}
{#if (object.comments ?? 0) > 0}
<div class="step-lr75">
<CommentsPresenter value={object.comments} {object} />
</div>
{/if} {/if}
<div class="flex-row-center">
{#if (object.attachments ?? 0) > 0}
<div class="step-lr75">
<AttachmentsPresenter value={object.attachments} {object} />
</div>
{/if}
{#if (object.comments ?? 0) > 0}
<div class="step-lr75">
<CommentsPresenter value={object.comments} {object} />
</div>
{/if}
</div>
</div>
<div class="flex-row-reverse flex-between mt-2">
<AssigneePresenter
value={object.assignee}
issueId={object._id}
defaultClass={contact.class.Employee}
currentSpace={object.space}
placeholderLabel={assigneeAttribute.label}
/>
<DueDatePresenter
value={object.dueDate}
shouldRender={object.dueDate !== null && object.dueDate !== undefined}
shouldIgnoreOverdue={object.doneState !== null}
onChange={async (e) => {
await client.update(object, { dueDate: e })
}}
/>
<LeadPresenter value={object} />
</div> </div>
</div> </div>
</div> </div>