| 
									
										
										
										
											2018-04-04 20:33:17 -07:00
										 |  |  | <ModalDialog | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |   :id | 
					
						
							| 
									
										
										
										
											2018-04-04 20:33:17 -07:00
										 |  |  |   :label | 
					
						
							|  |  |  |   :title | 
					
						
							|  |  |  |   background="var(--main-bg)" | 
					
						
							|  |  |  | > | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |   <div class="custom-emoji-container"> | 
					
						
							|  |  |  |     {{#if emojis.length}} | 
					
						
							|  |  |  |       <ul class="custom-emoji-list"> | 
					
						
							|  |  |  |         {{#each emojis as emoji}} | 
					
						
							|  |  |  |           <li class="custom-emoji"> | 
					
						
							|  |  |  |             <button type="button" on:click="onClickEmoji(emoji)"> | 
					
						
							|  |  |  |               <img src="{{$autoplayGifs ? emoji.url : emoji.static_url}}" | 
					
						
							|  |  |  |                    alt=":{{emoji.shortcode}}:" | 
					
						
							|  |  |  |                    title=":{{emoji.shortcode}}:" | 
					
						
							|  |  |  |               /> | 
					
						
							|  |  |  |             </button> | 
					
						
							|  |  |  |           </li> | 
					
						
							|  |  |  |         {{/each}} | 
					
						
							|  |  |  |       </ul> | 
					
						
							|  |  |  |     {{else}} | 
					
						
							|  |  |  |       <div class="custom-emoji-no-emoji">No custom emoji found for this instance.</div> | 
					
						
							|  |  |  |     {{/if}} | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | </ModalDialog> | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   .custom-emoji-container { | 
					
						
							|  |  |  |     max-width: 100%; | 
					
						
							|  |  |  |     width: 400px; | 
					
						
							|  |  |  |     height: 300px; | 
					
						
							| 
									
										
										
										
											2018-04-01 23:41:35 -07:00
										 |  |  |     overflow: auto; | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |   } | 
					
						
							|  |  |  |   .custom-emoji-no-emoji { | 
					
						
							|  |  |  |     font-size: 1.3em; | 
					
						
							|  |  |  |     padding: 20px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .custom-emoji-list { | 
					
						
							|  |  |  |     list-style: none; | 
					
						
							|  |  |  |     display: grid; | 
					
						
							| 
									
										
										
										
											2018-02-28 18:45:29 -08:00
										 |  |  |     grid-template-columns: repeat(auto-fill, minmax(48px, 1fr)); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |     grid-gap: 5px; | 
					
						
							|  |  |  |     padding: 20px 10px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .custom-emoji button { | 
					
						
							|  |  |  |     padding: 0; | 
					
						
							|  |  |  |     margin: 0; | 
					
						
							|  |  |  |     border: none; | 
					
						
							|  |  |  |     cursor: pointer; | 
					
						
							|  |  |  |     box-shadow: none; | 
					
						
							|  |  |  |     background: none; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .custom-emoji img { | 
					
						
							|  |  |  |     width: 48px; | 
					
						
							|  |  |  |     height: 48px; | 
					
						
							|  |  |  |     object-fit: contain; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  |   import ModalDialog from './ModalDialog.html' | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |   import { store } from '../../../_store/store' | 
					
						
							|  |  |  |   import { insertEmoji } from '../../../_actions/emoji' | 
					
						
							|  |  |  |   import { show } from '../helpers/showDialog' | 
					
						
							|  |  |  |   import { close } from '../helpers/closeDialog' | 
					
						
							|  |  |  |   import { oncreate } from '../helpers/onCreateDialog' | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export default { | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |     oncreate, | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |     components: { | 
					
						
							|  |  |  |       ModalDialog | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     store: () => store, | 
					
						
							|  |  |  |     computed: { | 
					
						
							|  |  |  |       emojis: ($currentCustomEmoji) => { | 
					
						
							|  |  |  |         if (!$currentCustomEmoji) { | 
					
						
							|  |  |  |           return [] | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $currentCustomEmoji.filter(emoji => emoji.visible_in_picker) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |       show, | 
					
						
							|  |  |  |       close, | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |       onClickEmoji(emoji) { | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |         insertEmoji(this.get('realm'), emoji) | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |         this.close() | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </script> |