mirror of
https://github.com/vector-im/element-web.git
synced 2024-11-17 05:55:00 +08:00
7b7728c93a
* Pressing enter now always adds whatever was in the input box to the invite list, if it's a valid address (previously it added it to the list of it was a search result but submitted the form straight away if there were no results). * Remove isValidAddress as it was only used in the context of testing whether its return value was true or null (where null meant "unsure") so just use getAddressType instead.
62 lines
1.8 KiB
JavaScript
62 lines
1.8 KiB
JavaScript
/*
|
|
Copyright 2016 OpenMarket Ltd
|
|
|
|
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 MatrixClientPeg from './MatrixClientPeg';
|
|
import MultiInviter from './utils/MultiInviter';
|
|
|
|
const emailRegex = /^\S+@\S+\.\S+$/;
|
|
|
|
export function getAddressType(inputText) {
|
|
const isEmailAddress = /^\S+@\S+\.\S+$/.test(inputText);
|
|
const isMatrixId = inputText[0] === '@' && inputText.indexOf(":") > 0;
|
|
|
|
// sanity check the input for user IDs
|
|
if (isEmailAddress) {
|
|
return 'email';
|
|
} else if (isMatrixId) {
|
|
return 'mx';
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
export function inviteToRoom(roomId, addr) {
|
|
const addrType = getAddressType(addr);
|
|
|
|
if (addrType == 'email') {
|
|
return MatrixClientPeg.get().inviteByEmail(roomId, addr);
|
|
} else if (addrType == 'mx') {
|
|
return MatrixClientPeg.get().invite(roomId, addr);
|
|
} else {
|
|
throw new Error('Unsupported address');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Invites multiple addresses to a room
|
|
* Simpler interface to utils/MultiInviter but with
|
|
* no option to cancel.
|
|
*
|
|
* @param {roomId} The ID of the room to invite to
|
|
* @param {array} Array of strings of addresses to invite. May be matrix IDs or 3pids.
|
|
* @returns Promise
|
|
*/
|
|
export function inviteMultipleToRoom(roomId, addrs) {
|
|
this.inviter = new MultiInviter(roomId);
|
|
return this.inviter.invite(addrs);
|
|
}
|
|
|