Skip to content

fix: pagination state on search for custom sounds and emojis#40115

Draft
nazabucciarelli wants to merge 5 commits into
developfrom
fix/pagination-reset-sounds-and-emojis
Draft

fix: pagination state on search for custom sounds and emojis#40115
nazabucciarelli wants to merge 5 commits into
developfrom
fix/pagination-reset-sounds-and-emojis

Conversation

@nazabucciarelli
Copy link
Copy Markdown
Contributor

@nazabucciarelli nazabucciarelli commented Apr 11, 2026

Proposed changes (including videos or screenshots)

Introduced a new optional parameter resetDependencies (an array) to the usePagination custom hook. When any value inside this array changes, the hook automatically resets the current page to 0.

Instead of accepting a single value for the reset trigger, I implemented it directly as an array. This allows any table using this hook to easily handle multiple simultaneous filters in the future (e.g., [text, status, category]) without modifying the hook's signature again.

Issue(s)

CORE-2096 [Improvement] Pagination not resetting on search in Custom Sounds and Custom Emojis tables

Steps to test or reproduce

To test this you will need to bring the changes from this PR to unblock the bug on Custom Sounds pagination.

  1. Navigate to Workspace > Custom Sounds (or Custom Emojis).
  2. Go to page 2 (or higher) of the table (you will need many records to test this).
  3. Type a search term in the search bar.
  4. Observe that the table returns an empty state (no results) because the API request is made using the updated search term but keeping the offset from page 2.

Further comments

Summary by CodeRabbit

  • Bug Fixes

    • Pagination now resets to the first page when searching or filtering Custom Sounds and Emojis, preventing empty or out-of-range pages and ensuring filtered results start from the beginning.
  • Chores

    • Added a release note entry for the upcoming patch release documenting this pagination fix.

@nazabucciarelli nazabucciarelli added this to the 8.4.0 milestone Apr 11, 2026
@dionisio-bot
Copy link
Copy Markdown
Contributor

dionisio-bot Bot commented Apr 11, 2026

Looks like this PR is not ready to merge, because of the following issues:

  • This PR is missing the 'stat: QA assured' label
  • This PR is missing the required milestone or project

Please fix the issues and try again

If you have any trouble, please check the PR guidelines

@changeset-bot
Copy link
Copy Markdown

changeset-bot Bot commented Apr 11, 2026

🦋 Changeset detected

Latest commit: e341162

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 42 packages
Name Type
@rocket.chat/meteor Patch
@rocket.chat/core-typings Patch
@rocket.chat/rest-typings Patch
@rocket.chat/uikit-playground Patch
@rocket.chat/api-client Patch
@rocket.chat/apps Patch
@rocket.chat/core-services Patch
@rocket.chat/cron Patch
@rocket.chat/ddp-client Patch
@rocket.chat/fuselage-ui-kit Patch
@rocket.chat/gazzodown Patch
@rocket.chat/http-router Patch
@rocket.chat/livechat Patch
@rocket.chat/model-typings Patch
@rocket.chat/models Patch
@rocket.chat/ui-avatar Patch
@rocket.chat/ui-client Patch
@rocket.chat/ui-contexts Patch
@rocket.chat/ui-voip Patch
@rocket.chat/web-ui-registration Patch
@rocket.chat/account-service Patch
@rocket.chat/authorization-service Patch
@rocket.chat/ddp-streamer Patch
@rocket.chat/omnichannel-transcript Patch
@rocket.chat/presence-service Patch
@rocket.chat/queue-worker Patch
@rocket.chat/abac Patch
@rocket.chat/federation-matrix Patch
@rocket.chat/license Patch
@rocket.chat/media-calls Patch
@rocket.chat/omnichannel-services Patch
@rocket.chat/pdf-worker Patch
@rocket.chat/presence Patch
rocketchat-services Patch
@rocket.chat/network-broker Patch
@rocket.chat/omni-core-ee Patch
@rocket.chat/mock-providers Patch
@rocket.chat/instance-status Patch
@rocket.chat/omni-core Patch
@rocket.chat/server-fetch Patch
@rocket.chat/ui-video-conf Patch
@rocket.chat/ui-composer Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@coderabbitai
Copy link
Copy Markdown
Contributor

coderabbitai Bot commented Apr 11, 2026

No actionable comments were generated in the recent review. 🎉

ℹ️ Recent review info
⚙️ Run configuration

Configuration used: Organization UI

Review profile: CHILL

Plan: Pro

Run ID: 75a3c642-69f1-4f84-b8e6-715fe014501d

