Step 8.5: Move report event dialog construction
This commit is contained in:
parent
8dab169c52
commit
226700ba95
4 changed files with 43 additions and 4 deletions
|
@ -34,7 +34,6 @@ import { isContentActionable } from '../../../utils/EventUtils';
|
||||||
import IconizedContextMenu, { IconizedContextMenuOption, IconizedContextMenuOptionList } from './IconizedContextMenu';
|
import IconizedContextMenu, { IconizedContextMenuOption, IconizedContextMenuOptionList } from './IconizedContextMenu';
|
||||||
import { ReadPinsEventId } from "../right_panel/types";
|
import { ReadPinsEventId } from "../right_panel/types";
|
||||||
import { Action } from "../../../dispatcher/actions";
|
import { Action } from "../../../dispatcher/actions";
|
||||||
import ReportEventDialog from '../dialogs/ReportEventDialog';
|
|
||||||
import ViewSource from '../../structures/ViewSource';
|
import ViewSource from '../../structures/ViewSource';
|
||||||
import { createRedactEventDialog } from '../dialogs/ConfirmRedactDialog';
|
import { createRedactEventDialog } from '../dialogs/ConfirmRedactDialog';
|
||||||
import ShareDialog from '../dialogs/ShareDialog';
|
import ShareDialog from '../dialogs/ShareDialog';
|
||||||
|
@ -47,6 +46,7 @@ import EndPollDialog from '../dialogs/EndPollDialog';
|
||||||
import { isPollEnded } from '../messages/MPollBody';
|
import { isPollEnded } from '../messages/MPollBody';
|
||||||
import { ViewRoomPayload } from "../../../dispatcher/payloads/ViewRoomPayload";
|
import { ViewRoomPayload } from "../../../dispatcher/payloads/ViewRoomPayload";
|
||||||
import { OpenForwardDialogPayload } from "../../../dispatcher/payloads/OpenForwardDialogPayload";
|
import { OpenForwardDialogPayload } from "../../../dispatcher/payloads/OpenForwardDialogPayload";
|
||||||
|
import { OpenReportEventDialogPayload } from "../../../dispatcher/payloads/OpenReportEventDialogPayload";
|
||||||
import { createMapSiteLink } from '../../../utils/location';
|
import { createMapSiteLink } from '../../../utils/location';
|
||||||
|
|
||||||
export function canCancel(status: EventStatus): boolean {
|
export function canCancel(status: EventStatus): boolean {
|
||||||
|
@ -154,9 +154,10 @@ export default class MessageContextMenu extends React.Component<IProps, IState>
|
||||||
};
|
};
|
||||||
|
|
||||||
private onReportEventClick = (): void => {
|
private onReportEventClick = (): void => {
|
||||||
Modal.createTrackedDialog('Report Event', '', ReportEventDialog, {
|
dis.dispatch({
|
||||||
mxEvent: this.props.mxEvent,
|
action: Action.OpenReportEventDialog,
|
||||||
}, 'mx_Dialog_reportEvent');
|
event: this.props.mxEvent,
|
||||||
|
} as OpenReportEventDialogPayload);
|
||||||
this.closeMenu();
|
this.closeMenu();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -271,4 +271,10 @@ export enum Action {
|
||||||
* Payload: OpenForwardDialogPayload
|
* Payload: OpenForwardDialogPayload
|
||||||
*/
|
*/
|
||||||
OpenForwardDialog = "open_forward_dialog",
|
OpenForwardDialog = "open_forward_dialog",
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fired when the "report event" dialog needs to be opened.
|
||||||
|
* Payload: OpenReportEventDialogPayload.
|
||||||
|
*/
|
||||||
|
OpenReportEventDialog = "open_report_event_dialog",
|
||||||
}
|
}
|
||||||
|
|
26
src/dispatcher/payloads/OpenReportEventDialogPayload.ts
Normal file
26
src/dispatcher/payloads/OpenReportEventDialogPayload.ts
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
/*
|
||||||
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
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 { MatrixEvent } from "matrix-js-sdk/src/models/event";
|
||||||
|
|
||||||
|
import { Action } from "../actions";
|
||||||
|
import { ActionPayload } from "../payloads";
|
||||||
|
|
||||||
|
export interface OpenReportEventDialogPayload extends ActionPayload {
|
||||||
|
action: Action.OpenReportEventDialog;
|
||||||
|
|
||||||
|
event: MatrixEvent;
|
||||||
|
}
|
|
@ -22,6 +22,7 @@ import { RoomViewStore } from "../stores/RoomViewStore";
|
||||||
import ForwardDialog from "../components/views/dialogs/ForwardDialog";
|
import ForwardDialog from "../components/views/dialogs/ForwardDialog";
|
||||||
import { MatrixClientPeg } from "../MatrixClientPeg";
|
import { MatrixClientPeg } from "../MatrixClientPeg";
|
||||||
import { Action } from "../dispatcher/actions";
|
import { Action } from "../dispatcher/actions";
|
||||||
|
import ReportEventDialog from "../components/views/dialogs/ReportEventDialog";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Auxiliary class to listen for dialog opening over the dispatcher and
|
* Auxiliary class to listen for dialog opening over the dispatcher and
|
||||||
|
@ -59,6 +60,11 @@ export class DialogOpener {
|
||||||
permalinkCreator: payload.permalinkCreator,
|
permalinkCreator: payload.permalinkCreator,
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
|
case Action.OpenReportEventDialog:
|
||||||
|
Modal.createTrackedDialog('Report Event', '', ReportEventDialog, {
|
||||||
|
event: payload.event,
|
||||||
|
}, 'mx_Dialog_reportEvent');
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue