2022-08-17 00:29:57 +00:00
|
|
|
let g_emojis;
|
|
|
|
|
|
|
|
function get_emojis() {
|
|
|
|
if (g_emojis) {
|
|
|
|
return Promise.resolve(g_emojis);
|
|
|
|
}
|
|
|
|
return fetch('emojis.json').then(function(result) {
|
|
|
|
g_emojis = result.json();
|
|
|
|
return g_emojis;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
export function picker(callback, anchor) {
|
|
|
|
get_emojis().then(function(json) {
|
|
|
|
let existing = document.getElementById('emoji_picker');
|
|
|
|
if (existing) {
|
|
|
|
existing.parentElement.removeChild(existing);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
let div = document.createElement('div');
|
|
|
|
div.id = 'emoji_picker';
|
|
|
|
div.style.color = '#000';
|
|
|
|
div.style.background = '#fff';
|
|
|
|
div.style.border = '1px solid #000';
|
|
|
|
div.style.display = 'block';
|
|
|
|
div.style.position = 'absolute';
|
|
|
|
div.style.maxWidth = '16em';
|
|
|
|
div.style.maxHeight = '16em';
|
|
|
|
div.style.overflow = 'scroll';
|
|
|
|
div.style.fontWeight = 'bold';
|
2022-08-18 00:23:56 +00:00
|
|
|
let input = document.createElement('input');
|
|
|
|
input.type = 'text';
|
|
|
|
div.appendChild(input);
|
|
|
|
let list = document.createElement('div');
|
|
|
|
div.appendChild(list);
|
|
|
|
function refresh() {
|
|
|
|
while (list.firstChild) {
|
|
|
|
list.removeChild(list.firstChild);
|
2022-08-17 00:29:57 +00:00
|
|
|
}
|
2022-08-18 00:23:56 +00:00
|
|
|
let search = input.value;
|
|
|
|
console.log('refrsh', search);
|
|
|
|
Object.entries(json).forEach(function(row) {
|
|
|
|
let header = document.createElement('div');
|
|
|
|
header.appendChild(document.createTextNode(row[0]));
|
|
|
|
list.appendChild(header);
|
|
|
|
let any = false;
|
|
|
|
for (let entry of row[1]) {
|
|
|
|
if (search &&
|
|
|
|
search.length &&
|
|
|
|
entry.name.indexOf(search) == -1) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
let emoji = document.createElement('span');
|
|
|
|
const k_size = '1.25em';
|
|
|
|
emoji.style.width = k_size;
|
|
|
|
emoji.style.maxWidth = k_size;
|
|
|
|
emoji.style.minWidth = k_size;
|
|
|
|
emoji.style.height = k_size;
|
|
|
|
emoji.style.maxHeight = k_size;
|
|
|
|
emoji.style.minHeight = k_size;
|
|
|
|
emoji.style.display = 'inline-block';
|
|
|
|
emoji.style.overflow = 'hidden';
|
|
|
|
emoji.style.cursor = 'pointer';
|
|
|
|
emoji.onclick = function() {
|
|
|
|
callback(entry);
|
|
|
|
div.parentElement.removeChild(div);
|
|
|
|
}
|
|
|
|
emoji.title = entry.name;
|
|
|
|
emoji.appendChild(document.createTextNode(entry.emoji));
|
|
|
|
list.appendChild(emoji);
|
|
|
|
any = true;
|
|
|
|
}
|
|
|
|
if (!any) {
|
|
|
|
list.removeChild(header);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
refresh();
|
|
|
|
input.oninput = refresh;
|
2022-08-17 00:29:57 +00:00
|
|
|
document.body.appendChild(div);
|
|
|
|
if (anchor) {
|
|
|
|
let rect = anchor.getBoundingClientRect();
|
2022-08-18 00:23:56 +00:00
|
|
|
if (rect.top < window.innerHeight / 2) {
|
2022-08-17 00:29:57 +00:00
|
|
|
div.style.top = rect.bottom + 'px';
|
|
|
|
} else {
|
|
|
|
div.style.top = (rect.top - div.clientHeight) + 'px';
|
|
|
|
}
|
|
|
|
if (rect.left < window.clientWidth / 2) {
|
|
|
|
div.style.left = rect.left + 'px';
|
|
|
|
} else {
|
|
|
|
div.style.left = (rect.left - div.clientWidth) + 'px';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|