| 
									
										
										
										
											2024-04-21 14:18:06 -04:00
										 |  |  | import {LitElement, html, unsafeHTML} from './lit-all.min.js'; | 
					
						
							|  |  |  | import {styles} from './tf-styles.js'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class TfReactionsModalElement extends LitElement { | 
					
						
							|  |  |  | 	static get properties() { | 
					
						
							|  |  |  | 		return { | 
					
						
							|  |  |  | 			users: {type: Object}, | 
					
						
							|  |  |  | 			votes: {type: Array}, | 
					
						
							|  |  |  | 		}; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	static styles = styles; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	constructor() { | 
					
						
							|  |  |  | 		super(); | 
					
						
							|  |  |  | 		this.votes = []; | 
					
						
							|  |  |  | 		this.users = {}; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	clear() { | 
					
						
							|  |  |  | 		this.votes = []; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	render() { | 
					
						
							|  |  |  | 		let self = this; | 
					
						
							| 
									
										
										
										
											2024-04-24 19:23:13 -04:00
										 |  |  | 		return this.votes?.length | 
					
						
							|  |  |  | 			? html` <div
 | 
					
						
							|  |  |  | 					class="w3-modal w3-animate-opacity" | 
					
						
							| 
									
										
										
										
											2024-12-22 14:45:16 -05:00
										 |  |  | 					style="display: block; box-sizing: border-box; z-index: 10" | 
					
						
							| 
									
										
										
										
											2024-10-16 12:34:32 -04:00
										 |  |  | 					@click=${this.clear} | 
					
						
							| 
									
										
										
										
											2024-04-24 19:23:13 -04:00
										 |  |  | 				> | 
					
						
							| 
									
										
										
										
											2024-10-23 15:38:49 -04:00
										 |  |  | 					<div | 
					
						
							|  |  |  | 						class="w3-modal-content w3-card-4 w3-theme-d1" | 
					
						
							|  |  |  | 						onclick="event.stopPropagation()" | 
					
						
							|  |  |  | 					> | 
					
						
							| 
									
										
										
										
											2024-04-24 19:23:13 -04:00
										 |  |  | 						<div class="w3-container w3-padding"> | 
					
						
							|  |  |  | 							<header class="w3-container"> | 
					
						
							|  |  |  | 								<h2>Reactions</h2> | 
					
						
							|  |  |  | 								<span class="w3-button w3-display-topright" @click=${this.clear} | 
					
						
							|  |  |  | 									>×</span | 
					
						
							|  |  |  | 								> | 
					
						
							|  |  |  | 							</header> | 
					
						
							|  |  |  | 							<ul class="w3-theme-dark w3-container w3-ul"> | 
					
						
							| 
									
										
										
										
											2025-04-20 09:35:39 -04:00
										 |  |  | 								${this.votes | 
					
						
							|  |  |  | 									.sort((x, y) => y.timestamp - x.timestamp) | 
					
						
							|  |  |  | 									.map( | 
					
						
							|  |  |  | 										(x) => html`
 | 
					
						
							|  |  |  | 											<li style="display: flex; flex-direction: row; gap: 4px"> | 
					
						
							|  |  |  | 												<span style="flex-basis: 3em" | 
					
						
							|  |  |  | 													>${x?.content?.vote?.expression}</span | 
					
						
							|  |  |  | 												> | 
					
						
							|  |  |  | 												<tf-user | 
					
						
							|  |  |  | 													style="flex: 1 1" | 
					
						
							|  |  |  | 													id=${x.author} | 
					
						
							|  |  |  | 													.users=${this.users} | 
					
						
							|  |  |  | 												></tf-user> | 
					
						
							|  |  |  | 												<span | 
					
						
							|  |  |  | 													style="flex-shrink: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis" | 
					
						
							|  |  |  | 													>${new Date(x?.timestamp).toLocaleString()}</span | 
					
						
							|  |  |  | 												> | 
					
						
							|  |  |  | 											</li> | 
					
						
							|  |  |  | 										`
 | 
					
						
							|  |  |  | 									)} | 
					
						
							| 
									
										
										
										
											2024-04-24 19:23:13 -04:00
										 |  |  | 							</ul> | 
					
						
							|  |  |  | 							<footer class="w3-container w3-padding"> | 
					
						
							|  |  |  | 								<button class="w3-button" @click=${this.clear}>Close</button> | 
					
						
							|  |  |  | 							</footer> | 
					
						
							|  |  |  | 						</div> | 
					
						
							|  |  |  | 					</div> | 
					
						
							|  |  |  | 				</div>` | 
					
						
							|  |  |  | 			: undefined; | 
					
						
							| 
									
										
										
										
											2024-04-21 14:18:06 -04:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | customElements.define('tf-reactions-modal', TfReactionsModalElement); |