📥 Commits

Reviewing files that changed from the base of the PR and between 6c822db and e341162.

📒 Files selected for processing (2)
  • .changeset/real-suns-float.md
  • apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx
✅ Files skipped from review due to trivial changes (1)
  • .changeset/real-suns-float.md
🚧 Files skipped from review as they are similar to previous changes (1)
  • apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx
📜 Recent review details
⏰ Context from checks skipped due to timeout of 90000ms. You can increase the timeout in your CodeRabbit configuration to a maximum of 15 minutes (900000ms). (4)
  • GitHub Check: Agent
  • GitHub Check: 📦 Build Packages
  • GitHub Check: CodeQL-Build
  • GitHub Check: CodeQL-Build

Walkthrough

Reset pagination to page 0 when filter text changes for Custom Emojis and Custom Sounds; add a changeset declaring a patch release for @rocket.chat/meteor documenting the pagination reset fix.

Changes

Changesets

Layer / File(s) Summary
Metadata
/.changeset/real-suns-float.md
Adds a changeset declaring a patch release for @rocket.chat/meteor with a note about fixing pagination resetting when searching Custom Sounds and Emojis.

Pagination reset on filter inputs

Layer / File(s) Summary
Control hook scope
apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx
usePagination is now called with [text] so pagination state is scoped to the current filter text.
Filter input handler
apps/meteor/client/views/admin/customSounds/CustomSoundsTable/CustomSoundsTable.tsx
FilterByText onChange now calls onSetCurrent(0) in addition to updating text, resetting table pagination to the first page on filter changes.
No-results rendering
apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx
Refined no-results check to isSuccess && data?.emojis.length === 0 (removed redundant data &&).

Estimated code review effort

🎯 2 (Simple) | ⏱️ ~8 minutes

Suggested labels

type: bug

🚥 Pre-merge checks | ✅ 5
✅ Passed checks (5 passed)
Check name Status Explanation
Description Check ✅ Passed Check skipped - CodeRabbit’s high-level summary is enabled.
Title check ✅ Passed The title 'fix: pagination state on search for custom sounds and emojis' clearly and specifically summarizes the main change: fixing pagination reset behavior when searching in Custom Sounds and Emojis tables.
Docstring Coverage ✅ Passed No functions found in the changed files to evaluate docstring coverage. Skipping docstring coverage check.
Linked Issues check ✅ Passed Check skipped because no linked issues were found for this pull request.
Out of Scope Changes check ✅ Passed Check skipped because no linked issues were found for this pull request.

✏️ Tip: You can configure your own custom pre-merge checks in the settings.

Warning

Review ran into problems

🔥 Problems

Errors were encountered while retrieving linked issues.

Errors (1)
  • CORE-2096: Request failed with status code 401

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

@nazabucciarelli nazabucciarelli marked this pull request as ready for review April 11, 2026 02:53
@nazabucciarelli nazabucciarelli requested a review from a team as a code owner April 11, 2026 02:53
Copy link
Copy Markdown
Contributor

@coderabbitai coderabbitai Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.

Inline comments:
In @.changeset/real-suns-float.md:
- Line 5: Update the changeset description string that currently reads "Fixes
pagination reset on search for Customs Sounds and Emojis" to use the correct
wording "Custom Sounds" (i.e., change "Customs Sounds" → "Custom Sounds") so the
description becomes "Fixes pagination reset on search for Custom Sounds and
Emojis"; ensure only the typo is corrected and punctuation/capitalization
remains consistent.
🪄 Autofix (Beta)

Fix all unresolved CodeRabbit comments on this PR:

  • Push a commit to this branch (recommended)
  • Create a new PR with the fixes

ℹ️ Review info
⚙️ Run configuration

Configuration used: Organization UI

Review profile: CHILL

Plan: Pro

Run ID: 8f2e7b1d-0bb3-4f4a-ae81-9d97ae3b6e81

📥 Commits

Reviewing files that changed from the base of the PR and between 9760d84 and 5b8801f.

📒 Files selected for processing (3)
  • .changeset/real-suns-float.md
  • apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx
  • apps/meteor/client/views/admin/customSounds/CustomSoundsTable/CustomSoundsTable.tsx
📜 Review details
⏰ Context from checks skipped due to timeout of 90000ms. You can increase the timeout in your CodeRabbit configuration to a maximum of 15 minutes (900000ms). (3)
  • GitHub Check: 📦 Build Packages
  • GitHub Check: cubic · AI code reviewer
  • GitHub Check: CodeQL-Build
