pleroma-fe/src/components/emoji_input/emoji_input.vue

215 行
4.7 KiB
Vue
Raw 通常表示 履歴

2019-03-26 11:38:15 +09:00
<template>
2019-07-29 06:10:43 +09:00
<div
2021-06-08 06:09:16 +09:00
ref="root"
2019-07-29 06:10:43 +09:00
class="emoji-input"
:class="{ 'with-picker': !hideEmojiButton }"
>
2019-07-05 16:17:44 +09:00
<slot />
2022-10-10 04:09:50 +09:00
<!-- TODO: make the 'x' disappear if at the end maybe? -->
2022-11-22 05:17:33 +09:00
<div
ref="hiddenOverlay"
class="hidden-overlay"
:style="overlayStyle"
>
2022-10-10 04:09:50 +09:00
<span>{{ preText }}</span>
2022-11-22 05:17:33 +09:00
<span
ref="hiddenOverlayCaret"
class="caret"
>x</span>
2022-10-10 04:09:50 +09:00
<span>{{ postText }}</span>
</div>
2019-09-13 02:36:43 +09:00
<template v-if="enableEmojiPicker">
2020-11-24 21:52:01 +09:00
<button
2019-09-13 02:36:43 +09:00
v-if="!hideEmojiButton"
2020-11-24 21:52:01 +09:00
class="button-unstyled emoji-picker-icon"
type="button"
2021-02-25 21:32:21 +09:00
@click.prevent="togglePicker"
2019-07-29 06:10:43 +09:00
>
<FAIcon :icon="['far', 'smile-beam']" />
2020-11-24 21:52:01 +09:00
</button>
<EmojiPicker
2019-09-13 02:36:43 +09:00
v-if="enableEmojiPicker"
ref="picker"
2019-09-13 02:36:43 +09:00
:enable-sticker-picker="enableStickerPicker"
class="emoji-picker-panel"
@emoji="insert"
@sticker-uploaded="onStickerUploaded"
@sticker-upload-failed="onStickerUploadFailed"
@show="onPickerShown"
@close="onPickerClosed"
2019-07-29 06:10:43 +09:00
/>
</template>
2022-10-10 04:09:50 +09:00
<Popover
2022-11-22 05:17:33 +09:00
ref="suggestorPopover"
2019-07-05 16:17:44 +09:00
class="autocomplete-panel"
2022-10-10 04:09:50 +09:00
placement="bottom"
2019-07-05 16:17:44 +09:00
>
2022-10-10 04:09:50 +09:00
<template #content>
2019-07-05 16:17:44 +09:00
<div
2022-10-10 04:09:50 +09:00
ref="panel-body"
class="autocomplete-panel-body"
2019-03-26 11:38:15 +09:00
>
2022-10-10 04:09:50 +09:00
<div
v-for="(suggestion, index) in suggestions"
:key="index"
class="autocomplete-item"
2022-11-25 13:26:31 +09:00
role="button"
2022-10-10 04:09:50 +09:00
:class="{ highlighted: index === highlighted }"
@click.stop.prevent="onClick($event, suggestion)"
>
<span class="image">
<img
v-if="suggestion.img"
:src="suggestion.img"
>
<span v-else>{{ suggestion.replacement }}</span>
</span>
2022-10-10 04:09:50 +09:00
<div class="label">
<span
v-if="suggestion.user"
class="displayText"
>
{{ suggestion.displayText }}<UnicodeDomainIndicator
:user="suggestion.user"
:at="false"
/>
</span>
<span
v-if="!suggestion.user"
class="displayText"
>
{{ maybeLocalizedEmojiName(suggestion) }}
</span>
<span class="detailText">{{ suggestion.detailText }}</span>
</div>
2019-07-05 16:17:44 +09:00
</div>
2019-03-26 11:38:15 +09:00
</div>
2022-10-10 04:09:50 +09:00
</template>
</Popover>
2019-03-26 11:38:15 +09:00
</div>
</template>
2019-08-12 19:18:37 +09:00
<script src="./emoji_input.js"></script>
2019-03-26 11:38:15 +09:00
<style lang="scss">
2023-01-10 03:02:16 +09:00
@import "../../variables";
2019-03-26 11:38:15 +09:00
.emoji-input {
display: flex;
flex-direction: column;
position: relative;
.emoji-picker-icon {
position: absolute;
top: 0;
right: 0;
2023-01-10 03:02:16 +09:00
margin: 0.2em 0.25em;
2022-04-21 05:44:33 +09:00
font-size: 1.3em;
cursor: pointer;
line-height: 24px;
&:hover i {
color: $fallback--text;
color: var(--text, $fallback--text);
}
}
2022-10-10 04:09:50 +09:00
.emoji-picker-panel {
position: absolute;
z-index: 20;
margin-top: 2px;
&.hide {
2023-01-10 03:02:16 +09:00
display: none;
}
}
2023-01-10 03:02:16 +09:00
input,
textarea {
2019-06-10 03:23:56 +09:00
flex: 1 0 auto;
2019-03-26 11:38:15 +09:00
}
2022-10-10 04:09:50 +09:00
2023-01-10 03:02:16 +09:00
&.with-picker input {
padding-right: 30px;
}
2022-10-10 04:09:50 +09:00
.hidden-overlay {
opacity: 0;
pointer-events: none;
position: absolute;
top: 0;
bottom: 0;
right: 0;
left: 0;
overflow: hidden;
2023-01-10 03:02:16 +09:00
2022-10-10 04:09:50 +09:00
/* DEBUG STUFF */
color: red;
2023-01-10 03:02:16 +09:00
2022-10-10 04:09:50 +09:00
/* set opacity to non-zero to see the overlay */
.caret {
width: 0;
margin-right: calc(-1ch - 1px);
border: 1px solid red;
}
}
2019-03-26 11:38:15 +09:00
}
2023-01-10 03:02:16 +09:00
2022-10-10 05:02:42 +09:00
.autocomplete {
&-panel {
position: absolute;
}
&-item {
display: flex;
cursor: pointer;
padding: 0.2em 0.4em;
2023-01-10 03:02:16 +09:00
border-bottom: 1px solid rgb(0 0 0 / 40%);
2022-10-10 05:02:42 +09:00
height: 32px;
.image {
width: 32px;
height: 32px;
line-height: 32px;
text-align: center;
font-size: 32px;
margin-right: 4px;
img {
width: 32px;
height: 32px;
object-fit: contain;
}
}
.label {
display: flex;
flex-direction: column;
justify-content: center;
margin: 0 0.1em 0 0.2em;
.displayText {
line-height: 1.5;
}
.detailText {
font-size: 9px;
line-height: 9px;
}
}
&.highlighted {
background-color: $fallback--fg;
background-color: var(--selectedMenuPopover, $fallback--fg);
color: var(--selectedMenuPopoverText, $fallback--text);
2023-01-10 03:02:16 +09:00
2022-10-10 05:02:42 +09:00
--faint: var(--selectedMenuPopoverFaintText, $fallback--faint);
--faintLink: var(--selectedMenuPopoverFaintLink, $fallback--faint);
--lightText: var(--selectedMenuPopoverLightText, $fallback--lightText);
--icon: var(--selectedMenuPopoverIcon, $fallback--icon);
}
}
}
2019-03-26 11:38:15 +09:00
</style>