Fixed #3921 - DataTable and TreeTable: new Paginator dropdown icon slots
parent
1b300b54f0
commit
43faf8704d
|
@ -1224,6 +1224,26 @@ export interface DataTableSlots {
|
||||||
* Custom paginator last page link icon template.
|
* Custom paginator last page link icon template.
|
||||||
*/
|
*/
|
||||||
paginatorlastpagelinkicon(): VNode[];
|
paginatorlastpagelinkicon(): VNode[];
|
||||||
|
/**
|
||||||
|
* Custom paginatorrowsperpagedropdownicon template.
|
||||||
|
* @param {Object} scope - paginator rowsperpagedropdownicon's params.
|
||||||
|
*/
|
||||||
|
paginatorrowsperpagedropdownicon(scope: {
|
||||||
|
/**
|
||||||
|
* Style class of the paginator rowsperpagedropdown icon.
|
||||||
|
*/
|
||||||
|
class: string;
|
||||||
|
}): VNode[];
|
||||||
|
/**
|
||||||
|
* Custom paginatorjumptopagedropdownicon template.
|
||||||
|
* @param {Object} scope - paginator jumptopagedropdownicon's params.
|
||||||
|
*/
|
||||||
|
paginatorjumptopagedropdownicon(scope: {
|
||||||
|
/**
|
||||||
|
* Style class of the paginator jumptopagedropdown icon.
|
||||||
|
*/
|
||||||
|
class: string;
|
||||||
|
}): VNode[];
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Defines valid emits in Datatable component.
|
* Defines valid emits in Datatable component.
|
||||||
|
|
|
@ -45,6 +45,12 @@
|
||||||
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
||||||
<slot name="paginatorlastpagelinkicon"></slot>
|
<slot name="paginatorlastpagelinkicon"></slot>
|
||||||
</template>
|
</template>
|
||||||
|
<template v-if="$slots.paginatorjumptopagedropdownicon" #jumptopagedropdownicon>
|
||||||
|
<slot name="paginatorjumptopagedropdownicon"></slot>
|
||||||
|
</template>
|
||||||
|
<template v-if="$slots.paginatorrowsperpagedropdownicon" #rowsperpagedropdownicon="slotProps">
|
||||||
|
<slot name="paginatorrowsperpagedropdownicon" :class="slotProps.class"></slot>
|
||||||
|
</template>
|
||||||
</DTPaginator>
|
</DTPaginator>
|
||||||
<div :class="cx('wrapper')" :style="[sx('wrapper'), { maxHeight: virtualScrollerDisabled ? scrollHeight : '' }]" v-bind="ptm('wrapper')">
|
<div :class="cx('wrapper')" :style="[sx('wrapper'), { maxHeight: virtualScrollerDisabled ? scrollHeight : '' }]" v-bind="ptm('wrapper')">
|
||||||
<DTVirtualScroller
|
<DTVirtualScroller
|
||||||
|
@ -257,6 +263,12 @@
|
||||||
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
||||||
<slot name="paginatorlastpagelinkicon"></slot>
|
<slot name="paginatorlastpagelinkicon"></slot>
|
||||||
</template>
|
</template>
|
||||||
|
<template v-if="$slots.paginatorjumptopagedropdownicon" #jumptopagedropdownicon="slotProps">
|
||||||
|
<slot name="paginatorjumptopagedropdownicon" :class="slotProps.class"></slot>
|
||||||
|
</template>
|
||||||
|
<template v-if="$slots.paginatorrowsperpagedropdownicon" #rowsperpagedropdownicon="slotProps">
|
||||||
|
<slot name="paginatorrowsperpagedropdownicon" :class="slotProps.class"></slot>
|
||||||
|
</template>
|
||||||
</DTPaginator>
|
</DTPaginator>
|
||||||
<div ref="resizeHelper" :class="cx('resizeHelper')" style="display: none" v-bind="ptm('resizeHelper')"></div>
|
<div ref="resizeHelper" :class="cx('resizeHelper')" style="display: none" v-bind="ptm('resizeHelper')"></div>
|
||||||
<span v-if="reorderableColumns" ref="reorderIndicatorUp" :class="cx('reorderIndicatorUp')" style="position: absolute; display: none" v-bind="ptm('reorderIndicatorUp')">
|
<span v-if="reorderableColumns" ref="reorderIndicatorUp" :class="cx('reorderIndicatorUp')" style="position: absolute; display: none" v-bind="ptm('reorderIndicatorUp')">
|
||||||
|
|
|
@ -11,7 +11,11 @@
|
||||||
:pt="ptm('jumpToPageDropdown')"
|
:pt="ptm('jumpToPageDropdown')"
|
||||||
data-pc-section="jumptopagedropdown"
|
data-pc-section="jumptopagedropdown"
|
||||||
data-pc-group-section="pagedropdown"
|
data-pc-group-section="pagedropdown"
|
||||||
></JTPDropdown>
|
>
|
||||||
|
<template v-if="templates['jumptopagedropdownicon']" #dropdownicon="slotProps">
|
||||||
|
<component :is="templates['jumptopagedropdownicon']" :class="slotProps.class" />
|
||||||
|
</template>
|
||||||
|
</JTPDropdown>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
@ -26,7 +30,8 @@ export default {
|
||||||
props: {
|
props: {
|
||||||
page: Number,
|
page: Number,
|
||||||
pageCount: Number,
|
pageCount: Number,
|
||||||
disabled: Boolean
|
disabled: Boolean,
|
||||||
|
templates: null
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
onChange(value) {
|
onChange(value) {
|
||||||
|
|
|
@ -302,6 +302,26 @@ export interface PaginatorSlots {
|
||||||
* Custom last page link icon template.
|
* Custom last page link icon template.
|
||||||
*/
|
*/
|
||||||
lastpagelinkicon(): VNode[];
|
lastpagelinkicon(): VNode[];
|
||||||
|
/**
|
||||||
|
* Custom rowsperpagedropdownicon template.
|
||||||
|
* @param {Object} scope - rowsperpagedropdownicon's params.
|
||||||
|
*/
|
||||||
|
rowsperpagedropdownicon(scope: {
|
||||||
|
/**
|
||||||
|
* Style class of the rowsperpagedropdown icon.
|
||||||
|
*/
|
||||||
|
class: string;
|
||||||
|
}): VNode[];
|
||||||
|
/**
|
||||||
|
* Custom jumptopagedropdownicon template.
|
||||||
|
* @param {Object} scope - jumptopagedropdownicon's params.
|
||||||
|
*/
|
||||||
|
jumptopagedropdownicon(scope: {
|
||||||
|
/**
|
||||||
|
* Style class of the jumptopagedropdown icon.
|
||||||
|
*/
|
||||||
|
class: string;
|
||||||
|
}): VNode[];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
:options="rowsPerPageOptions"
|
:options="rowsPerPageOptions"
|
||||||
@rows-change="onRowChange($event)"
|
@rows-change="onRowChange($event)"
|
||||||
:disabled="empty"
|
:disabled="empty"
|
||||||
|
:templates="$slots"
|
||||||
:unstyled="unstyled"
|
:unstyled="unstyled"
|
||||||
:pt="pt"
|
:pt="pt"
|
||||||
/>
|
/>
|
||||||
|
@ -40,6 +41,7 @@
|
||||||
:pageCount="pageCount"
|
:pageCount="pageCount"
|
||||||
@page-change="changePage($event)"
|
@page-change="changePage($event)"
|
||||||
:disabled="empty"
|
:disabled="empty"
|
||||||
|
:templates="$slots"
|
||||||
:unstyled="unstyled"
|
:unstyled="unstyled"
|
||||||
:pt="pt"
|
:pt="pt"
|
||||||
/>
|
/>
|
||||||
|
|
|
@ -11,7 +11,11 @@
|
||||||
:pt="ptm('rowPerPageDropdown')"
|
:pt="ptm('rowPerPageDropdown')"
|
||||||
data-pc-section="rowperpagedropdown"
|
data-pc-section="rowperpagedropdown"
|
||||||
data-pc-group-section="pagedropdown"
|
data-pc-group-section="pagedropdown"
|
||||||
></RPPDropdown>
|
>
|
||||||
|
<template v-if="templates['rowsperpagedropdownicon']" #dropdownicon="slotProps">
|
||||||
|
<component :is="templates['rowsperpagedropdownicon']" :class="slotProps.class" />
|
||||||
|
</template>
|
||||||
|
</RPPDropdown>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
@ -26,7 +30,8 @@ export default {
|
||||||
props: {
|
props: {
|
||||||
options: Array,
|
options: Array,
|
||||||
rows: Number,
|
rows: Number,
|
||||||
disabled: Boolean
|
disabled: Boolean,
|
||||||
|
templates: null
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
onChange(value) {
|
onChange(value) {
|
||||||
|
|
|
@ -655,6 +655,26 @@ export interface TreeTableSlots {
|
||||||
* Custom paginator last page link icon template.
|
* Custom paginator last page link icon template.
|
||||||
*/
|
*/
|
||||||
paginatorlastpagelinkicon(): VNode[];
|
paginatorlastpagelinkicon(): VNode[];
|
||||||
|
/**
|
||||||
|
* Custom paginatorrowsperpagedropdownicon template.
|
||||||
|
* @param {Object} scope - paginator rowsperpagedropdownicon's params.
|
||||||
|
*/
|
||||||
|
paginatorrowsperpagedropdownicon(scope: {
|
||||||
|
/**
|
||||||
|
* Style class of the paginator rowsperpagedropdown icon.
|
||||||
|
*/
|
||||||
|
class: string;
|
||||||
|
}): VNode[];
|
||||||
|
/**
|
||||||
|
* Custom paginatorjumptopagedropdownicon template.
|
||||||
|
* @param {Object} scope - paginator jumptopagedropdownicon's params.
|
||||||
|
*/
|
||||||
|
paginatorjumptopagedropdownicon(scope: {
|
||||||
|
/**
|
||||||
|
* Style class of the paginator jumptopagedropdown icon.
|
||||||
|
*/
|
||||||
|
class: string;
|
||||||
|
}): VNode[];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -44,6 +44,12 @@
|
||||||
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
||||||
<slot name="paginatorlastpagelinkicon"></slot>
|
<slot name="paginatorlastpagelinkicon"></slot>
|
||||||
</template>
|
</template>
|
||||||
|
<template v-if="$slots.paginatorjumptopagedropdownicon" #jumptopagedropdownicon>
|
||||||
|
<slot name="paginatorjumptopagedropdownicon"></slot>
|
||||||
|
</template>
|
||||||
|
<template v-if="$slots.paginatorrowsperpagedropdownicon" #rowsperpagedropdownicon="slotProps">
|
||||||
|
<slot name="paginatorrowsperpagedropdownicon" :class="slotProps.class"></slot>
|
||||||
|
</template>
|
||||||
</TTPaginator>
|
</TTPaginator>
|
||||||
<div :class="cx('wrapper')" :style="{ maxHeight: scrollHeight }" v-bind="ptm('wrapper')">
|
<div :class="cx('wrapper')" :style="{ maxHeight: scrollHeight }" v-bind="ptm('wrapper')">
|
||||||
<table ref="table" role="table" v-bind="{ ...tableProps, ...ptm('table') }">
|
<table ref="table" role="table" v-bind="{ ...tableProps, ...ptm('table') }">
|
||||||
|
@ -144,6 +150,12 @@
|
||||||
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
<template v-if="$slots.paginatorlastpagelinkicon" #lastpagelinkicon>
|
||||||
<slot name="paginatorlastpagelinkicon"></slot>
|
<slot name="paginatorlastpagelinkicon"></slot>
|
||||||
</template>
|
</template>
|
||||||
|
<template v-if="$slots.paginatorjumptopagedropdownicon" #jumptopagedropdownicon>
|
||||||
|
<slot name="paginatorjumptopagedropdownicon"></slot>
|
||||||
|
</template>
|
||||||
|
<template v-if="$slots.paginatorrowsperpagedropdownicon" #rowsperpagedropdownicon="slotProps">
|
||||||
|
<slot name="paginatorrowsperpagedropdownicon" :class="slotProps.class"></slot>
|
||||||
|
</template>
|
||||||
</TTPaginator>
|
</TTPaginator>
|
||||||
<div v-if="$slots.footer" :class="cx('footer')" v-bind="ptm('footer')">
|
<div v-if="$slots.footer" :class="cx('footer')" v-bind="ptm('footer')">
|
||||||
<slot name="footer"></slot>
|
<slot name="footer"></slot>
|
||||||
|
|
Loading…
Reference in New Issue