jormungandr-bite/src/client/app/admin/views/emoji.vue

146 lines
3.3 KiB
Vue
Raw Normal View History

2018-11-02 08:05:53 -06:00
<template>
<div class="tumhkfkmgtvzljezfvmgkeurkfncshbe">
2018-11-02 08:05:53 -06:00
<ui-card>
<div slot="title"><fa icon="plus"/> %i18n:@add-emoji.title%</div>
2018-11-02 08:05:53 -06:00
<section class="fit-top">
2018-11-03 23:23:28 -06:00
<ui-horizon-group inputs>
<ui-input v-model="name">
<span>%i18n:@add-emoji.name%</span>
<span slot="text">%i18n:@add-emoji.name-desc%</span>
</ui-input>
<ui-input v-model="aliases">
<span>%i18n:@add-emoji.aliases%</span>
<span slot="text">%i18n:@add-emoji.aliases-desc%</span>
</ui-input>
</ui-horizon-group>
2018-11-02 08:05:53 -06:00
<ui-input v-model="url">
<span>%i18n:@add-emoji.url%</span>
</ui-input>
<ui-info>%i18n:@add-emoji.info%</ui-info>
2018-11-02 08:05:53 -06:00
<ui-button @click="add">%i18n:@add-emoji.add%</ui-button>
</section>
</ui-card>
<ui-card>
<div slot="title"><fa :icon="['far', 'grin']"/> %i18n:@emojis.title%</div>
<section v-for="emoji in emojis">
<img :src="emoji.url" :alt="emoji.name" style="width: 64px;"/>
2018-11-03 23:23:28 -06:00
<ui-horizon-group inputs>
<ui-input v-model="emoji.name">
<span>%i18n:@add-emoji.name%</span>
</ui-input>
<ui-input v-model="emoji.aliases">
<span>%i18n:@add-emoji.aliases%</span>
</ui-input>
</ui-horizon-group>
<ui-input v-model="emoji.url">
<span>%i18n:@add-emoji.url%</span>
</ui-input>
2018-11-03 23:23:28 -06:00
<ui-horizon-group>
<ui-button @click="updateEmoji(emoji)"><fa :icon="['far', 'save']"/> %i18n:@emojis.update%</ui-button>
<ui-button @click="removeEmoji(emoji)"><fa :icon="['far', 'trash-alt']"/> %i18n:@emojis.remove%</ui-button>
2018-11-03 23:23:28 -06:00
</ui-horizon-group>
</section>
</ui-card>
2018-11-02 08:05:53 -06:00
</div>
</template>
<script lang="ts">
import Vue from "vue";
export default Vue.extend({
data() {
return {
name: '',
url: '',
aliases: '',
emojis: []
2018-11-02 08:05:53 -06:00
};
},
mounted() {
this.fetchEmojis();
},
2018-11-02 08:05:53 -06:00
methods: {
add() {
(this as any).api('admin/emoji/add', {
2018-11-02 08:05:53 -06:00
name: this.name,
url: this.url,
2018-11-04 21:23:30 -07:00
aliases: this.aliases.split(' ').filter(x => x.length > 0)
2018-11-02 08:05:53 -06:00
}).then(() => {
2018-11-04 18:32:45 -07:00
this.$swal({
type: 'success',
text: '%i18n:@add-emoji.added%'
});
this.fetchEmojis();
}).catch(e => {
2018-11-04 18:32:45 -07:00
this.$swal({
type: 'error',
text: e
});
});
},
fetchEmojis() {
(this as any).api('admin/emoji/list').then(emojis => {
2018-11-04 18:32:45 -07: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-04 21:23:30 -07:00
aliases: emoji.aliases.split(' ').filter(x => x.length > 0)
}).then(() => {
2018-11-04 18:32:45 -07:00
this.$swal({
type: 'success',
text: '%i18n:@updated%'
});
}).catch(e => {
2018-11-04 18:32:45 -07:00
this.$swal({
type: 'error',
text: e
});
});
},
removeEmoji(emoji) {
2018-11-04 18:32:45 -07:00
this.$swal({
type: 'warning',
text: '%i18n:@remove-emoji.are-you-sure%'.replace('$1', emoji.name),
showCancelButton: true
}).then(res => {
if (!res.value) return;
(this as any).api('admin/emoji/remove', {
id: emoji.id
}).then(() => {
this.$swal({
type: 'success',
text: '%i18n:@remove-emoji.removed%'
});
this.fetchEmojis();
}).catch(e => {
this.$swal({
type: 'error',
text: e
});
});
2018-11-02 08:05:53 -06:00
});
}
}
});
</script>
<style lang="stylus" scoped>
.tumhkfkmgtvzljezfvmgkeurkfncshbe
@media (min-width 500px)
padding 16px
</style>