mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-24 11:05:17 +08:00
refactor(components): [pagination/next] switch to script-setup syntax (#7748)
* refactor(components): [pagination/next] switch to script-setup syntax * fix(components): [pagination/next] move emits Co-authored-by: metanas <matanas@pre-history.com>
This commit is contained in:
parent
82484bab98
commit
f245986996
22
packages/components/pagination/src/components/next.ts
Normal file
22
packages/components/pagination/src/components/next.ts
Normal file
@ -0,0 +1,22 @@
|
||||
import { buildProps } from '@element-plus/utils'
|
||||
import type { ExtractPropTypes } from 'vue'
|
||||
import type Next from './next.vue'
|
||||
|
||||
export const paginationNextProps = buildProps({
|
||||
disabled: Boolean,
|
||||
currentPage: {
|
||||
type: Number,
|
||||
default: 1,
|
||||
},
|
||||
pageCount: {
|
||||
type: Number,
|
||||
default: 50,
|
||||
},
|
||||
nextText: {
|
||||
type: String,
|
||||
},
|
||||
} as const)
|
||||
|
||||
export type PaginationNextProps = ExtractPropTypes<typeof paginationNextProps>
|
||||
|
||||
export type NextInstance = InstanceType<typeof Next>
|
@ -11,48 +11,24 @@
|
||||
</button>
|
||||
</template>
|
||||
|
||||
<script lang="ts">
|
||||
import { computed, defineComponent } from 'vue'
|
||||
<script lang="ts" setup>
|
||||
import { computed } from 'vue'
|
||||
import { ElIcon } from '@element-plus/components/icon'
|
||||
import { ArrowRight } from '@element-plus/icons-vue'
|
||||
import { paginationNextProps } from './next'
|
||||
|
||||
const paginationNextProps = {
|
||||
disabled: Boolean,
|
||||
currentPage: {
|
||||
type: Number,
|
||||
default: 1,
|
||||
},
|
||||
pageCount: {
|
||||
type: Number,
|
||||
default: 50,
|
||||
},
|
||||
nextText: {
|
||||
type: String,
|
||||
default: '',
|
||||
},
|
||||
} as const
|
||||
|
||||
export default defineComponent({
|
||||
defineOptions({
|
||||
name: 'ElPaginationNext',
|
||||
})
|
||||
|
||||
components: {
|
||||
ElIcon,
|
||||
ArrowRight,
|
||||
},
|
||||
props: paginationNextProps,
|
||||
emits: ['click'],
|
||||
const props = defineProps(paginationNextProps)
|
||||
|
||||
setup(props) {
|
||||
const internalDisabled = computed(
|
||||
defineEmits(['click'])
|
||||
|
||||
const internalDisabled = computed(
|
||||
() =>
|
||||
props.disabled ||
|
||||
props.currentPage === props.pageCount ||
|
||||
props.pageCount === 0
|
||||
)
|
||||
|
||||
return {
|
||||
internalDisabled,
|
||||
}
|
||||
},
|
||||
})
|
||||
)
|
||||
</script>
|
||||
|
Loading…
Reference in New Issue
Block a user