Merge pull request #6257 from SimonBrandner/feature/pinned-click
						commit
						1f27049a5d
					
				|  | @ -17,4 +17,9 @@ limitations under the License. | |||
| .mx_TextualEvent { | ||||
|     opacity: 0.5; | ||||
|     overflow-y: hidden; | ||||
| 
 | ||||
|     a { | ||||
|         color: $accent-color; | ||||
|         cursor: pointer; | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -68,7 +68,7 @@ export const Notifier = { | |||
|     // or not
 | ||||
|     pendingEncryptedEventIds: [], | ||||
| 
 | ||||
|     notificationMessageForEvent: function(ev: MatrixEvent) { | ||||
|     notificationMessageForEvent: function(ev: MatrixEvent): string { | ||||
|         if (typehandlers.hasOwnProperty(ev.getContent().msgtype)) { | ||||
|             return typehandlers[ev.getContent().msgtype](ev); | ||||
|         } | ||||
|  |  | |||
|  | @ -13,6 +13,8 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |||
| See the License for the specific language governing permissions and | ||||
| limitations under the License. | ||||
| */ | ||||
| 
 | ||||
| import React from 'react'; | ||||
| import {MatrixClientPeg} from './MatrixClientPeg'; | ||||
| import { _t } from './languageHandler'; | ||||
| import * as Roles from './Roles'; | ||||
|  | @ -20,6 +22,11 @@ import {isValid3pidInvite} from "./RoomInvite"; | |||
| import SettingsStore from "./settings/SettingsStore"; | ||||
| import {ALL_RULE_TYPES, ROOM_RULE_TYPES, SERVER_RULE_TYPES, USER_RULE_TYPES} from "./mjolnir/BanList"; | ||||
| import {WIDGET_LAYOUT_EVENT_TYPE} from "./stores/widgets/WidgetLayoutStore"; | ||||
| import { RightPanelPhases } from './stores/RightPanelStorePhases'; | ||||
| import { Action } from './dispatcher/actions'; | ||||
| import defaultDispatcher from './dispatcher/dispatcher'; | ||||
| import { SetRightPanelPhasePayload } from './dispatcher/payloads/SetRightPanelPhasePayload'; | ||||
| import { MatrixEvent } from "matrix-js-sdk/src/models/event"; | ||||
| 
 | ||||
| // These functions are frequently used just to check whether an event has
 | ||||
| // any text to display at all. For this reason they return deferred values
 | ||||
|  | @ -479,9 +486,33 @@ function textForPowerEvent(event): () => string | null { | |||
|     }); | ||||
| } | ||||
| 
 | ||||
| function textForPinnedEvent(event): () => string | null { | ||||
| const onPinnedMessagesClick = (): void => { | ||||
|     defaultDispatcher.dispatch<SetRightPanelPhasePayload>({ | ||||
|         action: Action.SetRightPanelPhase, | ||||
|         phase: RightPanelPhases.PinnedMessages, | ||||
|         allowClose: false, | ||||
|     }); | ||||
| } | ||||
| 
 | ||||
| function textForPinnedEvent(event: MatrixEvent, allowJSX: boolean): () => string | JSX.Element | null { | ||||
|     if (!SettingsStore.getValue("feature_pinning")) return null; | ||||
|     const senderName = event.sender ? event.sender.name : event.getSender(); | ||||
|     return () => _t("%(senderName)s changed the pinned messages for the room.", {senderName}); | ||||
| 
 | ||||
|     if (allowJSX) { | ||||
|         return () => ( | ||||
|             <span> | ||||
|                 { | ||||
|                     _t( | ||||
|                         "%(senderName)s changed the <a>pinned messages</a> for the room.", | ||||
|                         { senderName }, | ||||
|                         { "a": (sub) => <a onClick={onPinnedMessagesClick}> { sub } </a> }, | ||||
|                     ) | ||||
|                 } | ||||
|             </span> | ||||
|         ); | ||||
|     } | ||||
| 
 | ||||
|     return () => _t("%(senderName)s changed the pinned messages for the room.", { senderName }); | ||||
| } | ||||
| 
 | ||||
| function textForWidgetEvent(event): () => string | null { | ||||
|  | @ -607,7 +638,7 @@ function textForMjolnirEvent(event): () => string | null { | |||
| } | ||||
| 
 | ||||
| interface IHandlers { | ||||
|     [type: string]: (ev: any) => (() => string | null); | ||||
|     [type: string]: (ev: MatrixEvent, allowJSX?: boolean) => (() => string | JSX.Element | null); | ||||
| } | ||||
| 
 | ||||
| const handlers: IHandlers = { | ||||
|  | @ -648,7 +679,9 @@ export function hasText(ev): boolean { | |||
|     return Boolean(handler?.(ev)); | ||||
| } | ||||
| 
 | ||||
| export function textForEvent(ev): string { | ||||
| export function textForEvent(ev: MatrixEvent): string; | ||||
| export function textForEvent(ev: MatrixEvent, allowJSX: true): string | JSX.Element; | ||||
| export function textForEvent(ev: MatrixEvent, allowJSX = false): string | JSX.Element { | ||||
|     const handler = (ev.isState() ? stateHandlers : handlers)[ev.getType()]; | ||||
|     return handler?.(ev)?.() || ''; | ||||
|     return handler?.(ev, allowJSX)?.() || ''; | ||||
| } | ||||
|  | @ -28,7 +28,7 @@ export default class TextualEvent extends React.Component { | |||
|     }; | ||||
| 
 | ||||
|     render() { | ||||
|         const text = TextForEvent.textForEvent(this.props.mxEvent); | ||||
|         const text = TextForEvent.textForEvent(this.props.mxEvent, true); | ||||
|         if (text == null || text.length === 0) return null; | ||||
|         return ( | ||||
|             <div className="mx_TextualEvent">{ text }</div> | ||||
|  |  | |||
|  | @ -27,6 +27,11 @@ export interface SetRightPanelPhasePayload extends ActionPayload { | |||
| 
 | ||||
|     phase: RightPanelPhases; | ||||
|     refireParams?: SetRightPanelPhaseRefireParams; | ||||
| 
 | ||||
|     /** | ||||
|      * By default SetRightPanelPhase can close the panel, this allows overriding that behaviour | ||||
|      */ | ||||
|     allowClose?: boolean; | ||||
| } | ||||
| 
 | ||||
| export interface SetRightPanelPhaseRefireParams { | ||||
|  |  | |||
|  | @ -562,6 +562,7 @@ | |||
|     "%(senderName)s made future room history visible to unknown (%(visibility)s).": "%(senderName)s made future room history visible to unknown (%(visibility)s).", | ||||
|     "%(senderName)s changed the power level of %(powerLevelDiffText)s.": "%(senderName)s changed the power level of %(powerLevelDiffText)s.", | ||||
|     "%(userId)s from %(fromPowerLevel)s to %(toPowerLevel)s": "%(userId)s from %(fromPowerLevel)s to %(toPowerLevel)s", | ||||
|     "%(senderName)s changed the <a>pinned messages</a> for the room.": "%(senderName)s changed the <a>pinned messages</a> for the room.", | ||||
|     "%(senderName)s changed the pinned messages for the room.": "%(senderName)s changed the pinned messages for the room.", | ||||
|     "%(widgetName)s widget modified by %(senderName)s": "%(widgetName)s widget modified by %(senderName)s", | ||||
|     "%(widgetName)s widget added by %(senderName)s": "%(widgetName)s widget added by %(senderName)s", | ||||
|  |  | |||
|  | @ -161,6 +161,7 @@ export default class RightPanelStore extends Store<ActionPayload> { | |||
|             case Action.SetRightPanelPhase: { | ||||
|                 let targetPhase = payload.phase; | ||||
|                 let refireParams = payload.refireParams; | ||||
|                 const allowClose = payload.allowClose ?? true; | ||||
|                 // redirect to EncryptionPanel if there is an ongoing verification request
 | ||||
|                 if (targetPhase === RightPanelPhases.RoomMemberInfo && payload.refireParams) { | ||||
|                     const {member} = payload.refireParams; | ||||
|  | @ -192,7 +193,7 @@ export default class RightPanelStore extends Store<ActionPayload> { | |||
|                         }); | ||||
|                     } | ||||
|                 } else { | ||||
|                     if (targetPhase === this.state.lastRoomPhase && !refireParams) { | ||||
|                     if (targetPhase === this.state.lastRoomPhase && !refireParams && allowClose) { | ||||
|                         this.setState({ | ||||
|                             showRoomPanel: !this.state.showRoomPanel, | ||||
|                             previousPhase: null, | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Michael Telatynski
						Michael Telatynski