| 
									
										
										
										
											2020-10-27 01:01:34 +01:00
										 |  |  | import {UIEventSource} from "../../Logic/UIEventSource"; | 
					
						
							| 
									
										
										
										
											2021-01-06 01:11:07 +01:00
										 |  |  | import {Utils} from "../../Utils"; | 
					
						
							| 
									
										
										
										
											2021-06-11 22:51:45 +02:00
										 |  |  | import BaseUIElement from "../BaseUIElement"; | 
					
						
							| 
									
										
										
										
											2021-06-14 02:39:23 +02:00
										 |  |  | import {VariableUiElement} from "../Base/VariableUIElement"; | 
					
						
							|  |  |  | import List from "../Base/List"; | 
					
						
							| 
									
										
										
										
											2021-06-14 17:28:11 +02:00
										 |  |  | import {SubstitutedTranslation} from "../SubstitutedTranslation"; | 
					
						
							| 
									
										
										
										
											2021-08-07 23:11:34 +02:00
										 |  |  | import TagRenderingConfig from "../../Models/ThemeConfig/TagRenderingConfig"; | 
					
						
							| 
									
										
										
										
											2022-01-29 02:45:59 +01:00
										 |  |  | import Combine from "../Base/Combine"; | 
					
						
							|  |  |  | import Img from "../Base/Img"; | 
					
						
							| 
									
										
										
										
											2020-10-27 01:01:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*** | 
					
						
							|  |  |  |  * Displays the correct value for a known tagrendering | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2021-06-14 02:39:23 +02:00
										 |  |  | export default class TagRenderingAnswer extends VariableUiElement { | 
					
						
							| 
									
										
										
										
											2020-10-27 01:01:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-10 08:51:24 +01:00
										 |  |  |     constructor(tagsSource: UIEventSource<any>, configuration: TagRenderingConfig, | 
					
						
							| 
									
										
										
										
											2021-12-21 18:35:31 +01:00
										 |  |  |                 state: any, | 
					
						
							| 
									
										
										
										
											2022-01-26 21:40:38 +01:00
										 |  |  |                 contentClasses: string = "", contentStyle: string = "", options?: { | 
					
						
							|  |  |  |             specialViz: Map<string, BaseUIElement> | 
					
						
							|  |  |  |         }) { | 
					
						
							| 
									
										
										
										
											2021-01-06 01:11:07 +01:00
										 |  |  |         if (configuration === undefined) { | 
					
						
							| 
									
										
										
										
											2020-11-17 02:22:48 +01:00
										 |  |  |             throw "Trying to generate a tagRenderingAnswer without configuration..." | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-11-08 14:18:45 +01:00
										 |  |  |         if (tagsSource === undefined) { | 
					
						
							|  |  |  |             throw "Trying to generate a tagRenderingAnswer without tagSource..." | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-06-14 02:39:23 +02:00
										 |  |  |         super(tagsSource.map(tags => { | 
					
						
							| 
									
										
										
										
											2021-07-16 02:13:41 +02:00
										 |  |  |             if (tags === undefined) { | 
					
						
							| 
									
										
										
										
											2021-01-06 01:11:07 +01:00
										 |  |  |                 return undefined; | 
					
						
							| 
									
										
										
										
											2021-03-13 17:25:44 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-07-16 02:13:41 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if (configuration.condition) { | 
					
						
							|  |  |  |                 if (!configuration.condition.matchesProperties(tags)) { | 
					
						
							| 
									
										
										
										
											2021-06-15 01:24:04 +02:00
										 |  |  |                     return undefined; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-07-16 02:13:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-14 02:39:23 +02:00
										 |  |  |             const trs = Utils.NoNull(configuration.GetRenderValues(tags)); | 
					
						
							| 
									
										
										
										
											2021-07-16 02:13:41 +02:00
										 |  |  |             if (trs.length === 0) { | 
					
						
							|  |  |  |                 return undefined; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-29 02:45:59 +01:00
										 |  |  |             const valuesToRender: BaseUIElement[] = trs.map(tr => { | 
					
						
							|  |  |  |                 const text = new SubstitutedTranslation(tr.then, tagsSource, state, options?.specialViz); | 
					
						
							|  |  |  |                 if(tr.icon === undefined){ | 
					
						
							|  |  |  |                     return text | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 return new Combine([new Img(tr.icon).SetClass("w-6 max-h-6 pr-2"), text]).SetClass("flex") | 
					
						
							|  |  |  |             }) | 
					
						
							| 
									
										
										
										
											2021-07-16 02:13:41 +02:00
										 |  |  |             if (valuesToRender.length === 1) { | 
					
						
							|  |  |  |                 return valuesToRender[0]; | 
					
						
							|  |  |  |             } else if (valuesToRender.length > 1) { | 
					
						
							| 
									
										
										
										
											2022-01-29 02:45:59 +01:00
										 |  |  |                 return new Combine(valuesToRender).SetClass("flex flex-col") | 
					
						
							| 
									
										
										
										
											2021-01-06 01:11:07 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-07-16 02:13:41 +02:00
										 |  |  |             return undefined; | 
					
						
							|  |  |  |         }).map((element: BaseUIElement) => element?.SetClass(contentClasses)?.SetStyle(contentStyle))) | 
					
						
							| 
									
										
										
										
											2021-01-06 01:11:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-16 02:13:41 +02:00
										 |  |  |         this.SetClass("flex items-center flex-row text-lg link-underline") | 
					
						
							| 
									
										
										
										
											2021-06-14 02:39:23 +02:00
										 |  |  |         this.SetStyle("word-wrap: anywhere;"); | 
					
						
							| 
									
										
										
										
											2020-10-27 01:01:34 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |