TeaWeb/shared/js/ui/react-elements/Icon.tsx

63 lines
2.5 KiB
TypeScript
Raw Normal View History

2020-04-10 20:57:50 +02:00
import * as React from "react";
2020-05-03 23:32:04 +02:00
import {LocalIcon} from "tc-shared/file/Icons";
2020-04-10 20:57:50 +02:00
export interface IconProperties {
icon: string | LocalIcon;
title?: string;
2020-04-10 20:57:50 +02:00
}
export class IconRenderer extends React.Component<IconProperties, {}> {
render() {
if(!this.props.icon)
return <div className={"icon-container icon-empty"} title={this.props.title} />;
else if(typeof this.props.icon === "string")
return <div className={"icon " + this.props.icon} title={this.props.title} />;
else if(this.props.icon instanceof LocalIcon)
return <LocalIconRenderer icon={this.props.icon} title={this.props.title} />;
else throw "JQuery icons are not longer supported";
}
}
export interface LoadedIconRenderer {
icon: LocalIcon;
title?: string;
}
export class LocalIconRenderer extends React.Component<LoadedIconRenderer, {}> {
private readonly callback_state_update;
2020-04-10 20:57:50 +02:00
constructor(props) {
super(props);
this.callback_state_update = () => {
const icon = this.props.icon;
if(icon.status !== "destroyed")
this.forceUpdate();
};
2020-04-10 20:57:50 +02:00
}
render() {
const icon = this.props.icon;
2020-04-21 16:17:21 +02:00
if(!icon || icon.status === "empty" || icon.status === "destroyed")
return <div className={"icon-container icon-empty"} title={this.props.title} />;
else if(icon.status === "loaded") {
if(icon.icon_id >= 0 && icon.icon_id <= 1000) {
if(icon.icon_id === 0)
return <div className={"icon-container icon-empty"} title={this.props.title} />;
return <div className={"icon_em client-group_" + icon.icon_id} />;
}
return <div key={"icon"} className={"icon-container"}><img style={{ maxWidth: "100%", maxHeight: "100%" }} src={icon.loaded_url} alt={this.props.title || ("icon " + icon.icon_id)} /></div>;
} else if(icon.status === "loading")
return <div key={"loading"} className={"icon-container"} title={this.props.title}><div className={"icon_loading"} /></div>;
else if(icon.status === "error")
return <div key={"error"} className={"icon client-warning"} title={icon.error_message || tr("Failed to load icon")} />;
2020-04-10 20:57:50 +02:00
}
componentDidMount(): void {
2020-04-21 16:17:21 +02:00
this.props.icon?.status_change_callbacks.push(this.callback_state_update);
2020-04-10 20:57:50 +02:00
}
2020-04-10 20:57:50 +02:00
componentWillUnmount(): void {
2020-04-21 16:17:21 +02:00
this.props.icon?.status_change_callbacks.remove(this.callback_state_update);
2020-04-10 20:57:50 +02:00
}
}