Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor(docs): use onPress event instead #4353

Merged
merged 1 commit into from
Dec 17, 2024
Merged

refactor(docs): use onPress event instead #4353

merged 1 commit into from
Dec 17, 2024

Conversation

wingkwong
Copy link
Member

@wingkwong wingkwong commented Dec 13, 2024

Closes #

📝 Description

replace deprecated onClick due to #4322

⛳️ Current behavior (updates)

🚀 New behavior

💣 Is this a breaking change (Yes/No):

📝 Additional Information

Summary by CodeRabbit

  • New Features

    • Updated event handling for buttons in various components to use onPress instead of onClick, enhancing interaction tracking.
  • Bug Fixes

    • Adjusted link behavior in the navbar components to utilize the standard Link component, improving navigation consistency.
  • Documentation

    • No changes to the documentation were made.
  • Chores

    • Simplified import statements across multiple components by removing custom link wrappers.

@wingkwong wingkwong added the 📋 Scope : Docs Related to the documentation label Dec 13, 2024
Copy link

vercel bot commented Dec 13, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
nextui-docs-v2 ✅ Ready (Inspect) Visit Preview 💬 Add feedback Dec 13, 2024 6:09am
nextui-storybook-v2 ✅ Ready (Inspect) Visit Preview 💬 Add feedback Dec 13, 2024 6:09am

Copy link

changeset-bot bot commented Dec 13, 2024

⚠️ No Changeset found

Latest commit: dc3c191

Merging this PR will not cause a version bump for any packages. If these changes should not result in a new version, you're good to go. If these changes should result in a version bump, you need to add a changeset.

This PR includes no changesets

When changesets are added to this PR, you'll see the packages that this PR includes changesets for and the associated semver types

Click here to learn what changesets are, and how to add one.

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

Copy link
Contributor

coderabbitai bot commented Dec 13, 2024

Walkthrough

This pull request introduces modifications primarily focused on changing event handling from onClick to onPress for various components, particularly buttons and links, across multiple files. The changes aim to align with the event handling conventions of the @nextui-org/react library. Additionally, custom link components that prevented default click behavior have been removed, simplifying the import statements and the overall structure of the affected components.

Changes

File Path Change Summary
apps/docs/app/examples/modal/placement/page.tsx Changed onClick to onPress for "Close" and "Action" buttons in ModalFooter.
apps/docs/app/examples/navbar/bordered/page.tsx Simplified import statement for Link, removing custom Link component that prevented default behavior.
apps/docs/app/examples/navbar/controlled-menu/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/custom-active-item/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/disable-menu-animation/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/disabled-blur/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/hide-on-scroll/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/static/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/usage/page.tsx Simplified import statement for Link, removing custom Link component and LinkProps.
apps/docs/app/examples/navbar/with-avatar/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/with-dropdown-menu/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/with-menu/page.tsx Simplified import statement for Link, removing custom Link component.
apps/docs/app/examples/navbar/with-search-input/page.tsx Simplified import statement for Link, removing custom Link component and LinkProps.
apps/docs/components/marketing/install-banner.tsx Changed onClick to onPress for "Get Started" and "Github" buttons.
apps/docs/components/marketing/sponsor-item.tsx Changed onClick to onPress for Link component interactions.
apps/docs/components/mdx-components.tsx Changed onClick to onPress for Link component interactions.
apps/docs/components/sandpack/copy-button.tsx Changed onClick to onPress for Button component interactions.

Possibly related PRs

  • fix(link): deprecated onClick warning on using onPress #3569: This PR addresses a deprecation warning related to the onClick event in the Link component, which is relevant to the changes made in the main PR that also modifies event handling for buttons in the modal.
  • feat(select): virtualization #4203: This PR introduces virtualization support for the Select component, which may relate to the overall event handling and user interaction improvements seen in the main PR.
  • feat(listbox): virtualization #4206: Similar to the previous PR, this one adds virtualization to the Listbox component, which could connect to the changes in event handling and user experience enhancements in the main PR.
  • refactor: button & card ripple #4284: This PR refactors the ripple effect in the Button and Card components, which aligns with the changes in the main PR that also involve button event handling and user interactions.

Suggested reviewers

  • jrgarciadev

Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Experiment)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link
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: 2

🧹 Outside diff range and nitpick comments (4)
apps/docs/app/examples/navbar/bordered/page.tsx (1)

Line range hint 44-48: Consider adding explicit onPress handler for the Sign Up button

While the basic Link functionality works, consider adding an explicit onPress handler for better control and analytics tracking on the Sign Up action.

 <Button as={Link} color="primary" href="#" variant="flat">
+  onPress={(e) => {
+    // Add analytics tracking or additional handling here
+    console.log('Sign up clicked');
+  }}
   Sign Up
 </Button>
apps/docs/app/examples/modal/placement/page.tsx (1)

Line range hint 61-65: LGTM! Event handler migration completed

The change from onClick to onPress on the modal buttons is correct and aligns with NextUI's conventions. Consider updating the component's documentation to reflect this change.

Consider adding a code comment to document that onPress is the preferred event handler for NextUI components.

apps/docs/app/examples/navbar/disable-menu-animation/page.tsx (2)

9-9: Systematic update needed for event handling

This change is part of a pattern across all navbar examples. While removing the custom Link wrapper is a good simplification, the migration to onPress events is incomplete. Consider:

  1. Adding onPress handlers for interactive elements
  2. Documenting the new event handling pattern in the examples

Would you like help creating a consistent pattern for handling press events across all navbar examples?


Line range hint 1-1: Global changes needed to align with PR objectives

The current changes across all navbar examples show a consistent pattern of removing the custom Link wrapper, but don't fully implement the stated objective of migrating from onClick to onPress. Consider:

  1. Implementing proper onPress handlers where interaction is needed
  2. Documenting the new event handling patterns in the examples
  3. Either maintaining preventDefault behavior or using proper routes instead of "#" hrefs
  4. Updating the PR description to accurately reflect the scope of changes
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between c9da5d4 and dc3c191.

📒 Files selected for processing (17)
  • apps/docs/app/examples/modal/placement/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/bordered/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/controlled-menu/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/custom-active-item/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/disable-menu-animation/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/disabled-blur/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/hide-on-scroll/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/static/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/usage/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/with-avatar/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/with-dropdown-menu/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/with-menu/page.tsx (1 hunks)
  • apps/docs/app/examples/navbar/with-search-input/page.tsx (1 hunks)
  • apps/docs/components/marketing/install-banner.tsx (2 hunks)
  • apps/docs/components/marketing/sponsor-item.tsx (1 hunks)
  • apps/docs/components/mdx-components.tsx (1 hunks)
  • apps/docs/components/sandpack/copy-button.tsx (1 hunks)
🔇 Additional comments (15)
apps/docs/components/marketing/sponsor-item.tsx (1)

Line range hint 20-25: LGTM! Event handler change looks good.

The change from onClick to onPress is correctly implemented while preserving the PostHog tracking functionality.

Let's verify if there are any remaining onClick handlers in sponsor-related components:

✅ Verification successful

No remaining onClick handlers found in sponsor components

The absence of results from our search queries indicates that there are no remaining onClick handlers in sponsor-related components. The change from onClick to onPress appears to be complete and consistent across the codebase.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for any remaining onClick handlers in sponsor-related files
rg -i "onClick" apps/docs/components/**/sponsor-*.{ts,tsx,js,jsx}

Length of output: 413


Script:

#!/bin/bash
# Let's try a more reliable search approach using fd to find sponsor-related files first
fd "sponsor.*\.(tsx?|jsx?)$" apps/docs/components/ -x rg -i "onClick" {}

Length of output: 74

apps/docs/components/sandpack/copy-button.tsx (1)

26-28: LGTM! Button event handler updated correctly.

The onPress event handler is properly implemented on the Button component while maintaining the copy functionality.

apps/docs/app/examples/navbar/usage/page.tsx (1)

3-3: Verify intended link behavior after removing custom Link component.

The import statement has been simplified by removing the custom Link component that prevented default behavior. Please confirm if this is the intended behavior for all navbar links.

Let's check for any remaining custom Link implementations:

apps/docs/app/examples/navbar/bordered/page.tsx (1)

3-3: Verify Button and Link component interaction

The import changes look good, but we should verify that the Button component properly handles events when used with as={Link}.

✅ Verification successful

Let me gather more information about the Button and Link components interaction.


Let me try a different approach to search for these components.


Let me search for the actual Link component implementation to verify its event handling.


Let me try one final search to find the polymorphic component handling.


Button with Link integration is properly handled

The Link component implementation shows proper event handling through useAriaLink hook which handles both onClick and onPress events. The Button component using as={Link} is a common pattern across multiple examples in the codebase, and the Link component is designed to work with polymorphic components through its proper event forwarding mechanism.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for Button component implementation to verify event handling
ast-grep --pattern 'export const Button = $$$' 

Length of output: 1692


Script:

#!/bin/bash
# Search for Button component implementation in the actual component files
rg -A 10 "export const Button = " --type typescript

# Search for any Button+Link usage patterns in the codebase
ast-grep --pattern 'Button as={Link}'

# Search for Link component implementation
rg -A 10 "export const Link = " --type typescript

Length of output: 215


Script:

#!/bin/bash
# Search for Button component implementation
rg -A 10 "export const Button"

# Search for Link component implementation
rg -A 10 "export const Link"

