import { cacheFirstUpdateAfter } from '../_utils/sync' import { database } from '../_database/database' import { getCustomEmoji } from '../_api/emoji' import { store } from '../_store/store' import { substring } from 'stringz' export async function updateCustomEmojiForInstance (instanceName) { await cacheFirstUpdateAfter( () => getCustomEmoji(instanceName), () => database.getCustomEmoji(instanceName), emoji => database.setCustomEmoji(instanceName, emoji), emoji => { let customEmoji = store.get('customEmoji') customEmoji[instanceName] = emoji store.set({customEmoji: customEmoji}) } ) } export function insertEmoji (realm, emoji) { let idx = store.get('composeSelectionStart') || 0 let oldText = store.getComposeData(realm, 'text') let pre = oldText ? substring(oldText, 0, idx) : '' let post = oldText ? substring(oldText, idx) : '' let newText = `${pre}:${emoji.shortcode}: ${post}` store.setComposeData(realm, {text: newText}) } export function insertEmojiAtPosition (realm, emoji, startIndex, endIndex) { let oldText = store.getComposeData(realm, 'text') let pre = oldText ? substring(oldText, 0, startIndex) : '' let post = oldText ? substring(oldText, endIndex) : '' let newText = `${pre}:${emoji.shortcode}: ${post}` store.setComposeData(realm, {text: newText}) } export async function clickSelectedAutosuggestionEmoji (realm) { let selectionStart = store.get('composeSelectionStart') let searchText = store.get('composeAutosuggestionSearchText') let selection = store.get('composeAutosuggestionSelected') || 0 let emoji = store.get('composeAutosuggestionSearchResults')[selection] let startIndex = selectionStart - searchText.length let endIndex = selectionStart await insertEmojiAtPosition(realm, emoji, startIndex, endIndex) }