Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
C
corporate-culture-qd
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
王立鹏
corporate-culture-qd
Commits
488d1643
Commit
488d1643
authored
Apr 03, 2026
by
lijiabin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
【需求 21133】 feat: 加入YAYA表情包
parent
7c1cf367
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
333 additions
and
216 deletions
+333
-216
index.vue
src/components/common/UploadEmojiIcon/index.vue
+139
-14
face.json
src/utils/emoji/face.json
+100
-200
index.ts
src/utils/emoji/index.ts
+12
-2
yaya.json
src/utils/emoji/yaya.json
+82
-0
No files found.
src/components/common/UploadEmojiIcon/index.vue
View file @
488d1643
<
script
setup
lang=
"ts"
>
import
{
computed
,
ref
}
from
'vue'
import
emojis
from
'@/utils/emoji/face.json'
import
yayas
from
'@/utils/emoji/yaya.json'
import
type
{
IEmoji
}
from
'@/utils/emoji/type'
const
emit
=
defineEmits
<
{
selectEmoji
:
[
emoji
:
IEmoji
]
}
>
()
type
EmojiTab
=
'face'
|
'yaya'
const
activeTab
=
ref
<
EmojiTab
>
(
'face'
)
const
emojiTabs
:
Array
<
{
key
:
EmojiTab
label
:
string
list
:
Array
<
Pick
<
IEmoji
,
'name'
|
'url'
|
'group'
>>
}
>
=
[
{
key
:
'face'
,
label
:
'默认表情'
,
list
:
emojis
,
},
{
key
:
'yaya'
,
label
:
'YAYA表情'
,
list
:
yayas
,
},
]
const
currentEmojiList
=
computed
(()
=>
{
return
emojiTabs
.
find
((
tab
)
=>
tab
.
key
===
activeTab
.
value
)?.
list
??
[]
})
</
script
>
<
template
>
<div
class=
"
w-8 h-8 text-gray-500 hover:bg-gray-100 hover:text-gray-700 rounded-lg flex items-center justify-center
"
class=
"
flex h-8 w-8 items-center justify-center rounded-lg text-gray-500 transition-all hover:bg-orange-50 hover:text-orange-500
"
>
<el-popover
placement=
"bottom"
trigger=
"click"
width=
"384
"
>
<el-popover
placement=
"bottom"
trigger=
"click"
:width=
"384"
popper-class=
"emoji-popover
"
>
<template
#
reference
>
<el-icon
size=
"20"
@
mousedown
.
prevent
>
<svg-icon
name=
"icon_face"
class=
"cursor-pointer"
/>
</el-icon>
<svg-icon
name=
"icon_face"
class=
"cursor-pointer"
/>
</el-icon>
</
template
>
<!-- 表情面板 -->
<el-scrollbar
class=
"h-50"
>
<div
class=
"flex flex-wrap"
>
<span
v-for=
"item in emojis"
<div
class=
"emoji-panel"
>
<div
class=
"emoji-tabs"
>
<button
v-for=
"tab in emojiTabs"
:key=
"tab.key"
type=
"button"
class=
"emoji-tab"
:class=
"{ 'emoji-tab--active': activeTab === tab.key }"
@
click=
"activeTab = tab.key"
>
{{ tab.label }}
</button>
</div>
<el-scrollbar
class=
"emoji-scrollbar"
>
<div
class=
"emoji-grid"
>
<button
v-for=
"item in currentEmojiList"
:key=
"item.name"
class=
"cursor-pointer hover:bg-gray-100 rounded p-1 flex items-center justify-center"
@
click=
"emit('selectEmoji', item)"
type=
"button"
class=
"emoji-item"
:title=
"item.name"
@
click=
"emit('selectEmoji', item as IEmoji)"
>
<img
:src=
"item.url"
alt=
""
class=
"w-6 h-6"
/>
</span>
<img
:src=
"item.url"
:alt=
"item.name"
class=
"h-6 w-6 object-contain"
:class=
"{ 'h-8 w-8': item.group === 'yaya' }"
/>
</button>
</div>
</el-scrollbar>
</div>
</el-popover>
</div>
</template>
<
style
scoped
></
style
>
<
style
scoped
>
.emoji-tabs
{
display
:
flex
;
align-items
:
center
;
gap
:
16px
;
margin-bottom
:
8px
;
padding
:
0
6px
8px
;
border-bottom
:
1px
solid
#f5f5f5
;
}
.emoji-tab
{
position
:
relative
;
border
:
0
;
background
:
transparent
;
color
:
#9ca3af
;
border-radius
:
0
;
font-size
:
12px
;
font-weight
:
500
;
cursor
:
pointer
;
transition
:
color
0.18s
ease
,
transform
0.18s
ease
;
}
.emoji-tab
:hover
{
color
:
#f97316
;
}
.emoji-tab--active
{
color
:
#ea580c
;
transform
:
none
;
}
.emoji-tab--active
::after
{
content
:
''
;
position
:
absolute
;
left
:
0
;
bottom
:
-9px
;
width
:
100%
;
height
:
2px
;
border-radius
:
999px
;
background
:
linear-gradient
(
90deg
,
#fb923c
0%
,
#f97316
100%
);
}
.emoji-scrollbar
{
height
:
188px
;
}
.emoji-grid
{
display
:
grid
;
grid-template-columns
:
repeat
(
8
,
minmax
(
0
,
1
fr
));
gap
:
6px
;
padding
:
2px
4px
10px
;
}
.emoji-item
{
display
:
flex
;
align-items
:
center
;
justify-content
:
center
;
width
:
100%
;
height
:
34px
;
border
:
0
;
border-radius
:
10px
;
background
:
#fff
;
cursor
:
pointer
;
transition
:
transform
0.18s
ease
,
background-color
0.18s
ease
,
box-shadow
0.18s
ease
;
}
.emoji-item
:hover
{
background
:
linear-gradient
(
180deg
,
#fff7ed
0%
,
#ffedd5
100%
);
box-shadow
:
0
6px
14px
rgb
(
251
146
60
/
16%
);
transform
:
translateY
(
-1px
);
}
</
style
>
src/utils/emoji/face.json
View file @
488d1643
...
...
@@ -2,601 +2,501 @@
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f600.png"
,
"name"
:
"[face_嘿嘿]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f603.png"
,
"name"
:
"[face_哈哈]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f604.png"
,
"name"
:
"[face_大笑]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f601.png"
,
"name"
:
"[face_嘻嘻]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f606.png"
,
"name"
:
"[face_斜眼笑]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f605.png"
,
"name"
:
"[face_苦笑]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f923.png"
,
"name"
:
"[face_笑得满地打滚]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f602.png"
,
"name"
:
"[face_笑哭了]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f642.png"
,
"name"
:
"[face_呵呵]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f643.png"
,
"name"
:
"[face_倒脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f609.png"
,
"name"
:
"[face_眨眼]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f60a.png"
,
"name"
:
"[face_羞涩微笑]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f607.png"
,
"name"
:
"[face_微笑天使]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f970.png"
,
"name"
:
"[face_喜笑颜开]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f60d.png"
,
"name"
:
"[face_花痴]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f929.png"
,
"name"
:
"[face_好崇拜哦]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f617.png"
,
"name"
:
"[face_亲亲]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f61a.png"
,
"name"
:
"[face_羞涩亲亲]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f619.png"
,
"name"
:
"[face_微笑亲亲]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f60b.png"
,
"name"
:
"[face_好吃]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f61b.png"
,
"name"
:
"[face_吐舌]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f61c.png"
,
"name"
:
"[face_单眼吐舌]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f92a.png"
,
"name"
:
"[face_滑稽]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f911.png"
,
"name"
:
"[face_发财]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f917.png"
,
"name"
:
"[face_抱抱]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f92d.png"
,
"name"
:
"[face_不说]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f92b.png"
,
"name"
:
"[face_安静的脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f914.png"
,
"name"
:
"[face_想一想]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f910.png"
,
"name"
:
"[face_闭嘴]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f928.png"
,
"name"
:
"[face_挑眉]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f610.png"
,
"name"
:
"[face_冷漠]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f611.png"
,
"name"
:
"[face_无语]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f636.png"
,
"name"
:
"[face_沉默]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f60f.png"
,
"name"
:
"[face_得意]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f612.png"
,
"name"
:
"[face_不高兴]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f644.png"
,
"name"
:
"[face_翻白眼]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f62c.png"
,
"name"
:
"[face_龇牙咧嘴]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f925.png"
,
"name"
:
"[face_说谎]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f60c.png"
,
"name"
:
"[face_松了口气]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f614.png"
,
"name"
:
"[face_沉思]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f62a.png"
,
"name"
:
"[face_困]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f634.png"
,
"name"
:
"[face_睡着了]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f637.png"
,
"name"
:
"[face_感冒]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f912.png"
,
"name"
:
"[face_发烧]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f915.png"
,
"name"
:
"[face_受伤]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f922.png"
,
"name"
:
"[face_恶心]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f92e.png"
,
"name"
:
"[face_呕吐]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f975.png"
,
"name"
:
"[face_脸发烧]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f976.png"
,
"name"
:
"[face_冷脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f974.png"
,
"name"
:
"[face_头昏眼花]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f92f.png"
,
"name"
:
"[face_爆炸头]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f920.png"
,
"name"
:
"[face_牛仔帽脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f973.png"
,
"name"
:
"[face_聚会笑脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f60e.png"
,
"name"
:
"[face_墨镜笑脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f913.png"
,
"name"
:
"[face_书呆子脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f9d0.png"
,
"name"
:
"[face_带单片眼镜的脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f615.png"
,
"name"
:
"[face_困扰]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f641.png"
,
"name"
:
"[face_微微不满]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/2639-fe0f.png"
,
"name"
:
"[face_不满]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f62f.png"
,
"name"
:
"[face_缄默]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f632.png"
,
"name"
:
"[face_震惊]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f633.png"
,
"name"
:
"[face_脸红]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f97a.png"
,
"name"
:
"[face_恳求的脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f626.png"
,
"name"
:
"[face_啊]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f627.png"
,
"name"
:
"[face_极度痛苦]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f628.png"
,
"name"
:
"[face_害怕]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f630.png"
,
"name"
:
"[face_冷汗]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f625.png"
,
"name"
:
"[face_失望但如释重负]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f622.png"
,
"name"
:
"[face_哭]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f62d.png"
,
"name"
:
"[face_放声大哭]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f631.png"
,
"name"
:
"[face_吓死了]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f616.png"
,
"name"
:
"[face_困惑]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f61e.png"
,
"name"
:
"[face_失望]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f613.png"
,
"name"
:
"[face_汗]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f629.png"
,
"name"
:
"[face_累死了]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f62b.png"
,
"name"
:
"[face_累]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f971.png"
,
"name"
:
"[face_打呵欠]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f624.png"
,
"name"
:
"[face_傲慢]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f621.png"
,
"name"
:
"[face_怒火中烧]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f620.png"
,
"name"
:
"[face_生气]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f92c.png"
,
"name"
:
"[face_嘴上有符号的脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f608.png"
,
"name"
:
"[face_恶魔微笑]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f47f.png"
,
"name"
:
"[face_生气的恶魔]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f480.png"
,
"name"
:
"[face_头骨]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/2620-fe0f.png"
,
"name"
:
"[face_骷髅]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f4a9.png"
,
"name"
:
"[face_大便]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f921.png"
,
"name"
:
"[face_小丑脸]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f479.png"
,
"name"
:
"[face_食人魔]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f47a.png"
,
"name"
:
"[face_小妖精]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f47b.png"
,
"name"
:
"[face_鬼]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f47d.png"
,
"name"
:
"[face_外星人]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f47e.png"
,
"name"
:
"[face_外星怪物]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f916.png"
,
"name"
:
"[face_机器人]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f63a.png"
,
"name"
:
"[face_大笑的猫]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f639.png"
,
"name"
:
"[face_笑出眼泪的猫]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f63b.png"
,
"name"
:
"[face_花痴的猫]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f63c.png"
,
"name"
:
"[face_奸笑的猫]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f63d.png"
,
"name"
:
"[face_亲亲猫]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f640.png"
,
"name"
:
"[face_疲倦的猫]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
},
{
"url"
:
"https://www.emojiall.com/images/60/skype/1f63f.png"
,
"name"
:
"[face_哭泣的猫]"
,
"group"
:
"face"
,
"className"
:
"emoji_small"
"group"
:
"face"
}
]
src/utils/emoji/index.ts
View file @
488d1643
import
emojis
from
'./face.json'
import
yayas
from
'./yaya.json'
type
EmojiAsset
=
{
name
:
string
url
:
string
group
:
string
}
const
emojiList
:
EmojiAsset
[]
=
[...
emojis
,
...
yayas
]
function
escapeHTML
(
str
:
string
)
{
return
str
.
replace
(
/&/g
,
'&'
).
replace
(
/</g
,
'<'
).
replace
(
/>/g
,
'>'
)
...
...
@@ -9,17 +18,18 @@ export const parseEmoji = (content: string) => {
let
html
=
escapeHTML
(
content
)
emoji
s
.
forEach
((
item
)
=>
{
emoji
List
.
forEach
((
item
)
=>
{
const
escapedName
=
item
.
name
.
replace
(
/
[
.*+?^${}()|[
\]\\]
/g
,
'
\\
$&'
)
const
reg
=
new
RegExp
(
escapedName
,
'g'
)
console
.
log
(
item
.
group
)
html
=
html
.
replace
(
reg
,
`<img
src="
${
item
.
url
}
"
alt="
${
item
.
name
}
"
class="
${
item
.
className
||
'emoji_small'
}
inline-block align-text-bottom w-6 h-6
"
class="
${
item
.
group
===
'yaya'
?
'w-8 h-8'
:
'w-6 h-6'
}
"
/>`
,
)
})
...
...
src/utils/emoji/yaya.json
0 → 100644
View file @
488d1643
[
{
"name"
:
"[YAYA_OK]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842153149.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_OK1]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842183051.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_OKK]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842204358.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_拜托]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842337245.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_点赞]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842370496.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_非常感谢]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842403468.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_恭喜]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842433720.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_恭喜1]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842456906.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_好滴]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842482423.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_加油]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842512339.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_焦急]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842540763.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_开心]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842564724.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_哭泣]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842593525.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_努力]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842629597.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_谢谢]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842649971.png"
,
"group"
:
"yaya"
},
{
"name"
:
"[YAYA_亚声人]"
,
"url"
:
"https://soundasia.oss-cn-shenzhen.aliyuncs.com/OA/png/2026/03/30/Common/1774842693166.png"
,
"group"
:
"yaya"
}
]
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment