mirror of
https://github.com/khairul169/vaulterm.git
synced 2025-04-28 16:49:39 +07:00
40 lines
822 B
TypeScript
40 lines
822 B
TypeScript
import React, { useEffect, useMemo, useState } from "react";
|
|
import { View } from "react-native";
|
|
import { PagerViewProps } from "./pager-view";
|
|
|
|
const PagerView = ({
|
|
className,
|
|
children,
|
|
page,
|
|
initialPage,
|
|
}: PagerViewProps) => {
|
|
const [curPage, setPage] = useState<number>(page || initialPage || 0);
|
|
|
|
useEffect(() => {
|
|
if (page != null) {
|
|
setPage(page);
|
|
}
|
|
}, [page]);
|
|
|
|
const content = useMemo(() => {
|
|
if (!Array.isArray(children)) {
|
|
return null;
|
|
}
|
|
|
|
return children.map((element, index) => {
|
|
return (
|
|
<View
|
|
key={element.key || index}
|
|
style={{ display: index === curPage ? "flex" : "none", flex: 1 }}
|
|
>
|
|
{element}
|
|
</View>
|
|
);
|
|
});
|
|
}, [curPage, children]);
|
|
|
|
return content;
|
|
};
|
|
|
|
export default PagerView;
|