| 
					
				 | 
			
			
				@@ -11,7 +11,10 @@ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             @click="handleClickMenu(item)" 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             :disabled="item.disabled" 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				           > 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            <Popconfirm v-if="popconfirm && item.popConfirm" v-bind="omit(item.popConfirm, 'icon')"> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            <Popconfirm 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+              v-if="popconfirm && item.popConfirm" 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+              v-bind="getPopConfirmAttrs(item.popConfirm)" 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            > 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				               <template #icon v-if="item.popConfirm.icon"> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                 <Icon :icon="item.popConfirm.icon" /> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				               </template> 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -33,13 +36,14 @@ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 </template> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 <script lang="ts"> 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-  import type { PropType } from 'vue'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  import { computed, PropType } from 'vue'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				   import type { DropMenu } from './typing'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				   import { defineComponent } from 'vue'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				   import { Dropdown, Menu, Popconfirm } from 'ant-design-vue'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				   import { Icon } from '/@/components/Icon'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				   import { omit } from 'lodash-es'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  import { isFunction } from '/@/utils/is'; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				   export default defineComponent({ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     name: 'BasicDropdown', 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -82,9 +86,20 @@ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         item.onClick?.(); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				       } 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      const getPopConfirmAttrs = computed(() => { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        return (attrs) => { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          const originAttrs = omit(attrs, ['confirm', 'cancel', 'icon']); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          if (!attrs.onConfirm && attrs.confirm && isFunction(attrs.confirm)) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            originAttrs['onConfirm'] = attrs.confirm; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          if (!attrs.onCancel && attrs.cancel && isFunction(attrs.cancel)) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            originAttrs['onCancel'] = attrs.cancel; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          return originAttrs; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        }; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      }); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				       return { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         handleClickMenu, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-        omit, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        getPopConfirmAttrs, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         getAttr: (key: string | number) => ({ key }), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				       }; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     }, 
			 |