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:
Anas Boudih 2022-05-19 15:21:09 +01:00 committed by GitHub
parent 82484bab98
commit f245986996
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 37 additions and 39 deletions

View 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>

View File

@ -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>