-
-
Notifications
You must be signed in to change notification settings - Fork 813
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] CSS for PostCard.tsx #2935
[REFACTOR] CSS for PostCard.tsx #2935
Conversation
Warning Rate limit exceeded@hustlernik has exceeded the limit for the number of commits or files that can be reviewed per hour. Please wait 17 minutes and 51 seconds before requesting another review. ⌛ How to resolve this issue?After the wait time has elapsed, a review can be triggered using the We recommend that you space out your commits to avoid hitting the rate limit. 🚦 How do rate limits work?CodeRabbit enforces hourly rate limits for each developer per organization. Our paid plans have higher rate limits than the trial, open-source and free plans. In all cases, we re-allow further reviews after a brief timeout. Please see our FAQ for further information. ⛔ Files ignored due to path filters (1)
📒 Files selected for processing (1)
WalkthroughThis pull request focuses on refactoring the CSS for the PostCard component by removing the local CSS module Changes
Assessment against linked issues
Possibly related issues
Possibly related PRs
Suggested reviewers
Poem
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? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
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)
Other keywords and placeholders
Documentation and Community
|
Our Pull Request Approval ProcessThanks for contributing! Testing Your CodeRemember, your PRs won't be reviewed until these criteria are met:
Our policies make our code better. ReviewersDo not assign reviewers. Our Queue Monitors will review your PR and assign them.
Reviewing Your CodeYour reviewer(s) will have the following roles:
CONTRIBUTING.mdRead our CONTRIBUTING.md file. Most importantly:
Other
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (1)
src/style/app.module.css (1)
2467-2478
: Sticky modal footer approach.Positioning with absolute coordinates can be tricky in modals, especially on smaller screens or dynamic content. Consider thoroughly testing in responsive or multi-line comment scenarios to ensure no overlap or clipping occurs. A sticky or pinned approach within scrollable content might require additional container rules.
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (3)
src/components/UserPortal/PostCard/PostCard.module.css
(0 hunks)src/components/UserPortal/PostCard/PostCard.tsx
(4 hunks)src/style/app.module.css
(1 hunks)
💤 Files with no reviewable changes (1)
- src/components/UserPortal/PostCard/PostCard.module.css
🔇 Additional comments (9)
src/components/UserPortal/PostCard/PostCard.tsx (4)
36-36
: Ensure consistent path usage for CSS imports.
Importing app.module.css
from './../../../style/app.module.css'
seems appropriate, but confirm if there's a more standardized approach to referencing global styles across the project (e.g., via an absolute path or alias). This helps avoid brittle relative paths that can break if files are relocated.
275-275
: Good readability with the new cardHeaderPostCard
class.
The updated class name is specific and descriptive. It clearly indicates that this style is for the card header in the PostCard
component, which is good for maintainability.
319-319
: Meaningful class name for the title.
Using cardTitlePostCard
clarifies the targeted element. This reduces confusion when scanning the global CSS, as multiple components may have similarly named title styles.
358-358
: Reusability consideration for modal header styling.
Here, you're reusing cardHeaderPostCard
for a modal header. Ensure it does not conflict with main card styling if the design logic or spacing differs across modals and cards. Consider extracting a separate modal-specific class if differences arise in the future.
src/style/app.module.css (5)
2305-2314
: Scoped class for the card container.
The .cardStyles
class is a concise set of styles. Double-check that these do not clash with other .card
references in the global scope, especially if the project uses .card
utility classes or third-party libraries with similar naming.
2316-2326
: Proper layout & background in .cardHeaderPostCard
.
The usage of flex layout, border, and background is properly balanced. This approach fosters a clear separation between the card’s header area and its body. Keep an eye on whether you need padding vs. margin for consistent spacing.
2328-2336
: Effective .creator
class structure.
Utilizing flex and clear gap spacing improves the layout for user info (icon and name). The approach is good for responsiveness and maintainability.
2378-2387
: Restricting title lines with -webkit-line-clamp
.
This is a desirable approach to truncate long titles elegantly. However, confirm cross-browser compatibility to ensure older browsers can gracefully handle or degrade this style (e.g., fallback to normal overflow behavior).
2486-2489
: Appropriate sizing for .postImage
.
Constraining image height to 300px and applying object-fit: cover
offers a neat approach for uniformity. Confirm that the aspect ratio does not cause unintended cropping for wide or tall images. This may be fine for typical post images, but ensure there's user acceptance if partial content is cropped.
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## develop-postgres #2935 +/- ##
=====================================================
+ Coverage 46.89% 88.93% +42.04%
=====================================================
Files 299 320 +21
Lines 7414 8290 +876
Branches 1621 1869 +248
=====================================================
+ Hits 3477 7373 +3896
+ Misses 3697 692 -3005
+ Partials 240 225 -15 ☔ View full report in Codecov by Sentry. |
Please fix the conflicting file |
@palisadoes okay, doing. |
…wa-admin into refactor-issue#2895
0408dff
There was a problem hiding this 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
🧹 Nitpick comments (4)
src/style/app.module.css (4)
2335-2341
: Consider using responsive width for better mobile supportThe fixed width of
20rem
may cause layout issues on smaller screens. Consider using relative units or media queries for better responsiveness..cardStyles { - width: 20rem; + width: 100%; + max-width: 20rem; background-color: white; padding: 0; border: none !important; outline: none !important; }
2368-2371
: Make SVG icons more flexibleConsider using relative units for SVG dimensions to maintain proportions across different screen sizes.
.creator svg { - width: 2rem; - height: 2rem; + width: clamp(1.5rem, 2vw, 2rem); + height: auto; + aspect-ratio: 1; }
2401-2403
: Enhance image container with aspect ratioConsider adding aspect ratio to maintain consistent image dimensions.
.imageContainerPostCard { max-width: 100%; + aspect-ratio: 16/9; + overflow: hidden; }
2513-2516
: Make post image height responsiveFixed height for images may cause distortion or cropping. Consider using aspect ratio instead.
.postImage { - height: 300px; + width: 100%; + aspect-ratio: 16/9; object-fit: cover; }
Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See comment
…alawa-admin into refactor-issue#2895
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (4)
src/style/app.module.css (4)
2335-2341
: Consider making the card width responsiveThe fixed width of
20rem
may cause layout issues on mobile devices. Consider using relative units or media queries for better responsiveness..cardStyles { - width: 20rem; + width: 100%; + max-width: 20rem; background-color: white; padding: 0; border: none !important; outline: none !important; }
2405-2431
: Improve maintainability and browser compatibilityConsider the following improvements:
- Use CSS variables for colors instead of hardcoded values
- Remove unnecessary
!important
flags- Add vendor prefixes for better browser support
.cardTitlePostCard { --max-lines: 1; display: -webkit-box; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: var(--max-lines); - font-size: 1.3rem !important; + font-size: 1.3rem; font-weight: 600; } .cardText { --max-lines: 2; display: -webkit-box; + display: -moz-box; + display: box; overflow: hidden; -webkit-box-orient: vertical; + -moz-box-orient: vertical; + box-orient: vertical; -webkit-line-clamp: var(--max-lines); + -moz-box-clamp: var(--max-lines); + box-clamp: var(--max-lines); padding-top: 0; font-weight: 300; margin-top: 0.7rem !important; text-align: justify; }
2509-2512
: Improve image handlingThe fixed height for post images may cause aspect ratio issues or image distortion.
.postImage { - height: 300px; + width: 100%; + height: auto; + max-height: 300px; object-fit: cover; }
2488-2492
: Consider adjusting comment container constraintsThe fixed max-height of 18rem for comments may be too restrictive for posts with many comments.
.commentContainer { overflow: auto; - max-height: 18rem; + max-height: min(18rem, 60vh); padding-bottom: 1rem; }
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/style/app.module.css
(1 hunks)
🔇 Additional comments (1)
src/style/app.module.css (1)
2373-2396
: LGTM! Clean implementation of custom toggle button
The toggle button styles effectively override Bootstrap defaults while maintaining clean hover and focus states.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See comments
There was a problem hiding this 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
🧹 Nitpick comments (4)
src/style/app.module.css (4)
2353-2353
: Use CSS variables for consistent border colorsThe border colors are hardcoded as
#dddddd
. Consider using the existing--input-shadow-color
variable for consistency.- border-bottom: 1px solid #dddddd; + border-bottom: 1px solid var(--input-shadow-color);Also applies to: 2501-2501
2374-2397
: Simplify toggle button stylesThe toggle button styles have duplicate rules and can be simplified.
.customToggle { padding: 0; background: none; border: none; margin-right: 1rem; --bs-btn-active-bg: none; -} -.customToggle svg { - color: black; -} - -.customToggle::after { - content: none; -} -.customToggle:hover, -.customToggle:focus, -.customToggle:active { - background: none; - border: none; -} -.customToggle svg { - color: black; + + &::after { + content: none; + } + + &:hover, + &:focus, + &:active { + background: none; + border: none; + } + + svg { + color: black; + } }
2489-2493
: Add scrollbar styles for better UXThe comment container has a scrollbar but lacks custom styling for consistency with the app's design.
.commentContainer { overflow: auto; max-height: 18rem; padding-bottom: 1rem; + scrollbar-width: thin; + scrollbar-color: var(--bs-gray-400) transparent; + + &::-webkit-scrollbar { + width: 8px; + } + + &::-webkit-scrollbar-track { + background: transparent; + } + + &::-webkit-scrollbar-thumb { + background-color: var(--bs-gray-400); + border-radius: 4px; + } }
2510-2513
: Add responsive image handlingThe post image has a fixed height which might cause aspect ratio issues on different screen sizes.
.postImage { - height: 300px; + max-height: 300px; + width: 100%; object-fit: cover; + aspect-ratio: 16/9; }
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/style/app.module.css
(2 hunks)
🔇 Additional comments (1)
src/style/app.module.css (1)
32-32
: LGTM: CSS variable follows naming conventions
The new CSS variable --input-area-color
is well-named and follows the existing pattern of defining colors as CSS variables.
Please make code rabbit approve your changes |
Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
Please fix the failing test |
…wa-admin into refactor-issue#2895
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (4)
src/style/app.module.css (4)
2336-2342
: Consider making the card width responsiveThe fixed width of
20rem
might cause layout issues on smaller screens. Consider using a responsive approach..cardStyles { - width: 20rem; + width: 100%; + max-width: 20rem; background-color: white; padding: 0; border: none !important; outline: none !important; }
2369-2372
: Use CSS variables for icon dimensionsConsider using CSS variables for SVG dimensions to maintain consistency across the application.
+:root { + --icon-size-md: 2rem; +} .creator svg { - width: 2rem; - height: 2rem; + width: var(--icon-size-md); + height: var(--icon-size-md); }
2421-2432
: Improve text readabilityText justification can create inconsistent word spacing and affect readability. Consider using left alignment instead.
.cardText { /* ... other styles ... */ - text-align: justify; + text-align: left; }
2514-2517
: Improve image handlingConsider using aspect-ratio instead of fixed height to maintain image proportions.
.postImage { - height: 300px; + aspect-ratio: 16/9; + width: 100%; object-fit: cover; }
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/style/app.module.css
(2 hunks)
🔇 Additional comments (4)
src/style/app.module.css (4)
32-32
: LGTM: CSS variable declaration
The new CSS variable follows naming conventions and is appropriately scoped.
2344-2354
: Use CSS variable for border color
Convert the hardcoded color to use the existing CSS variable for consistency.
.cardHeaderPostCard {
/* ... other styles ... */
- border-bottom: 1px solid #dddddd;
+ border-bottom: 1px solid var(--input-shadow-color);
}
2374-2397
: LGTM: Toggle button implementation
The toggle button implementation follows accessibility best practices with proper focus states.
2450-2465
: LGTM: Action buttons implementation
The action buttons implementation follows accessibility best practices with proper focus states and uses CSS variables appropriately.
Please fix the conflicting file |
There was a problem hiding this 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
🧹 Nitpick comments (6)
src/style/app.module.css (6)
3525-3531
: Improve card container styles for better responsiveness and consistencyConsider these improvements:
- Make the card width responsive using relative units
- Use CSS variable for background color to maintain consistency with the theme
.cardStyles { - width: 20rem; + width: 100%; + max-width: 20rem; - background-color: white; + background-color: var(--bs-white); padding: 0; border: none !important; outline: none !important; }
3533-3543
: Use CSS variables for colors in card headerFor better maintainability and consistency with the theme, use CSS variables for colors.
.cardHeaderPostCard { display: flex; width: 100%; padding-inline: 0; padding-block: 0; flex-direction: row; gap: 0.5rem; align-items: center; - background-color: white; + background-color: var(--bs-white); - border-bottom: 1px solid #dddddd; + border-bottom: 1px solid var(--input-shadow-color); }
3558-3561
: Use CSS variables for SVG dimensionsFor consistency across the application, consider using CSS variables for icon dimensions.
.creator svg { - width: 2rem; - height: 2rem; + width: var(--icon-size, 2rem); + height: var(--icon-size, 2rem); }
3587-3621
: Improve card body typography and line clampingConsider these improvements:
- Create a reusable utility class for line clamping
- Use CSS variables for font properties
+/* Add to top of file */ +.lineClamp { + display: -webkit-box; + overflow: hidden; + -webkit-box-orient: vertical; + -webkit-line-clamp: var(--max-lines); +} .cardTitlePostCard { --max-lines: 1; - display: -webkit-box; - overflow: hidden; - -webkit-box-orient: vertical; - -webkit-line-clamp: var(--max-lines); + composes: lineClamp; - font-size: 1.3rem !important; - font-weight: 600; + font-size: var(--font-size-title, 1.3rem); + font-weight: var(--font-weight-bold, 600); } .cardText { --max-lines: 2; - display: -webkit-box; - overflow: hidden; - -webkit-box-orient: vertical; - -webkit-line-clamp: var(--max-lines); + composes: lineClamp; padding-top: 0; - font-weight: 300; + font-weight: var(--font-weight-light, 300); margin-top: 0.7rem !important; text-align: justify; }
3639-3654
: Use CSS variables for action button colorsThe implementation has good accessibility features with hover/focus states and transitions. However, colors should use CSS variables for consistency.
.cardActionBtn { - background-color: rgba(0, 0, 0, 0); + background-color: transparent; padding: 0; border: none; - color: black; + color: var(--bs-black); transition: background-color 0.2s ease; } .cardActionBtn:hover, .cardActionBtn:focus { - background-color: ghostwhite; + background-color: var(--dropdown-hover-color); border: none; - color: black !important; + color: var(--bs-black) !important; outline: 2px solid var(--subtle-blue-grey); outline-offset: 2px; }
3682-3706
: Use CSS variables for modal dimensionsConsider using CSS variables for dimensions to maintain consistency across modals.
.commentContainer { overflow: auto; - max-height: 18rem; + max-height: var(--modal-comment-max-height, 18rem); padding-bottom: 1rem; } .postImage { - height: 300px; + height: var(--post-image-height, 300px); object-fit: cover; }
…wa-admin into refactor-issue#2895
Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
…wa-admin into refactor-issue#2895
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See comments
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This file should not be included.
@palisadoes I have messed stuffs a bit, so will close the PR if needed and raise another in sometime. |
What kind of change does this PR introduce?
Streamlined all CSS for PostCard.tsx into a single global file, fixed UI bugs on the PostCard.tsx , and ensured no conflicts with other pages.
Issue Number:
Fixes #2895
Did you add tests for your changes?
No
Does this PR introduce a breaking change?
No
Have you read the contributing guide?
Yes
Summary by CodeRabbit