Add emoji reactions

This commit is contained in:
Jon Staab
2024-09-25 13:46:10 -07:00
parent 0b8f80ed0e
commit ce733e5743
10 changed files with 145 additions and 16 deletions
+15
View File
@@ -0,0 +1,15 @@
<script lang="ts">
import 'emoji-picker-element'
import type {Emoji} from 'emoji-picker-element/shared'
import {onMount} from 'svelte'
export let onClick: (emoji: Emoji) => void
let element: Element
onMount(() => {
element.addEventListener('emoji-click', (event: any) => onClick(event.detail as Emoji))
})
</script>
<emoji-picker bind:this={element} />
+30
View File
@@ -0,0 +1,30 @@
<script lang="ts">
import {onMount} from 'svelte'
import type {SvelteComponent, ComponentType, ComponentProps} from 'svelte'
import tippy, {type Instance, type Props} from "tippy.js"
export let component: ComponentType
export let props: ComponentProps<any> = {}
export let params: Partial<Props> = {}
export let popover: Instance | undefined = undefined
export let instance: SvelteComponent | undefined = undefined
let element: Element
$: instance?.$set(props)
onMount(() => {
const target = document.createElement("div")
popover = tippy(element, {content: target, ...params})
instance = new component({target, props})
return () => {
popover?.destroy()
instance?.$destroy()
}
})
</script>
<div bind:this={element} />