-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdropdown-button.jsx
83 lines (79 loc) · 1.99 KB
/
dropdown-button.jsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import Button from '../button'
import { ButtonGroupProps } from '../button/button-group'
import Icon from '../icon'
import Dropdown from './dropdown'
import PropTypes from '../_util/vue-types'
import { hasProp, getComponentFromProp } from '../_util/props-util'
import getDropdownProps from './getDropdownProps'
const DropdownProps = getDropdownProps()
const ButtonGroup = Button.Group
const DropdownButtonProps = {
...ButtonGroupProps,
...DropdownProps,
type: PropTypes.oneOf(['primary', 'ghost', 'dashed', 'default']).def('default'),
disabled: PropTypes.bool,
prefixCls: PropTypes.string.def('ant-dropdown-button'),
placement: DropdownProps.placement.def('bottomRight'),
}
export { DropdownButtonProps }
export default {
name: 'ADropdownButton',
props: DropdownButtonProps,
methods: {
onClick (e) {
this.$emit('click', e)
},
onVisibleChange (val) {
this.$emit('visibleChange', val)
},
},
model: {
prop: 'visible',
event: 'visibleChange',
},
render () {
const {
type, disabled,
prefixCls, trigger, align,
visible, placement, getPopupContainer,
...restProps
} = this.$props
const dropdownProps = {
props: {
align,
disabled,
trigger: disabled ? [] : trigger,
placement,
getPopupContainer,
},
on: {
visibleChange: this.onVisibleChange,
},
}
if (hasProp(this, 'visible')) {
dropdownProps.props.visible = visible
}
return (
<ButtonGroup
{...restProps}
class={prefixCls}
>
<Button
type={type}
disabled={disabled}
onClick={this.onClick}
>
{this.$slots.default}
</Button>
<Dropdown {...dropdownProps}>
<template slot='overlay'>
{getComponentFromProp(this, 'overlay')}
</template>
<Button type={type}>
<Icon type='down' />
</Button>
</Dropdown>
</ButtonGroup>
)
},
}