File "utils.ts"

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

Download   Open   Edit   Advanced Editor   Back

import { CLASS_LIST, CLASS_ROOT, CLASS_SLIDE, CLASS_TRACK } from '../../constants/classes';
import { Splide } from '../../core/Splide/Splide';
import { Options } from '../../types';
import { assign } from '../../utils';
import { buildHtml, BuildHtmlArgs } from '../fixtures';
import { SLIDER_WIDTH } from '../fixtures/constants';


interface InitArgs extends BuildHtmlArgs {
  mount?: boolean;
  html?: string;
  insertHtml?: boolean;
}

const DOM_RECT = {
  x     : 0,
  y     : 0,
  width : 0,
  height: 0,
  top   : 0,
  right : 0,
  bottom: 0,
  left  : 0,
  toJSON: () => '',
};

/**
 * Creates a new splide instance.
 *
 * @param args    - Arguments for initialization.
 * @param options - Options for Splide.
 *
 * @return A created Splide instance.
 */
export function init( options: Options = {}, args: InitArgs = {} ): Splide {
  const { width = SLIDER_WIDTH, height = 0 } = options;
  const {
    id,
    length = 10,
    arrows,
    autoplay,
    progress,
    mount  = true,
    html,
    src,
    dataSrc,
    dataSrcset,
    json,
    insertHtml,
    dataInterval,
  } = args;

  const slideWidth  = +width / ( options.perPage || 1 );
  const slideHeight = +height / ( options.perPage || 1 );
  const innerHtml   = html
    || buildHtml( { length, arrows, autoplay, progress, src, dataSrc, dataSrcset, json, id, dataInterval } );

  if ( insertHtml ) {
    if ( ! document.body.innerHTML ) {
      throw new Error( 'Invalid usage.' );
    }

    document.body.insertAdjacentHTML( 'beforeend', innerHtml );
  } else {
    document.head.innerHTML = '';
    document.body.innerHTML = innerHtml;
  }

  const root   = id ? document.getElementById( id ) : document.querySelector( `.${ CLASS_ROOT }` );
  const track  = root.querySelector( `.${ CLASS_TRACK }` );
  const list   = root.querySelector<HTMLElement>( `.${ CLASS_LIST }` );
  const slides = root.querySelectorAll<HTMLElement>( `.${ CLASS_SLIDE }` );

  root.getBoundingClientRect = (): DOMRect => {
    return assign( {}, DOM_RECT, { width: +width } );
  };

  track.getBoundingClientRect = (): DOMRect => {
    return assign( {}, DOM_RECT, { width: +width, right: +width } );
  };

  list.getBoundingClientRect = (): DOMRect => {
    return assign( {}, DOM_RECT, {
      width: +width,
      ...parseTransform( list ),
    } );
  };

  setSlidesRect( Array.from( slides ), list, slideWidth, slideHeight );

  const splide = new Splide( root as HTMLElement, options );

  if ( mount ) {
    splide.mount();
  }

  return splide;
}

/**
 * Forcibly sets dimensions of provided slides.
 *
 * @param slides - An array with slides.
 * @param list   - A List element.
 * @param width  - Width of each slide.
 * @param height - Height of each slide.
 */
export function setSlidesRect( slides: HTMLElement[], list: HTMLElement, width: number, height: number ): void {
  slides.forEach( ( slide, index ) => {
    slide.getBoundingClientRect = (): DOMRect => {
      const offsets = parseTransform( list );

      return assign( {}, DOM_RECT, {
        width : width,
        height: height,
        left  : width * index + offsets.left,
        right : width * index + width + offsets.left,
      } );
    };
  } );
}

/**
 * Converts translate values to position.
 *
 * @param elm - An element to parse.
 *
 * @return An object with left and top offsets.
 */
export function parseTransform( elm: HTMLElement ): { left: number, top: number } {
  const position = { left: 0, top: 0 };

  if ( elm && elm.style.transform ) {
    const { transform } = elm.style;

    if ( transform.includes( 'translateX' ) ) {
      position.left = parseFloat( transform.replace( /translateX\(|\)/g, '' ) ) || 0;
    }

    if ( transform.includes( 'translateY' ) ) {
      position.top = parseFloat( transform.replace( /translateY\(|\)/g, '' ) ) || 0;
    }
  }

  return position;
}

/**
 * Fires any native event manually.
 *
 * @param target        - A target.
 * @param type          - An event type.
 * @param data          - Optional. Additional data.
 * @param eventInitDict - Optional. An EventInit object.
 *
 * @return An event object.
 */
export function fire(
  target: Window | Document | Element,
  type: string,
  data: any = {},
  eventInitDict: EventInit = {}
): Event {
  const e = new Event( type, eventInitDict );

  if ( data.timeStamp !== undefined ) {
    Object.defineProperty( e, 'timeStamp', { value: data.timeStamp } );
    delete data.timeStamp;
  }

  target.dispatchEvent( Object.assign( e, data ) );
  return e;
}

/**
 * Emulates keydown.
 *
 * @param key    - A key to press.
 * @param target - A target.
 */
export function keydown( key: string, target: Window | Element = window ): void {
  fire( target, 'keydown', { key } );
}

/**
 * Returns a new Promise resolved after the specified duration.
 *
 * @param duration - Duration to wait.
 *
 * @return A Promise instance.
 */
export function wait( duration = 0 ): Promise<void> {
  return new Promise( resolve => {
    setTimeout( resolve, duration );
  } );
}