mirror of
https://github.com/antd-tiny-vue/antd-tiny-vue.git
synced 2025-01-10 16:19:08 +08:00
43 lines
1022 B
TypeScript
43 lines
1022 B
TypeScript
import { computed, defineComponent } from 'vue'
|
|
import { useProviderConfigState } from '../config-provider/context'
|
|
import Wave from '../_util/wave'
|
|
import useStyle from './style'
|
|
import { buttonProps } from './interface'
|
|
|
|
const Button = defineComponent({
|
|
name: 'AButton',
|
|
inheritAttrs: false,
|
|
__ANT_BUTTON: true,
|
|
props: {
|
|
...buttonProps
|
|
},
|
|
setup(props, { slots, attrs }) {
|
|
const { getPrefixCls } = useProviderConfigState()
|
|
const prefixCls = computed(() => getPrefixCls('btn', props.prefixCls))
|
|
const [wrapSSR, hashId] = useStyle(prefixCls)
|
|
|
|
const cls = computed(() => {
|
|
return {
|
|
[prefixCls.value]: true,
|
|
[`${prefixCls.value}-${props.type}`]: !!props.type,
|
|
[hashId.value]: true
|
|
}
|
|
})
|
|
|
|
return () => {
|
|
return wrapSSR(
|
|
<Wave>
|
|
<button
|
|
{...attrs}
|
|
class={[cls.value, attrs.class]}
|
|
>
|
|
{slots.default?.()}
|
|
</button>
|
|
</Wave>
|
|
)
|
|
}
|
|
}
|
|
})
|
|
|
|
export default Button
|