forked from MapComplete/MapComplete
		
	UX: indicate that a search field is actually a regex, add feedback to the filterview
This commit is contained in:
		
							parent
							
								
									5da63bf83a
								
							
						
					
					
						commit
						ebe7ff85f8
					
				
					 5 changed files with 39 additions and 7 deletions
				
			
		|  | @ -15,9 +15,6 @@ import UrlValidator from "./Validators/UrlValidator" | |||
| import PhoneValidator from "./Validators/PhoneValidator" | ||||
| import OpeningHoursValidator from "./Validators/OpeningHoursValidator" | ||||
| import ColorValidator from "./Validators/ColorValidator" | ||||
| import BaseUIElement from "../BaseUIElement" | ||||
| import Combine from "../Base/Combine" | ||||
| import Title from "../Base/Title" | ||||
| import SimpleTagValidator from "./Validators/SimpleTagValidator" | ||||
| import ImageUrlValidator from "./Validators/ImageUrlValidator" | ||||
| import TagKeyValidator from "./Validators/TagKeyValidator" | ||||
|  | @ -30,6 +27,7 @@ import SlopeValidator from "./Validators/SlopeValidator" | |||
| import VeloparkValidator from "./Validators/VeloparkValidator" | ||||
| import NameSuggestionIndexValidator from "./Validators/NameSuggestionIndexValidator" | ||||
| import CurrencyValidator from "./Validators/CurrencyValidator" | ||||
| import RegexValidator from "./Validators/RegexValidator" | ||||
| 
 | ||||
| export type ValidatorType = (typeof Validators.availableTypes)[number] | ||||
| 
 | ||||
|  | @ -64,6 +62,7 @@ export default class Validators { | |||
|         "velopark", | ||||
|         "nsi", | ||||
|         "currency", | ||||
|         "regex" | ||||
|     ] as const | ||||
| 
 | ||||
|     public static readonly AllValidators: ReadonlyArray<Validator> = [ | ||||
|  | @ -95,6 +94,7 @@ export default class Validators { | |||
|         new VeloparkValidator(), | ||||
|         new NameSuggestionIndexValidator(), | ||||
|         new CurrencyValidator(), | ||||
|         new RegexValidator() | ||||
|     ] | ||||
| 
 | ||||
|     private static _byType = Validators._byTypeConstructor() | ||||
|  |  | |||
							
								
								
									
										22
									
								
								src/UI/InputElement/Validators/RegexValidator.ts
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/UI/InputElement/Validators/RegexValidator.ts
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | |||
| import StringValidator from "./StringValidator" | ||||
| import { s } from "vitest/dist/env-afee91f0" | ||||
| import { Translation } from "../../i18n/Translation" | ||||
| import Translations from "../../i18n/Translations" | ||||
| 
 | ||||
| export default class RegexValidator extends StringValidator{ | ||||
|     constructor() { | ||||
|         super("regex", "Validates a regex") | ||||
|     } | ||||
| 
 | ||||
|     getFeedback(s: string): Translation | undefined { | ||||
|         try{ | ||||
|             new RegExp(s) | ||||
|         }catch (e) { | ||||
|             return Translations.T("Not a valid Regex: "+e) | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     isValid(s: string): boolean { | ||||
|         return this.getFeedback(s) === undefined | ||||
|     } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue