123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- "use client";
- import Box from "@/components/Box";
- import { FC, PropsWithChildren, ReactNode, useRef } from "react";
- import { Swiper, SwiperClass, SwiperSlide } from "swiper/react";
- import { Category, GameListRep } from "@/api/home";
- import { CardProps } from "@/components/Card/Card";
- import GroupCard, { GroupProps } from "@/components/Card/GroupCard";
- import clsx from "clsx";
- import { useTranslations } from "next-intl";
- import styles from "./style.module.scss";
- type TodoHandler = (item: Category) => void;
- interface SwiperGroupProps extends GroupProps, CardProps {
- group: Category;
- page?: number;
- // style
- bg?: boolean;
- visibleTitle?: boolean;
- // todos
- visibleTodos?: boolean;
- todoHandler?: TodoHandler;
- // icon
- offsetX?: number;
- offsetY?: number;
- // SwiperSlide
- slideRender?: (data: GameListRep[]) => ReactNode;
- }
- const HomeSwiper: FC<PropsWithChildren<SwiperGroupProps>> = (props) => {
- const {
- group,
- page = 3,
- todoHandler,
- bg = true,
- visibleTitle = true,
- visibleTodos = true,
- slideRender,
- ...other
- } = props;
- const t = useTranslations("HomePage");
- const swiperRef = useRef<SwiperClass | null>(null);
- const bodyClass = clsx(
- styles.gameContainer,
- // "mb-[0.11rem]",
- "pt-[0.08rem]"
- // "pb-[0.11rem]",
- );
- if (!group.game_list) return;
- const lineNum = page * group.line_num;
- const gameList = group.game_list.slice(0, group.line_config_amount);
- const swiperData = Array(gameList.length ? Math.ceil(gameList.length / lineNum) : 0)
- .fill(0)
- .map((_, index) => {
- const showData = gameList
- .slice(index * lineNum, index * lineNum + lineNum)
- .map((subItem) => ({ ...subItem, category_name: group.category_name }));
- return {
- key: index,
- data: showData,
- };
- });
- console.log(swiperData);
- const prev = () => {
- swiperRef.current!.slidePrev();
- };
- const next = () => {
- swiperRef.current!.slideNext();
- };
- const iconClass = clsx(styles.mainLeftIcon, "pro-iconfont", `pro-${group.icon}`);
- return (
- <div>
- {visibleTitle && (
- <Box none>
- <div className={styles.mainTitle}>
- {!group.image && (
- <div className={styles.mainLeft}>
- <div className={iconClass}></div>
- <div className={styles.marginLeftTitle}>{group.category_name}</div>
- {/* <div className={styles.marginLeftTag}> {t("gameTag")}</div> */}
- </div>
- )}
- {group.image && (
- <div className={clsx(styles.mainLeft, "flex items-center")}>
- <img className="h-[.3rem] w-[.3rem]" src={group.image} alt="" />
- <div className={styles.marginLeftTitle}>{group.category_name}</div>
- {/* <div className={styles.marginLeftTag}> {t("gameTag")}</div> */}
- </div>
- )}
- {/* <img
- src=""
- alt=""
- /> */}
- <div className={styles.mainRight}>
- {visibleTodos && (
- <div onClick={() => todoHandler && todoHandler(group)}>
- {/* Todos */}
- <div className="text-[#d76bff]">Todo</div>
- <div className={styles.marginRightCount}>
- <span>{group.to_tal}</span>
- </div>
- </div>
- )}
- {/* <div onClick={prev}>
- <span className="iconfont icon-xiangzuo1"></span>
- </div>
- <div onClick={next}>
- <span className="iconfont icon-xiangyou1"></span>
- </div> */}
- </div>
- </div>
- </Box>
- )}
- <Box none className={bodyClass}>
- <Box>
- <Swiper
- spaceBetween={10}
- slidesPerView={1}
- onSwiper={(swiper) => {
- swiperRef.current = swiper;
- }}
- loop
- >
- {swiperData?.map((data, index) => {
- return (
- <SwiperSlide key={data.key}>
- {slideRender ? (
- slideRender(data.data)
- ) : (
- <GroupCard
- data={data.data}
- {...other}
- groupType={1}
- ></GroupCard>
- )}
- </SwiperSlide>
- );
- })}
- </Swiper>
- </Box>
- </Box>
- </div>
- );
- };
- export default HomeSwiper;
|