useRecordsPage
- Category:
Composables
- Relate:
getRecords
- Dependencies:
@lark-base-open/js-sdk
- Last Changed: last week
Notice
This function needs to use in Base, please use this website as a plugin in a Base to see the demo.
Demo
Show demo code
vue
<script setup lang="ts">
import {
useRecordsPage,
useTable,
useSelection,
useFieldMetaList,
} from "@qww0302/use-bitable";
import { ElButton, ElTableV2, vLoading } from "element-plus";
import { computed } from "vue";
const { tableId, viewId } = useSelection();
const { table } = useTable(tableId);
const { records, total, curPage, totalPage, pending } = useRecordsPage(table, {
pageSize: 10,
viewId: viewId,
});
const { fieldMetaList } = useFieldMetaList(table);
const columns = computed(() =>
fieldMetaList.value.map((fieldMeta) => ({
title: fieldMeta.name,
prop: fieldMeta.id,
key: fieldMeta.id,
dataKey: fieldMeta.id,
width: 150,
})),
);
const rows = computed(() =>
records.value.map((record) => {
const row: Record<string, any> = {};
fieldMetaList.value.forEach((fieldMeta) => {
row[fieldMeta.id] = JSON.stringify(record.fields[fieldMeta.id]);
});
row.id = record.recordId;
return row;
}),
);
const next = () => {
curPage.value += 1;
};
const prev = () => {
curPage.value -= 1;
};
</script>
<template>
<div>
<p>Total: {{ total }}</p>
<p>Pending: {{ pending }}</p>
<p>Current page: {{ curPage + 1 }} / {{ totalPage }}</p>
<ElButton @click="prev" :disabled="curPage === 0">Prev</ElButton>
<ElButton @click="next">Next</ElButton>
<ElTableV2
:columns="columns"
:data="rows"
:width="400"
:height="400"
v-loading="pending"
fixed
/>
</div>
</template>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
Usage
Type Declarations
Show Type Declarations
ts
import { MaybeRef } from "vue"
import type { MaybeRefOrGetter } from "vue"
import type {
ITable,
IFilterInfo,
ISortInfo,
IRecord,
} from "@lark-base-open/js-sdk"
/**
* Page option
*/
interface RecordsPageOption {
/**
* Per page size
*
* 每页大小
*
* @default 200
*/
pageSize: number
/**
* Filter
*
* 过滤条件
*/
filter?: IFilterInfo
/**
* Sorts
*
* 排序
*/
sort?: ISortInfo[]
/**
* View ID
*
* 视图 ID
*/
viewId?: MaybeRef<string | null>
/**
* Whether to get shallow records
*
* @default false
*/
shallow?: boolean
}
/**
* Reactive Records Page
*
* 响应式记录分页
*
* @param table
* @param option
* @returns
*/
export declare function useRecordsPage(
table: MaybeRefOrGetter<ITable | null>,
option?: RecordsPageOption,
): {
/**
* Total number of records
*/
total: import("vue").Ref<number, number>
records: import("vue").Ref<
{
recordId: string
fields: {
[fieldId: string]: import("@lark-base-open/js-sdk").IOpenCellValue
}
}[],
| IRecord[]
| {
recordId: string
fields: {
[fieldId: string]: import("@lark-base-open/js-sdk").IOpenCellValue
}
}[]
>
totalPage: import("vue").ComputedRef<number>
/**
* Current page number, starting from 0
*/
curPage: import("vue").WritableComputedRef<number, number>
pending: import("vue").Ref<boolean, boolean>
hasMore: import("vue").Ref<boolean, boolean>
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85