116 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Vue
		
	
	
| import { provide, inject } from 'vue';
 | |
| import Button from '../button';
 | |
| import classNames from 'classnames';
 | |
| import buttonTypes from '../button/buttonTypes';
 | |
| import { ButtonGroupProps } from '../button/button-group';
 | |
| import Dropdown from './dropdown';
 | |
| import PropTypes from '../_util/vue-types';
 | |
| import { hasProp, getComponent, getSlot } from '../_util/props-util';
 | |
| import getDropdownProps from './getDropdownProps';
 | |
| import { ConfigConsumerProps } from '../config-provider';
 | |
| import EllipsisOutlined from '@ant-design/icons-vue/EllipsisOutlined';
 | |
| 
 | |
| const ButtonTypesProps = buttonTypes();
 | |
| const DropdownProps = getDropdownProps();
 | |
| const ButtonGroup = Button.Group;
 | |
| const DropdownButtonProps = {
 | |
|   ...ButtonGroupProps,
 | |
|   ...DropdownProps,
 | |
|   type: PropTypes.oneOf(['primary', 'ghost', 'dashed', 'danger', 'default']).def('default'),
 | |
|   size: PropTypes.oneOf(['small', 'large', 'default']).def('default'),
 | |
|   htmlType: ButtonTypesProps.htmlType,
 | |
|   href: PropTypes.string,
 | |
|   disabled: PropTypes.bool,
 | |
|   prefixCls: PropTypes.string,
 | |
|   placement: DropdownProps.placement.def('bottomRight'),
 | |
|   icon: PropTypes.any,
 | |
|   title: PropTypes.string,
 | |
|   onClick: PropTypes.func,
 | |
|   onVisibleChange: PropTypes.func,
 | |
|   'onUpdate:visible': PropTypes.func,
 | |
| };
 | |
| export { DropdownButtonProps };
 | |
| export default {
 | |
|   name: 'ADropdownButton',
 | |
|   inheritAttrs: false,
 | |
|   props: DropdownButtonProps,
 | |
|   setup() {
 | |
|     return {
 | |
|       configProvider: inject('configProvider', ConfigConsumerProps),
 | |
|     };
 | |
|   },
 | |
|   created() {
 | |
|     provide('savePopupRef', this.savePopupRef);
 | |
|   },
 | |
|   methods: {
 | |
|     savePopupRef(ref) {
 | |
|       this.popupRef = ref;
 | |
|     },
 | |
|     handleClick(e) {
 | |
|       this.$emit('click', e);
 | |
|     },
 | |
|     handleVisibleChange(val) {
 | |
|       this.$emit('update:visible', val);
 | |
|       this.$emit('visibleChange', val);
 | |
|     },
 | |
|   },
 | |
|   render() {
 | |
|     const {
 | |
|       type,
 | |
|       disabled,
 | |
|       onClick,
 | |
|       htmlType,
 | |
|       class: className,
 | |
|       prefixCls: customizePrefixCls,
 | |
|       overlay,
 | |
|       trigger,
 | |
|       align,
 | |
|       visible,
 | |
|       onVisibleChange,
 | |
|       placement,
 | |
|       getPopupContainer,
 | |
|       href,
 | |
|       title,
 | |
|       ...restProps
 | |
|     } = { ...this.$props, ...this.$attrs };
 | |
|     const icon = getComponent(this, 'icon') || <EllipsisOutlined />;
 | |
|     const { getPopupContainer: getContextPopupContainer } = this.configProvider;
 | |
|     const getPrefixCls = this.configProvider.getPrefixCls;
 | |
|     const prefixCls = getPrefixCls('dropdown-button', customizePrefixCls);
 | |
|     const dropdownProps = {
 | |
|       align,
 | |
|       disabled,
 | |
|       trigger: disabled ? [] : trigger,
 | |
|       placement,
 | |
|       getPopupContainer: getPopupContainer || getContextPopupContainer,
 | |
|       onVisibleChange: this.handleVisibleChange,
 | |
|     };
 | |
|     if (hasProp(this, 'visible')) {
 | |
|       dropdownProps.visible = visible;
 | |
|     }
 | |
| 
 | |
|     const buttonGroupProps = {
 | |
|       ...restProps,
 | |
|       class: classNames(prefixCls, className),
 | |
|     };
 | |
| 
 | |
|     return (
 | |
|       <ButtonGroup {...buttonGroupProps}>
 | |
|         <Button
 | |
|           type={type}
 | |
|           disabled={disabled}
 | |
|           onClick={this.handleClick}
 | |
|           htmlType={htmlType}
 | |
|           href={href}
 | |
|           title={title}
 | |
|         >
 | |
|           {getSlot(this)}
 | |
|         </Button>
 | |
|         <Dropdown {...dropdownProps} overlay={getComponent(this, 'overlay')}>
 | |
|           <Button type={type}>{icon}</Button>
 | |
|         </Dropdown>
 | |
|       </ButtonGroup>
 | |
|     );
 | |
|   },
 | |
| };
 |