UNPKG

@glidejs/glide

Version:

Glide.js is a dependency-free JavaScript ES6 slider and carousel. It’s lightweight, flexible and fast. Designed to slide. No less, no more

84 lines (55 loc) 2.5 kB
import html from '../fixtures/html' import { query } from '../fixtures/query' import { afterTransition } from '../fixtures/transition' import defaults from '../../src/defaults' import Glide from '../../entry/entry-complete' describe('Class', () => { beforeEach(() => { document.body.innerHTML = html }) test('`classes.slider` should be applied on the root element', () => { let { root } = query(document) new Glide('#glide').mount() expect(root.classList.contains(defaults.classes.slider)).toBe(true) }) test('`classes.carousel` should be applied on the root element', () => { let { root } = query(document) new Glide('#glide', { type: 'carousel' }).mount() expect(root.classList.contains(defaults.classes.carousel)).toBe(true) }) test('`classes.activeSlide` should be applied on the 0 indexed slide element by default', () => { let { slides } = query(document) new Glide('#glide').mount() expect(slides[0].classList.contains(defaults.classes.activeSlide)).toBe(true) }) test('`classes.activeSlide` should be applied on the `startAt` indexed slide element', () => { let { slides } = query(document) new Glide('#glide', { startAt: 2 }).mount() expect(slides[2].classList.contains(defaults.classes.activeSlide)).toBe(true) }) test('`classes.activeSlide` should be applied to the new slide element after moving', (done) => { let { slides } = query(document) let glide = new Glide('#glide', { startAt: 0 }).mount() glide.go('>') afterTransition(() => { expect(slides[0].classList.contains(defaults.classes.activeSlide)).toBe(false) expect(slides[1].classList.contains(defaults.classes.activeSlide)).toBe(true) done() }) }) test('`classes.swipeable` should be applied on the root element', () => { let { root } = query(document) new Glide('#glide').mount() expect(root.classList.contains(defaults.classes.swipeable)).toBe(true) }) test('`classes.direction.ltr` should be applied on the root element in `ltr` mode', () => { let { root } = query(document) new Glide('#glide').mount() expect(root.classList.contains(defaults.classes.direction.ltr)).toBe(true) }) test('`classes.direction.rtl` should be applied on the root element in `rtl` mode', () => { let { root } = query(document) new Glide('#glide', { direction: 'rtl' }).mount() expect(root.classList.contains(defaults.classes.direction.rtl)).toBe(true) }) })