🧰 Additional context used
📓 Path-based instructions (1)
**/*.{ts,tsx,js}

📄 CodeRabbit inference engine (.cursor/rules/playwright.mdc)

**/*.{ts,tsx,js}: Write concise, technical TypeScript/JavaScript with accurate typing in Playwright tests
Avoid code comments in the implementation

Files:

  • apps/meteor/client/views/admin/customSounds/CustomSoundsTable/CustomSoundsTable.tsx
  • apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx
🧠 Learnings (5)
📚 Learning: 2026-02-24T19:09:09.561Z
Learnt from: ahmed-n-abdeltwab
Repo: RocketChat/Rocket.Chat PR: 38974
File: apps/meteor/app/api/server/v1/im.ts:220-221
Timestamp: 2026-02-24T19:09:09.561Z
Learning: In RocketChat/Rocket.Chat OpenAPI migration PRs for apps/meteor/app/api/server/v1 endpoints, maintainers prefer to avoid any logic changes; style-only cleanups (like removing inline comments) may be deferred to follow-ups to keep scope tight.

Applied to files:

  • .changeset/real-suns-float.md
📚 Learning: 2026-02-24T19:05:56.710Z
Learnt from: ahmed-n-abdeltwab
Repo: RocketChat/Rocket.Chat PR: 0
File: :0-0
Timestamp: 2026-02-24T19:05:56.710Z
Learning: Rocket.Chat repo context: When a workspace manifest on develop already pins a dependency version (e.g., packages/web-ui-registration → "rocket.chat/ui-contexts": "27.0.1"), a lockfile change in a feature PR that upgrades only that dependency’s resolution is considered a manifest-driven sync and can be kept, preferably as a small "chore: sync yarn.lock with manifests" commit.

Applied to files:

  • .changeset/real-suns-float.md
📚 Learning: 2025-11-19T18:20:07.720Z
Learnt from: gabriellsh
Repo: RocketChat/Rocket.Chat PR: 37419
File: packages/i18n/src/locales/en.i18n.json:918-921
Timestamp: 2025-11-19T18:20:07.720Z
Learning: Repo: RocketChat/Rocket.Chat — i18n/formatting
Learning: This repository uses a custom message formatting parser in UI blocks/messages; do not assume standard Markdown rules. For keys like Call_ended_bold, Call_not_answered_bold, Call_failed_bold, and Call_transferred_bold in packages/i18n/src/locales/en.i18n.json, retain the existing single-asterisk emphasis unless maintainers request otherwise.

Applied to files:

  • .changeset/real-suns-float.md
📚 Learning: 2026-03-16T21:50:37.589Z
Learnt from: amitb0ra
Repo: RocketChat/Rocket.Chat PR: 39676
File: .changeset/migrate-users-register-openapi.md:3-3
Timestamp: 2026-03-16T21:50:37.589Z
Learning: For changes related to OpenAPI migrations in Rocket.Chat/OpenAPI, when removing endpoint types and validators from rocket.chat/rest-typings (e.g., UserRegisterParamsPOST, /v1/users.register) document this as a minor changeset (not breaking) per RocketChat/Rocket.Chat-Open-API#150 Rule 7. Note that the endpoint type is re-exposed via a module augmentation .d.ts in the consuming package (e.g., packages/web-ui-registration/src/users-register.d.ts). In reviews, ensure the changeset clearly states: this is a non-breaking change, the major version should not be bumped, and the changeset reflects a minor version bump. Do not treat this as a breaking change during OpenAPI migrations.

Applied to files:

  • .changeset/real-suns-float.md
📚 Learning: 2026-03-27T14:52:56.865Z
Learnt from: dougfabris
Repo: RocketChat/Rocket.Chat PR: 39892
File: apps/meteor/client/views/room/contextualBar/Threads/Thread.tsx:150-155
Timestamp: 2026-03-27T14:52:56.865Z
Learning: In Rocket.Chat, there are two different `ModalBackdrop` components with different prop APIs. During review, confirm the import source: (1) `rocket.chat/fuselage` `ModalBackdrop` uses `ModalBackdropProps` based on `BoxProps` (so it supports `onClick` and other Box/DOM props) and does not have an `onDismiss` prop; (2) `rocket.chat/ui-client` `ModalBackdrop` uses a narrower props interface like `{ children?: ReactNode; onDismiss?: () => void }` and handles Escape keypress and outside mouse-up, and it does not forward arbitrary DOM props such as `onClick`. Flag mismatched props (e.g., `onDismiss` passed to the fuselage component or `onClick` passed to the ui-client component) and ensure the usage matches the correct component being imported.

