platform/packages/ui/src/components/PopupItem.svelte.txt
Andrey Sobolev 5b6ef778f3
Migrate to hcengineering and publish to github packages (#2273)
Signed-off-by: Andrey Sobolev <haiodo@gmail.com>
2022-09-21 14:08:25 +06:00

89 lines
2.4 KiB
Plaintext

<!--
// Copyright © 2020 Anticrm Platform Contributors.
//
// 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 type { IntlString } from '@hcengineering/platform'
import type { AnySvelteComponent } from '../types'
import Label from './Label.svelte'
import Check from './icons/Check.svelte'
export let title: IntlString | undefined = undefined
export let component: AnySvelteComponent | undefined = undefined
export let props: Object = {}
export let selectable: boolean = false
export let selected: boolean = false
export let action: () => Promise<void> = async () => {}
if (title) {
component = Label
props = { label: title }
}
</script>
<button class="popup-item" on:click={() => {
if (selectable) selected = !selected
action()
}}>
<div class="title">
<svelte:component this={component} {...props}/>
</div>
{#if selectable}
<div class="check" class:selected={selected}><Check/></div>
{/if}
</button>
<style lang="scss">
.popup-item {
position: relative;
justify-content: space-between;
padding: .5rem .75rem;
height: 2.5rem;
border-radius: .5rem;
.title {
flex-grow: 1;
text-align: left;
color: var(--theme-content-accent-color);
}
.check {
margin-left: .75rem;
border-radius: 50%;
opacity: 0;
&.selected { opacity: .8; }
}
&:hover {
background-color: var(--theme-button-bg-pressed);
border: 1px solid var(--theme-bg-accent-color);
.title { color: var(--theme-caption-color); }
.check {
opacity: .2;
&.selected { opacity: 1; }
}
}
&:focus {
border: 1px solid var(--primary-button-focused-border);
box-shadow: 0 0 0 3px var(--primary-button-outline);
z-index: 1;
.title { color: var(--theme-caption-color); }
.check {
opacity: .2;
&.selected { opacity: .8; }
}
}
}
</style>