39 lines
933 B
Vue
39 lines
933 B
Vue
<script setup lang="ts">
|
|
const props = defineProps<{
|
|
smallMode?: boolean
|
|
defaultClass?: string
|
|
class?: string
|
|
}>()
|
|
|
|
const defaultClass = props.defaultClass ?? 'm-2 flex gap-2 px-2'
|
|
const additionalClass = props.class ?? ''
|
|
const btnClass = props.smallMode ? '[&_button]:w-7 [&_button]:h-7 [&_button]:2xl:w-8 [&_button]:2xl:h-9 [&_button]:!p-0' : ''
|
|
|
|
type ClickType = 'back' | 'submit'
|
|
|
|
const emit = defineEmits<{
|
|
(e: 'click', type: ClickType): void
|
|
}>()
|
|
|
|
function onClick(type: ClickType) {
|
|
emit('click', type)
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<div :class="`${defaultClass} ${additionalClass} ${btnClass}`">
|
|
<div>
|
|
<Button variant="ghost"@click="onClick('back')" >
|
|
<Icon name="i-lucide-arrow-left" class="" />
|
|
Back
|
|
</Button>
|
|
</div>
|
|
<div>
|
|
<Button @click="onClick('submit')">
|
|
<Icon name="i-lucide-check" class="" />
|
|
Submit
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
</template>
|