|
|
@ -21,65 +21,61 @@ export default function suggest (data) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function suggestEmoji (emojis) {
|
|
|
|
export const suggestEmoji = (emojis) => input => {
|
|
|
|
return input => {
|
|
|
|
const noPrefix = input.toLowerCase().substr(1)
|
|
|
|
const noPrefix = input.toLowerCase().substr(1)
|
|
|
|
return emojis
|
|
|
|
return emojis
|
|
|
|
.filter(({ displayText }) => displayText.toLowerCase().startsWith(noPrefix))
|
|
|
|
.filter(({ displayText }) => displayText.toLowerCase().startsWith(noPrefix))
|
|
|
|
.sort((a, b) => {
|
|
|
|
.sort((a, b) => {
|
|
|
|
let aScore = 0
|
|
|
|
let aScore = 0
|
|
|
|
let bScore = 0
|
|
|
|
let bScore = 0
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Make custom emojis a priority
|
|
|
|
// Make custom emojis a priority
|
|
|
|
aScore += Number(!!a.imageUrl) * 10
|
|
|
|
aScore += a.imageUrl ? 10 : 0
|
|
|
|
bScore += Number(!!b.imageUrl) * 10
|
|
|
|
bScore += b.imageUrl ? 10 : 0
|
|
|
|
|
|
|
|
|
|
|
|
// Sort alphabetically
|
|
|
|
// Sort alphabetically
|
|
|
|
const alphabetically = a.displayText > b.displayText ? 1 : -1
|
|
|
|
const alphabetically = a.displayText > b.displayText ? 1 : -1
|
|
|
|
|
|
|
|
|
|
|
|
return bScore - aScore + alphabetically
|
|
|
|
return bScore - aScore + alphabetically
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function suggestUsers (users) {
|
|
|
|
export const suggestUsers = (users) => input => {
|
|
|
|
return input => {
|
|
|
|
const noPrefix = input.toLowerCase().substr(1)
|
|
|
|
const noPrefix = input.toLowerCase().substr(1)
|
|
|
|
return users.filter(
|
|
|
|
return users.filter(
|
|
|
|
user =>
|
|
|
|
user =>
|
|
|
|
user.screen_name.toLowerCase().startsWith(noPrefix) ||
|
|
|
|
user.screen_name.toLowerCase().startsWith(noPrefix) ||
|
|
|
|
user.name.toLowerCase().startsWith(noPrefix)
|
|
|
|
user.name.toLowerCase().startsWith(noPrefix)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* taking only 20 results so that sorting is a bit cheaper, we display
|
|
|
|
/* taking only 20 results so that sorting is a bit cheaper, we display
|
|
|
|
* only 5 anyway. could be inaccurate, but we ideally we should query
|
|
|
|
* only 5 anyway. could be inaccurate, but we ideally we should query
|
|
|
|
* backend anyway
|
|
|
|
* backend anyway
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
).slice(0, 20).sort((a, b) => {
|
|
|
|
).slice(0, 20).sort((a, b) => {
|
|
|
|
let aScore = 0
|
|
|
|
let aScore = 0
|
|
|
|
let bScore = 0
|
|
|
|
let bScore = 0
|
|
|
|
|
|
|
|
|
|
|
|
// Matches on screen name (i.e. user@instance) makes a priority
|
|
|
|
// Matches on screen name (i.e. user@instance) makes a priority
|
|
|
|
aScore += a.screen_name.toLowerCase().startsWith(noPrefix) * 2
|
|
|
|
aScore += a.screen_name.toLowerCase().startsWith(noPrefix) ? 2 : 0
|
|
|
|
bScore += b.screen_name.toLowerCase().startsWith(noPrefix) * 2
|
|
|
|
bScore += b.screen_name.toLowerCase().startsWith(noPrefix) ? 2 : 0
|
|
|
|
|
|
|
|
|
|
|
|
// Matches on name takes second priority
|
|
|
|
// Matches on name takes second priority
|
|
|
|
aScore += a.name.toLowerCase().startsWith(noPrefix)
|
|
|
|
aScore += a.name.toLowerCase().startsWith(noPrefix) ? 1 : 0
|
|
|
|
bScore += b.name.toLowerCase().startsWith(noPrefix)
|
|
|
|
bScore += b.name.toLowerCase().startsWith(noPrefix) ? 1 : 0
|
|
|
|
|
|
|
|
|
|
|
|
const diff = bScore * 10 - aScore * 10
|
|
|
|
const diff = (bScore - aScore) * 10
|
|
|
|
|
|
|
|
|
|
|
|
// Then sort alphabetically
|
|
|
|
// Then sort alphabetically
|
|
|
|
const nameAlphabetically = a.name > b.name ? 1 : -1
|
|
|
|
const nameAlphabetically = a.name > b.name ? 1 : -1
|
|
|
|
const screenNameAlphabetically = a.screen_name > b.screen_name ? 1 : -1
|
|
|
|
const screenNameAlphabetically = a.screen_name > b.screen_name ? 1 : -1
|
|
|
|
|
|
|
|
|
|
|
|
return diff + nameAlphabetically + screenNameAlphabetically
|
|
|
|
return diff + nameAlphabetically + screenNameAlphabetically
|
|
|
|
/* eslint-disable camelcase */
|
|
|
|
/* eslint-disable camelcase */
|
|
|
|
}).map(({ screen_name, name, profile_image_url_original }) => ({
|
|
|
|
}).map(({ screen_name, name, profile_image_url_original }) => ({
|
|
|
|
displayText: screen_name,
|
|
|
|
displayText: screen_name,
|
|
|
|
detailText: name,
|
|
|
|
detailText: name,
|
|
|
|
imageUrl: profile_image_url_original,
|
|
|
|
imageUrl: profile_image_url_original,
|
|
|
|
replacement: '@' + screen_name + ' '
|
|
|
|
replacement: '@' + screen_name + ' '
|
|
|
|
}))
|
|
|
|
}))
|
|
|
|
/* eslint-enable camelcase */
|
|
|
|
/* eslint-enable camelcase */
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|