platform/packages/ui/src/components/ListView.svelte
Alexander Platov ec0795e687
Prepare UI for mobile (#2277)
Signed-off-by: Alexander Platov <sas_lord@mail.ru>
2022-10-04 22:49:11 +07:00

87 lines
2.1 KiB
Svelte

<!--
// 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 { afterUpdate, createEventDispatcher } from 'svelte'
export let selection: number = 0
export let count: number
const refs: HTMLElement[] = []
const dispatch = createEventDispatcher()
let oldSelection = Date.now()
function onRow (item: number): void {
if (updateSelection(item)) {
dispatch('on-select', item)
}
}
function updateSelection (item: number): boolean {
const now = Date.now()
if (now - oldSelection >= 25) {
selection = item
oldSelection = now
return true
}
return false
}
export function select (pos: number): void {
if (pos < 0) {
pos = 0
}
if (pos >= count) {
pos = count - 1
}
const r = refs[pos]
onRow(pos)
if (r !== undefined) {
r?.scrollIntoView({ behavior: 'auto', block: 'nearest' })
}
}
afterUpdate(() => dispatch('changeContent'))
</script>
{#if count}
<div class="list-container flex-col flex-grow" style:overflow={'auto'}>
{#each Array(count) as _, row}
<slot name="category" item={row} />
<div
class:selection={row === selection}
on:mouseover={() => onRow(row)}
on:focus={() => {}}
bind:this={refs[row]}
on:click={() => dispatch('click', row)}
>
<slot name="item" item={row} />
</div>
{/each}
</div>
{/if}
<style lang="scss">
.list-container {
border-radius: 0.25rem;
user-select: none;
.selection {
background-color: var(--menu-bg-select);
}
}
</style>