mirror of
https://github.com/SteamDeckHomebrew/decky-frontend-lib.git
synced 2026-05-23 03:18:48 +02:00
28 lines
967 B
TypeScript
28 lines
967 B
TypeScript
import { HTMLAttributes, ReactNode, RefAttributes, VFC } from "react";
|
|
import { findModuleChild } from "../webpack";
|
|
|
|
export interface CarouselProps extends HTMLAttributes<HTMLDivElement> {
|
|
autoFocus?: boolean;
|
|
enableBumperPaging?: boolean;
|
|
fnDoesItemTakeFocus?: (...unknown: any[]) => boolean;
|
|
fnGetColumnWidth?: (...unknown: any[]) => number;
|
|
fnGetId?: (id: number) => number;
|
|
fnItemRenderer?: (id: number, ...unknown: any[]) => ReactNode;
|
|
fnUpdateArrows?: (...unknown: any[]) => any;
|
|
initialColumn?: number;
|
|
nHeight?: number;
|
|
nIndexLeftmost?: number;
|
|
nItemHeight?: number;
|
|
nItemMarginX?: number;
|
|
nNumItems?: number;
|
|
name?: string;
|
|
scrollToAlignment?: 'center';
|
|
}
|
|
|
|
export const Carousel = findModuleChild((m) => {
|
|
if (typeof m !== 'object') return undefined;
|
|
for (let prop in m) {
|
|
if (m[prop]?.render?.toString().includes("setFocusedColumn:"))
|
|
return m[prop];
|
|
}
|
|
}) as VFC<CarouselProps & RefAttributes<HTMLDivElement>>; |