| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 | import { minimum } from '../data/html';import Splide from '../../src/js/splide';import { sprintf } from '../../src/js/utils/utils';import { COMPLETE } from '../../src/js/components';describe( 'The A11y', () => {	beforeEach( () => {		document.body.innerHTML = minimum;	} );	test( 'should update aria labels of arrows properly.', done => {		const splide = new Splide( '#splide', { arrows: true, rewind: true }, COMPLETE );		splide.mount();		const Arrows = splide.Components.Arrows;		const i18n   = splide.i18n;		const prev   = Arrows.arrows.prev;		const next   = Arrows.arrows.next;		expect( prev.getAttribute( 'aria-label' ) ).toBe( i18n.last );		expect( next.getAttribute( 'aria-label' ) ).toBe( i18n.next );		splide.on( 'moved', () => {			expect( prev.getAttribute( 'aria-label' ) ).toBe( i18n.prev );			expect( next.getAttribute( 'aria-label' ) ).toBe( i18n.first );			done();		} );		splide.go( splide.length - 1 );	} );	describe( 'should initialize aria labels of pagination properly', () => {		function confirm( splide, labelFormat ) {			const items = splide.Components.Pagination.data.items;			items.forEach( ( { button, page } ) => {				const label = sprintf( labelFormat, page + 1 );				expect( button.getAttribute( 'aria-label' ) ).toBe( label );			} );		}		test( 'with "go to slide X" when perPage is 1.', () => {			const splide = new Splide( '#splide', { pagination: true }, COMPLETE );			splide.mount();			confirm( splide, splide.i18n.slideX );		} );		test( 'with "go to page X" when perPage is not 1.', () => {			const splide = new Splide( '#splide', { pagination: true, perPage: 2 }, COMPLETE );			splide.mount();			confirm( splide, splide.i18n.pageX );		} );	} );	test( 'should add tabindex to slides when slideFocus is true.', () => {		const splide = new Splide( '#splide', {}, COMPLETE );		splide.mount();		expect( splide.Components.Elements.slides[0].getAttribute( 'tabindex' ) ).toBe( '0' );	} );	test( 'should not add tabindex to slides when slideFocus is false.', () => {		const splide = new Splide( '#splide', { slideFocus: false }, COMPLETE );		splide.mount();		expect( splide.Components.Elements.slides[0].getAttribute( 'tabindex' ) ).toBeNull();	} );} );
 |