2018-02-28 08:18:07 +01:00
|
|
|
import { cacheFirstUpdateAfter } from '../_utils/sync'
|
2018-08-30 04:03:12 +02:00
|
|
|
import { database } from '../_database/database'
|
2018-02-28 08:18:07 +01:00
|
|
|
import { getCustomEmoji } from '../_api/emoji'
|
|
|
|
import { store } from '../_store/store'
|
|
|
|
|
|
|
|
export async function updateCustomEmojiForInstance (instanceName) {
|
|
|
|
await cacheFirstUpdateAfter(
|
|
|
|
() => getCustomEmoji(instanceName),
|
2018-08-30 04:03:12 +02:00
|
|
|
() => database.getCustomEmoji(instanceName),
|
|
|
|
emoji => database.setCustomEmoji(instanceName, emoji),
|
2018-02-28 08:18:07 +01:00
|
|
|
emoji => {
|
2018-04-19 18:37:05 +02:00
|
|
|
let { customEmoji } = store.get()
|
2018-02-28 08:18:07 +01:00
|
|
|
customEmoji[instanceName] = emoji
|
2018-08-30 06:42:57 +02:00
|
|
|
store.set({ customEmoji: customEmoji })
|
2018-02-28 08:18:07 +01:00
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2018-03-03 23:51:48 +01:00
|
|
|
export function insertEmoji (realm, emoji) {
|
2018-04-19 18:37:05 +02:00
|
|
|
let { composeSelectionStart } = store.get()
|
|
|
|
let idx = composeSelectionStart || 0
|
2018-04-18 03:38:36 +02:00
|
|
|
let oldText = store.getComposeData(realm, 'text') || ''
|
|
|
|
let pre = oldText.substring(0, idx)
|
|
|
|
let post = oldText.substring(idx)
|
2018-03-01 03:45:29 +01:00
|
|
|
let newText = `${pre}:${emoji.shortcode}: ${post}`
|
2018-08-30 06:42:57 +02:00
|
|
|
store.setComposeData(realm, { text: newText })
|
2018-02-28 08:18:07 +01:00
|
|
|
}
|