SwiperGroup.tsx 6.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. "use client";
  2. import Box from "@/components/Box";
  3. import { FC, PropsWithChildren, useRef } from "react";
  4. import { Swiper, SwiperClass, SwiperSlide } from "swiper/react";
  5. import { GroupType } from "@/api/home";
  6. import { CardProps } from "@/components/Card/Card";
  7. import GroupCard, { GroupProps } from "@/components/Card/GroupCard";
  8. import styles from "./style.module.scss";
  9. interface SwiperGroupProps extends GroupProps, CardProps {
  10. group: GroupType;
  11. page?: number;
  12. // todos
  13. visibleTodos?: boolean;
  14. // icon
  15. offsetX?: number;
  16. offsetY?: number;
  17. }
  18. const HomeSwiper: FC<PropsWithChildren<SwiperGroupProps>> = (props) => {
  19. const { group, page = 6, visibleTodos = true, ...other } = props;
  20. const swiperRef = useRef<SwiperClass | null>(null);
  21. const swiperData = Array(Math.ceil(group.to_tal! / page))
  22. .fill(0)
  23. .map((_, index) => {
  24. return {
  25. key: index,
  26. data: group.game_list!.slice(index * page, index * page + page),
  27. };
  28. });
  29. const prev = () => {
  30. swiperRef.current!.slidePrev();
  31. };
  32. const next = () => {
  33. swiperRef.current!.slideNext();
  34. };
  35. return (
  36. <>
  37. <Box none>
  38. <div className={styles.mainTitle}>
  39. <div className={styles.mainLeft}>
  40. <div className={styles.mainLeftIcon}></div>
  41. <div className={styles.marginLeftTitle}>{group.category_name}</div>
  42. <div className={styles.marginLeftTag}>{group.tag}</div>
  43. </div>
  44. <img
  45. src=""
  46. alt=""
  47. />
  48. <div className={styles.mainRight}>
  49. {visibleTodos && (
  50. <div>
  51. Todos
  52. <span className={styles.marginRightCount}>{group.to_tal}</span>
  53. </div>
  54. )}
  55. <div onClick={prev}>
  56. <span className="iconfont icon-xiangzuo1"></span>
  57. </div>
  58. <div onClick={next}>
  59. <span className="iconfont icon-xiangyou1"></span>
  60. </div>
  61. </div>
  62. </div>
  63. </Box>
  64. <Box none className={"mb-[0.11rem] bg-[#1a1a1a]"}>
  65. <Box>
  66. <Swiper
  67. spaceBetween={10}
  68. slidesPerView={1}
  69. onSwiper={(swiper) => {
  70. swiperRef.current = swiper;
  71. }}
  72. loop
  73. >
  74. {swiperData?.map((data, index) => (
  75. <SwiperSlide key={data.key}>
  76. <GroupCard data={data.data} {...other}></GroupCard>
  77. </SwiperSlide>
  78. ))}
  79. </Swiper>
  80. </Box>
  81. </Box>
  82. </>
  83. );
  84. };
  85. export default HomeSwiper;