Applied to files:

  • apps/meteor/client/views/admin/customSounds/CustomSoundsTable/CustomSoundsTable.tsx
  • apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx
🔇 Additional comments (2)
apps/meteor/client/views/admin/customSounds/CustomSoundsTable/CustomSoundsTable.tsx (1)

68-74: Good fix: page index reset is applied at the right place.

Resetting current inside the search onChange handler correctly prevents stale offsets during filtered queries.

apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx (1)

71-77: Looks correct: search now reliably starts from page 1.

This change properly resets pagination state when the filter text changes.

Comment thread .changeset/real-suns-float.md Outdated
Copy link
Copy Markdown
Contributor

@cubic-dev-ai cubic-dev-ai Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No issues found across 3 files

@codecov
Copy link
Copy Markdown

codecov Bot commented Apr 11, 2026

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 69.57%. Comparing base (dbce434) to head (e341162).

Additional details and impacted files

Impacted file tree graph

@@             Coverage Diff             @@
##           develop   #40115      +/-   ##
===========================================
- Coverage    69.57%   69.57%   -0.01%     
===========================================
  Files         3317     3317              
  Lines       121867   121866       -1     
  Branches     21801    21847      +46     
===========================================
- Hits         84794    84788       -6     
- Misses       33740    33748       +8     
+ Partials      3333     3330       -3     
Flag Coverage Δ
e2e 58.89% <100.00%> (+<0.01%) ⬆️
e2e-api 46.30% <ø> (+<0.01%) ⬆️
unit 70.41% <100.00%> (-0.02%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.
  • 📦 JS Bundle Analysis: Save yourself from yourself by tracking and limiting bundle sizes in JS merges.

Copy link
Copy Markdown
Member

@dougfabris dougfabris left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This fix seems a little weak, I'm wondering if we could have a more wider solution under the usePagination or something else, so all places we use it, could benefit from a potential fix

@nazabucciarelli nazabucciarelli modified the milestones: 8.4.0, 8.5.0 Apr 19, 2026
@alfredodelfabro alfredodelfabro removed this from the 8.5.0 milestone Apr 30, 2026
@nazabucciarelli nazabucciarelli force-pushed the fix/pagination-reset-sounds-and-emojis branch from 6c822db to e341162 Compare May 7, 2026 01:34
@nazabucciarelli nazabucciarelli requested a review from Copilot May 7, 2026 01:35
Copy link
Copy Markdown
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

This PR fixes an admin UI pagination bug where searching in Custom Sounds / Custom Emojis could keep the previous page offset, resulting in empty/out-of-range results. It does so by extending the shared usePagination hook to allow resetting the current page when specified “reset trigger” values change.

Changes:

  • Extended usePagination to accept an optional resetDependencies array that triggers setCurrent(0) when any dependency changes.
  • Wired Custom Sounds and Custom Emojis tables to reset pagination when the search text changes.
  • Added a changeset entry for a patch release.

Reviewed changes

Copilot reviewed 4 out of 4 changed files in this pull request and generated 2 comments.

File Description
packages/ui-client/src/components/GenericTable/hooks/usePagination.ts Adds optional reset-dependencies support to reset pagination state when filters/search change.
apps/meteor/client/views/admin/customSounds/CustomSoundsTable/CustomSoundsTable.tsx Passes search text into usePagination so pagination resets on search changes.
apps/meteor/client/views/admin/customEmoji/CustomEmoji.tsx Passes search text into usePagination so pagination resets on search changes; minor null-safe condition tweak.
.changeset/real-suns-float.md Patch release note for the pagination reset fix.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment on lines 26 to +29
// Reset to first page when itemsPerPage changes
useEffect(() => {
setCurrent(0);
}, [itemsPerPage, setCurrent]);
}, [itemsPerPage, setCurrent, ...resetDependencies]);
Comment on lines 26 to 31
const CustomSoundsTable = ({ reload, onClick }: CustomSoundsTableProps) => {
const t = useTranslation();
const { sortBy, sortDirection, setSort } = useSort<'name'>('name');
const { current, itemsPerPage, setItemsPerPage: onSetItemsPerPage, setCurrent: onSetCurrent, ...paginationProps } = usePagination();

const [text, setText] = useState('');
const { current, itemsPerPage, setItemsPerPage: onSetItemsPerPage, setCurrent: onSetCurrent, ...paginationProps } = usePagination([text]);

@nazabucciarelli nazabucciarelli marked this pull request as draft May 11, 2026 14:33
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants