Files
mini-programs/src/components/ListLoadError/index.tsx
2025-11-29 22:52:05 +08:00

40 lines
1.2 KiB
TypeScript

import { Image, View, Text } from "@tarojs/components";
import styles from "./index.module.scss";
import img from "@/config/images";
interface IProps {
reload?: () => void;
text?: string;
errorImg?: string;
btnText?: string;
btnImg?: string;
wrapperHeight?: string;
width?: string;
height?: string;
}
const ListLoadError = (props: IProps) => {
const { reload, text, errorImg, btnText, btnImg, wrapperHeight="", width = "", height = "" } = props;
const handleReload = () => {
reload && typeof reload === "function" && reload();
};
return (
<View className={styles.listLoadError} style={{height: wrapperHeight}}>
<Image
className={styles.listLoadErrorImg}
style={{ width, height }}
src={errorImg ? img[errorImg] : img.ICON_LIST_LOAD_ERROR}
/>
{text && <Text className={styles.listLoadErrorText}>{text}</Text>}
{reload && (
<View className={styles.listLoadErrorBtn} onClick={handleReload}>
<Image src={btnImg ? img[btnImg] : img?.ICON_LIST_RELOAD} className={styles.reloadIcon} />
{btnText ? " " + btnText : "重试"}
</View>
)}
</View>
);
};
export default ListLoadError;