61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
| import PropTypes from '../_util/vue-types';
 | |
| import classNames from '../_util/classNames';
 | |
| import { defineComponent } from 'vue';
 | |
| 
 | |
| export default defineComponent({
 | |
|   name: 'Pager',
 | |
|   inheritAttrs: false,
 | |
|   props: {
 | |
|     rootPrefixCls: PropTypes.string,
 | |
|     page: PropTypes.number,
 | |
|     active: PropTypes.looseBool,
 | |
|     last: PropTypes.looseBool,
 | |
|     locale: PropTypes.object,
 | |
|     showTitle: PropTypes.looseBool,
 | |
|     itemRender: {
 | |
|       type: Function,
 | |
|       default: () => {},
 | |
|     },
 | |
|   },
 | |
|   eimt: ['click', 'keypress'],
 | |
|   setup(props, { emit, attrs }) {
 | |
|     const handleClick = () => {
 | |
|       emit('click', props.page);
 | |
|     };
 | |
|     const handleKeyPress = (event: KeyboardEvent) => {
 | |
|       emit('keypress', event, handleClick, props.page);
 | |
|     };
 | |
|     return () => {
 | |
|       const { showTitle, page, itemRender } = props;
 | |
|       const { class: _cls, style } = attrs;
 | |
|       const prefixCls = `${props.rootPrefixCls}-item`;
 | |
|       const cls = classNames(
 | |
|         prefixCls,
 | |
|         `${prefixCls}-${props.page}`,
 | |
|         {
 | |
|           [`${prefixCls}-active`]: props.active,
 | |
|           [`${prefixCls}-disabled`]: !props.page,
 | |
|         },
 | |
|         _cls,
 | |
|       );
 | |
| 
 | |
|       return (
 | |
|         <li
 | |
|           onClick={handleClick}
 | |
|           onKeypress={handleKeyPress}
 | |
|           title={showTitle ? String(page) : null}
 | |
|           tabindex="0"
 | |
|           class={cls}
 | |
|           style={style}
 | |
|         >
 | |
|           {itemRender({
 | |
|             page,
 | |
|             type: 'page',
 | |
|             originalElement: <a rel="nofollow">{page}</a>,
 | |
|           })}
 | |
|         </li>
 | |
|       );
 | |
|     };
 | |
|   },
 | |
| });
 |