* feat(build): inline chrome-extension-toolkit fix: tsconfig docs: add chrome-extension-toolkit README.md chore: update imports fix: stores fix: chrome-extension-toolkit ForegroundMessenger fix: calendarBackgroundHandler fix: format and lint fix: path alias fix: add jsdom env and fix imports Co-authored-by: Sriram Hariharan <sghsri@gmail.com> * build: vite storybook config crx toolkit line --------- Co-authored-by: Sriram Hariharan <sghsri@gmail.com> Co-authored-by: Derek <derex1987@gmail.com>
32 lines
1.1 KiB
TypeScript
32 lines
1.1 KiB
TypeScript
import type { MessageHandler } from '@chrome-extension-toolkit';
|
|
import type GitHubStatsMessages from '@shared/messages/GitHubStatsMessages';
|
|
import { GitHubStatsService } from '@views/lib/getGitHubStats';
|
|
|
|
const gitHubStatsService = new GitHubStatsService();
|
|
|
|
/**
|
|
* Handler for GitHub stats related messages
|
|
*/
|
|
const gitHubStatsHandler: MessageHandler<GitHubStatsMessages> = {
|
|
async fetchGitHubStats({ data, sendResponse }) {
|
|
try {
|
|
const includeMergedPRs = data ?? false;
|
|
const stats = await gitHubStatsService.fetchGitHubStats({ includeMergedPRs });
|
|
sendResponse(stats);
|
|
} catch (error) {
|
|
console.error('Error fetching GitHub stats in background:', error);
|
|
sendResponse({
|
|
adminGitHubStats: {},
|
|
userGitHubStats: {},
|
|
contributors: [],
|
|
names: {},
|
|
dataFetched: new Date(),
|
|
lastUpdated: new Date(),
|
|
isCached: false,
|
|
});
|
|
}
|
|
},
|
|
};
|
|
|
|
export default gitHubStatsHandler;
|