Skip to content

Commit

Permalink
Merge 52ff048 into 20d45db
Browse files Browse the repository at this point in the history
  • Loading branch information
setchy authored May 8, 2024
2 parents 20d45db + 52ff048 commit 566bcdc
Show file tree
Hide file tree
Showing 14 changed files with 314 additions and 39 deletions.
1 change: 1 addition & 0 deletions src/__mocks__/mock-state.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,4 +18,5 @@ export const mockSettings: SettingsState = {
detailedNotifications: false,
markAsDoneOnOpen: false,
showAccountHostname: false,
delayNotificationState: false,
};
7 changes: 5 additions & 2 deletions src/components/NotificationRow.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ export const NotificationRow: FC<IProps> = ({ notification, hostname }) => {
markNotificationDone(notification.id, hostname);
} else {
// no need to mark as read, github does it by default when opening it
removeNotificationFromState(notification.id, hostname);
removeNotificationFromState(settings, notification.id, hostname);
}
}, [notifications, notification, accounts, settings]); // notifications required here to prevent weird state issues

Expand Down Expand Up @@ -84,7 +84,10 @@ export const NotificationRow: FC<IProps> = ({ notification, hostname }) => {
]);

return (
<div className="flex space-x-3 py-2 px-3 bg-white dark:bg-gray-dark dark:text-white hover:bg-gray-100 dark:hover:bg-gray-darker border-b border-gray-100 dark:border-gray-darker group">
<div
id={notification.id}
className="flex space-x-3 py-2 px-3 bg-white dark:bg-gray-dark dark:text-white hover:bg-gray-100 dark:hover:bg-gray-darker border-b border-gray-100 dark:border-gray-darker group"
>
<div
className={`flex justify-center items-center w-5 ${iconColor}`}
title={notificationTitle}
Expand Down
2 changes: 2 additions & 0 deletions src/components/__snapshots__/NotificationRow.test.tsx.snap

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

12 changes: 11 additions & 1 deletion src/context/App.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,12 @@ describe('context/App.tsx', () => {

expect(markNotificationReadMock).toHaveBeenCalledTimes(1);
expect(markNotificationReadMock).toHaveBeenCalledWith(
{ enterpriseAccounts: [], token: null, user: null },
{
enterpriseAccounts: [],
token: null,
user: null,
},
mockSettings,
'123-456',
'github.com',
);
Expand Down Expand Up @@ -160,6 +165,7 @@ describe('context/App.tsx', () => {
expect(markNotificationDoneMock).toHaveBeenCalledTimes(1);
expect(markNotificationDoneMock).toHaveBeenCalledWith(
{ enterpriseAccounts: [], token: null, user: null },
mockSettings,
'123-456',
'github.com',
);
Expand Down Expand Up @@ -188,6 +194,7 @@ describe('context/App.tsx', () => {
expect(unsubscribeNotificationMock).toHaveBeenCalledTimes(1);
expect(unsubscribeNotificationMock).toHaveBeenCalledWith(
{ enterpriseAccounts: [], token: null, user: null },
mockSettings,
'123-456',
'github.com',
);
Expand Down Expand Up @@ -221,6 +228,7 @@ describe('context/App.tsx', () => {
expect(markRepoNotificationsMock).toHaveBeenCalledTimes(1);
expect(markRepoNotificationsMock).toHaveBeenCalledWith(
{ enterpriseAccounts: [], token: null, user: null },
mockSettings,
'gitify-app/notifications-test',
'github.com',
);
Expand Down Expand Up @@ -325,6 +333,7 @@ describe('context/App.tsx', () => {
detailedNotifications: false,
markAsDoneOnOpen: false,
showAccountHostname: false,
delayNotificationState: false,
},
);
});
Expand Down Expand Up @@ -369,6 +378,7 @@ describe('context/App.tsx', () => {
detailedNotifications: false,
markAsDoneOnOpen: false,
showAccountHostname: false,
delayNotificationState: false,
},
);
});
Expand Down
17 changes: 11 additions & 6 deletions src/context/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ export const defaultSettings: SettingsState = {
detailedNotifications: false,
markAsDoneOnOpen: false,
showAccountHostname: false,
delayNotificationState: false,
};

interface AppContextState {
Expand All @@ -57,7 +58,11 @@ interface AppContextState {
notifications: AccountNotifications[];
status: Status;
errorDetails: GitifyError;
removeNotificationFromState: (id: string, hostname: string) => void;
removeNotificationFromState: (
settings: SettingsState,
id: string,
hostname: string,
) => void;
fetchNotifications: () => Promise<void>;
markNotificationRead: (id: string, hostname: string) => Promise<void>;
markNotificationDone: (id: string, hostname: string) => Promise<void>;
Expand Down Expand Up @@ -199,31 +204,31 @@ export const AppProvider = ({ children }: { children: ReactNode }) => {

const markNotificationReadWithAccounts = useCallback(
async (id: string, hostname: string) =>
await markNotificationRead(accounts, id, hostname),
await markNotificationRead(accounts, settings, id, hostname),
[accounts, notifications],
);

const markNotificationDoneWithAccounts = useCallback(
async (id: string, hostname: string) =>
await markNotificationDone(accounts, id, hostname),
await markNotificationDone(accounts, settings, id, hostname),
[accounts, notifications],
);

const unsubscribeNotificationWithAccounts = useCallback(
async (id: string, hostname: string) =>
await unsubscribeNotification(accounts, id, hostname),
await unsubscribeNotification(accounts, settings, id, hostname),
[accounts, notifications],
);

const markRepoNotificationsWithAccounts = useCallback(
async (repoSlug: string, hostname: string) =>
await markRepoNotifications(accounts, repoSlug, hostname),
await markRepoNotifications(accounts, settings, repoSlug, hostname),
[accounts, notifications],
);

const markRepoNotificationsDoneWithAccounts = useCallback(
async (repoSlug: string, hostname: string) =>
await markRepoNotificationsDone(accounts, repoSlug, hostname),
await markRepoNotificationsDone(accounts, settings, repoSlug, hostname),
[accounts, notifications],
);

Expand Down
Loading

0 comments on commit 566bcdc

Please sign in to comment.