Add tooltip to Room Tile Icon
Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>pull/21833/head
							parent
							
								
									113a0f1b5c
								
							
						
					
					
						commit
						ae17cd3ec6
					
				|  | @ -22,6 +22,8 @@ import { MatrixEvent } from "matrix-js-sdk/src/models/event"; | |||
| import DMRoomMap from "../../../utils/DMRoomMap"; | ||||
| import { MatrixClientPeg } from "../../../MatrixClientPeg"; | ||||
| import { isPresenceEnabled } from "../../../utils/presence"; | ||||
| import { _t } from "../../../languageHandler"; | ||||
| import TextWithTooltip from "../elements/TextWithTooltip"; | ||||
| 
 | ||||
| enum Icon { | ||||
|     // Note: the names here are used in CSS class names
 | ||||
|  | @ -32,6 +34,19 @@ enum Icon { | |||
|     PresenceOffline = "OFFLINE", | ||||
| } | ||||
| 
 | ||||
| function tooltipText(variant: Icon) { | ||||
|     switch (variant) { | ||||
|         case Icon.Globe: | ||||
|             return _t("Public Room"); | ||||
|         case Icon.PresenceOnline: | ||||
|             return _t("Online"); | ||||
|         case Icon.PresenceAway: | ||||
|             return _t("Away"); | ||||
|         case Icon.PresenceOffline: | ||||
|             return _t("Offline"); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| interface IProps { | ||||
|     room: Room; | ||||
|     tag: TagID; | ||||
|  | @ -145,6 +160,10 @@ export default class RoomTileIcon extends React.Component<IProps, IState> { | |||
|     public render(): React.ReactElement { | ||||
|         if (this.state.icon === Icon.None) return null; | ||||
| 
 | ||||
|         return <span className={`mx_RoomTileIcon mx_RoomTileIcon_${this.state.icon.toLowerCase()}`} />; | ||||
|         return <TextWithTooltip | ||||
|             tooltip={tooltipText(this.state.icon)} | ||||
|             tooltipClass="mx_Tooltip_timeline" | ||||
|             class={`mx_RoomTileIcon mx_RoomTileIcon_${this.state.icon.toLowerCase()}`} | ||||
|         />; | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -1239,6 +1239,8 @@ | |||
|     "Leave Room": "Leave Room", | ||||
|     "Forget Room": "Forget Room", | ||||
|     "Room options": "Room options", | ||||
|     "Public Room": "Public Room", | ||||
|     "Away": "Away", | ||||
|     "Add a topic": "Add a topic", | ||||
|     "Upgrading this room will shut down the current instance of the room and create an upgraded room with the same name.": "Upgrading this room will shut down the current instance of the room and create an upgraded room with the same name.", | ||||
|     "This room has already been upgraded.": "This room has already been upgraded.", | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Michael Telatynski
						Michael Telatynski