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

Plugin and advertisement screen revamp #2006

Conversation

duplixx
Copy link
Member

@duplixx duplixx commented May 24, 2024

What kind of change does this PR introduce?

Redesign

Issue Number:

Fixes #1918

Did you add tests for your changes?

No

Snapshots/Videos:
image
image

If relevant, did you update the documentation?

Summary

Does this PR introduce a breaking change?

Other information

Have you read the contributing guide?

Summary by CodeRabbit

Release Notes

  • New Features

    • Renamed "Add On Store" to "Plugin Store" for clarity.
    • Introduced search functionality in the Advertisements component.
    • Enhanced plugin filtering options in the AddOnStore.
  • Bug Fixes

    • Improved date validation in Advertisement tests.
  • Documentation

    • Updated pull request template to clarify branching strategy and contribution guidelines.
  • Style

    • Adjusted styles for buttons and advertisement entries to improve visual presentation.

Copy link
Contributor

coderabbitai bot commented May 24, 2024

Walkthrough

The changes in this pull request involve updates to various components and their related files in the codebase. Key modifications include terminology changes in the translation files, enhancements in the AddOnEntry and AddOnStore components for better type safety and UI presentation, the addition of search functionality in the Advertisements component, and refactoring of related test suites. The pull request also updates the pull request template to clarify contribution guidelines.

Changes

File Change Summary
public/locales/en/translation.json Updated "Add On Store" to "Plugin Store" and changed "Create new advertisement" to "Create".
src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx Changed getInstalledPlugins prop type from any to void, added inline styles, updated button icon and logic.
src/components/AddOn/core/AddOnStore/AddOnStore.tsx Introduced InterfacePluginHelper, updated getInstalledPlugins to return void, enhanced GraphQL query typing.
src/components/Advertisements/Advertisements.tsx Renamed component to advertisements, added search functionality, updated refetch type to any.
src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.tsx Added console.log, updated Card component styles, and included advertisement start date display.
src/components/Advertisements/core/AdvertisementRegister/AdvertisementRegister.module.css Modified icon spacing in button styles.
src/components/AddOn/core/AddOnStore/AddOnStore.test.tsx Added InterfacePlugin, removed outdated filter tests, and improved type safety in tests.
src/components/Advertisements/Advertisements.test.tsx Adjusted date categorization test logic.
.github/pull_request_template.md Added branching strategy and contribution guidelines to the pull request template.

Assessment against linked issues

