mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-01-25 21:52:56 +08:00
Load items faster
This commit is contained in:
parent
6c2f66fa2d
commit
32f11e29b1
@ -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"}>
|
||||||
|
Loading…
Reference in New Issue
Block a user