emoji.ts 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. export const emojiList = [
  2. { name: '[笑掉牙]', file: 'xiaodiaoya.png' },
  3. { name: '[可爱]', file: 'keai.png' },
  4. { name: '[冷酷]', file: 'lengku.png' },
  5. { name: '[闭嘴]', file: 'bizui.png' },
  6. { name: '[生气]', file: 'shengqi.png' },
  7. { name: '[惊恐]', file: 'jingkong.png' },
  8. { name: '[瞌睡]', file: 'keshui.png' },
  9. { name: '[大笑]', file: 'daxiao.png' },
  10. { name: '[爱心]', file: 'aixin.png' },
  11. { name: '[坏笑]', file: 'huaixiao.png' },
  12. { name: '[飞吻]', file: 'feiwen.png' },
  13. { name: '[疑问]', file: 'yiwen.png' },
  14. { name: '[开心]', file: 'kaixin.png' },
  15. { name: '[发呆]', file: 'fadai.png' },
  16. { name: '[流泪]', file: 'liulei.png' },
  17. { name: '[汗颜]', file: 'hanyan.png' },
  18. { name: '[惊悚]', file: 'jingshu.png' },
  19. { name: '[困~]', file: 'kun.png' },
  20. { name: '[心碎]', file: 'xinsui.png' },
  21. { name: '[天使]', file: 'tianshi.png' },
  22. { name: '[晕]', file: 'yun.png' },
  23. { name: '[啊]', file: 'a.png' },
  24. { name: '[愤怒]', file: 'fennu.png' },
  25. { name: '[睡着]', file: 'shuizhuo.png' },
  26. { name: '[面无表情]', file: 'mianwubiaoqing.png' },
  27. { name: '[难过]', file: 'nanguo.png' },
  28. { name: '[犯困]', file: 'fankun.png' },
  29. { name: '[好吃]', file: 'haochi.png' },
  30. { name: '[呕吐]', file: 'outu.png' },
  31. { name: '[龇牙]', file: 'ziya.png' },
  32. { name: '[懵比]', file: 'mengbi.png' },
  33. { name: '[白眼]', file: 'baiyan.png' },
  34. { name: '[饿死]', file: 'esi.png' },
  35. { name: '[凶]', file: 'xiong.png' },
  36. { name: '[感冒]', file: 'ganmao.png' },
  37. { name: '[流汗]', file: 'liuhan.png' },
  38. { name: '[笑哭]', file: 'xiaoku.png' },
  39. { name: '[流口水]', file: 'liukoushui.png' },
  40. { name: '[尴尬]', file: 'ganga.png' },
  41. { name: '[惊讶]', file: 'jingya.png' },
  42. { name: '[大惊]', file: 'dajing.png' },
  43. { name: '[不好意思]', file: 'buhaoyisi.png' },
  44. { name: '[大闹]', file: 'danao.png' },
  45. { name: '[不可思议]', file: 'bukesiyi.png' },
  46. { name: '[爱你]', file: 'aini.png' },
  47. { name: '[红心]', file: 'hongxin.png' },
  48. { name: '[点赞]', file: 'dianzan.png' },
  49. { name: '[恶魔]', file: 'emo.png' }
  50. ]
  51. export const emojiPage = {}
  52. emojiList.forEach((item, index) => {
  53. if (!emojiPage[Math.floor(index / 30) + 1]) {
  54. emojiPage[Math.floor(index / 30) + 1] = []
  55. }
  56. emojiPage[Math.floor(index / 30) + 1].push(item)
  57. })
  58. // 后端上传地址
  59. const staticUrl = import.meta.env.VITE_STATIC_URL
  60. // 处理表情
  61. export function replaceEmoji(data: string) {
  62. let newData = data
  63. if (typeof newData !== 'object') {
  64. const reg = /\[(.+?)\]/g // [] 中括号
  65. const zhEmojiName = newData.match(reg)
  66. if (zhEmojiName) {
  67. zhEmojiName.forEach((item) => {
  68. const emojiFile = selEmojiFile(item)
  69. newData = newData.replace(
  70. item,
  71. `<img class="chat-img" style="width: 24px;height: 24px;margin: 0 3px;" src="${
  72. staticUrl + '/static/img/chat/emoji/' + emojiFile
  73. }"/>`
  74. )
  75. })
  76. }
  77. }
  78. return newData
  79. }
  80. function selEmojiFile(name: string) {
  81. for (const index in emojiList) {
  82. if (emojiList[index].name === name) {
  83. return emojiList[index].file
  84. }
  85. }
  86. return false
  87. }