# Search for Button with Link usage examples
rg -A 3 "Button.*as=.*Link"

Length of output: 13244


Script:

#!/bin/bash
# Search for Link component in the components directory
fd Link.tsx -t f packages/components | xargs cat

# Search for any polymorphic component handling
rg -A 5 "as={" packages/components

Length of output: 159


Script:

#!/bin/bash
# Search for Link component implementation
fd -e tsx -e ts -t f -d 3 "link" packages/components/link/src | xargs cat

# Search for polymorphic component patterns
rg "type.*Props.*as.*=" packages/components

Length of output: 4614

apps/docs/app/examples/navbar/static/page.tsx (1)

3-3: LGTM! Changes are consistent with other navbar examples

The import changes align with the PR objectives and maintain consistency across components.

apps/docs/app/examples/navbar/hide-on-scroll/page.tsx (1)

3-3: LGTM! Verify scroll behavior with event handling

The import changes are consistent. Since this component uses shouldHideOnScroll, we should verify that the scroll behavior doesn't interfere with link/button event handling.

apps/docs/app/examples/navbar/disabled-blur/page.tsx (1)

3-3: Verify Link component event handling behavior

The import change from custom NextUiLink to the standard Link component is aligned with the migration to onPress events. However, we should verify the event handling behavior in nested components.

✅ Verification successful

Let me gather more information about the Link component implementation and its event handling.


Let me check one more thing about the AriaLinkProps to understand the complete event handling interface.


Import change is safe and correctly implemented

The verification shows that the Link component from @nextui-org/react is properly used in the navbar example without any onClick handlers. The component is used consistently for both regular links and button-styled links, following the library's patterns. The implementation aligns with the migration to onPress events, and there are no compatibility issues to address.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for any remaining onClick handlers in Link components
ast-grep --pattern 'Link $props={$$$} onClick={$_}'

# Search for documentation or type definitions of Link component
rg -A 5 "export (type|interface) LinkProps"

Length of output: 476


Script:

#!/bin/bash
# Check the Link component implementation for event handling
ast-grep --pattern 'const Link = $_ => {
  $$$
}'

# Search for UseLinkProps definition to understand available props
rg -A 10 "export (type|interface) UseLinkProps"

# Search for useLink hook implementation
ast-grep --pattern 'export const useLink = $_ => {
  $$$
}'

Length of output: 2913


Script:

#!/bin/bash
# Search for AriaLinkProps definition and its event handlers
rg -A 5 "type AriaLinkProps"

# Check if there are any onClick handlers in the navbar example
ast-grep --pattern 'onPress={$_}' apps/docs/app/examples/navbar/disabled-blur/page.tsx

# Check the actual implementation of the navbar example
cat apps/docs/app/examples/navbar/disabled-blur/page.tsx

Length of output: 1696

apps/docs/app/examples/navbar/custom-active-item/page.tsx (1)

3-3: LGTM! Import changes are consistent

The changes align with the standardization of event handling while preserving the custom active item styling functionality.

apps/docs/app/examples/navbar/with-avatar/page.tsx (1)

8-8: LGTM: Import statement updated correctly

The direct import of Link from @nextui-org/react aligns with the migration from onClick to onPress events, as the updated component internally handles the new event system.

apps/docs/app/examples/navbar/with-search-input/page.tsx (1)

8-8: LGTM: Import statement updated correctly

The direct import of Link from @nextui-org/react is consistent with the migration to the new event system.

apps/docs/app/examples/navbar/with-dropdown-menu/page.tsx (2)

8-8: LGTM: Import statement updated correctly

The direct import of Link from @nextui-org/react aligns with the migration to onPress events.


Line range hint 119-121: Verify Button and Link interaction with onPress event

The Button as={Link} pattern needs verification to ensure proper event handling with the new onPress system.

✅ Verification successful

Let me generate additional scripts to check for the implementation details of the Button and Link components to understand how they handle events.


Based on the analysis of the codebase, I can now provide a final response:

Button as={Link} pattern is properly handled with the new onPress system

The codebase shows that both Button and Link components are using React Aria's press event system consistently:

  • The Button component uses useAriaButton hook which properly handles both onClick and onPress events
  • The Link component uses useAriaLink hook with similar event handling
  • Both hooks include mobile-specific handling and proper event chaining
  • The pattern is consistently used across multiple examples in the codebase
  • No conflicting event handling patterns were found
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for similar Button as={Link} patterns in the codebase
# and verify consistent event handling

# Search for Button components using Link
rg -l "Button.*as=\{Link\}" | while read -r file; do
  echo "=== $file ==="
  rg -A 2 "Button.*as=\{Link\}" "$file"
done

# Search for any explicit onClick handlers on Button or Link
rg -l "onClick.*Button|onClick.*Link" | while read -r file; do
  echo "=== $file ==="
  rg -A 2 "onClick.*Button|onClick.*Link" "$file"
