Skip to content

Commit

Permalink
✨ Add new feature for pagination
Browse files Browse the repository at this point in the history
If we are on the first page of the data, the "Previous" button is not shown.
If we are on the last page of the data, the "Next" button is not shown.

I've updated the following tests:
- easy-paginator.spec.ts
- paginator.spec.ts

All tests pass.
  • Loading branch information
ckersey2 committed Jul 20, 2024
1 parent fac1baf commit 76c58ae
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 64 deletions.
45 changes: 25 additions & 20 deletions src/components/paginator-ui-component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,7 @@ import type {
Nullable,
} from '../internal/types';

export type PaginatorActionIdFn = StringReturnableFn<PaginatorState
& { buttonId: PaginatorButtonId }>;
export type PaginatorActionIdFn = StringReturnableFn<PaginatorState & { buttonId: PaginatorButtonId }>;

Check failure on line 13 in src/components/paginator-ui-component.ts

View workflow job for this annotation

GitHub Actions / Lint, Test, and Build on Node.js 12.x

This line has a length of 103. Maximum allowed is 100

Check failure on line 13 in src/components/paginator-ui-component.ts

View workflow job for this annotation

GitHub Actions / Lint, Test, and Build on Node.js 13.x

This line has a length of 103. Maximum allowed is 100

Check failure on line 13 in src/components/paginator-ui-component.ts

View workflow job for this annotation

GitHub Actions / Lint, Test, and Build on Node.js 14.x

This line has a length of 103. Maximum allowed is 100

Check failure on line 13 in src/components/paginator-ui-component.ts

View workflow job for this annotation

GitHub Actions / Lint, Test, and Build on Node.js 16.x

This line has a length of 103. Maximum allowed is 100

export interface PageCountTextFnParams {
page: number;
Expand All @@ -28,7 +27,7 @@ interface PaginatorUIComponentParams<T> {
previousButtonText: Nullable<string>;
pageCountTextFunction: Nullable<PaginatorPageCountTextFn>;
actionIdFunction: PaginatorActionIdFn;
builderFunction: PaginatorBuilderFn<T>,
builderFunction: PaginatorBuilderFn<T>;
}

const defaultPageCountText = ({ page, totalPages }: PageCountTextFnParams) => `Page ${page} of ${totalPages}`;
Expand Down Expand Up @@ -65,6 +64,28 @@ export class PaginatorUIComponent<T> {
blocksForEach.push(this.builderFunction({ item: this.items[i] }).flat());
}

const actionButtons = [];

if (this.paginator.getPage() > 1) {
actionButtons.push(Elements.Button({
text: this.previousButtonText,
actionId: this.actionIdFunction({
buttonId: PaginatorButtonId.Previous,
...this.paginator.getPreviousPageState(),
}),
}));
}

if (this.paginator.getPage() < this.paginator.getTotalPages()) {
actionButtons.push(Elements.Button({
text: this.nextButtonText,
actionId: this.actionIdFunction({
buttonId: PaginatorButtonId.Next,
...this.paginator.getNextPageState(),
}),
}));
}

const unpruned = this.paginator.getTotalPages() > 1
? [
...blocksForEach.flat(),
Expand All @@ -73,23 +94,7 @@ export class PaginatorUIComponent<T> {
totalPages: this.paginator.getTotalPages(),
})),
Blocks.Divider(),
Blocks.Actions()
.elements(
Elements.Button({
text: this.previousButtonText,
actionId: this.actionIdFunction({
buttonId: PaginatorButtonId.Previous,
...this.paginator.getPreviousPageState(),
}),
}),
Elements.Button({
text: this.nextButtonText,
actionId: this.actionIdFunction({
buttonId: PaginatorButtonId.Next,
...this.paginator.getNextPageState(),
}),
}),
),
Blocks.Actions().elements(...actionButtons),
]
: blocksForEach.flat();