Objective Addressed Explanation
Redesign the advertisement and plugin screen in talawa-Admin portal (#1918)

Possibly related PRs

Suggested labels

refactor, test

Suggested reviewers

  • palisadoes
  • varshith257
  • pranshugupta54
  • AVtheking

🐇 In the code where I hop and play,
Changes bloom like flowers in May.
From "Add On" to "Plugin" we glide,
With search and style, we take great pride.
So let’s embrace this new delight,
As we code and create, into the night! 🌼


📜 Recent review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between a63e0d4 and a35b2ab.

📒 Files selected for processing (1)
  • src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx (5 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
  • src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx

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 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

github-actions bot commented May 24, 2024

Our Pull Request Approval Process

Thanks for contributing!

Testing Your Code

Remember, your PRs won't be reviewed until these criteria are met:

  1. We don't merge PRs with poor code quality.
    1. Follow coding best practices such that CodeRabbit.ai approves your PR.
  2. We don't merge PRs with failed tests.
    1. When tests fail, click on the Details link to learn more.
    2. Write sufficient tests for your changes (CodeCov Patch Test). Your testing level must be better than the target threshold of the repository
    3. Tests may fail if you edit sensitive files. Ask to add the ignore-sensitive-files-pr label if the edits are necessary.
  3. We cannot merge PRs with conflicting files. These must be fixed.

Our policies make our code better.

Reviewers

Do not assign reviewers. Our Queue Monitors will review your PR and assign them.
When your PR has been assigned reviewers contact them to get your code reviewed and approved via:

  1. comments in this PR or
  2. our slack channel

Reviewing Your Code

Your reviewer(s) will have the following roles:

  1. arbitrators of future discussions with other contributors about the validity of your changes
  2. point of contact for evaluating the validity of your work
  3. person who verifies matching issues by others that should be closed.
  4. person who gives general guidance in fixing your tests

CONTRIBUTING.md

Read our CONTRIBUTING.md file. Most importantly:

  1. PRs with issues not assigned to you will be closed by the reviewer
  2. Fix the first comment in the PR so that each issue listed automatically closes

Other

  1. 🎯 Please be considerate of our volunteers' time. Contacting the person who assigned the reviewers is not advised unless they ask for your input. Do not @ the person who did the assignment otherwise.
  2. Read the CONTRIBUTING.md file make

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: 8

Outside diff range and nitpick comments (12)
src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.tsx (3)

Line range hint 77-81: Specify the type attribute for the button to ensure correct behavior in forms.

+ type="button"

Line range hint 99-99: Add keyboard accessibility to the delete button by handling key events.

+ onKeyUp={(event) => { if (event.key === 'Enter') toggleShowDeleteModal(); }}

Line range hint 147-147: Self-close JSX elements that don't have children.

- <Card.Img className={styles.admedia} variant="top" src={mediaUrl} data-testid="media"></Card.Img>
+ <Card.Img className={styles.admedia} variant="top" src={mediaUrl} data-testid="media" />

Also applies to: 158-158

src/components/AddOn/core/AddOnStore/AddOnStore.tsx (1)

Line range hint 75-75: Self-close JSX elements that don't have children.

- <div className={styles.loader}></div>
+ <div className={styles.loader} />
src/components/Advertisements/Advertisements.tsx (3)

Line range hint 53-53: Use optional chaining to safely access nested properties.

- orgAdvertisementListData && orgAdvertisementListData.organizations
+ orgAdvertisementListData?.organizations

Also applies to: 67-67


Line range hint 126-128: Self-close JSX elements that don't have children.

- <div className={styles.itemCard}></div>
+ <div className={styles.itemCard} />

Also applies to: 130-130, 205-207, 209-209


Line range hint 123-123: Avoid using the index of an array as a key in React lists.

- key={index}
+ key={`ad-${index}`}

Also applies to: 176-176, 202-202, 255-255

src/components/Advertisements/core/AdvertisementRegister/AdvertisementRegister.tsx (5)

Line range hint 217-217: Self-close JSX elements that don't have children.

- <video></video>
+ <video />

Also applies to: 312-312


Line range hint 221-221: Add keyboard accessibility to interactive elements by handling key events.

+ onKeyUp={(event) => { if (event.key === 'Enter') handleShow(); }}

Line range hint 267-267: Use optional chaining to safely access nested properties.

- if (error instanceof Error) {
+ if (error?.message) {

Line range hint 292-293: Provide alt text for images to improve accessibility.

- <img src={formState.advertisementMedia} />
+ <img src={formState.advertisementMedia} alt="Advertisement Media" />

Line range hint 295-311: Specify the type attribute for buttons to ensure correct behavior in forms.

+ type="button"
Review Details

Configuration used: .coderabbit.yaml
Review profile: CHILL

Commits Files that changed from the base of the PR and between 7993f66 and 6173faf.
Files selected for processing (15)
  • public/locales/en.json (2 hunks)
  • src/components/ActionItems/ActionItemsModal.tsx (2 hunks)
  • src/components/AddOn/core/AddOnEntry/AddOnEntry.module.css (1 hunks)
  • src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx (5 hunks)
  • src/components/AddOn/core/AddOnStore/AddOnStore.module.css (2 hunks)
  • src/components/AddOn/core/AddOnStore/AddOnStore.tsx (6 hunks)
  • src/components/AddOn/support/services/Plugin.helper.test.ts (1 hunks)
  • src/components/AddOn/support/services/Plugin.helper.ts (1 hunks)
  • src/components/Advertisements/Advertisements.module.css (2 hunks)
  • src/components/Advertisements/Advertisements.tsx (7 hunks)
  • src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.module.css (1 hunks)
  • src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.tsx (6 hunks)
  • src/components/Advertisements/core/AdvertisementRegister/AdvertisementRegister.module.css (1 hunks)
  • src/components/Advertisements/core/AdvertisementRegister/AdvertisementRegister.tsx (2 hunks)
  • src/components/EventCalendar/EventCalendar.module.css (1 hunks)
Files not reviewed due to errors (3)
  • src/components/AddOn/core/AddOnStore/AddOnStore.module.css (no review received)
  • src/components/AddOn/support/services/Plugin.helper.test.ts (no review received)
  • src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx (no review received)
Files skipped from review due to trivial changes (5)
  • public/locales/en.json
  • src/components/ActionItems/ActionItemsModal.tsx
  • src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.module.css
  • src/components/Advertisements/core/AdvertisementRegister/AdvertisementRegister.module.css
  • src/components/EventCalendar/EventCalendar.module.css
Additional Context Used
Biome (42)
src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx (1)

102-104: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.

src/components/AddOn/core/AddOnStore/AddOnStore.tsx (12)

75-75: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


108-108: Do not use template literals if interpolation and special-character handling are not needed.


144-144: Use === instead of ==.
== is only allowed when comparing against null


146-152: This else clause can be omitted because previous branches break early.


159-159: Use === instead of ==.
== is only allowed when comparing against null


161-167: This else clause can be omitted because previous branches break early.


202-208: This else clause can be omitted because previous branches break early.


218-218: Use === instead of ==.
== is only allowed when comparing against null


220-226: This else clause can be omitted because previous branches break early.


1-1: The default import is only used as a type.


174-174: Avoid using the index of an array as key property in an element.


233-233: Avoid using the index of an array as key property in an element.

src/components/AddOn/support/services/Plugin.helper.ts (1)

22-22: Do not use template literals if interpolation and special-character handling are not needed.

src/components/Advertisements/Advertisements.tsx (16)

38-38: Unexpected any. Specify a different type.


53-53: Change to an optional chain.


67-67: Change to an optional chain.


99-99: Do not use template literals if interpolation and special-character handling are not needed.


126-128: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


130-130: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


130-130: Provide screen reader accessible content when using heading elements.


205-207: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


209-209: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


209-209: Provide screen reader accessible content when using heading elements.


1-1: The default import is only used as a type.


52-52: This hook does not specify all of its dependencies: advertisements


123-123: Avoid using the index of an array as key property in an element.


176-176: Avoid using the index of an array as key property in an element.


202-202: Avoid using the index of an array as key property in an element.


255-255: Avoid using the index of an array as key property in an element.

src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.tsx (5)

99-99: Enforce to have the onClick mouse event with the onKeyUp, the onKeyDown, or the onKeyPress keyboard event.


147-147: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


158-158: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


74-74: Avoid using the index of an array as key property in an element.


77-81: Provide an explicit type prop for the button element.

src/components/Advertisements/core/AdvertisementRegister/AdvertisementRegister.tsx (7)

217-217: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


221-221: Enforce to have the onClick mouse event with the onKeyUp, the onKeyDown, or the onKeyPress keyboard event.


267-267: Change to an optional chain.


292-293: Provide a text alternative through the alt, aria-label or aria-labelledby attribute


312-312: JSX elements without children should be marked as self-closing. In JSX, it is valid for any element to be self-closing.


1-1: The default import is only used as a type.


295-311: Provide an explicit type prop for the button element.

Additional comments not posted (9)
src/components/AddOn/core/AddOnEntry/AddOnEntry.module.css (2)

10-11: Updated background and text color for .entryaction class enhances visual consistency and appeal.


14-14: Green border addition to .card class aligns with the redesign objectives to make UI elements more visually appealing.

src/components/Advertisements/Advertisements.module.css (3)

4-10: Updated .listBox to use grid layout enhances alignment and spacing, improving the visual structure of the component.


21-25: Updated .input class with specific width and position settings enhances control over the layout and appearance.


26-30: Updated .justifysp to use grid layout enhances alignment and spacing, improving the visual structure of the component.

src/components/AddOn/support/services/Plugin.helper.ts (3)

1-12: Introduction of InterfacePluginHelper enhances type safety and clarity in handling plugin data.


26-31: Refinement of generateLinks to use InterfacePluginHelper enhances data handling and consistency.


15-18: Ensure type consistency by updating the return type of fetchStore to Promise<InterfacePluginHelper[]>.

- const result = await fetch(`http://localhost:${port}/store`);
+ const result = await fetch('http://localhost:4321/store');

Avoid using template literals when not necessary for interpolation.

Likely invalid or redundant comment.

src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.tsx (1)

21-21: Ensure the setAfter function is properly documented and tested, especially since it's part of the component's interface.

@palisadoes
Copy link
Contributor

Please make the suggested code rabbit updates to the code

@palisadoes
Copy link
Contributor

Please fix the conflicting files and address the coderabbit suggestions

@duplixx
Copy link
Member Author

duplixx commented Jun 5, 2024

sorry for late response i'll make the suggested changes

Copy link

This pull request did not get any activity in the past 10 days and will be closed in 180 days if no update occurs. Please verify it has no conflicts with the develop branch and rebase if needed. Mention it now if you need help or give permission to other people to finish your work.

@github-actions github-actions bot added the no-pr-activity No pull request activity label Jun 16, 2024
@palisadoes
Copy link
Contributor

Please fix the conflicting files.

@github-actions github-actions bot removed the no-pr-activity No pull request activity label Jun 18, 2024
Copy link

This pull request did not get any activity in the past 10 days and will be closed in 180 days if no update occurs. Please verify it has no conflicts with the develop branch and rebase if needed. Mention it now if you need help or give permission to other people to finish your work.

@github-actions github-actions bot added the no-pr-activity No pull request activity label Jun 29, 2024
@palisadoes
Copy link
Contributor

Closing. Inactivity and many conflicting files

@palisadoes palisadoes closed this Jul 4, 2024
@duplixx duplixx reopened this Nov 13, 2024
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: 8

🧹 Outside diff range and nitpick comments (7)
src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx (3)

62-62: Remove commented console.log statement

Debug statements should be removed before committing to production code.

- // console.log(currentOrg);

105-108: Move inline styles to CSS module

Consider moving the Card's inline styles to the existing AddOnEntry.module.css file for better maintainability and consistency.

- <Card
-   data-testid="AddOnEntry"
-   style={{ border: '1px solid #31BB6B', borderRadius: '10px' }}
- >
+ <Card
+   data-testid="AddOnEntry"
+   className={styles.addOnCard}
+ >

Add to AddOnEntry.module.css:

.addOnCard {
  border: 1px solid #31BB6B;
  border-radius: 10px;
}

121-121: Move title font weight to CSS module

Consider moving the Card.Title's inline style to the CSS module for consistency.

- <Card.Title style={{ fontWeight: '800' }}>{title}</Card.Title>
+ <Card.Title className={styles.cardTitle}>{title}</Card.Title>

Add to AddOnEntry.module.css:

.cardTitle {
  font-weight: 800;
}
src/components/Advertisements/Advertisements.tsx (2)

103-103: Use translation for placeholder text

The placeholder text should use the translation system for consistency with the rest of the application.

-placeholder={'Search..'}
+placeholder={t('searchPlaceholder')}

Line range hint 126-275: Reduce code duplication

The InfiniteScroll implementation and date filtering logic is duplicated between the active and archived tabs. Consider:

  1. Creating a reusable component for the InfiniteScroll implementation
  2. Extracting the date comparison logic into a utility function

Example refactor for the date logic:

const isAdvertisementActive = (ad: Ad): boolean => new Date(ad.endDate) > new Date();
const isAdvertisementArchived = (ad: Ad): boolean => !isAdvertisementActive(ad);

// Usage in JSX:
advertisements.filter(isAdvertisementActive).map(...)
advertisements.filter(isAdvertisementArchived).map(...)
src/components/AddOn/core/AddOnStore/AddOnStore.tsx (2)

45-45: Remove unused state variable for cleaner code.

The state variable dataList is not used anywhere in the code. Removing it can simplify the component and reduce unnecessary state management.

Apply this diff to remove the unused state variable:

- const [, setDataList] = useState<InterfacePluginHelper[]>([]);
+ // Removed unused state variable

232-232: Use strict equality checks (===) for accurate comparisons.

Replace == with === when comparing searchText to ensure strict type comparison and avoid unexpected behavior.

Apply this diff:

- if (searchText == '') {
+ if (searchText === '') {

Also applies to lines: 176, 233

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 6173faf and 323a0c7.

📒 Files selected for processing (6)
  • public/locales/en/translation.json (2 hunks)
  • src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx (5 hunks)
  • src/components/AddOn/core/AddOnStore/AddOnStore.tsx (9 hunks)
  • src/components/Advertisements/Advertisements.tsx (5 hunks)
  • src/components/Advertisements/core/AdvertisementEntry/AdvertisementEntry.tsx (3 hunks)
  • src/components/Advertisements/core/AdvertisementRegister/AdvertisementRegister.module.css (1 hunks)
✅ Files skipped from review due to trivial changes (1)
  • public/locales/en/translation.json
🔇 Additional comments (4)
src/components/AddOn/core/AddOnEntry/AddOnEntry.tsx (2)

22-22: LGTM: Improved type safety

The change from any to void return type for getInstalledPlugins is a good improvement in type safety.


Line range hint 1-153: Add test coverage for the UI changes

The PR objectives mention that no tests were added for these changes. Consider adding tests for:

  • Visual regression tests for the new styling
  • Unit tests for the installation/uninstallation logic
  • Integration tests for the plugin management workflow

Would you like help creating the test cases?

src/components/Advertisements/Advertisements.tsx (2)

237-237: Verify translation key exists

The 'endOfResults' translation key has been moved from the common namespace to the advertisement namespace. Please ensure this key exists in the advertisement translations.

✅ Verification successful

Translation key exists in both namespaces

The 'endOfResults' translation key exists in both the common namespace (common.json) and the default namespace (translation.json) for all supported languages (en, fr, hi, sp, zh). The change from tCommon('endOfResults') to t('endOfResults') is safe as the key is present in both locations.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if the translation key exists in the advertisement namespace
fd -e json . public/locales | xargs rg '"endOfResults"'

Length of output: 1823


122-126: ⚠️ Potential issue

Fix spelling in tab key

The tab key 'archievedAds' contains a spelling error.

-eventKey="archievedAds"
+eventKey="archivedAds"

Likely invalid or redundant comment.

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: 0

🧹 Outside diff range and nitpick comments (6)
src/components/AddOn/core/AddOnStore/AddOnStore.test.tsx (2)

323-334: LGTM! Consider enhancing test coverage.

The updated test assertions correctly reflect the new dropdown-based filter UI. However, consider adding these test scenarios for more comprehensive coverage:

  • Verify that selecting different filter options updates the displayed plugins
  • Test edge cases like rapid toggling of the dropdown
  • Ensure proper keyboard navigation support

Add these test cases:

// Test filter functionality
test('filters plugins correctly when dropdown option is selected', async () => {
  // ... setup code ...
  
  const dropdownButton = screen.getByRole('button', { name: /enabled/i });
  userEvent.click(dropdownButton);
  
  // Select "Disabled" option
  userEvent.click(screen.getByText(/disabled/i));
  
  // Verify only disabled plugins are shown
  expect(screen.queryByText('EnabledPlugin')).not.toBeInTheDocument();
  expect(screen.getByText('DisabledPlugin')).toBeInTheDocument();
});

// Test keyboard navigation
test('supports keyboard navigation in dropdown', async () => {
  // ... setup code ...
  
  const dropdownButton = screen.getByRole('button', { name: /enabled/i });
  
  // Open dropdown with Enter key
  dropdownButton.focus();
  fireEvent.keyDown(dropdownButton, { key: 'Enter' });
  
  // Verify dropdown options are focusable
  expect(screen.getByText(/disabled/i)).toHaveFocus();
});

Line range hint 1-424: Consider enhancing overall test structure and coverage.

While the test file is well-organized, consider these improvements for better maintainability and coverage:

  1. Extract mock data to a separate file to improve readability
  2. Add more varied test cases for error scenarios
  3. Enhance the loading test to verify loading states for both tabs

Here's a suggested approach for the loading test:

test('displays loading states correctly', async () => {
  const mocks = [ORGANIZATIONS_LIST_MOCK, PLUGIN_LOADING_MOCK];
  render(
    // ... setup code ...
  );

  // Verify initial loading state
  expect(screen.getByTestId('AddOnEntryStore')).toBeInTheDocument();
  expect(screen.getByRole('progressbar')).toBeInTheDocument();

  // Switch to Installed tab
  userEvent.click(screen.getByText('Installed'));
  expect(screen.getByRole('progressbar')).toBeInTheDocument();

  // Wait for loading to complete
  await wait();
  expect(screen.queryByRole('progressbar')).not.toBeInTheDocument();
});

Consider moving mock data to a separate file:

// __mocks__/addOnStore.mocks.ts
export const PLUGIN_GET_MOCK = {
  // ... existing mock data ...
};

export const ORGANIZATIONS_LIST_MOCK = {
  // ... existing mock data ...
};
src/components/Advertisements/Advertisements.test.tsx (4)

464-464: Consider making date validation tests more robust.

The change from date[1] to date[0] suggests a dependency on array order. Consider making the test more resilient by:

  1. Adding explicit assertions about the expected number of date elements
  2. Using a more specific test ID or data attribute to target the exact date element
-    const dateString = date[0].innerHTML;
+    expect(date).toHaveLength(2); // Verify expected number of dates
+    const dateString = date.find(el => el.getAttribute('data-type') === 'end-date')?.innerHTML;
+    expect(dateString).toBeDefined(); // Ensure we found the correct date element

Line range hint 676-677: Remove console.log statements from test code.

Debug logging statements should not be committed to test files as they add noise to test output.

-    console.log('before scroll', moreiconbtn);
-    fireEvent.scroll(window, { target: { scrollY: 500 } });
+    fireEvent.scroll(window, { target: { scrollY: 500 } });

Line range hint 679-679: Remove console.log statement.

Debug logging statement should be removed.

-    console.log('after scroll', moreiconbtn);

Line range hint 462-482: Consider using a mock date to make tests deterministic.

The test relies on comparing dates with the current time, which can make tests non-deterministic. Consider using a mocked date for consistent test results.

+    // Mock current date to ensure consistent test results
+    const mockCurrentDate = new Date('2024-01-01');
+    jest.spyOn(global, 'Date').mockImplementation(() => mockCurrentDate);

     const date = await screen.findAllByTestId('Ad_end_date');
     const dateString = date[0].innerHTML;
     const dateMatch = dateString.match(
       /\b(?:Sun|Mon|Tue|Wed|Thu|Fri|Sat)\s+(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\s+(\d{1,2})\s+(\d{4})\b/,
     );
     let dateObject = new Date();

     if (dateMatch) {
       const monthName = dateMatch[1];
       const day = parseInt(dateMatch[2], 10);
       const year = parseInt(dateMatch[3], 10);

       const monthIndex =
         'JanFebMarAprMayJunJulAugSepOctNovDec'.indexOf(monthName) / 3;

       dateObject = new Date(year, monthIndex, day);
     }

-    expect(dateObject.getTime()).toBeLessThan(new Date().getTime());
+    expect(dateObject.getTime()).toBeLessThan(mockCurrentDate.getTime());
+
+    // Restore Date after test
+    jest.restoreAllMocks();
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 323a0c7 and 9bc0676.

📒 Files selected for processing (2)
  • src/components/AddOn/core/AddOnStore/AddOnStore.test.tsx (1 hunks)
  • src/components/Advertisements/Advertisements.test.tsx (1 hunks)

@github-actions github-actions bot removed the no-pr-activity No pull request activity label Nov 14, 2024
Copy link

codecov bot commented Nov 14, 2024

Codecov Report

Attention: Patch coverage is 78.37838% with 8 lines in your changes missing coverage. Please review.

Project coverage is 83.75%. Comparing base (c2630ae) to head (a35b2ab).
Report is 1 commits behind head on develop-postgres.

Files with missing lines Patch % Lines
...rc/components/AddOn/core/AddOnStore/AddOnStore.tsx 76.47% 8 Missing ⚠️
Additional details and impacted files
@@                  Coverage Diff                  @@
##           develop-postgres    #2006       +/-   ##
=====================================================
- Coverage             95.82%   83.75%   -12.07%     
=====================================================
  Files                   295      312       +17     
  Lines                  7037     8118     +1081     
  Branches               1520     1773      +253     
=====================================================
+ Hits                   6743     6799       +56     
- Misses                   98     1180     +1082     
+ Partials                196      139       -57     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

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 (2)
src/components/AddOn/core/AddOnStore/AddOnStore.tsx (2)

102-113: Enhance robustness of plugin filtering.

The current implementation has potential issues with null safety and case handling.

Consider this improved implementation:

 const filterPlugins = (
   plugins: InterfacePluginHelper[],
   searchTerm: string,
 ): InterfacePluginHelper[] => {
-  if (!searchTerm) {
+  if (!searchTerm.trim()) {
     return plugins;
   }
 
+  const normalizedSearch = searchTerm.toLowerCase().trim();
   return plugins.filter((plugin) =>
-    plugin.pluginName?.toLowerCase().includes(searchTerm.toLowerCase()),
+    plugin.pluginName.toLowerCase().includes(normalizedSearch),
   );
 };

126-141: Move inline styles to CSS modules.

Inline styles make the code harder to maintain and don't support media queries or pseudo-classes. Consider moving these styles to your CSS module.

Move the styles to AddOnStore.module.css:

.container {
  background-color: white;
  margin: 2px;
  padding: 10px;
  border-radius: 20px;
}

.headerCol {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

Then update the JSX:

- <Row
-   className=""
-   style={{
-     backgroundColor: 'white',
-     margin: '2px',
-     padding: '10px',
-     borderRadius: '20px',
-   }}
- >
+ <Row className={styles.container}>
-   <Col
-     style={{
-       display: 'flex',
-       alignItems: 'center',
-       justifyContent: 'space-between',
-     }}
-   >
+   <Col className={styles.headerCol}>
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 9bc0676 and 9e12260.

📒 Files selected for processing (3)
  • src/components/AddOn/core/AddOnStore/AddOnStore.test.tsx (2 hunks)
  • src/components/AddOn/core/AddOnStore/AddOnStore.tsx (7 hunks)
  • src/components/Advertisements/Advertisements.tsx (4 hunks)
🚧 Files skipped from review as they are similar to previous changes (2)
  • src/components/AddOn/core/AddOnStore/AddOnStore.test.tsx
  • src/components/Advertisements/Advertisements.tsx

src/components/AddOn/core/AddOnStore/AddOnStore.tsx Outdated Show resolved Hide resolved
coderabbitai[bot]
coderabbitai bot previously approved these changes Nov 14, 2024
dependabot bot added 4 commits November 14, 2024 10:53
Bumps [sass](https://github.com/sass/dart-sass) from 1.80.6 to 1.80.7.
- [Release notes](https://github.com/sass/dart-sass/releases)
- [Changelog](https://github.com/sass/dart-sass/blob/main/CHANGELOG.md)
- [Commits](sass/dart-sass@1.80.6...1.80.7)

---
updated-dependencies:
- dependency-name: sass
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
…oesFoundation#2434)

Bumps [eslint-plugin-import](https://github.com/import-js/eslint-plugin-import) from 2.30.0 to 2.31.0.
- [Release notes](https://github.com/import-js/eslint-plugin-import/releases)
- [Changelog](https://github.com/import-js/eslint-plugin-import/blob/main/CHANGELOG.md)
- [Commits](import-js/eslint-plugin-import@v2.30.0...v2.31.0)

---
updated-dependencies:
- dependency-name: eslint-plugin-import
  dependency-type: direct:development
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
…dation#2435)

Bumps [@mui/x-charts](https://github.com/mui/mui-x/tree/HEAD/packages/x-charts) from 7.22.1 to 7.22.2.
- [Release notes](https://github.com/mui/mui-x/releases)
- [Changelog](https://github.com/mui/mui-x/blob/v7.22.2/CHANGELOG.md)
- [Commits](https://github.com/mui/mui-x/commits/v7.22.2/packages/x-charts)

---
updated-dependencies:
- dependency-name: "@mui/x-charts"
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
…dation#2436)

Bumps [@types/react](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/HEAD/types/react) from 18.3.3 to 18.3.12.
- [Release notes](https://github.com/DefinitelyTyped/DefinitelyTyped/releases)
- [Commits](https://github.com/DefinitelyTyped/DefinitelyTyped/commits/HEAD/types/react)

---
updated-dependencies:
- dependency-name: "@types/react"
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
@palisadoes palisadoes merged commit 90ae8b8 into PalisadoesFoundation:develop-postgres Dec 7, 2024
11 of 14 checks passed
devender18 pushed a commit to devender18/talawa-admin that referenced this pull request Dec 7, 2024
* advertisement and plugin screen

* added revamped design

* fixes added

* fixed testcases

* chore(deps): bump sass from 1.80.6 to 1.80.7 (PalisadoesFoundation#2433)

Bumps [sass](https://github.com/sass/dart-sass) from 1.80.6 to 1.80.7.
- [Release notes](https://github.com/sass/dart-sass/releases)
- [Changelog](https://github.com/sass/dart-sass/blob/main/CHANGELOG.md)
- [Commits](sass/dart-sass@1.80.6...1.80.7)

---
updated-dependencies:
- dependency-name: sass
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* chore(deps): bump eslint-plugin-import from 2.30.0 to 2.31.0 (PalisadoesFoundation#2434)

Bumps [eslint-plugin-import](https://github.com/import-js/eslint-plugin-import) from 2.30.0 to 2.31.0.
- [Release notes](https://github.com/import-js/eslint-plugin-import/releases)
- [Changelog](https://github.com/import-js/eslint-plugin-import/blob/main/CHANGELOG.md)
- [Commits](import-js/eslint-plugin-import@v2.30.0...v2.31.0)

---
updated-dependencies:
- dependency-name: eslint-plugin-import
  dependency-type: direct:development
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* chore(deps): bump @mui/x-charts from 7.22.1 to 7.22.2 (PalisadoesFoundation#2435)

Bumps [@mui/x-charts](https://github.com/mui/mui-x/tree/HEAD/packages/x-charts) from 7.22.1 to 7.22.2.
- [Release notes](https://github.com/mui/mui-x/releases)
- [Changelog](https://github.com/mui/mui-x/blob/v7.22.2/CHANGELOG.md)
- [Commits](https://github.com/mui/mui-x/commits/v7.22.2/packages/x-charts)

---
updated-dependencies:
- dependency-name: "@mui/x-charts"
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* chore(deps): bump @types/react from 18.3.3 to 18.3.12 (PalisadoesFoundation#2436)

Bumps [@types/react](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/HEAD/types/react) from 18.3.3 to 18.3.12.
- [Release notes](https://github.com/DefinitelyTyped/DefinitelyTyped/releases)
- [Commits](https://github.com/DefinitelyTyped/DefinitelyTyped/commits/HEAD/types/react)

---
updated-dependencies:
- dependency-name: "@types/react"
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Update pull-request.yml

* Update dependabot.yaml

* added docker check to workflow (PalisadoesFoundation#2414)

* added docker check to workflow

* made recommended changes to docker check in workflow

* added changes to docker check inn workflow as recommended

* added changes

* updated indentation in pull-request.yml file

* updated indentation in pull-request.yml file

* added Dockerfile and Docker-compose.yml file

* added Dockerfile and Docker-compose.yml file

* updated .docker-ignore file

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* properly formatted code

* trying to make docker check pass

* trying to make docker check pass

* updated INSTALLATION.md

* updated INSTALLATION.md

* added recommended changes to INSTALLATION.md

* added recommended changes to INSTALLATION.md

* added recommended changes to INSTALLATION.md

* updated docker workflow

* updated INSTALLATION.md

* eslint-rule-no_unused_vars (PalisadoesFoundation#2428)

* Updated pr template with checklist (PalisadoesFoundation#2454)

* Updated pr template with checklist

* Additional changes for the PR template

* Changed the url for the PR template

* refactored addOnStore

* refactored addOnEntry v1

---------

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Peter Harrison <[email protected]>
Co-authored-by: Vanshika Sabharwal <[email protected]>
Co-authored-by: prayansh_chhablani <[email protected]>
Co-authored-by: Dhiraj Udhani <[email protected]>
palisadoes added a commit that referenced this pull request Dec 13, 2024
* refactored OrganizationDashboard css/ closes #2513

* refactor:OrganizationDashboard_css(fixes #2513)

* Plugin and  advertisement screen revamp (#2006)

* advertisement and plugin screen

* added revamped design

* fixes added

* fixed testcases

* chore(deps): bump sass from 1.80.6 to 1.80.7 (#2433)

Bumps [sass](https://github.com/sass/dart-sass) from 1.80.6 to 1.80.7.
- [Release notes](https://github.com/sass/dart-sass/releases)
- [Changelog](https://github.com/sass/dart-sass/blob/main/CHANGELOG.md)
- [Commits](sass/dart-sass@1.80.6...1.80.7)

---
updated-dependencies:
- dependency-name: sass
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* chore(deps): bump eslint-plugin-import from 2.30.0 to 2.31.0 (#2434)

Bumps [eslint-plugin-import](https://github.com/import-js/eslint-plugin-import) from 2.30.0 to 2.31.0.
- [Release notes](https://github.com/import-js/eslint-plugin-import/releases)
- [Changelog](https://github.com/import-js/eslint-plugin-import/blob/main/CHANGELOG.md)
- [Commits](import-js/eslint-plugin-import@v2.30.0...v2.31.0)

---
updated-dependencies:
- dependency-name: eslint-plugin-import
  dependency-type: direct:development
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* chore(deps): bump @mui/x-charts from 7.22.1 to 7.22.2 (#2435)

Bumps [@mui/x-charts](https://github.com/mui/mui-x/tree/HEAD/packages/x-charts) from 7.22.1 to 7.22.2.
- [Release notes](https://github.com/mui/mui-x/releases)
- [Changelog](https://github.com/mui/mui-x/blob/v7.22.2/CHANGELOG.md)
- [Commits](https://github.com/mui/mui-x/commits/v7.22.2/packages/x-charts)

---
updated-dependencies:
- dependency-name: "@mui/x-charts"
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* chore(deps): bump @types/react from 18.3.3 to 18.3.12 (#2436)

Bumps [@types/react](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/HEAD/types/react) from 18.3.3 to 18.3.12.
- [Release notes](https://github.com/DefinitelyTyped/DefinitelyTyped/releases)
- [Commits](https://github.com/DefinitelyTyped/DefinitelyTyped/commits/HEAD/types/react)

---
updated-dependencies:
- dependency-name: "@types/react"
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Update pull-request.yml

* Update dependabot.yaml

* added docker check to workflow (#2414)

* added docker check to workflow

* made recommended changes to docker check in workflow

* added changes to docker check inn workflow as recommended

* added changes

* updated indentation in pull-request.yml file

* updated indentation in pull-request.yml file

* added Dockerfile and Docker-compose.yml file

* added Dockerfile and Docker-compose.yml file

* updated .docker-ignore file

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* added recommended changes by code rabbit

* properly formatted code

* trying to make docker check pass

* trying to make docker check pass

* updated INSTALLATION.md

* updated INSTALLATION.md

* added recommended changes to INSTALLATION.md

* added recommended changes to INSTALLATION.md

* added recommended changes to INSTALLATION.md

* updated docker workflow

* updated INSTALLATION.md

* eslint-rule-no_unused_vars (#2428)

* Updated pr template with checklist (#2454)

* Updated pr template with checklist

* Additional changes for the PR template

* Changed the url for the PR template

* refactored addOnStore

* refactored addOnEntry v1

---------

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Peter Harrison <[email protected]>
Co-authored-by: Vanshika Sabharwal <[email protected]>
Co-authored-by: prayansh_chhablani <[email protected]>
Co-authored-by: Dhiraj Udhani <[email protected]>

* refactored: CSS files in src/screens/OrgSettings(fixes: #2523) (#2610)

* refactored: CSS files in src/screens/OrgSettings(fixes: #2523)

* refactored: CSS files in src/screens/OrgSettings(fixes: #2523)

* refactored: CSS files in src/screens/OrgSettings(fixes: #2523)

* refactored: CSS files in src/screens/OrgSettings(fixes: #2523)

* Update pull-request.yml

* refactored: CSS files in src/screens/OrganizationDashboard(fixes: #2513)

* refactored: CSS files in src/screens/OrganizationDashboard(fixes: #2513)

* improve import for global css

---------

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: Shekhar Patel <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Peter Harrison <[email protected]>
Co-authored-by: Vanshika Sabharwal <[email protected]>
Co-authored-by: prayansh_chhablani <[email protected]>
Co-authored-by: Dhiraj Udhani <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ignore-sensitive-files-pr The contributor has a legitimate reason for editiing protected files
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants