@@ -366,20 +397,15 @@ function organizationActionItems(): JSX.Element {
required
className={styles.inputField}
value={searchValue}
- onChange={(e) => setSearchValue(e.target.value)}
- onKeyUp={(e) => {
- if (e.key === 'Enter') {
- setSearchTerm(searchValue);
- } else if (e.key === 'Backspace' && searchValue === '') {
- setSearchTerm('');
- }
+ onChange={(e) => {
+ setSearchValue(e.target.value);
+ debouncedSearch(e.target.value);
}}
data-testid="searchBy"
/>
);
diff --git a/src/screens/OrganizationActionItems/testObject.mocks.ts b/src/screens/OrganizationActionItems/testObject.mocks.ts
new file mode 100644
index 0000000000..d43f574e8c
--- /dev/null
+++ b/src/screens/OrganizationActionItems/testObject.mocks.ts
@@ -0,0 +1,402 @@
+import {
+ EVENT_VOLUNTEER_GROUP_LIST,
+ EVENT_VOLUNTEER_LIST,
+} from 'GraphQl/Queries/EventVolunteerQueries';
+import {
+ ACTION_ITEM_CATEGORY_LIST,
+ MEMBERS_LIST,
+} from 'GraphQl/Queries/Queries';
+import type { InterfaceActionItemInfo } from 'utils/interfaces';
+
+export const actionItemCategory1 = {
+ _id: 'actionItemCategoryId1',
+ name: 'Category 1',
+};
+
+export const actionItemCategory2 = {
+ _id: 'actionItemCategoryId2',
+ name: 'Category 2',
+};
+
+export const baseActionItem = {
+ assigner: {
+ _id: 'userId',
+ firstName: 'Wilt',
+ lastName: 'Shepherd',
+ image: null,
+ },
+ creator: {
+ _id: 'userId',
+ firstName: 'Wilt',
+ lastName: 'Shepherd',
+ image: null,
+ __typename: 'User',
+ },
+};
+
+export const itemWithVolunteer: InterfaceActionItemInfo = {
+ _id: 'actionItemId1',
+ assigneeType: 'EventVolunteer',
+ assignee: {
+ _id: 'volunteerId1',
+ hasAccepted: true,
+ hoursVolunteered: 12,
+ assignments: [],
+ groups: [],
+ user: {
+ _id: 'userId1',
+ firstName: 'John',
+ lastName: 'Doe',
+ image: null,
+ },
+ },
+ assigneeUser: null,
+ assigneeGroup: null,
+ preCompletionNotes: 'Notes 1',
+ postCompletionNotes: 'Cmp Notes 1',
+ assignmentDate: new Date('2024-08-27'),
+ dueDate: new Date('2044-08-30'),
+ completionDate: new Date('2044-09-03'),
+ isCompleted: true,
+ event: null,
+ allottedHours: 24,
+ actionItemCategory: actionItemCategory1,
+ ...baseActionItem,
+};
+
+export const itemWithVolunteerImage: InterfaceActionItemInfo = {
+ _id: 'actionItemId1b',
+ assigneeType: 'EventVolunteer',
+ assignee: {
+ _id: 'volunteerId1',
+ hasAccepted: true,
+ hoursVolunteered: 12,
+ assignments: [],
+ groups: [],
+ user: {
+ _id: 'userId1',
+ firstName: 'John',
+ lastName: 'Doe',
+ image: 'user-image',
+ },
+ },
+ assigneeUser: null,
+ assigneeGroup: null,
+ preCompletionNotes: 'Notes 1',
+ postCompletionNotes: 'Cmp Notes 1',
+ assignmentDate: new Date('2024-08-27'),
+ dueDate: new Date('2044-08-30'),
+ completionDate: new Date('2044-09-03'),
+ isCompleted: true,
+ event: null,
+ allottedHours: 24,
+ actionItemCategory: actionItemCategory1,
+ ...baseActionItem,
+};
+
+export const itemWithUser: InterfaceActionItemInfo = {
+ _id: 'actionItemId2',
+ assigneeType: 'User',
+ assigneeUser: {
+ _id: 'userId1',
+ firstName: 'Jane',
+ lastName: 'Doe',
+ image: null,
+ },
+ assignee: null,
+ assigneeGroup: null,
+ preCompletionNotes: 'Notes 2',
+ postCompletionNotes: null,
+ assignmentDate: new Date('2024-08-27'),
+ dueDate: new Date('2044-09-30'),
+ completionDate: new Date('2044-10-03'),
+ isCompleted: false,
+ event: null,
+ allottedHours: null,
+ actionItemCategory: actionItemCategory2,
+ ...baseActionItem,
+};
+
+export const itemWithUserImage: InterfaceActionItemInfo = {
+ _id: 'actionItemId2b',
+ assigneeType: 'User',
+ assigneeUser: {
+ _id: 'userId1',
+ firstName: 'Jane',
+ lastName: 'Doe',
+ image: 'user-image',
+ },
+ assignee: null,
+ assigneeGroup: null,
+ preCompletionNotes: 'Notes 2',
+ postCompletionNotes: null,
+ assignmentDate: new Date('2024-08-27'),
+ dueDate: new Date('2044-09-30'),
+ completionDate: new Date('2044-10-03'),
+ isCompleted: false,
+ event: null,
+ allottedHours: null,
+ actionItemCategory: actionItemCategory2,
+ ...baseActionItem,
+};
+
+export const itemWithGroup: InterfaceActionItemInfo = {
+ _id: 'actionItemId3',
+ assigneeType: 'EventVolunteerGroup',
+ assigneeUser: null,
+ assignee: null,
+ assigneeGroup: {
+ _id: 'volunteerGroupId1',
+ name: 'Group 1',
+ description: 'Group 1 Description',
+ volunteersRequired: 10,
+ event: {
+ _id: 'eventId1',
+ },
+ assignments: [],
+ volunteers: [],
+ createdAt: '2024-08-27',
+ creator: {
+ _id: 'userId1',
+ firstName: 'John',
+ lastName: 'Doe',
+ image: null,
+ },
+ leader: {
+ _id: 'userId1',
+ firstName: 'John',
+ lastName: 'Doe',
+ image: null,
+ },
+ },
+ preCompletionNotes: 'Notes 1',
+ postCompletionNotes: 'Cmp Notes 1',
+ assignmentDate: new Date('2024-08-27'),
+ dueDate: new Date('2044-08-30'),
+ completionDate: new Date('2044-09-03'),
+ isCompleted: true,
+ event: null,
+ allottedHours: 24,
+ actionItemCategory: actionItemCategory1,
+ ...baseActionItem,
+};
+
+export const memberListQuery = {
+ request: {
+ query: MEMBERS_LIST,
+ variables: { id: 'orgId' },
+ },
+ result: {
+ data: {
+ organizations: [
+ {
+ _id: 'orgId',
+ members: [
+ {
+ _id: 'userId1',
+ firstName: 'Harve',
+ lastName: 'Lance',
+ email: 'harve@example.com',
+ image: '',
+ organizationsBlockedBy: [],
+ createdAt: '2024-02-14',
+ },
+ {
+ _id: 'userId2',
+ firstName: 'Wilt',
+ lastName: 'Shepherd',
+ email: 'wilt@example.com',
+ image: '',
+ organizationsBlockedBy: [],
+ createdAt: '2024-02-14',
+ },
+ ],
+ },
+ ],
+ },
+ },
+};
+
+export const volunteerListQuery = [
+ {
+ request: {
+ query: EVENT_VOLUNTEER_LIST,
+ variables: { where: { eventId: 'eventId', hasAccepted: true } },
+ },
+ result: {
+ data: {
+ getEventVolunteers: [
+ {
+ _id: 'volunteerId1',
+ hasAccepted: true,
+ hoursVolunteered: 0,
+ user: {
+ _id: 'userId1',
+ firstName: 'Teresa',
+ lastName: 'Bradley',
+ image: null,
+ },
+ assignments: [],
+ groups: [
+ {
+ _id: 'groupId1',
+ name: 'group1',
+ volunteers: [
+ {
+ _id: 'volunteerId1',
+ },
+ ],
+ },
+ ],
+ },
+ {
+ _id: 'volunteerId2',
+ hasAccepted: true,
+ hoursVolunteered: 0,
+ user: {
+ _id: 'userId3',
+ firstName: 'Bruce',
+ lastName: 'Graza',
+ image: null,
+ },
+ assignments: [],
+ groups: [],
+ },
+ ],
+ },
+ },
+ },
+ {
+ request: {
+ query: EVENT_VOLUNTEER_LIST,
+ variables: { where: { hasAccepted: true } },
+ },
+ result: {
+ data: {
+ getEventVolunteers: [],
+ },
+ },
+ },
+];
+
+export const groupListQuery = [
+ {
+ request: {
+ query: EVENT_VOLUNTEER_GROUP_LIST,
+ variables: { where: { eventId: 'eventId' } },
+ },
+ result: {
+ data: {
+ getEventVolunteerGroups: [
+ {
+ _id: 'groupId1',
+ name: 'group1',
+ description: 'desc',
+ volunteersRequired: 10,
+ createdAt: '2024-10-27T15:34:15.889Z',
+ creator: {
+ _id: 'userId2',
+ firstName: 'Wilt',
+ lastName: 'Shepherd',
+ image: null,
+ },
+ leader: {
+ _id: 'userId1',
+ firstName: 'Teresa',
+ lastName: 'Bradley',
+ image: null,
+ },
+ volunteers: [
+ {
+ _id: 'volunteerId1',
+ user: {
+ _id: 'userId1',
+ firstName: 'Teresa',
+ lastName: 'Bradley',
+ image: null,
+ },
+ },
+ ],
+ assignments: [],
+ event: {
+ _id: 'eventId',
+ },
+ },
+ {
+ _id: 'groupId2',
+ name: 'group2',
+ description: 'desc',
+ volunteersRequired: 10,
+ createdAt: '2024-10-27T15:34:15.889Z',
+ creator: {
+ _id: 'userId2',
+ firstName: 'Wilt',
+ lastName: 'Shepherd',
+ image: null,
+ },
+ leader: {
+ _id: 'userId1',
+ firstName: 'Teresa',
+ lastName: 'Bradley',
+ image: null,
+ },
+ volunteers: [],
+ assignments: [],
+ event: {
+ _id: 'eventId',
+ },
+ },
+ ],
+ },
+ },
+ },
+ {
+ request: {
+ query: EVENT_VOLUNTEER_GROUP_LIST,
+ variables: { where: { eventId: undefined } },
+ },
+ result: {
+ data: {
+ getEventVolunteerGroups: [],
+ },
+ },
+ },
+];
+
+export const actionItemCategoryListQuery = {
+ request: {
+ query: ACTION_ITEM_CATEGORY_LIST,
+ variables: {
+ organizationId: 'orgId',
+ where: { is_disabled: false },
+ },
+ },
+ result: {
+ data: {
+ actionItemCategoriesByOrganization: [
+ {
+ _id: 'categoryId1',
+ name: 'Category 1',
+ isDisabled: false,
+ createdAt: '2024-08-26',
+ creator: {
+ _id: 'creatorId1',
+ firstName: 'Wilt',
+ lastName: 'Shepherd',
+ },
+ },
+ {
+ _id: 'categoryId2',
+ name: 'Category 2',
+ isDisabled: true,
+ createdAt: '2024-08-25',
+ creator: {
+ _id: 'creatorId2',
+ firstName: 'John',
+ lastName: 'Doe',
+ },
+ },
+ ],
+ },
+ },
+};
diff --git a/src/screens/OrganizationDashboard/OrganizationDashboard.module.css b/src/screens/OrganizationDashboard/OrganizationDashboard.module.css
index f9423de686..3ffe274196 100644
--- a/src/screens/OrganizationDashboard/OrganizationDashboard.module.css
+++ b/src/screens/OrganizationDashboard/OrganizationDashboard.module.css
@@ -27,3 +27,9 @@
justify-content: center;
align-items: center;
}
+
+.rankings {
+ aspect-ratio: 1;
+ border-radius: 50%;
+ width: 35px;
+}
diff --git a/src/screens/OrganizationDashboard/OrganizationDashboard.test.tsx b/src/screens/OrganizationDashboard/OrganizationDashboard.test.tsx
index cf44fb3dbc..38b9bacda6 100644
--- a/src/screens/OrganizationDashboard/OrganizationDashboard.test.tsx
+++ b/src/screens/OrganizationDashboard/OrganizationDashboard.test.tsx
@@ -1,202 +1,278 @@
+import React from 'react';
import { MockedProvider } from '@apollo/react-testing';
-import { fireEvent, render, screen } from '@testing-library/react';
-import 'jest-location-mock';
+import { LocalizationProvider } from '@mui/x-date-pickers';
+import { AdapterDayjs } from '@mui/x-date-pickers/AdapterDayjs';
+import type { RenderResult } from '@testing-library/react';
+import { render, screen, waitFor } from '@testing-library/react';
+import userEvent from '@testing-library/user-event';
import { I18nextProvider } from 'react-i18next';
import { Provider } from 'react-redux';
-import { BrowserRouter } from 'react-router-dom';
-
-import userEvent from '@testing-library/user-event';
-import { toast } from 'react-toastify';
+import { MemoryRouter, Route, Routes } from 'react-router-dom';
import { store } from 'state/store';
import { StaticMockLink } from 'utils/StaticMockLink';
-import i18nForTest from 'utils/i18nForTest';
-import useLocalStorage from 'utils/useLocalstorage';
+import i18n from 'utils/i18nForTest';
import OrganizationDashboard from './OrganizationDashboard';
-import { EMPTY_MOCKS, ERROR_MOCKS, MOCKS } from './OrganizationDashboardMocks';
-import React, { act } from 'react';
-const { setItem } = useLocalStorage();
-import type { InterfaceQueryOrganizationEventListItem } from 'utils/interfaces';
-
-async function wait(ms = 100): Promise
{
- await act(() => {
- return new Promise((resolve) => {
- setTimeout(resolve, ms);
- });
- });
-}
-const link1 = new StaticMockLink(MOCKS, true);
-const link2 = new StaticMockLink(EMPTY_MOCKS, true);
-const link3 = new StaticMockLink(ERROR_MOCKS, true);
+import type { ApolloLink } from '@apollo/client';
+import { MOCKS, EMPTY_MOCKS, ERROR_MOCKS } from './OrganizationDashboardMocks';
+import { toast } from 'react-toastify';
jest.mock('react-toastify', () => ({
toast: {
success: jest.fn(),
- warn: jest.fn(),
error: jest.fn(),
},
}));
-const mockNavgate = jest.fn();
-let mockId: string | undefined = undefined;
-jest.mock('react-router-dom', () => ({
- ...jest.requireActual('react-router-dom'),
- useNavigate: () => mockNavgate,
- useParams: () => ({ orgId: mockId }),
-}));
-beforeEach(() => {
- setItem('FirstName', 'John');
- setItem('LastName', 'Doe');
- setItem(
- 'UserImage',
- 'https://api.dicebear.com/5.x/initials/svg?seed=John%20Doe',
+const link1 = new StaticMockLink(MOCKS);
+const link2 = new StaticMockLink(ERROR_MOCKS);
+const link3 = new StaticMockLink(EMPTY_MOCKS);
+const t = {
+ ...JSON.parse(
+ JSON.stringify(i18n.getDataByLanguage('en')?.translation.dashboard ?? {}),
+ ),
+ ...JSON.parse(JSON.stringify(i18n.getDataByLanguage('en')?.common ?? {})),
+ ...JSON.parse(JSON.stringify(i18n.getDataByLanguage('en')?.errors ?? {})),
+};
+
+const renderOrganizationDashboard = (link: ApolloLink): RenderResult => {
+ return render(
+
+
+
+
+
+
+ }
+ />
+