mirror of
https://github.com/SillyTavern/SillyTavern.git
synced 2025-01-19 04:50:12 +01:00
add font-awesome picker popup
This commit is contained in:
parent
98dfd25ee7
commit
25c8002e9e
@ -3,7 +3,7 @@ import { getRequestHeaders } from '../script.js';
|
||||
import { isMobile } from './RossAscends-mods.js';
|
||||
import { collapseNewlines } from './power-user.js';
|
||||
import { debounce_timeout } from './constants.js';
|
||||
import { Popup } from './popup.js';
|
||||
import { Popup, POPUP_RESULT, POPUP_TYPE } from './popup.js';
|
||||
|
||||
/**
|
||||
* Pagination status string template.
|
||||
@ -1882,3 +1882,68 @@ export function getFreeName(name, list, numberFormatter = (n) => ` #${n}`) {
|
||||
}
|
||||
return `${name}${numberFormatter(counter)}`;
|
||||
}
|
||||
|
||||
export async function showFontAwesomePicker() {
|
||||
const fetchFa = async(name)=>{
|
||||
const style = document.createElement('style');
|
||||
style.innerHTML = await (await fetch(`/css/${name}`)).text();
|
||||
document.head.append(style);
|
||||
const sheet = style.sheet;
|
||||
style.remove();
|
||||
return [...sheet.cssRules].filter(it=>it.style?.content).map(it=>it.selectorText.split('::').shift().slice(1));
|
||||
};
|
||||
const faList = [...new Set((await Promise.all([
|
||||
fetchFa('fontawesome.min.css'),
|
||||
])).flat())];
|
||||
const fas = {};
|
||||
const dom = document.createElement('div'); {
|
||||
const search = document.createElement('div'); {
|
||||
const qry = document.createElement('input'); {
|
||||
qry.classList.add('text_pole');
|
||||
qry.classList.add('faQuery');
|
||||
qry.type = 'search';
|
||||
qry.placeholder = 'Filter icons';
|
||||
qry.autofocus = true;
|
||||
const qryDebounced = debounce(()=>{
|
||||
const result = faList.filter(it=>it.includes(qry.value));
|
||||
for (const fa of faList) {
|
||||
if (!result.includes(fa)) {
|
||||
fas[fa].classList.add('hidden');
|
||||
} else {
|
||||
fas[fa].classList.remove('hidden');
|
||||
}
|
||||
}
|
||||
});
|
||||
qry.addEventListener('input', qryDebounced);
|
||||
search.append(qry);
|
||||
}
|
||||
dom.append(search);
|
||||
}
|
||||
const grid = document.createElement('div'); {
|
||||
grid.classList.add('faPicker');
|
||||
for (const fa of faList) {
|
||||
const opt = document.createElement('div'); {
|
||||
fas[fa] = opt;
|
||||
opt.classList.add('menu_button');
|
||||
opt.classList.add('fa-solid');
|
||||
opt.classList.add(fa);
|
||||
opt.title = fa.slice(3);
|
||||
opt.dataset.result = POPUP_RESULT.AFFIRMATIVE.toString();
|
||||
opt.addEventListener('click', ()=>{
|
||||
value = fa;
|
||||
picker.completeAffirmative();
|
||||
});
|
||||
grid.append(opt);
|
||||
}
|
||||
}
|
||||
dom.append(grid);
|
||||
}
|
||||
}
|
||||
let value;
|
||||
const picker = new Popup(dom, POPUP_TYPE.CONFIRM, null, { allowVerticalScrolling:true });
|
||||
await picker.show();
|
||||
if (picker.result == POPUP_RESULT.AFFIRMATIVE) {
|
||||
return value;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
@ -5322,3 +5322,23 @@ body:not(.movingUI) .drawer-content.maximized {
|
||||
.regex-highlight {
|
||||
color: #FAF8F6;
|
||||
}
|
||||
|
||||
.faPicker {
|
||||
display: flex;
|
||||
gap: 1em;
|
||||
flex-wrap: wrap;
|
||||
justify-content: space-between;
|
||||
|
||||
.menu_button {
|
||||
aspect-ratio: 1 / 1;
|
||||
font-size: 2em;
|
||||
height: 1lh;
|
||||
line-height: 1.2;
|
||||
padding: 0.25em;
|
||||
width: unset;
|
||||
box-sizing: content-box;
|
||||
&.stcdx--hidden {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user