Files
axp-ui/src/components/Btn.vue
2023-10-11 10:17:11 +03:00

60 lines
1.1 KiB
Vue

<script lang="ts">
import type { TColor } from '../colors'
import type { TIcon } from '../icons'
export type TUiBtnType = 'button' | 'submit'
export type TUiBtnProps = {
label?: string
type?: TUiBtnType
color?: TColor
icon?: TIcon
to?: string
disabled?: boolean
}
export type TUiBtnEmits = {
(e: 'click', v: PointerEvent): void
}
</script>
<script setup lang="ts">
import UiIcon from './Icon.vue'
import { computed } from 'vue'
// Props.
const props = defineProps<TUiBtnProps>()
// Emits.
const emit = defineEmits<TUiBtnEmits>()
// Handlers.
const clickHandler = (e: PointerEvent) => emit('click', e)
// Computed.
const cssClass = computed(() => {
let obj: any = {
'ui-btn': true,
'ui-btn-icon': props.icon
}
if (props.color) obj[props.color] = true
return obj
})
</script>
<template>
<component
:is="props.to ? 'router-link' : 'button'"
:to="props.to"
:type="props.type"
:class="cssClass"
:disabled="props.disabled"
@click="clickHandler"
>
<ui-icon v-if="props.icon" :name="props.icon" />
<div v-if="props.label" class="label">{{ props.label }}</div>
<slot v-if="$slots.default" name="default" />
</component>
</template>