1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { visitView } from '#tests/support/components/visitView.ts'
- import { mockUserCurrent } from '#tests/support/mock-userCurrent.ts'
- import { EnumAppearanceTheme } from '#shared/graphql/types.ts'
- import { waitForUserCurrentAppearanceMutationCalls } from '#desktop/pages/personal-setting/graphql/mutations/userCurrentAppearance.mocks.ts'
- describe('appearance page', () => {
- it('should have dark theme set', async () => {
- mockUserCurrent({
- preferences: {
- theme: EnumAppearanceTheme.Dark,
- },
- })
- const view = await visitView('/personal-setting/appearance')
- expect(view.getByRole('radio', { checked: true })).toHaveTextContent('dark')
- })
- it('should have light theme set', async () => {
- mockUserCurrent({
- preferences: {
- theme: EnumAppearanceTheme.Light,
- },
- })
- const view = await visitView('/personal-setting/appearance')
- expect(view.getByRole('radio', { checked: true })).toHaveTextContent(
- 'light',
- )
- })
- it('update appearance to dark', async () => {
- mockUserCurrent({
- preferences: {
- theme: EnumAppearanceTheme.Light,
- },
- })
- const view = await visitView('/personal-setting/appearance')
- expect(view.getByLabelText('Light')).toBeChecked()
- const darkMode = view.getByText('Dark')
- const lightMode = view.getByText('Light')
- const syncWithComputer = view.getByText('Sync with computer')
- await view.events.click(darkMode)
- expect(view.getByLabelText('Dark')).toBeChecked()
- const calls = await waitForUserCurrentAppearanceMutationCalls()
- expect(calls.at(-1)?.variables).toEqual({ theme: 'dark' })
- expect(window.matchMedia('(prefers-color-scheme: light)').matches).toBe(
- false,
- )
- await view.events.click(lightMode)
- await vi.waitUntil(() => calls.length === 2)
- expect(calls.at(-1)?.variables).toEqual({ theme: 'light' })
- expect(window.matchMedia('(prefers-color-scheme: dark)').matches).toBe(
- false,
- )
- await view.events.click(syncWithComputer)
- expect(view.getByLabelText('Sync with computer')).toBeChecked()
- })
- })
|