UNPKG

@egjs/conveyer

Version:

Conveyer adds Drag gestures to your Native Scroll.

183 lines (171 loc) 6.43 kB
/** * egjs-conveyer * Copyright (c) 2022-present NAVER Corp. * MIT license */ import { CONVEYER_METHODS } from "./consts"; import Conveyer from "./Conveyer"; /** * @typedef */ export interface ConveyerOptions { /** * scroll direction. (true: Horizontal Scroll, false: Vertical Scroll) * <ko>스크롤 방향. (true: 가로 스크롤, false: 세로 스크롤)</ko> * @default true */ horizontal?: boolean; /** * selector to find items inside. * <ko>내부의 아이템들을 찾기 위한 selector.</ko> * @default "" */ itemSelector?: string; /** * Whether to use drag. * <ko> 드래그를 사용할지 여부.</ko> * @default true */ useDrag?: boolean; /** * Whether to use the mouse wheel in a direction aside from the scroll direction. * <ko>스크롤 방향과 다른 방향의 마우스 휠 입력을 사용할지 여부.</ko> * @default false */ useSideWheel?: boolean; /** * The minimum margin space for {@link Conveyer#event-reachStart reachStart}, {@link Conveyer#event-leaveStart leaveStart}, {@link Conveyer#event-reachEnd reachEnd}, and {@link Conveyer#event-leaveEnd leaveEnd} events to be triggered at the beginning and end of the scroll area. * <ko> 스크롤 영역의 시작과 끝에서 {@link Conveyer#event-reachStart reachStart}, {@link Conveyer#event-leaveStart leaveStart}, {@link Conveyer#event-reachEnd reachEnd}, {@link Conveyer#event-leaveEnd leaveEnd} 이벤트들이 발생하기 위한 최소 여백.</ko> * @default 0 */ boundaryMargin?: number; /** * The maximum amount of time the scroll event does not fire for the finishScroll event to be triggered. * <ko> finishScroll 이벤트가 발생되기 위한 scroll 이벤트가 발생하지 않는 최대 시간.</ko> * @default 100 */ scrollDebounce?: number; /** * Whether to prevent being selected. * <ko>셀렉트가 되는 것을 막을지 여부.</ko> * @default true */ preventDefault?: boolean; /** * Whether to prevent click event when dragging. * <ko>드래그하면 클릭이벤트를 막을지 여부.</ko> * @default false */ preventClickOnDrag?: boolean; /** * Whether to use the {@link https://developer.mozilla.org/ko/docs/Web/API/Event/preventDefault preventDefault} when the user starts dragging. * <ko>사용자가 드래그를 시작할 때 {@link https://developer.mozilla.org/ko/docs/Web/API/Event/preventDefault preventDefault} 실행 여부</ko> * @default false */ preventDefaultOnDrag?: boolean; /** * Whether to automatically initialize when an instance is created. If set to false, initialization is possible while calling the init method. * <ko>인스턴스를 생성할 때 자동으로 초기화할지 여부. false로 설정하면 init 메서드를 호출하면서 초기화가 가능하다.</ko> * @default true */ autoInit?: boolean; /** * If this option is enabled on a Conveyer placed inside an egjs component that has the same scroll direction including the Conveyer itself. The parent component moves in the same direction after the Conveyer reaches the first/last scroll position. * <ko>Conveyer 자신을 포함해서 동일한 스크롤 방향을 가진 egjs 컴포넌트 내부에 배치된 Conveyer에서 이 옵션을 활성화하면 Conveyer가 첫/마지막 스크롤 위치에 도달한 뒤부터 같은 방향으로 상위 컴포넌트가 움직인다.</ko> * @default false */ nested?: boolean; /** * Whether to use the {@link https://developer.mozilla.org/en-US/docs/Web/API/ResizeObserver ResizeObserver} when resizing the Conveyer element and ConveyerItem elements. * <ko>Conveyer element와 ConveyerItem element 크기가 변경될 때 {@link https://developer.mozilla.org/en-US/docs/Web/API/ResizeObserver ResizeObserver} 적용 여부 </ko> * @default false */ useResizeObserver?: boolean; } /** * @typedef */ export interface OnFinishScroll { isWheelScroll: boolean; isDragScroll: boolean; isAnimationScroll: boolean; isTrusted: boolean; } export interface ConveyerEvents { reachStart: void; reachEnd: void; leaveStart: void; leaveEnd: void; beginScroll: void; finishScroll: OnFinishScroll; } export interface ConveyerReactiveState { readonly isReachStart: boolean; readonly isReachEnd: boolean; readonly scrollPos: number; } /** * @typedef */ export interface FindItemOptions { /** * size ratio to find items. Use it if `padding` inside the item plays the same role as `margin` or `gap`. * <ko>아이템을 찾기 위한 사이즈 비율. 아이템 내부에 `padding`이 `margin`, `gap`과 같은 역할을 한다면 사용해라.</ko> * @default 1 */ hitTest?: number; /** * A number indicating how much the items intersect on the side. (true is 1) * * If 0, there is no intersect. The closer it is to 1, the greater the intersect distance. * <ko>사이드에서 아이템이 얼마나 교차되는지 수치. (true의 경우 1) * 0인 경우 교차를 하지 않는다. 1에 가까울수록 교차거리가 늘어난다.</ko> * @default 0 */ intersection?: boolean | number; /** * The number of items next to the item's index to return. * <ko>해당 아이템의 index에서 얼마나 옆에 있는 아이템을 반환할지 개수.</ko> * @default 0 */ sibling?: number; } /** * @typedef * @extends FindItemOptions */ export interface ScrollIntoViewOptions extends FindItemOptions { /** * The position to align the target to. * <ko>target을 정렬할 위치.</ko> */ align?: "start" | "end" | "center"; /** * Whether to find the next item except sorting it in place. * <ko>아이템을 제자리에 정렬하는 것을 제외하고 다음 아이템을 찾을지 여부.</ko> * @default false */ excludeStand?: boolean; /** * The value to scroll further from the sort position. * <ko>정렬하는 위치에서 얼만큼 더 스크롤할 값.</ko> * @default 0 */ offset?: number; /** * How long to scroll animation time. * <ko>얼마동한 스크롤할 할지 애니메이션 시간.</ko> * @default 0 */ duration?: number; } /** * @typedef */ export interface ConveyerItem { element?: HTMLElement | null; pos: number; size: number; } export type ConveyerMethods = { [key in typeof CONVEYER_METHODS[number]]: Conveyer[key]; }