done

Length of output: 10076


Script:

#!/bin/bash
# Check Button and Link component implementations
ast-grep --pattern 'export const Button = $$$'

# Check for any onPress related code
rg -A 3 "onPress.*Button|onPress.*Link"

# Check for any event handling in Button or Link components
rg -A 3 "handlePress|pressHandler" 

Length of output: 31657

apps/docs/components/marketing/install-banner.tsx (1)

Line range hint 75-82: LGTM! Event handlers updated correctly.

The onClick handlers have been properly replaced with onPress while maintaining the analytics tracking functionality.

Let's verify if there are any remaining onClick handlers in the component:

Also applies to: 94-101

✅ Verification successful

LGTM! Event handlers are correctly implemented

The verification confirms that:

  • All click handlers are using onPress
  • No remaining onClick handlers exist in the component
  • Both "Get Started" and "Github" buttons are properly using onPress with their respective analytics tracking
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for any remaining onClick handlers in the InstallBanner component
ast-grep --pattern 'onClick={$_}' apps/docs/components/marketing/install-banner.tsx

Length of output: 85


Script:

#!/bin/bash
# Let's first check if the file exists and view its content
cat apps/docs/components/marketing/install-banner.tsx

# Also search for any click-related handlers with ripgrep for broader coverage
rg "(?i)(onclick|onpress)" apps/docs/components/marketing/install-banner.tsx

Length of output: 4564

apps/docs/components/mdx-components.tsx (2)

201-201: LGTM! Event handler updated correctly.

The onClick handler has been properly replaced with onPress while maintaining the analytics tracking functionality.

Let's verify keyboard accessibility and remaining onClick handlers:

✅ Verification successful

Keyboard accessibility is properly handled by NextUI's Link component

After examining the code, the change from onClick to onPress is safe because:

  1. The Link component uses NextUI's Link component which inherently provides keyboard accessibility
  2. The component spreads external props including target and rel attributes for proper external link handling
  3. The analytics tracking is preserved through the handleClick function

The NextUI Link component internally handles keyboard interactions, making explicit onKeyDown handlers unnecessary. The component maintains both accessibility and analytics requirements.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for any remaining onClick handlers in the MDX components
ast-grep --pattern 'onClick={$_}' apps/docs/components/mdx-components.tsx

# Check if the Link component has proper keyboard handling
ast-grep --pattern 'onKeyDown={$_}' apps/docs/components/mdx-components.tsx

Length of output: 153


Script:

#!/bin/bash
# Let's examine the Link component implementation more thoroughly
cat apps/docs/components/mdx-components.tsx

Length of output: 11332


201-201: Consider verifying keyboard accessibility.

Since we're switching from onClick to onPress, ensure that keyboard navigation (Enter key) still works correctly with the Link component. The NextUI Link component should handle this internally, but it's worth verifying.

Let's check the NextUI Link component implementation:

✅ Verification successful

Keyboard accessibility is properly handled by NextUI Link component

The implementation is using NextUI's Link component which inherently handles keyboard interactions. The code shows:

  • The Link is rendered using Components.Link from "@nextui-org/react"
  • It maintains proper accessibility by:
    • Using semantic anchor elements
    • Preserving proper href attributes
    • Including proper external link attributes when needed (target, rel)
  • The onPress handler is only used for analytics tracking and doesn't interfere with the default keyboard behavior
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Look for keyboard event handling in NextUI Link component
rg -A 5 'onKeyDown|onPress' node_modules/@nextui-org/react/

Length of output: 133


Script:

#!/bin/bash
# Let's check the actual implementation in the codebase
rg -A 5 "onPress.*handleClick" apps/docs/components/mdx-components.tsx

# Let's also check if there are any keyboard event handlers
rg -A 5 "onKeyDown|onKeyPress" apps/docs/components/mdx-components.tsx

# Let's see the Link component usage context
ast-grep --pattern 'Link {
  $$$
  onPress={$_}
  $$$
}'

Length of output: 286


Script:

#!/bin/bash
# Let's check the Link component import and its source
rg "import.*Link.*from" apps/docs/components/mdx-components.tsx

# Let's also see the full Link component implementation
ast-grep --pattern 'const Components.Link = ({ $$$, children }) => {
  $$$
}'

Length of output: 145


Script:

#!/bin/bash
# Let's see the entire content of the file to understand the Link component implementation
cat apps/docs/components/mdx-components.tsx

Length of output: 11332

@jrgarciadev jrgarciadev merged commit d9a55d0 into main Dec 17, 2024
3 checks passed
@jrgarciadev jrgarciadev deleted the docs/on-press branch December 17, 2024 14:17
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
📋 Scope : Docs Related to the documentation
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants