123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { flushPromises } from '@vue/test-utils'
- import { renderComponent } from '#tests/support/components/index.ts'
- import { EnumTextDirection } from '#shared/graphql/types.ts'
- import { i18n } from '#shared/i18n.ts'
- import { useLocaleStore } from '#shared/stores/locale.ts'
- import CommonBackButton from '../CommonBackButton.vue'
- // $walker.back not tested because there is a unit test for it
- describe('rendering common back button', () => {
- it('renders label', async () => {
- window.history.replaceState({ back: '/back' }, '/back')
- const view = renderComponent(CommonBackButton, {
- router: true,
- props: {
- fallback: '/back-url',
- },
- })
- expect(view.getByRole('button', { name: 'Go back' })).toBeInTheDocument()
- await view.rerender({
- label: 'Back',
- })
- expect(view.container).toHaveTextContent('Back')
- i18n.setTranslationMap(new Map([['Back', 'Zurück']]))
- await flushPromises()
- expect(view.container).toHaveTextContent('Zurück')
- expect(view.getByRole('button', { name: 'Go back' })).toBeInTheDocument()
- i18n.setTranslationMap(new Map([]))
- })
- it('renders home button, if no history is present', async () => {
- window.history.replaceState({}, '')
- const view = renderComponent(CommonBackButton, {
- router: true,
- props: {
- fallback: '/',
- },
- })
- expect(view.getByRole('button', { name: 'Go home' })).toBeInTheDocument()
- expect(view.getByIconName('home')).toBeInTheDocument()
- await view.rerender({
- label: 'Back',
- })
- expect(view.container).toHaveTextContent('Home')
- })
- it('renders home button, if history is present and previous route is home', async () => {
- window.history.replaceState({ back: '/' }, '/')
- const view = renderComponent(CommonBackButton, {
- router: true,
- props: {
- fallback: '/',
- },
- })
- expect(view.getByRole('button', { name: 'Go home' })).toBeInTheDocument()
- expect(view.getByIconName('home')).toBeInTheDocument()
- await view.rerender({
- label: 'Back',
- })
- expect(view.container).toHaveTextContent('Home')
- })
- it('renders back button, if history is present', async () => {
- window.history.replaceState(
- { back: '/tickets/1/information/customer' },
- '/tickets/1/information/customer',
- )
- const view = renderComponent(CommonBackButton, {
- router: true,
- props: {
- fallback: '/',
- },
- })
- expect(view.getByRole('button', { name: 'Go back' })).toBeInTheDocument()
- expect(view.getByIconName('chevron-left')).toBeInTheDocument()
- await view.rerender({
- label: 'Back',
- })
- expect(view.container).toHaveTextContent('Back')
- })
- it('back button changes direction when locale changes', async () => {
- window.history.replaceState(
- { back: '/tickets/1/information/customer' },
- '/tickets/1/information/customer',
- )
- const view = renderComponent(CommonBackButton, {
- router: true,
- props: {
- fallback: '/',
- },
- })
- expect(view.getByIconName('chevron-left')).toBeInTheDocument()
- const locale = useLocaleStore()
- locale.localeData = {
- dir: EnumTextDirection.Rtl,
- } as any
- await expect(
- view.findByIconName('chevron-right'),
- ).resolves.toBeInTheDocument()
- })
- })
|