2021-01-12 09:15:10 +00:00
|
|
|
<template>
|
|
|
|
<i v-if="showWrap" :class="className">{{ iconContent }}</i>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import { hasEmojiSupport } from 'shared/helpers/emoji';
|
|
|
|
import { mapGetters } from 'vuex';
|
|
|
|
|
|
|
|
export default {
|
|
|
|
props: {
|
|
|
|
icon: { type: String, default: '' },
|
|
|
|
emoji: { type: String, default: '' },
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
...mapGetters({ uiSettings: 'getUISettings' }),
|
|
|
|
isIconTypeEmoji() {
|
2021-05-05 06:39:34 +00:00
|
|
|
const { icon_type: iconType } = this.uiSettings || {};
|
2021-01-12 09:15:10 +00:00
|
|
|
return iconType === 'emoji';
|
|
|
|
},
|
|
|
|
showEmoji() {
|
|
|
|
return this.isIconTypeEmoji && this.emoji && hasEmojiSupport(this.emoji);
|
|
|
|
},
|
|
|
|
showIcon() {
|
|
|
|
return !this.showEmoji && this.icon;
|
|
|
|
},
|
|
|
|
showWrap() {
|
|
|
|
return this.showEmoji || this.showIcon;
|
|
|
|
},
|
|
|
|
iconContent() {
|
|
|
|
return this.showEmoji ? this.emoji : '';
|
|
|
|
},
|
|
|
|
className() {
|
|
|
|
return {
|
|
|
|
'icon--emoji': this.showEmoji,
|
|
|
|
'icon--font': this.showIcon,
|
|
|
|
[this.icon]: this.showIcon,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
.icon--emoji {
|
|
|
|
font-style: normal;
|
|
|
|
}
|
|
|
|
</style>
|