refactor: move notification domain to lib/notification/
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -1,7 +1,7 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import * as m from '$lib/paraglide/messages.js';
|
import * as m from '$lib/paraglide/messages.js';
|
||||||
import { relativeTime } from '$lib/utils/time';
|
import { relativeTime } from '$lib/utils/time';
|
||||||
import type { NotificationItem } from '$lib/stores/notifications.svelte';
|
import type { NotificationItem } from '$lib/notification/notifications.svelte';
|
||||||
import { buildCommentHref } from '$lib/utils/commentDeepLink';
|
import { buildCommentHref } from '$lib/utils/commentDeepLink';
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import { page, userEvent } from 'vitest/browser';
|
import { page, userEvent } from 'vitest/browser';
|
||||||
|
|
||||||
import ChronikFuerDichBox from './ChronikFuerDichBox.svelte';
|
import ChronikFuerDichBox from './ChronikFuerDichBox.svelte';
|
||||||
import type { NotificationItem } from '$lib/stores/notifications.svelte';
|
import type { NotificationItem } from '$lib/notification/notifications.svelte';
|
||||||
|
|
||||||
afterEach(cleanup);
|
afterEach(cleanup);
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { onMount, onDestroy } from 'svelte';
|
|||||||
import { goto } from '$app/navigation';
|
import { goto } from '$app/navigation';
|
||||||
import { m } from '$lib/paraglide/messages.js';
|
import { m } from '$lib/paraglide/messages.js';
|
||||||
import { clickOutside } from '$lib/actions/clickOutside';
|
import { clickOutside } from '$lib/actions/clickOutside';
|
||||||
import { notificationStore } from '$lib/stores/notifications.svelte';
|
import { notificationStore } from '$lib/notification/notifications.svelte';
|
||||||
import { buildCommentHref } from '$lib/utils/commentDeepLink';
|
import { buildCommentHref } from '$lib/utils/commentDeepLink';
|
||||||
import NotificationDropdown from './NotificationDropdown.svelte';
|
import NotificationDropdown from './NotificationDropdown.svelte';
|
||||||
|
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
import { afterEach, describe, it, expect, vi } from 'vitest';
|
import { afterEach, describe, it, expect, vi } from 'vitest';
|
||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import type { NotificationItem } from '$lib/utils/notifications';
|
import type { NotificationItem } from '$lib/notification/notifications';
|
||||||
import NotificationBell from './NotificationBell.svelte';
|
import NotificationBell from './NotificationBell.svelte';
|
||||||
|
|
||||||
const gotoMock = vi.hoisted(() => vi.fn());
|
const gotoMock = vi.hoisted(() => vi.fn());
|
||||||
@@ -9,7 +9,7 @@ vi.mock('$app/navigation', () => ({ goto: gotoMock, beforeNavigate: vi.fn() }));
|
|||||||
const mockMarkRead = vi.hoisted(() => vi.fn().mockResolvedValue(undefined));
|
const mockMarkRead = vi.hoisted(() => vi.fn().mockResolvedValue(undefined));
|
||||||
const mockNotificationList = vi.hoisted((): { value: NotificationItem[] } => ({ value: [] }));
|
const mockNotificationList = vi.hoisted((): { value: NotificationItem[] } => ({ value: [] }));
|
||||||
|
|
||||||
vi.mock('$lib/stores/notifications.svelte', () => ({
|
vi.mock('$lib/notification/notifications.svelte', () => ({
|
||||||
notificationStore: {
|
notificationStore: {
|
||||||
get notifications() {
|
get notifications() {
|
||||||
return mockNotificationList.value;
|
return mockNotificationList.value;
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { m } from '$lib/paraglide/messages.js';
|
import { m } from '$lib/paraglide/messages.js';
|
||||||
import { relativeTime } from '$lib/utils/time';
|
import { relativeTime } from '$lib/utils/time';
|
||||||
import type { NotificationItem } from '$lib/stores/notifications.svelte';
|
import type { NotificationItem } from '$lib/notification/notifications.svelte';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
notifications: NotificationItem[];
|
notifications: NotificationItem[];
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
import { describe, it, expect } from 'vitest';
|
import { describe, it, expect } from 'vitest';
|
||||||
import { parseNotificationEvent } from '$lib/utils/notifications';
|
import { parseNotificationEvent } from '$lib/notification/notifications';
|
||||||
|
|
||||||
describe('parseNotificationEvent', () => {
|
describe('parseNotificationEvent', () => {
|
||||||
const valid = {
|
const valid = {
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
||||||
import type { NotificationItem } from '$lib/utils/notifications';
|
import type { NotificationItem } from '$lib/notification/notifications';
|
||||||
|
|
||||||
let lastEventSource: MockEventSource | null = null;
|
let lastEventSource: MockEventSource | null = null;
|
||||||
let eventSourceCount = 0;
|
let eventSourceCount = 0;
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
import { type NotificationItem, parseNotificationEvent } from '$lib/utils/notifications';
|
import { type NotificationItem, parseNotificationEvent } from '$lib/notification/notifications';
|
||||||
|
|
||||||
export type { NotificationItem };
|
export type { NotificationItem };
|
||||||
|
|
||||||
@@ -5,7 +5,7 @@ import { onMount, untrack } from 'svelte';
|
|||||||
import * as m from '$lib/paraglide/messages.js';
|
import * as m from '$lib/paraglide/messages.js';
|
||||||
import LanguageSwitcher from '$lib/components/LanguageSwitcher.svelte';
|
import LanguageSwitcher from '$lib/components/LanguageSwitcher.svelte';
|
||||||
import ThemeToggle from '$lib/components/ThemeToggle.svelte';
|
import ThemeToggle from '$lib/components/ThemeToggle.svelte';
|
||||||
import NotificationBell from '$lib/components/NotificationBell.svelte';
|
import NotificationBell from '$lib/notification/NotificationBell.svelte';
|
||||||
import AppNav from './AppNav.svelte';
|
import AppNav from './AppNav.svelte';
|
||||||
import UserMenu from './UserMenu.svelte';
|
import UserMenu from './UserMenu.svelte';
|
||||||
import ConfirmDialog from '$lib/components/ConfirmDialog.svelte';
|
import ConfirmDialog from '$lib/components/ConfirmDialog.svelte';
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { onMount, onDestroy } from 'svelte';
|
|||||||
import { goto } from '$app/navigation';
|
import { goto } from '$app/navigation';
|
||||||
import { page, navigating } from '$app/state';
|
import { page, navigating } from '$app/state';
|
||||||
import * as m from '$lib/paraglide/messages.js';
|
import * as m from '$lib/paraglide/messages.js';
|
||||||
import { notificationStore, type NotificationItem } from '$lib/stores/notifications.svelte';
|
import { notificationStore, type NotificationItem } from '$lib/notification/notifications.svelte';
|
||||||
import ChronikFuerDichBox from '$lib/activity/ChronikFuerDichBox.svelte';
|
import ChronikFuerDichBox from '$lib/activity/ChronikFuerDichBox.svelte';
|
||||||
import ChronikFilterPills from '$lib/activity/ChronikFilterPills.svelte';
|
import ChronikFilterPills from '$lib/activity/ChronikFilterPills.svelte';
|
||||||
import ChronikTimeline from '$lib/activity/ChronikTimeline.svelte';
|
import ChronikTimeline from '$lib/activity/ChronikTimeline.svelte';
|
||||||
|
|||||||
Reference in New Issue
Block a user