Files
overleaf-cep/services/web/test/frontend/shared/hooks/use-active-overall-theme.spec.tsx
T
Mathias Jakobsen b554b0cfcc Merge pull request #28497 from overleaf/mj-system-editor-theme-dark-light-split
[web] Split editor theme into two when using system overall theme

GitOrigin-RevId: 1efa5553fdff8a17de634017882feb2ede614cd6
2025-12-12 09:05:10 +00:00

82 lines
2.5 KiB
TypeScript

import { EditorProviders } from '../../helpers/editor-providers'
import { SplitTestProvider } from '@/shared/context/split-test-context'
import { useActiveOverallTheme } from '@/shared/hooks/use-active-overall-theme'
const MOCK_IEEE_BRAND_ID = 123
const TestComponent = ({ overallTheme }: { overallTheme: string }) => {
return (
<SplitTestProvider>
<EditorProviders
userSettings={{
overallTheme,
}}
>
<TestComponentInner />
</EditorProviders>
</SplitTestProvider>
)
}
const TestComponentInner = () => {
const overallTheme = useActiveOverallTheme()
return <div data-testid="overall-theme">{overallTheme}</div>
}
describe('useActiveOverallTheme', function () {
beforeEach(function () {
cy.window().then(win => {
win.metaAttributesCache.set('ol-brandVariation', { brand_id: undefined })
win.metaAttributesCache.get('ol-ExposedSettings').ieeeBrandId =
MOCK_IEEE_BRAND_ID
})
})
it('Is dark in default mode', function () {
cy.mount(<TestComponent overallTheme="" />)
cy.findByTestId('overall-theme').should('have.text', 'dark')
})
it('Is light when in light mode', function () {
cy.mount(<TestComponent overallTheme="light-" />)
cy.findByTestId('overall-theme').should('have.text', 'light')
})
describe('when overall theme is system', function () {
function stubMediaQuery(prefersDark: boolean) {
cy.window().then(win => {
cy.stub(win, 'matchMedia')
.withArgs('(prefers-color-scheme: dark)')
.returns({
matches: prefersDark,
addEventListener: () => {},
removeEventListener: () => {},
} as any)
})
}
it('is dark when browser prefers dark', function () {
stubMediaQuery(true)
cy.mount(<TestComponent overallTheme="system" />)
cy.findByTestId('overall-theme').should('have.text', 'dark')
})
it('is light when browser prefers light', function () {
stubMediaQuery(false)
cy.mount(<TestComponent overallTheme="system" />)
cy.findByTestId('overall-theme').should('have.text', 'light')
})
it('uses dark when in IEEE document', function () {
stubMediaQuery(false)
cy.window().then(win => {
win.metaAttributesCache.set('ol-brandVariation', {
brand_id: MOCK_IEEE_BRAND_ID,
})
})
cy.mount(<TestComponent overallTheme="system" />)
cy.findByTestId('overall-theme').should('have.text', 'dark')
})
})
})