123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe 'Popover', type: :system do
- # This test covers generic PopoverProvidable behavior
- it 'opening & auto-closing' do
- visit "#ticket/zoom/#{Ticket.first.id}"
- within :active_content do
- trigger_popover('.ticketZoom-header .js-avatar .user-popover')
- end
- # popover opened up
- expect(page).to have_css('.popover')
- visit '#dashboard'
- # move mouse to another location
- # for reliable popover re-spawning
- find('.menu').hover
- # popover is not visible when moving to another page without moving mouse
- # https://github.com/zammad/zammad/issues/4058
- expect(page).to have_no_css('.popover')
- visit "#ticket/zoom/#{Ticket.first.id}"
- # popover is not visible when moving back to the original page without moving mouse
- expect(page).to have_no_css('.popover')
- within :active_content do
- trigger_popover('.ticketZoom-header .js-avatar .user-popover')
- end
- # popover opens up again
- expect(page).to have_css('.popover')
- end
- it 'popover in overviews closes after overview update', ensure_threads_exited: true do
- ensure_websocket do
- visit '#ticket/view/all_unassigned'
- end
- within :active_content do
- trigger_popover('.user-popover')
- end
- expect(page).to have_css('.popover')
- Ticket.find(1).update!(owner: current_user)
- ensure_block_keeps_running do
- Sessions.thread_client(Sessions.sessions.first, 0, Time.now.utc, nil)
- end
- expect(page).to have_no_css('.popover')
- end
- it 'popover of another agent closes after taskbar update' do
- ensure_websocket do
- visit "#ticket/zoom/#{Ticket.first.id}"
- end
- allow_any_instance_of(Taskbar).to receive(:update_preferences_infos)
- taskbar = Taskbar.where(key: 'Ticket-1', user_id: current_user.id).first
- within :active_content do
- taskbar.update! preferences: { 'tasks' => [{
- 'user_id' => create(:admin).id,
- 'apps' => taskbar.preferences['tasks'].first['apps'],
- }] }
- TransactionDispatcher.commit
- trigger_popover('.js-attributeBar .user-popover')
- end
- expect(page).to have_css('.popover')
- taskbar.update! preferences: { 'tasks' => [] }
- TransactionDispatcher.commit
- expect(page).to have_no_css('.popover')
- end
- def trigger_popover(selector)
- find(selector) do |elem|
- elem.evaluate_script('Object.keys($(this).data()).includes("bs.popover")')
- end.hover
- end
- end
|