| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  | <script lang="ts"> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-31 03:28:11 +02:00
										 |  |  |   import { UIEventSource } from "../../Logic/UIEventSource"; | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  |   import type { ValidatorType } from "./Validators"; | 
					
						
							|  |  |  |   import Validators from "./Validators"; | 
					
						
							|  |  |  |   import { ExclamationIcon } from "@rgossiaux/svelte-heroicons/solid"; | 
					
						
							|  |  |  |   import { Translation } from "../i18n/Translation"; | 
					
						
							| 
									
										
										
										
											2023-04-16 03:42:26 +02:00
										 |  |  |   import { createEventDispatcher, onDestroy } from "svelte"; | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |   import {Validator} from "./Validator"; | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export let value: UIEventSource<string>; | 
					
						
							|  |  |  |   // Internal state, only copied to 'value' so that no invalid values leak outside | 
					
						
							| 
									
										
										
										
											2023-03-31 03:28:11 +02:00
										 |  |  |   let _value = new UIEventSource(value.data ?? ""); | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  |   export let type: ValidatorType; | 
					
						
							| 
									
										
										
										
											2023-03-31 03:28:11 +02:00
										 |  |  |   export let feedback: UIEventSource<Translation> | undefined = undefined; | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |   export let getCountry: () => string | undefined | 
					
						
							| 
									
										
										
										
											2023-05-06 01:23:55 +02:00
										 |  |  |   export let placeholder: string | Translation | undefined | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |   let validator : Validator = Validators.get(type) | 
					
						
							| 
									
										
										
										
											2023-05-06 01:23:55 +02:00
										 |  |  |   let _placeholder = placeholder ?? validator?.getPlaceholder() ?? type | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |   $: { | 
					
						
							|  |  |  |     // The type changed -> reset some values | 
					
						
							|  |  |  |     validator = Validators.get(type) | 
					
						
							| 
									
										
										
										
											2023-05-05 11:00:31 +02:00
										 |  |  |     _value.setData(value.data ?? "") | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |     feedback =  feedback?.setData(validator?.getFeedback(_value.data, getCountry)); | 
					
						
							| 
									
										
										
										
											2023-05-06 01:23:55 +02:00
										 |  |  |     _placeholder = placeholder ?? validator?.getPlaceholder() ?? type | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |   } | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2023-04-16 03:42:26 +02:00
										 |  |  |   onDestroy(_value.addCallbackAndRun(v => { | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |     if (validator.isValid(v, getCountry)) { | 
					
						
							| 
									
										
										
										
											2023-03-31 03:28:11 +02:00
										 |  |  |       feedback?.setData(undefined); | 
					
						
							|  |  |  |       value.setData(v); | 
					
						
							|  |  |  |       return; | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-03-31 03:28:11 +02:00
										 |  |  |     value.setData(undefined); | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |     feedback?.setData(validator.getFeedback(v, getCountry)); | 
					
						
							| 
									
										
										
										
											2023-04-16 03:42:26 +02:00
										 |  |  |   })) | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (validator === undefined) { | 
					
						
							|  |  |  |     throw "Not a valid type for a validator:" + type; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-03 00:57:15 +02:00
										 |  |  |   const isValid = _value.map(v => validator.isValid(v, getCountry)); | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-31 03:28:11 +02:00
										 |  |  |   let htmlElem: HTMLInputElement; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let dispatch = createEventDispatcher<{ selected }>(); | 
					
						
							|  |  |  |   $: { | 
					
						
							|  |  |  |     if (htmlElem !== undefined) { | 
					
						
							| 
									
										
										
										
											2023-04-24 03:36:02 +02:00
										 |  |  |       htmlElem.onfocus = () => dispatch("selected"); | 
					
						
							| 
									
										
										
										
											2023-03-31 03:28:11 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {#if validator.textArea} | 
					
						
							| 
									
										
										
										
											2023-05-06 01:23:55 +02:00
										 |  |  |   <textarea class="w-full" bind:value={$_value} inputmode={validator.inputmode ?? "text"} placeholder={_placeholder}></textarea> | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  | {:else } | 
					
						
							| 
									
										
										
										
											2023-04-16 03:42:26 +02:00
										 |  |  |   <span class="inline-flex"> | 
					
						
							| 
									
										
										
										
											2023-05-06 01:23:55 +02:00
										 |  |  |     <input bind:this={htmlElem} bind:value={$_value} inputmode={validator.inputmode ?? "text"} placeholder={_placeholder}> | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  |     {#if !$isValid} | 
					
						
							|  |  |  |       <ExclamationIcon class="h-6 w-6 -ml-6"></ExclamationIcon> | 
					
						
							|  |  |  |     {/if} | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  |   </span> | 
					
						
							| 
									
										
										
										
											2023-03-30 04:51:56 +02:00
										 |  |  | {/if} |