misskey/src/client/app/admin/views/emoji.vue

171 lines
3.8 KiB
Vue
Raw Normal View History

2018-11-02 23:05:53 +09:00
<template>
2019-01-19 23:00:15 +09:00
<div>
2018-11-02 23:05:53 +09:00
<ui-card>
<div slot="title"><fa icon="plus"/> {{ $t('add-emoji.title') }}</div>
2018-11-02 23:05:53 +09:00
<section class="fit-top">
2018-11-04 14:23:28 +09:00
<ui-horizon-group inputs>
<ui-input v-model="name">
<span>{{ $t('add-emoji.name') }}</span>
<span slot="desc">{{ $t('add-emoji.name-desc') }}</span>
2018-11-04 14:23:28 +09:00
</ui-input>
<ui-input v-model="aliases">
<span>{{ $t('add-emoji.aliases') }}</span>
<span slot="desc">{{ $t('add-emoji.aliases-desc') }}</span>
2018-11-04 14:23:28 +09:00
</ui-input>
</ui-horizon-group>
2018-11-02 23:05:53 +09:00
<ui-input v-model="url">
2018-11-06 07:28:49 +09:00
<i slot="icon"><fa icon="link"/></i>
<span>{{ $t('add-emoji.url') }}</span>
2018-11-02 23:05:53 +09:00
</ui-input>
<ui-info>{{ $t('add-emoji.info') }}</ui-info>
<ui-button @click="add">{{ $t('add-emoji.add') }}</ui-button>
2018-11-02 23:05:53 +09:00
</section>
</ui-card>
<ui-card>
2018-11-14 14:57:59 +09:00
<div slot="title"><fa :icon="faGrin"/> {{ $t('emojis.title') }}</div>
2018-12-15 16:48:28 +09:00
<section v-for="emoji in emojis" class="oryfrbft">
<div>
<img :src="emoji.url" :alt="emoji.name" style="width: 64px;"/>
</div>
<div>
<ui-horizon-group>
<ui-input v-model="emoji.name">
<span>{{ $t('add-emoji.name') }}</span>
</ui-input>
<ui-input v-model="emoji.aliases">
<span>{{ $t('add-emoji.aliases') }}</span>
</ui-input>
</ui-horizon-group>
<ui-input v-model="emoji.url">
<i slot="icon"><fa icon="link"/></i>
<span>{{ $t('add-emoji.url') }}</span>
2018-11-04 14:23:28 +09:00
</ui-input>
2018-12-15 16:48:28 +09:00
<ui-horizon-group class="fit-bottom">
<ui-button @click="updateEmoji(emoji)"><fa :icon="['far', 'save']"/> {{ $t('emojis.update') }}</ui-button>
<ui-button @click="removeEmoji(emoji)"><fa :icon="['far', 'trash-alt']"/> {{ $t('emojis.remove') }}</ui-button>
</ui-horizon-group>
</div>
</section>
</ui-card>
2018-11-02 23:05:53 +09:00
</div>
</template>
<script lang="ts">
import Vue from 'vue';
import i18n from '../../i18n';
2018-11-14 14:57:59 +09:00
import { faGrin } from '@fortawesome/free-regular-svg-icons';
2018-11-02 23:05:53 +09:00
export default Vue.extend({
i18n: i18n('admin/views/emoji.vue'),
2018-11-02 23:05:53 +09:00
data() {
return {
name: '',
url: '',
aliases: '',
2018-11-14 14:57:59 +09:00
emojis: [],
faGrin
2018-11-02 23:05:53 +09:00
};
},
mounted() {
this.fetchEmojis();
},
2018-11-02 23:05:53 +09:00
methods: {
add() {
2018-11-09 08:13:34 +09:00
this.$root.api('admin/emoji/add', {
2018-11-02 23:05:53 +09:00
name: this.name,
url: this.url,
2018-11-05 13:23:30 +09:00
aliases: this.aliases.split(' ').filter(x => x.length > 0)
2018-11-02 23:05:53 +09:00
}).then(() => {
2018-12-02 15:28:52 +09:00
this.$root.dialog({
2018-11-05 10:32:45 +09:00
type: 'success',
text: this.$t('add-emoji.added')
2018-11-05 10:32:45 +09:00
});
this.fetchEmojis();
}).catch(e => {
2018-12-02 15:28:52 +09:00
this.$root.dialog({
2018-11-05 10:32:45 +09:00
type: 'error',
text: e
});
});
},
fetchEmojis() {
2018-11-09 08:13:34 +09:00
this.$root.api('admin/emoji/list').then(emojis => {
2018-11-05 10:32:45 +09:00
emojis.reverse();
for (const e of emojis) {
e.aliases = (e.aliases || []).join(' ');
}
this.emojis = emojis;
});
},
updateEmoji(emoji) {
2018-11-09 08:13:34 +09:00
this.$root.api('admin/emoji/update', {
id: emoji.id,
name: emoji.name,
url: emoji.url,
2018-11-05 13:23:30 +09:00
aliases: emoji.aliases.split(' ').filter(x => x.length > 0)
}).then(() => {
2018-12-02 15:28:52 +09:00
this.$root.dialog({
2018-11-05 10:32:45 +09:00
type: 'success',
text: this.$t('updated')
2018-11-05 10:32:45 +09:00
});
}).catch(e => {
2018-12-02 15:28:52 +09:00
this.$root.dialog({
2018-11-05 10:32:45 +09:00
type: 'error',
text: e
});
});
},
removeEmoji(emoji) {
2018-12-02 15:28:52 +09:00
this.$root.dialog({
2018-11-05 10:32:45 +09:00
type: 'warning',
text: this.$t('remove-emoji.are-you-sure').replace('$1', emoji.name),
2018-11-05 10:32:45 +09:00
showCancelButton: true
2018-12-02 20:10:53 +09:00
}).then(({ canceled }) => {
if (canceled) return;
2018-11-05 10:32:45 +09:00
2018-11-09 08:13:34 +09:00
this.$root.api('admin/emoji/remove', {
2018-11-05 10:32:45 +09:00
id: emoji.id
}).then(() => {
2018-12-02 15:28:52 +09:00
this.$root.dialog({
2018-11-05 10:32:45 +09:00
type: 'success',
text: this.$t('remove-emoji.removed')
2018-11-05 10:32:45 +09:00
});
this.fetchEmojis();
}).catch(e => {
2018-12-02 15:28:52 +09:00
this.$root.dialog({
2018-11-05 10:32:45 +09:00
type: 'error',
text: e
});
});
2018-11-02 23:05:53 +09:00
});
}
}
});
</script>
<style lang="stylus" scoped>
2019-01-19 23:00:15 +09:00
.oryfrbft
@media (min-width 500px)
2019-01-19 23:00:15 +09:00
display flex
2019-01-19 23:00:15 +09:00
> div:first-child
@media (max-width 500px)
padding-bottom 16px
2018-12-15 16:48:28 +09:00
2019-01-19 23:00:15 +09:00
> img
vertical-align bottom
2018-12-15 16:48:28 +09:00
2019-01-19 23:00:15 +09:00
> div:last-child
flex 1
2018-12-15 16:48:28 +09:00
2019-01-19 23:00:15 +09:00
@media (min-width 500px)
padding-left 16px
2018-12-15 16:48:28 +09:00
</style>