support for only icon

This commit is contained in:
SrGooglo 2025-04-02 01:51:53 +00:00
parent edb52ae9cd
commit bfd4e28d01

View File

@ -9,74 +9,76 @@ import User from "@models/user"
import "./index.less"
export default (props) => {
let [userData, setUserData] = React.useState(props.user)
const UserPreview = (props) => {
let [userData, setUserData] = React.useState(props.user)
const fetchUser = async () => {
if (!props.user_id && !props.username) {
console.error("Cannot fetch user data without user_id or username")
return false
}
const fetchUser = async () => {
if (!props.user_id && !props.username) {
console.error("Cannot fetch user data without user_id or username")
return false
}
const data = await User.data({
user_id: props.user_id,
username: props.username
}).catch((err) => {
console.error(err)
app.message.error("Failed to fetch user data")
return null
})
const data = await User.data({
user_id: props.user_id,
username: props.username,
}).catch((err) => {
console.error(err)
app.message.error("Failed to fetch user data")
return null
})
if (data) {
setUserData(data)
}
}
if (data) {
setUserData(data)
}
}
const handleOnClick = async () => {
if (typeof props.onClick !== "function") {
console.warn("UserPreview: onClick is not a function, executing default action")
return app.navigation.goToAccount(userData.username)
}
const handleOnClick = async () => {
if (typeof props.onClick !== "function") {
console.warn(
"UserPreview: onClick is not a function, executing default action",
)
return app.navigation.goToAccount(userData.username)
}
return await props.onClick(userData)
}
return await props.onClick(userData)
}
React.useEffect(() => {
if (typeof userData === "undefined") {
fetchUser()
}
}, [])
React.useEffect(() => {
if (typeof userData === "undefined") {
fetchUser()
}
}, [])
if (!userData) {
return <div className="userPreview">
<Skeleton.Avatar active />
</div>
}
if (!userData) {
return (
<div className="userPreview">
<Skeleton.Avatar active />
</div>
)
}
return <div
className={classnames(
"userPreview",
{
["clickable"]: typeof props.onClick === "function",
["small"]: props.small && !props.big,
["big"]: props.big && !props.small,
}
)}
>
<div className="avatar" onClick={handleOnClick}>
<Image
alt="Avatar"
src={userData.avatar}
/>
</div>
<div className="info" onClick={handleOnClick}>
<h1>
{userData.fullName ?? userData.username}
{userData.verified && <Icons.verifiedBadge />}
</h1>
<span>
@{userData.username}
</span>
</div>
</div>
}
return (
<div
className={classnames("userPreview", {
["clickable"]: typeof props.onClick === "function",
["small"]: props.small && !props.big,
["big"]: props.big && !props.small,
})}
>
<div className="avatar" onClick={handleOnClick}>
<Image alt="Avatar" src={userData.avatar} />
</div>
{!props.onlyIcon && (
<div className="info" onClick={handleOnClick}>
<h1>
{userData.fullName ?? userData.username}
{userData.verified && <Icons.verifiedBadge />}
</h1>
<span>@{userData.username}</span>
</div>
)}
</div>
)
}
export default UserPreview