platform/plugins/view-resources/src/components/UpDownNavigator.svelte

64 lines
1.5 KiB
Svelte
Raw Normal View History

<script lang="ts">
import { Doc } from '@hcengineering/core'
import { getClient } from '@hcengineering/presentation'
2023-01-14 10:54:54 +00:00
import ui, {
Button,
closeTooltip,
IconDownOutline,
IconNavPrev,
IconUpOutline,
navigate,
panelstore
} from '@hcengineering/ui'
import { tick } from 'svelte'
import { select } from '../actionImpl'
import { focusStore } from '../selection'
import { getObjectLinkFragment } from '../utils'
export let element: Doc
const client = getClient()
async function next (evt: Event, pn: boolean): Promise<void> {
select(evt, pn ? 1 : -1, element, 'vertical')
await tick()
if ($focusStore.focus !== undefined && $panelstore.panel !== undefined) {
const doc = await client.findOne($focusStore.focus._class, { _id: $focusStore.focus._id })
if (doc !== undefined) {
const link = await getObjectLinkFragment(client.getHierarchy(), doc, {}, $panelstore.panel.component)
navigate(link)
}
}
}
function goBack () {
closeTooltip()
history.back()
}
2022-04-29 05:27:17 +00:00
$: select(undefined, 0, element, 'vertical')
</script>
<Button
focusIndex={10005}
icon={IconDownOutline}
kind={'secondary'}
size={'medium'}
on:click={(evt) => next(evt, true)}
/>
<Button
focusIndex={10006}
icon={IconUpOutline}
kind={'secondary'}
size={'medium'}
on:click={(evt) => next(evt, false)}
/>
<Button
focusIndex={10007}
2023-01-14 10:54:54 +00:00
showTooltip={{ label: ui.string.Back, direction: 'bottom' }}
icon={IconNavPrev}
kind={'secondary'}
size={'medium'}
on:click={goBack}
/>