All files / src/setups scrollbarsSetup.ts

95.65% Statements 22/23
66.67% Branches 6/9
66.67% Functions 2/3
95.65% Lines 22/23

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71                                                1x 2x 2x 2x   2x 2x   2x             1x 1x 1x 1x 1x 1x 1x       1x       1x 1x   1x 1x   1x 1x   1x                
import { appendChildren, createDiv, removeElements, isFunction } from 'support';
import {
  classNameScrollbar,
  classNameScrollbarHorizontal,
  classNameScrollbarVertical,
  classNameScrollbarTrack,
  classNameScrollbarHandle,
} from 'classnames';
import { getEnvironment, ScrollbarsInitializationStrategy } from 'environment';
import { OSTarget, ScrollbarsInitialization } from 'typings';
import { StructureSetup } from 'setups/structureSetup';
 
export interface ScrollbarStructure {
  _scrollbar: HTMLElement;
  _track: HTMLElement;
  _handle: HTMLElement;
}
 
export interface ScrollbarsSetup {
  _horizontalScrollbarStructure: ScrollbarStructure;
  _verticalScrollbarStructure: ScrollbarStructure;
  _destroy: () => void;
}
 
const generateScrollbarDOM = (scrollbarClassName: string): ScrollbarStructure => {
  const scrollbar = createDiv(`${classNameScrollbar} ${scrollbarClassName}`);
  const track = createDiv(classNameScrollbarTrack);
  const handle = createDiv(classNameScrollbarHandle);
 
  appendChildren(scrollbar, track);
  appendChildren(track, handle);
 
  return {
    _scrollbar: scrollbar,
    _track: track,
    _handle: handle,
  };
};
 
export const createScrollbarsSetup = (target: OSTarget | ScrollbarsInitialization, structureSetup: StructureSetup): ScrollbarsSetup => {
  const { _getInitializationStrategy } = getEnvironment();
  const { _scrollbarsSlot: environmentScrollbarSlot } = _getInitializationStrategy() as ScrollbarsInitializationStrategy;
  const { _targetObj, _targetCtx } = structureSetup;
  const { _target, _host, _viewport } = _targetObj;
  const initializationScrollbarSlot = !_targetCtx._targetIsElm && (target as ScrollbarsInitialization).scrollbarsSlot;
  const initializationScrollbarSlotResult = isFunction(initializationScrollbarSlot)
    ? initializationScrollbarSlot(_target, _host, _viewport)
    : initializationScrollbarSlot;
  const evaluatedScrollbarSlot =
    initializationScrollbarSlotResult ||
    (isFunction(environmentScrollbarSlot) ? environmentScrollbarSlot(_target, _host, _viewport) : environmentScrollbarSlot) ||
    _host;
 
  const horizontalScrollbarStructure = generateScrollbarDOM(classNameScrollbarHorizontal);
  const verticalScrollbarStructure = generateScrollbarDOM(classNameScrollbarVertical);
 
  const { _scrollbar: horizontalScrollbar } = horizontalScrollbarStructure;
  const { _scrollbar: verticalScrollbar } = verticalScrollbarStructure;
 
  appendChildren(evaluatedScrollbarSlot, horizontalScrollbar);
  appendChildren(evaluatedScrollbarSlot, verticalScrollbar);
 
  return {
    _horizontalScrollbarStructure: horizontalScrollbarStructure,
    _verticalScrollbarStructure: verticalScrollbarStructure,
    _destroy() {
      removeElements([horizontalScrollbar, verticalScrollbar]);
    },
  };
};