Expand Down
20 changes: 2 additions & 18 deletions tests/components/easy-paginator.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ const getModalString = (blocks: BlockBuilder[]): string => Modal({ title: 'Testi
.buildToJSON();

describe('Testing Easy Paginator:', () => {
test('Creating a paginator with the default parameters creates the correct UI and callback data.', () => {
test('Creating a paginator with the default parameters creates the correct UI and callback data for the first page.', () => {
const result = getModalString(EasyPaginator<Human>({
page: 1,
perPage: 5,
Expand Down Expand Up @@ -184,14 +184,6 @@ describe('Testing Easy Paginator:', () => {
},
{
elements: [
{
text: {
type: 'plain_text',
text: 'Previous',
},
action_id: '{"buttonId":"previous","totalItems":20,"perPage":5,"totalPages":4,"offset":15,"page":4}',
type: 'button',
},
{
text: {
type: 'plain_text',
Expand Down Expand Up @@ -401,7 +393,7 @@ describe('Testing Easy Paginator:', () => {
}));
});

test('Creating a paginator with the default parameters creates the correct UI and callback data.', () => {
test('Creating a paginator with the default parameters creates the correct UI and callback data for the last page.', () => {
const result = getModalString(EasyPaginator({
items: humans,
page: 4,
Expand Down Expand Up @@ -581,14 +573,6 @@ describe('Testing Easy Paginator:', () => {
action_id: '{"buttonId":"previous","totalItems":20,"perPage":5,"totalPages":4,"offset":10,"page":3}',
type: 'button',
},
{
text: {
type: 'plain_text',
text: 'TEST FORWARD',
},
action_id: '{"buttonId":"next","totalItems":20,"perPage":5,"totalPages":4,"offset":0,"page":1}',
type: 'button',
},
],
type: 'actions',
},
Expand Down
28 changes: 2 additions & 26 deletions tests/components/paginator.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ const getModalString = (blocks: BlockBuilder[]): string => Modal({ title: 'Testi
.buildToJSON();

describe('Testing Paginator:', () => {
test('Creating a paginator with the default parameters creates the correct UI and callback data.', () => {
test('Creating a paginator with the default parameters creates the correct UI and callback data for the first page.', () => {
const items = [humans[0], humans[1], humans[2], humans[3], humans[4]];
const result = getModalString(Paginator<Human>({
items,
Expand Down Expand Up @@ -190,14 +190,6 @@ describe('Testing Paginator:', () => {
},
{
elements: [
{
text: {
type: 'plain_text',
text: 'Previous',
},
action_id: '{"buttonId":"previous","totalItems":20,"perPage":5,"totalPages":4,"offset":15,"page":4}',
type: 'button',
},
{
text: {
type: 'plain_text',
Expand Down Expand Up @@ -409,7 +401,7 @@ describe('Testing Paginator:', () => {
}));
});

test('Creating a paginator with the default parameters creates the correct UI and callback data.', () => {
test('Creating a paginator on the last page creates the correct UI and callback data.', () => {
const items = [humans[15], humans[16], humans[17], humans[18], humans[19]];
const result = getModalString(Paginator({
items,
Expand Down Expand Up @@ -591,14 +583,6 @@ describe('Testing Paginator:', () => {
action_id: '{"buttonId":"previous","totalItems":20,"perPage":5,"totalPages":4,"offset":10,"page":3}',
type: 'button',
},
{
text: {
type: 'plain_text',
text: 'TEST FORWARD',
},
action_id: '{"buttonId":"next","totalItems":20,"perPage":5,"totalPages":4,"offset":0,"page":1}',
type: 'button',
},
],
type: 'actions',
},
Expand Down Expand Up @@ -789,14 +773,6 @@ describe('Testing Paginator:', () => {
},
{
elements: [
{
text: {
type: 'plain_text',
text: 'Previous',
},
action_id: '{"buttonId":"previous","totalItems":20,"perPage":5,"totalPages":4,"offset":15,"page":4}',
type: 'button',
},
{
text: {
type: 'plain_text',
Expand Down

0 comments on commit 76c58ae

Please sign in to comment.