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

150 lines
3.5 KiB
Vue
Raw Normal View History

2018-11-02 23:05:53 +09:00
<template>
<div class="tumhkfkmgtvzljezfvmgkeurkfncshbe">
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>
<div slot="title"><fa :icon="['far', 'grin']"/> {{ $t('emojis.title') }}</div>
<section v-for="emoji in emojis">
<img :src="emoji.url" :alt="emoji.name" style="width: 64px;"/>
2018-11-04 14:23:28 +09:00
<ui-horizon-group inputs>
<ui-input v-model="emoji.name">
<span>{{ $t('add-emoji.name') }}</span>
2018-11-04 14:23:28 +09:00
</ui-input>
<ui-input v-model="emoji.aliases">
<span>{{ $t('add-emoji.aliases') }}</span>
2018-11-04 14:23:28 +09:00
</ui-input>
</ui-horizon-group>
<ui-input v-model="emoji.url">
2018-11-06 07:28:49 +09:00
<i slot="icon"><fa icon="link"/></i>
<span>{{ $t('add-emoji.url') }}</span>
</ui-input>
2018-11-04 14:23:28 +09:00
<ui-horizon-group>
<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>
2018-11-04 14:23:28 +09:00
</ui-horizon-group>
</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-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: '',
emojis: []
2018-11-02 23:05:53 +09:00
};
},
mounted() {
this.fetchEmojis();
},
2018-11-02 23:05:53 +09:00
methods: {
add() {
(this as any).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-11-05 10:32:45 +09:00
this.$swal({
type: 'success',
text: this.$t('add-emoji.added')
2018-11-05 10:32:45 +09:00
});
this.fetchEmojis();
}).catch(e => {
2018-11-05 10:32:45 +09:00
this.$swal({
type: 'error',
text: e
});
});
},
fetchEmojis() {
(this as any).api('admin/emoji/list').then(emojis => {
2018-11-05 10:32:45 +09:00
emojis.reverse();
emojis.forEach(e => e.aliases = (e.aliases || []).join(' '));
this.emojis = emojis;
});
},
updateEmoji(emoji) {
(this as any).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-11-05 10:32:45 +09:00
this.$swal({
type: 'success',
text: this.$t('updated')
2018-11-05 10:32:45 +09:00
});
}).catch(e => {
2018-11-05 10:32:45 +09:00
this.$swal({
type: 'error',
text: e
});
});
},
removeEmoji(emoji) {
2018-11-05 10:32:45 +09:00
this.$swal({
type: 'warning',
text: this.$t('remove-emoji.are-you-sure').replace('$1', emoji.name),
2018-11-05 10:32:45 +09:00
showCancelButton: true
}).then(res => {
if (!res.value) return;
(this as any).api('admin/emoji/remove', {
id: emoji.id
}).then(() => {
this.$swal({
type: 'success',
text: this.$t('remove-emoji.removed')
2018-11-05 10:32:45 +09:00
});
this.fetchEmojis();
}).catch(e => {
this.$swal({
type: 'error',
text: e
});
});
2018-11-02 23:05:53 +09:00
});
}
}
});
</script>
<style lang="stylus" scoped>
.tumhkfkmgtvzljezfvmgkeurkfncshbe
@media (min-width 500px)
padding 16px
</style>