2023-04-22 17:32:34 +02:00
|
|
|
import emojis from '../../../assets/emoji.json';
|
2024-10-29 10:20:49 +01:00
|
|
|
import {GET} from '../modules/fetch.ts';
|
2024-10-30 21:06:36 +01:00
|
|
|
import type {Issue} from '../features/issue.ts';
|
2023-04-22 17:32:34 +02:00
|
|
|
|
|
|
|
const maxMatches = 6;
|
|
|
|
|
2024-10-29 10:20:49 +01:00
|
|
|
function sortAndReduce<T>(map: Map<T, number>): T[] {
|
2023-05-18 03:14:31 +02:00
|
|
|
const sortedMap = new Map(Array.from(map.entries()).sort((a, b) => a[1] - b[1]));
|
2023-04-22 17:32:34 +02:00
|
|
|
return Array.from(sortedMap.keys()).slice(0, maxMatches);
|
|
|
|
}
|
|
|
|
|
2024-08-28 18:32:38 +02:00
|
|
|
export function matchEmoji(queryText: string): string[] {
|
2023-04-22 17:32:34 +02:00
|
|
|
const query = queryText.toLowerCase().replaceAll('_', ' ');
|
|
|
|
if (!query) return emojis.slice(0, maxMatches).map((e) => e.aliases[0]);
|
|
|
|
|
|
|
|
// results is a map of weights, lower is better
|
2024-08-28 18:32:38 +02:00
|
|
|
const results = new Map<string, number>();
|
2023-04-22 17:32:34 +02:00
|
|
|
for (const {aliases} of emojis) {
|
|
|
|
const mainAlias = aliases[0];
|
|
|
|
for (const [aliasIndex, alias] of aliases.entries()) {
|
|
|
|
const index = alias.replaceAll('_', ' ').indexOf(query);
|
|
|
|
if (index === -1) continue;
|
|
|
|
const existing = results.get(mainAlias);
|
|
|
|
const rankedIndex = index + aliasIndex;
|
|
|
|
results.set(mainAlias, existing ? existing - rankedIndex : rankedIndex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return sortAndReduce(results);
|
|
|
|
}
|
|
|
|
|
2024-10-29 10:20:49 +01:00
|
|
|
type MentionSuggestion = {value: string; name: string; fullname: string; avatar: string};
|
|
|
|
export function matchMention(queryText: string): MentionSuggestion[] {
|
2023-04-22 17:32:34 +02:00
|
|
|
const query = queryText.toLowerCase();
|
|
|
|
|
|
|
|
// results is a map of weights, lower is better
|
2024-10-29 10:20:49 +01:00
|
|
|
const results = new Map<MentionSuggestion, number>();
|
2023-08-12 10:36:23 +02:00
|
|
|
for (const obj of window.config.mentionValues ?? []) {
|
2023-04-22 17:32:34 +02:00
|
|
|
const index = obj.key.toLowerCase().indexOf(query);
|
|
|
|
if (index === -1) continue;
|
|
|
|
const existing = results.get(obj);
|
|
|
|
results.set(obj, existing ? existing - index : index);
|
|
|
|
}
|
|
|
|
|
|
|
|
return sortAndReduce(results);
|
|
|
|
}
|
2024-10-29 10:20:49 +01:00
|
|
|
|
|
|
|
export async function matchIssue(owner: string, repo: string, issueIndexStr: string, query: string): Promise<Issue[]> {
|
|
|
|
const res = await GET(`${window.config.appSubUrl}/${owner}/${repo}/issues/suggestions?q=${encodeURIComponent(query)}`);
|
|
|
|
|
|
|
|
const issues: Issue[] = await res.json();
|
2024-10-30 21:06:36 +01:00
|
|
|
const issueNumber = parseInt(issueIndexStr);
|
2024-10-29 10:20:49 +01:00
|
|
|
|
|
|
|
// filter out issue with same id
|
2024-10-30 21:06:36 +01:00
|
|
|
return issues.filter((i) => i.number !== issueNumber);
|
2024-10-29 10:20:49 +01:00
|
|
|
}
|