[Client] Improve Emoji management page of admin panel
This commit is contained in:
		
							parent
							
								
									3487ddabea
								
							
						
					
					
						commit
						dfce5bc0af
					
				
					 2 changed files with 65 additions and 1 deletions
				
			
		| 
						 | 
					@ -1142,6 +1142,10 @@ admin/views/emoji.vue:
 | 
				
			||||||
    aliases-desc: "スペースで区切って複数設定できます。"
 | 
					    aliases-desc: "スペースで区切って複数設定できます。"
 | 
				
			||||||
    url: "絵文字画像URL"
 | 
					    url: "絵文字画像URL"
 | 
				
			||||||
    add: "追加"
 | 
					    add: "追加"
 | 
				
			||||||
 | 
					  emojis:
 | 
				
			||||||
 | 
					    title: "絵文字一覧"
 | 
				
			||||||
 | 
					    update: "更新"
 | 
				
			||||||
 | 
					    remove: "削除"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
admin/views/announcements.vue:
 | 
					admin/views/announcements.vue:
 | 
				
			||||||
  announcements: "お知らせ"
 | 
					  announcements: "お知らせ"
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -17,6 +17,28 @@
 | 
				
			||||||
			<ui-button @click="add">%i18n:@add-emoji.add%</ui-button>
 | 
								<ui-button @click="add">%i18n:@add-emoji.add%</ui-button>
 | 
				
			||||||
		</section>
 | 
							</section>
 | 
				
			||||||
	</ui-card>
 | 
						</ui-card>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						<ui-card>
 | 
				
			||||||
 | 
							<div slot="title">%fa:grin R% %i18n:@emojis.title%</div>
 | 
				
			||||||
 | 
							<section v-for="emoji in emojis">
 | 
				
			||||||
 | 
								<img :src="emoji.url" :alt="emoji.name" style="width: 64px;"/>
 | 
				
			||||||
 | 
								<ui-input v-model="emoji.name">
 | 
				
			||||||
 | 
									<span>%i18n:@add-emoji.name%</span>
 | 
				
			||||||
 | 
									<span slot="text">%i18n:@add-emoji.name-desc%</span>
 | 
				
			||||||
 | 
								</ui-input>
 | 
				
			||||||
 | 
								<ui-input v-model="emoji.aliases">
 | 
				
			||||||
 | 
									<span>%i18n:@add-emoji.aliases%</span>
 | 
				
			||||||
 | 
									<span slot="text">%i18n:@add-emoji.aliases-desc%</span>
 | 
				
			||||||
 | 
								</ui-input>
 | 
				
			||||||
 | 
								<ui-input v-model="emoji.url">
 | 
				
			||||||
 | 
									<span>%i18n:@add-emoji.url%</span>
 | 
				
			||||||
 | 
								</ui-input>
 | 
				
			||||||
 | 
								<ui-button-group>
 | 
				
			||||||
 | 
									<ui-button inline @click="updateEmoji(emoji)">%fa:save R% %i18n:@emojis.update%</ui-button>
 | 
				
			||||||
 | 
									<ui-button inline @click="removeEmoji(emoji)">%fa:trash-alt R% %i18n:@emojis.remove%</ui-button>
 | 
				
			||||||
 | 
								</ui-button-group>
 | 
				
			||||||
 | 
							</section>
 | 
				
			||||||
 | 
						</ui-card>
 | 
				
			||||||
</div>
 | 
					</div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -29,16 +51,54 @@ export default Vue.extend({
 | 
				
			||||||
			name: '',
 | 
								name: '',
 | 
				
			||||||
			url: '',
 | 
								url: '',
 | 
				
			||||||
			aliases: '',
 | 
								aliases: '',
 | 
				
			||||||
 | 
								emojis: []
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mounted() {
 | 
				
			||||||
 | 
							this.fetchEmojis();
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	methods: {
 | 
						methods: {
 | 
				
			||||||
		add() {
 | 
							add() {
 | 
				
			||||||
			(this as any).api('admin/add-emoji', {
 | 
								(this as any).api('admin/emoji/add', {
 | 
				
			||||||
				name: this.name,
 | 
									name: this.name,
 | 
				
			||||||
				url: this.url,
 | 
									url: this.url,
 | 
				
			||||||
				aliases: this.aliases.split(' ')
 | 
									aliases: this.aliases.split(' ')
 | 
				
			||||||
			}).then(() => {
 | 
								}).then(() => {
 | 
				
			||||||
				(this as any).os.apis.dialog({ text: `Added` });
 | 
									(this as any).os.apis.dialog({ text: `Added` });
 | 
				
			||||||
 | 
									this.fetchEmojis();
 | 
				
			||||||
 | 
								}).catch(e => {
 | 
				
			||||||
 | 
									(this as any).os.apis.dialog({ text: `Failed ${e}` });
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							fetchEmojis() {
 | 
				
			||||||
 | 
								(this as any).api('admin/emoji/list').then(emojis => {
 | 
				
			||||||
 | 
									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,
 | 
				
			||||||
 | 
									aliases: emoji.aliases.split(' ')
 | 
				
			||||||
 | 
								}).then(() => {
 | 
				
			||||||
 | 
									(this as any).os.apis.dialog({ text: `Updated` });
 | 
				
			||||||
 | 
								}).catch(e => {
 | 
				
			||||||
 | 
									(this as any).os.apis.dialog({ text: `Failed ${e}` });
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							removeEmoji(emoji) {
 | 
				
			||||||
 | 
								(this as any).api('admin/emoji/remove', {
 | 
				
			||||||
 | 
									id: emoji.id
 | 
				
			||||||
 | 
								}).then(() => {
 | 
				
			||||||
 | 
									(this as any).os.apis.dialog({ text: `Removed` });
 | 
				
			||||||
 | 
									this.fetchEmojis();
 | 
				
			||||||
			}).catch(e => {
 | 
								}).catch(e => {
 | 
				
			||||||
				(this as any).os.apis.dialog({ text: `Failed ${e}` });
 | 
									(this as any).os.apis.dialog({ text: `Failed ${e}` });
 | 
				
			||||||
			});
 | 
								});
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue