Load items faster

This commit is contained in:
KingRainbow44 2023-04-08 23:35:20 -04:00
parent 6c2f66fa2d
commit 32f11e29b1
No known key found for this signature in database
GPG Key ID: FC2CB64B00D257BE

View File

@ -12,15 +12,19 @@ interface IProps {
interface IState { interface IState {
popout: boolean; popout: boolean;
icon: boolean; icon: boolean;
loaded: boolean;
} }
class Item extends React.Component<IProps, IState> { class Item extends React.Component<IProps, IState> {
loading: number | any;
constructor(props: IProps) { constructor(props: IProps) {
super(props); super(props);
this.state = { this.state = {
popout: false, popout: false,
icon: true icon: true,
loaded: false
}; };
} }
@ -29,23 +33,37 @@ class Item extends React.Component<IProps, IState> {
* @private * @private
*/ */
private replaceIcon(): void { private replaceIcon(): void {
this.setState({ icon: false }); this.setState({ icon: false, loaded: false });
}
private forceReplace(): void {
if (!this.state.loaded)
this.replaceIcon();
}
componentDidMount() {
this.loading = setTimeout(this.forceReplace.bind(this), 1e3);
}
componentWillUnmount() {
clearTimeout(this.loading);
this.loading = null;
} }
render() { render() {
return ( return (
<div className={"Item"}> <div className={"Item"}>
<div className={"Item_Background"}> <div className={"Item_Background"}>
{ { this.state.icon && <img
this.state.icon ? (
<img
className={"Item_Icon"} className={"Item_Icon"}
alt={this.props.data.name} alt={this.props.data.name}
src={itemIcon(this.props.data)} src={itemIcon(this.props.data)}
onError={this.replaceIcon.bind(this)} onError={this.replaceIcon.bind(this)}
/> onLoad={() => this.setState({ loaded: true })}
) : <p className={"Item_Label"}>{this.props.data.name}</p> /> }
}
{ (!this.state.loaded || !this.state.icon) &&
<p className={"Item_Label"}>{this.props.data.name}</p> }
</div> </div>
<div className={"Item_Info"}> <div className={"Item_Info"}>