matrix-react-sdk
Version:
SDK for matrix.org using React
84 lines (79 loc) • 11.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.startDm = startDm;
var _actions = require("../../dispatcher/actions");
var _directMessages = require("../direct-messages");
var _DMRoomMap = _interopRequireDefault(require("../DMRoomMap"));
var _isLocalRoom = require("../localRoom/isLocalRoom");
var _findDMForUser = require("./findDMForUser");
var _dispatcher = _interopRequireDefault(require("../../dispatcher/dispatcher"));
var _UserAddress = require("../../UserAddress");
var _createRoom = _interopRequireDefault(require("../../createRoom"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2022 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
/**
* Start a DM.
*
* @returns {Promise<string | null} Resolves to the room id.
*/
async function startDm(client, targets, showSpinner = true) {
const targetIds = targets.map(t => t.userId);
// Check if there is already a DM with these people and reuse it if possible.
let existingRoom;
if (targetIds.length === 1) {
existingRoom = (0, _findDMForUser.findDMForUser)(client, targetIds[0]);
} else {
existingRoom = _DMRoomMap.default.shared().getDMRoomForIdentifiers(targetIds) ?? undefined;
}
if (existingRoom && !(0, _isLocalRoom.isLocalRoom)(existingRoom)) {
_dispatcher.default.dispatch({
action: _actions.Action.ViewRoom,
room_id: existingRoom.roomId,
should_peek: false,
joining: false,
metricsTrigger: "MessageUser"
});
return Promise.resolve(existingRoom.roomId);
}
const createRoomOptions = {
inlineErrors: true
};
if (await (0, _directMessages.determineCreateRoomEncryptionOption)(client, targets)) {
createRoomOptions.encryption = true;
}
// Check if it's a traditional DM and create the room if required.
// TODO: [Canonical DMs] Remove this check and instead just create the multi-person DM
const isSelf = targetIds.length === 1 && targetIds[0] === client.getUserId();
if (targetIds.length === 1 && !isSelf) {
createRoomOptions.dmUserId = targetIds[0];
}
if (targetIds.length > 1) {
createRoomOptions.createOpts = targetIds.reduce((roomOptions, address) => {
const type = (0, _UserAddress.getAddressType)(address);
if (type === "email") {
const invite = {
id_server: client.getIdentityServerUrl(true),
medium: "email",
address
};
roomOptions.invite_3pid.push(invite);
} else if (type === "mx-user-id") {
roomOptions.invite.push(address);
}
return roomOptions;
}, {
invite: [],
invite_3pid: []
});
}
createRoomOptions.spinner = showSpinner;
return (0, _createRoom.default)(client, createRoomOptions);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_actions","require","_directMessages","_DMRoomMap","_interopRequireDefault","_isLocalRoom","_findDMForUser","_dispatcher","_UserAddress","_createRoom","startDm","client","targets","showSpinner","targetIds","map","t","userId","existingRoom","length","findDMForUser","DMRoomMap","shared","getDMRoomForIdentifiers","undefined","isLocalRoom","dis","dispatch","action","Action","ViewRoom","room_id","roomId","should_peek","joining","metricsTrigger","Promise","resolve","createRoomOptions","inlineErrors","determineCreateRoomEncryptionOption","encryption","isSelf","getUserId","dmUserId","createOpts","reduce","roomOptions","address","type","getAddressType","invite","id_server","getIdentityServerUrl","medium","invite_3pid","push","spinner","createRoom"],"sources":["../../../src/utils/dm/startDm.ts"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport { IInvite3PID, MatrixClient, Room } from \"matrix-js-sdk/src/matrix\";\nimport { Optional } from \"matrix-events-sdk\";\n\nimport { Action } from \"../../dispatcher/actions\";\nimport { ViewRoomPayload } from \"../../dispatcher/payloads/ViewRoomPayload\";\nimport { determineCreateRoomEncryptionOption, Member } from \"../direct-messages\";\nimport DMRoomMap from \"../DMRoomMap\";\nimport { isLocalRoom } from \"../localRoom/isLocalRoom\";\nimport { findDMForUser } from \"./findDMForUser\";\nimport dis from \"../../dispatcher/dispatcher\";\nimport { getAddressType } from \"../../UserAddress\";\nimport createRoom, { IOpts } from \"../../createRoom\";\n\n/**\n * Start a DM.\n *\n * @returns {Promise<string | null} Resolves to the room id.\n */\nexport async function startDm(client: MatrixClient, targets: Member[], showSpinner = true): Promise<string | null> {\n    const targetIds = targets.map((t) => t.userId);\n\n    // Check if there is already a DM with these people and reuse it if possible.\n    let existingRoom: Optional<Room>;\n    if (targetIds.length === 1) {\n        existingRoom = findDMForUser(client, targetIds[0]);\n    } else {\n        existingRoom = DMRoomMap.shared().getDMRoomForIdentifiers(targetIds) ?? undefined;\n    }\n    if (existingRoom && !isLocalRoom(existingRoom)) {\n        dis.dispatch<ViewRoomPayload>({\n            action: Action.ViewRoom,\n            room_id: existingRoom.roomId,\n            should_peek: false,\n            joining: false,\n            metricsTrigger: \"MessageUser\",\n        });\n        return Promise.resolve(existingRoom.roomId);\n    }\n\n    const createRoomOptions: IOpts = { inlineErrors: true };\n\n    if (await determineCreateRoomEncryptionOption(client, targets)) {\n        createRoomOptions.encryption = true;\n    }\n\n    // Check if it's a traditional DM and create the room if required.\n    // TODO: [Canonical DMs] Remove this check and instead just create the multi-person DM\n    const isSelf = targetIds.length === 1 && targetIds[0] === client.getUserId();\n    if (targetIds.length === 1 && !isSelf) {\n        createRoomOptions.dmUserId = targetIds[0];\n    }\n\n    if (targetIds.length > 1) {\n        createRoomOptions.createOpts = targetIds.reduce<{\n            invite_3pid: IInvite3PID[];\n            invite: string[];\n        }>(\n            (roomOptions, address) => {\n                const type = getAddressType(address);\n                if (type === \"email\") {\n                    const invite: IInvite3PID = {\n                        id_server: client.getIdentityServerUrl(true)!,\n                        medium: \"email\",\n                        address,\n                    };\n                    roomOptions.invite_3pid.push(invite);\n                } else if (type === \"mx-user-id\") {\n                    roomOptions.invite.push(address);\n                }\n                return roomOptions;\n            },\n            { invite: [], invite_3pid: [] },\n        );\n    }\n\n    createRoomOptions.spinner = showSpinner;\n    return createRoom(client, createRoomOptions);\n}\n"],"mappings":"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","ignoreList":[]}