File "ltr.test.ts"

Full path: /home/fsibplc/public_html/sommilito-bank2/splide-4.1.3/src/js/components/Layout/test/ltr.test.ts
File size: 3.56 B (3.56 KB bytes)
MIME-type: text/x-java
Charset: utf-8

Download   Open   Edit   Advanced Editor   Back

import { init } from '../../../test';
import { SLIDER_WIDTH } from '../../../test/fixtures/constants';


describe( 'Layout in the LTR mode', () => {
  test( 'can set paddings to the track element.', () => {
    const splide1 = init( { padding: '2rem' } );
    const track1  = splide1.Components.Elements.track;

    expect( track1.style.paddingLeft ).toBe( '2rem' );
    expect( track1.style.paddingRight ).toBe( '2rem' );
    splide1.destroy();

    const splide2 = init( { padding: { left: '4%', right: '5%' } } );
    const track2  = splide2.Components.Elements.track;

    expect( track2.style.paddingLeft ).toBe( '4%' );
    expect( track2.style.paddingRight ).toBe( '5%' );
    splide2.destroy();

    const splide3 = init( { padding: { left: '4%' } } );
    const track3  = splide3.Components.Elements.track;

    expect( track3.style.paddingLeft ).toBe( '4%' );
    expect( track3.style.paddingRight ).toBe( '0px' );
    splide3.destroy();
  } );

  test( 'can set margin as a gap.', () => {
    const splide = init( { gap: '2rem' } );
    const slides = splide.Components.Elements.slides;

    expect( slides[ 0 ].style.marginRight ).toBe( '2rem' );
    expect( slides[ 1 ].style.marginRight ).toBe( '2rem' );
    splide.destroy();
  } );

  test( 'can fix the slide width.', () => {
    const splide = init( { fixedWidth: 100 } );

    expect( splide.Components.Elements.slides[ 0 ].style.width ).toBe( '100px' );
    expect( splide.Components.Elements.slides[ 1 ].style.width ).toBe( '100px' );
    splide.destroy();
  } );

  test( 'can set the slide height.', () => {
    const splide = init( { height: '10rem' } );

    expect( splide.Components.Elements.slides[ 0 ].style.height ).toBe( '10rem' );
    expect( splide.Components.Elements.slides[ 1 ].style.height ).toBe( '10rem' );
    splide.destroy();
  } );

  test( 'can set the slide height by ratio against the slider width.', () => {
    const splide = init( { width: 500, heightRatio: 0.5 } );

    expect( splide.Components.Elements.slides[ 0 ].style.height ).toBe( '250px' );
    expect( splide.Components.Elements.slides[ 1 ].style.height ).toBe( '250px' );
    splide.destroy();
  } );

  test( 'can fix the slide height.', () => {
    const splide = init( { fixedHeight: 100 } );

    expect( splide.Components.Elements.slides[ 0 ].style.height ).toBe( '100px' );
    expect( splide.Components.Elements.slides[ 1 ].style.height ).toBe( '100px' );
    splide.destroy();
  } );

  test( 'should not set the slide width when the autoWidth is true.', () => {
    const splide = init( { autoWidth: true } );

    expect( splide.Components.Elements.slides[ 0 ].style.width ).toBe( '' );
    expect( splide.Components.Elements.slides[ 1 ].style.width ).toBe( '' );
    splide.destroy();
  } );

  test( 'can provide the list width.', () => {
    const splide = init( { width: 100 } );
    expect( splide.Components.Layout.listSize() ).toBe( 100 );
    splide.destroy();
  } );

  test( 'can provide the slide width.', () => {
    const splide1 = init();

    expect( splide1.Components.Layout.slideSize( 0 ) ).toBe( SLIDER_WIDTH );
    expect( splide1.Components.Layout.slideSize( 1 ) ).toBe( SLIDER_WIDTH );
    splide1.destroy();

    const splide2 = init( { perPage: 2 } );

    expect( splide2.Components.Layout.slideSize( 0 ) ).toBe( SLIDER_WIDTH / 2 );
    expect( splide2.Components.Layout.slideSize( 1 ) ).toBe( SLIDER_WIDTH / 2 );
    splide2.destroy();
  } );

  test( 'should not set the track width.', () => {
    const splide = init( { height: 100 } );

    expect( splide.Components.Elements.track.style.height ).toBe( '' );
    splide.destroy();
  } );
} );