Co-authored-by: Michael Telatynski <7t3chguy@gmail.com>pull/21833/head
							parent
							
								
									bf2bb26cda
								
							
						
					
					
						commit
						e502fafad2
					
				|  | @ -18,6 +18,7 @@ limitations under the License. | |||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     overflow: hidden; | ||||
|     flex-grow: 1; | ||||
| } | ||||
| 
 | ||||
| .mx_GroupView_error { | ||||
|  |  | |||
|  | @ -975,7 +975,7 @@ export default class MatrixChat extends React.PureComponent<IProps, IState> { | |||
|             this.viewWelcome(); | ||||
|             return; | ||||
|         } | ||||
|         if (!this.state.currentGroupId && !this.state.currentRoomId) { | ||||
|         if (!this.state.currentGroupId && !this.state.currentRoomId && !this.state.currentUserId) { | ||||
|             this.viewHome(); | ||||
|         } | ||||
|     } | ||||
|  |  | |||
|  | @ -94,10 +94,23 @@ export default class RightPanel extends React.Component<IProps, IState> { | |||
|     } | ||||
| 
 | ||||
|     public static getDerivedStateFromProps(props: IProps): Partial<IState> { | ||||
|         const currentCard = RightPanelStore.instance.currentCardForRoom(props.room.roomId); | ||||
|         let currentCard: IRightPanelCard; | ||||
|         if (props.room) { | ||||
|             currentCard = RightPanelStore.instance.currentCardForRoom(props.room.roomId); | ||||
|         } | ||||
|         if (props.groupId) { | ||||
|             currentCard = RightPanelStore.instance.currentGroup; | ||||
|         } | ||||
| 
 | ||||
|         if (currentCard?.phase && !RightPanelStore.instance.isPhaseValid(currentCard.phase, !!props.room)) { | ||||
|             // XXX: We can probably get rid of this workaround once GroupView is dead, it's unmounting happens weirdly
 | ||||
|             // late causing the app to soft-crash due to lack of a room object being passed to a RightPanel
 | ||||
|             return null; // skip this update, we're about to be unmounted and don't have the appropriate props
 | ||||
|         } | ||||
| 
 | ||||
|         return { | ||||
|             cardState: currentCard.state, | ||||
|             phase: currentCard.phase, | ||||
|             cardState: currentCard?.state, | ||||
|             phase: currentCard?.phase, | ||||
|         }; | ||||
|     } | ||||
| 
 | ||||
|  | @ -118,11 +131,7 @@ export default class RightPanel extends React.Component<IProps, IState> { | |||
|     }; | ||||
| 
 | ||||
|     private onRightPanelStoreUpdate = () => { | ||||
|         const currentCard = RightPanelStore.instance.currentCardForRoom(this.props.room.roomId); | ||||
|         this.setState({ | ||||
|             cardState: currentCard.state, | ||||
|             phase: currentCard.phase, | ||||
|         }); | ||||
|         this.setState({ ...RightPanel.getDerivedStateFromProps(this.props) as IState }); | ||||
|     }; | ||||
| 
 | ||||
|     private onClose = () => { | ||||
|  | @ -139,7 +148,7 @@ export default class RightPanel extends React.Component<IProps, IState> { | |||
|             }); | ||||
|         } else if ( | ||||
|             this.state.phase === RightPanelPhases.EncryptionPanel && | ||||
|             this.state.cardState.verificationRequest && this.state.cardState.verificationRequest.pending | ||||
|             this.state.cardState.verificationRequest?.pending | ||||
|         ) { | ||||
|             // When the user clicks close on the encryption panel cancel the pending request first if any
 | ||||
|             this.state.cardState.verificationRequest.cancel(); | ||||
|  | @ -154,7 +163,7 @@ export default class RightPanel extends React.Component<IProps, IState> { | |||
| 
 | ||||
|     public render(): JSX.Element { | ||||
|         let card = <div />; | ||||
|         const roomId = this.props.room ? this.props.room.roomId : undefined; | ||||
|         const roomId = this.props.room?.roomId; | ||||
|         const phase = this.props.overwriteCard?.phase ?? this.state.phase; | ||||
|         const cardState = this.props.overwriteCard?.state ?? this.state.cardState; | ||||
|         switch (phase) { | ||||
|  |  | |||
|  | @ -94,7 +94,7 @@ export default class ThreadView extends React.Component<IProps, IState> { | |||
| 
 | ||||
|     public componentWillUnmount(): void { | ||||
|         this.teardownThread(); | ||||
|         dis.unregister(this.dispatcherRef); | ||||
|         if (this.dispatcherRef) dis.unregister(this.dispatcherRef); | ||||
|         const room = MatrixClientPeg.get().getRoom(this.props.mxEvent.getRoomId()); | ||||
|         room.removeListener(ThreadEvent.New, this.onNewThread); | ||||
|         SettingsStore.unwatchSetting(this.layoutWatcherRef); | ||||
|  |  | |||
|  | @ -155,7 +155,7 @@ export default class RightPanelStore extends ReadyWatchingStore { | |||
|         const cardState = redirect?.state ?? (Object.keys(card.state ?? {}).length === 0 ? null : card.state); | ||||
| 
 | ||||
|         // Checks for wrong SetRightPanelPhase requests
 | ||||
|         if (!this.isPhaseActionValid(targetPhase)) return; | ||||
|         if (!this.isPhaseValid(targetPhase)) return; | ||||
| 
 | ||||
|         if ((targetPhase === this.currentCardForRoom(rId)?.phase && !!cardState)) { | ||||
|             // Update state: set right panel with a new state but keep the phase (dont know it this is ever needed...)
 | ||||
|  | @ -194,16 +194,16 @@ export default class RightPanelStore extends ReadyWatchingStore { | |||
|         const pState = redirect?.state ?? (Object.keys(card.state ?? {}).length === 0 ? null : card.state); | ||||
| 
 | ||||
|         // Checks for wrong SetRightPanelPhase requests
 | ||||
|         if (!this.isPhaseActionValid(targetPhase)) return; | ||||
|         if (!this.isPhaseValid(targetPhase)) return; | ||||
| 
 | ||||
|         let roomCache = this.byRoom[rId]; | ||||
|         const roomCache = this.byRoom[rId]; | ||||
|         if (!!roomCache) { | ||||
|             // append new phase
 | ||||
|             roomCache.history.push({ state: pState, phase: targetPhase }); | ||||
|             roomCache.isOpen = allowClose ? roomCache.isOpen : true; | ||||
|         } else { | ||||
|             // setup room panel cache with the new card
 | ||||
|             roomCache = { | ||||
|             this.byRoom[rId] = { | ||||
|                 history: [{ phase: targetPhase, state: pState ?? {} }], | ||||
|                 // if there was no right panel store object the the panel was closed -> keep it closed, except if allowClose==false
 | ||||
|                 isOpen: !allowClose, | ||||
|  | @ -344,18 +344,18 @@ export default class RightPanelStore extends ReadyWatchingStore { | |||
|         return null; | ||||
|     } | ||||
| 
 | ||||
|     private isPhaseActionValid(targetPhase) { | ||||
|     public isPhaseValid(targetPhase: RightPanelPhases, isViewingRoom = this.isViewingRoom): boolean { | ||||
|         if (!RightPanelPhases[targetPhase]) { | ||||
|             logger.warn(`Tried to switch right panel to unknown phase: ${targetPhase}`); | ||||
|             return false; | ||||
|         } | ||||
|         if (GROUP_PHASES.includes(targetPhase) && this.isViewingRoom) { | ||||
|         if (GROUP_PHASES.includes(targetPhase) && isViewingRoom) { | ||||
|             logger.warn( | ||||
|                 `Tried to switch right panel to a group phase: ${targetPhase}, ` + | ||||
|                 `but we are currently not viewing a group`, | ||||
|             ); | ||||
|             return false; | ||||
|         } else if (!GROUP_PHASES.includes(targetPhase) && !this.isViewingRoom) { | ||||
|         } else if (!GROUP_PHASES.includes(targetPhase) && !isViewingRoom) { | ||||
|             logger.warn( | ||||
|                 `Tried to switch right panel to a room phase: ${targetPhase}, ` + | ||||
|                 `but we are currently not viewing a room`, | ||||
|  |  | |||
|  | @ -56,23 +56,3 @@ export function backLabelForPhase(phase: RightPanelPhases) { | |||
|     } | ||||
|     return null; | ||||
| } | ||||
| 
 | ||||
| // These are the phases that are safe to persist (the ones that don't require additional
 | ||||
| // arguments).
 | ||||
| export const RIGHT_PANEL_PHASES_NO_ARGS = [ | ||||
|     RightPanelPhases.RoomSummary, | ||||
|     RightPanelPhases.NotificationPanel, | ||||
|     RightPanelPhases.PinnedMessages, | ||||
|     RightPanelPhases.FilePanel, | ||||
|     RightPanelPhases.RoomMemberList, | ||||
|     RightPanelPhases.GroupMemberList, | ||||
|     RightPanelPhases.GroupRoomList, | ||||
|     RightPanelPhases.Timeline, | ||||
| ]; | ||||
| 
 | ||||
| // Subset of phases visible in the Space View
 | ||||
| export const RIGHT_PANEL_SPACE_PHASES = [ | ||||
|     RightPanelPhases.SpaceMemberList, | ||||
|     RightPanelPhases.Space3pidMemberInfo, | ||||
|     RightPanelPhases.SpaceMemberInfo, | ||||
| ]; | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 David Baker
						David Baker