123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { getAllByRole } from '@testing-library/vue'
- import { visitView } from '#tests/support/components/visitView.ts'
- import { mockPermissions } from '#tests/support/mock-permissions.ts'
- import { mockUserCurrent } from '#tests/support/mock-userCurrent.ts'
- import { waitForNextTick } from '#tests/support/utils.ts'
- import { convertToGraphQLId } from '#shared/graphql/utils.ts'
- import { mockUserCurrentOverviewResetOrderMutation } from '../graphql/mutations/userCurrentOverviewResetOrder.mocks.ts'
- import { mockUserCurrentOverviewListQuery } from '../graphql/queries/userCurrentOverviewList.mocks.ts'
- import { getUserCurrentOverviewOrderingUpdatesSubscriptionHandler } from '../graphql/subscriptions/userCurrentOverviewOrderingUpdates.mocks.ts'
- const userCurrentOverviewList = [
- {
- id: convertToGraphQLId('Overview', 1),
- name: 'Open Tickets',
- },
- {
- id: convertToGraphQLId('Overview', 2),
- name: 'My Tickets',
- },
- {
- id: convertToGraphQLId('Overview', 3),
- name: 'All Tickets',
- },
- ]
- const userCurrentOverviewListAferReset = userCurrentOverviewList.reverse()
- describe('personal settings for token access', () => {
- beforeEach(() => {
- mockUserCurrent({
- firstname: 'John',
- lastname: 'Doe',
- })
- mockPermissions(['user_preferences.overview_sorting'])
- })
- it('shows the overviews order by priority', async () => {
- mockUserCurrentOverviewListQuery({ userCurrentOverviewList })
- const view = await visitView('/personal-setting/ticket-overviews')
- const overviewContainer = view.getByLabelText('Order of ticket overviews')
- const overviews = getAllByRole(overviewContainer, 'listitem')
- userCurrentOverviewList.forEach((overview, index) => {
- expect(overviews[index]).toHaveTextContent(overview.name)
- })
- })
- // TODO: Cover the update of overview order when the items are moved around the list.
- // We may need to implement a testable mechanism for reordering the list, though, as drag events are not fully
- // supported in JSDOM due to missing client-rectangle coordinate mocking.
- // One approach could be to add keyboard shortcuts for changing the order, or perhaps even hidden buttons.
- it('allows to reset the order of overviews', async () => {
- mockUserCurrentOverviewListQuery({ userCurrentOverviewList })
- const view = await visitView('/personal-setting/ticket-overviews')
- mockUserCurrentOverviewResetOrderMutation({
- userCurrentOverviewResetOrder: {
- success: true,
- overviews: userCurrentOverviewListAferReset,
- errors: null,
- },
- })
- const resetButton = view.getByRole('button', {
- name: 'Reset Overview Order',
- })
- expect(resetButton).toBeInTheDocument()
- await view.events.click(resetButton)
- await waitForNextTick()
- expect(
- await view.findByRole('dialog', { name: 'Confirmation' }),
- ).toBeInTheDocument()
- await view.events.click(view.getByRole('button', { name: 'Yes' }))
- await waitForNextTick()
- userCurrentOverviewListAferReset.forEach((overview) => {
- expect(view.getByText(overview.name)).toBeInTheDocument()
- })
- })
- it('updates the overviews list when a new overview is added', async () => {
- mockUserCurrentOverviewListQuery({ userCurrentOverviewList })
- const view = await visitView('/personal-setting/ticket-overviews')
- const overviewUpdateSubscription =
- getUserCurrentOverviewOrderingUpdatesSubscriptionHandler()
- userCurrentOverviewList.forEach((overview) => {
- expect(view.getByText(overview.name)).toBeInTheDocument()
- })
- overviewUpdateSubscription.trigger({
- userCurrentOverviewOrderingUpdates: {
- overviews: [
- ...userCurrentOverviewList,
- {
- id: convertToGraphQLId('Overview', 4),
- name: 'New Overview',
- },
- ],
- },
- })
- await waitForNextTick()
- expect(view.getByText('New Overview')).toBeInTheDocument()
- })
- })
|