forked from MapComplete/MapComplete
		
	Add 24/7 detection to Opening Hours
This commit is contained in:
		
							parent
							
								
									6563298d16
								
							
						
					
					
						commit
						b93f25d79c
					
				
					 5 changed files with 115 additions and 7 deletions
				
			
		|  | @ -29,6 +29,9 @@ export class OH { | ||||||
|         const partsPerWeekday: string [][] = [[], [], [], [], [], [], []]; |         const partsPerWeekday: string [][] = [[], [], [], [], [], [], []]; | ||||||
| 
 | 
 | ||||||
|         function hhmm(h, m) { |         function hhmm(h, m) { | ||||||
|  |             if (h == 24) { | ||||||
|  |                 return "00:00"; | ||||||
|  |             } | ||||||
|             return Utils.TwoDigits(h) + ":" + Utils.TwoDigits(m); |             return Utils.TwoDigits(h) + ":" + Utils.TwoDigits(m); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -69,7 +72,11 @@ export class OH { | ||||||
|         } |         } | ||||||
|         pushRule(); |         pushRule(); | ||||||
| 
 | 
 | ||||||
|         return rules.join("; ") + ";" |         const oh = rules.join("; ") + ";" | ||||||
|  |         if (oh === "Mo-Su 00:00-00:00;") { | ||||||
|  |             return "24/7" | ||||||
|  |         } | ||||||
|  |         return oh; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  | @ -184,6 +191,10 @@ export class OH { | ||||||
|         endHour: number, |         endHour: number, | ||||||
|         endMinutes: number |         endMinutes: number | ||||||
|     } { |     } { | ||||||
|  |         if(hhmmhhmm == "off"){ | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |          | ||||||
|         const timings = hhmmhhmm.split("-"); |         const timings = hhmmhhmm.split("-"); | ||||||
|         const start = OH.parseHHMM(timings[0]) |         const start = OH.parseHHMM(timings[0]) | ||||||
|         const end = OH.parseHHMM(timings[1]); |         const end = OH.parseHHMM(timings[1]); | ||||||
|  | @ -205,6 +216,7 @@ export class OH { | ||||||
|             .map(s => s.trim()) |             .map(s => s.trim()) | ||||||
|             .filter(str => str !== "") |             .filter(str => str !== "") | ||||||
|             .map(OH.parseHHMMRange) |             .map(OH.parseHHMMRange) | ||||||
|  |             .filter(v => v != null) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private static ParseWeekday(weekday: string): number { |     private static ParseWeekday(weekday: string): number { | ||||||
|  | @ -252,6 +264,10 @@ export class OH { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static ParseRule(rule: string): OpeningHour[] { |     public static ParseRule(rule: string): OpeningHour[] { | ||||||
|  |         if (rule.trim() == "24/7") { | ||||||
|  |             return OH.multiply([0, 1, 2, 3, 4, 5, 6], [{startHour: 0, startMinutes: 0, endHour: 24, endMinutes: 0}]); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         const split = rule.trim().replace(/, */g, ",").split(" "); |         const split = rule.trim().replace(/, */g, ",").split(" "); | ||||||
|         if (split.length == 1) { |         if (split.length == 1) { | ||||||
|             // First, try to parse this rule as a rule without weekdays
 |             // First, try to parse this rule as a rule without weekdays
 | ||||||
|  |  | ||||||
							
								
								
									
										2
									
								
								State.ts
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								State.ts
									
										
									
									
									
								
							|  | @ -23,7 +23,7 @@ export default class State { | ||||||
|     // The singleton of the global state
 |     // The singleton of the global state
 | ||||||
|     public static state: State; |     public static state: State; | ||||||
|      |      | ||||||
|     public static vNumber = "0.1.0"; |     public static vNumber = "0.1.0a"; | ||||||
|      |      | ||||||
|     // The user journey states thresholds when a new feature gets unlocked
 |     // The user journey states thresholds when a new feature gets unlocked
 | ||||||
|     public static userJourney = { |     public static userJourney = { | ||||||
|  |  | ||||||
|  | @ -3,6 +3,7 @@ import {OpeningHour} from "../../../Logic/OpeningHours"; | ||||||
| import {UIEventSource} from "../../../Logic/UIEventSource"; | import {UIEventSource} from "../../../Logic/UIEventSource"; | ||||||
| import {Utils} from "../../../Utils"; | import {Utils} from "../../../Utils"; | ||||||
| import {UIElement} from "../../UIElement"; | import {UIElement} from "../../UIElement"; | ||||||
|  | import Translations from "../../i18n/Translations"; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * This is the base-table which is selectable by hovering over it. |  * This is the base-table which is selectable by hovering over it. | ||||||
|  | @ -12,7 +13,17 @@ export default class OpeningHoursPickerTable extends InputElement<OpeningHour[]> | ||||||
|     public readonly IsSelected: UIEventSource<boolean>; |     public readonly IsSelected: UIEventSource<boolean>; | ||||||
|     private readonly weekdays: UIEventSource<UIElement[]>; |     private readonly weekdays: UIEventSource<UIElement[]>; | ||||||
| 
 | 
 | ||||||
|     public static readonly days = ["Maan", "Din", "Woe", "Don", "Vrij", "Zat", "Zon"]; |     public static readonly days: UIElement[] = | ||||||
|  |         [ | ||||||
|  |             Translations.t.general.weekdays.abbreviations.monday, | ||||||
|  |             Translations.t.general.weekdays.abbreviations.tuesday, | ||||||
|  |             Translations.t.general.weekdays.abbreviations.wednesday, | ||||||
|  |             Translations.t.general.weekdays.abbreviations.thursday, | ||||||
|  |             Translations.t.general.weekdays.abbreviations.friday, | ||||||
|  |             Translations.t.general.weekdays.abbreviations.saturday, | ||||||
|  |             Translations.t.general.weekdays.abbreviations.sunday | ||||||
|  |         ] | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|     private readonly source: UIEventSource<OpeningHour[]>; |     private readonly source: UIEventSource<OpeningHour[]>; | ||||||
| 
 | 
 | ||||||
|  | @ -48,7 +59,7 @@ export default class OpeningHoursPickerTable extends InputElement<OpeningHour[]> | ||||||
|                 Utils.Times(id => `<td id="${this.id}-timecell-${id}-${h}-30" class="oh-timecell oh-timecell-half"><div class="oh-timecell-inner"></div></td>`, 7) + |                 Utils.Times(id => `<td id="${this.id}-timecell-${id}-${h}-30" class="oh-timecell oh-timecell-half"><div class="oh-timecell-inner"></div></td>`, 7) + | ||||||
|                 '</tr>'; |                 '</tr>'; | ||||||
|         } |         } | ||||||
|         let days = OpeningHoursPickerTable.days.join("</th><th width='14%'>"); |         let days = OpeningHoursPickerTable.days.map(day => day.Render()).join("</th><th width='14%'>"); | ||||||
|         return `<table id="oh-table-${this.id}" class="oh-table"><tr><th></th><th width='14%'>${days}</th></tr>${rows}</table>`; |         return `<table id="oh-table-${this.id}" class="oh-table"><tr><th></th><th width='14%'>${days}</th></tr>${rows}</table>`; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -807,7 +807,81 @@ export default class Translations { | ||||||
|                 "en": "Zoom in to see this layer", |                 "en": "Zoom in to see this layer", | ||||||
|                 "nl": "Vergroot de kaart om deze laag te zien", |                 "nl": "Vergroot de kaart om deze laag te zien", | ||||||
|                 "de": "Vergrößern, um diese Ebene zu sehen" |                 "de": "Vergrößern, um diese Ebene zu sehen" | ||||||
|             }) |             }), | ||||||
|  |             weekdays: { | ||||||
|  |                 abbreviations:{ | ||||||
|  |                     monday: new T({ | ||||||
|  |                         "en": "Mon", | ||||||
|  |                         "nl": "Maan", | ||||||
|  |                         "fr": "Lun", | ||||||
|  |                     }), | ||||||
|  |                     tuesday: new T({ | ||||||
|  |                         "en": "Tue", | ||||||
|  |                         "nl": "Din", | ||||||
|  |                         "fr": "Mar", | ||||||
|  |                     }), | ||||||
|  |                     wednesday: new T({ | ||||||
|  |                         "en": "Wed", | ||||||
|  |                         "nl": "Woe", | ||||||
|  |                         "fr": "Mercr", | ||||||
|  |                     }), | ||||||
|  |                     thursday: new T({ | ||||||
|  |                         "en": "Thu", | ||||||
|  |                         "nl": "Don", | ||||||
|  |                         "fr": "Jeudi", | ||||||
|  |                     }), | ||||||
|  |                     friday: new T({ | ||||||
|  |                         "en": "Fri", | ||||||
|  |                         "nl": "Vrij", | ||||||
|  |                         "fr": "Vendr", | ||||||
|  |                     }), | ||||||
|  |                     saturday: new T({ | ||||||
|  |                         "en": "Sat", | ||||||
|  |                         "nl": "Zat", | ||||||
|  |                         "fr": "Sam", | ||||||
|  |                     }), | ||||||
|  |                     sunday: new T({ | ||||||
|  |                         "en": "Sun", | ||||||
|  |                         "nl": "Zon", | ||||||
|  |                         "fr": "Dim", | ||||||
|  |                     }) | ||||||
|  |                 }, | ||||||
|  |                 monday: new T({ | ||||||
|  |                     "en": "Monday", | ||||||
|  |                     "nl": "Maandag", | ||||||
|  |                     "fr": "Lundi", | ||||||
|  |                 }), | ||||||
|  |                 tuesday: new T({ | ||||||
|  |                     "en": "Tuesdday", | ||||||
|  |                     "nl": "Dinsdag", | ||||||
|  |                     "fr": "Mardi", | ||||||
|  |                 }), | ||||||
|  |                 wednesday: new T({ | ||||||
|  |                     "en": "Wednesday", | ||||||
|  |                     "nl": "Woensdag", | ||||||
|  |                     "fr": "Mercredi", | ||||||
|  |                 }), | ||||||
|  |                 thursday: new T({ | ||||||
|  |                     "en": "Thursday", | ||||||
|  |                     "nl": "Donderdag", | ||||||
|  |                     "fr": "Jeudi", | ||||||
|  |                 }), | ||||||
|  |                 friday: new T({ | ||||||
|  |                     "en": "Friday", | ||||||
|  |                     "nl": "Vrijdag", | ||||||
|  |                     "fr": "Vendredi", | ||||||
|  |                 }), | ||||||
|  |                 saturday: new T({ | ||||||
|  |                     "en": "Saturday", | ||||||
|  |                     "nl": "Zaterdag", | ||||||
|  |                     "fr": "Samedi", | ||||||
|  |                 }), | ||||||
|  |                 sunday: new T({ | ||||||
|  |                     "en": "Sunday", | ||||||
|  |                     "nl": "Zondag", | ||||||
|  |                     "fr": "Dimance", | ||||||
|  |                 }) | ||||||
|  |             } | ||||||
|         }, |         }, | ||||||
|         favourite: { |         favourite: { | ||||||
|             title: new T({ |             title: new T({ | ||||||
|  |  | ||||||
|  | @ -278,6 +278,13 @@ new T([ | ||||||
|             }, |             }, | ||||||
| 
 | 
 | ||||||
|         ]); |         ]); | ||||||
|         equal(rules, "Tu 10:00-12:00; Sucons 13:00-17:00;"); |         equal(rules, "Tu 10:00-12:00; Su 13:00-17:00;"); | ||||||
|  |     }], | ||||||
|  |     ["OH 24/7",() => { | ||||||
|  |         const rules = OH.Parse("24/7"); | ||||||
|  |         equal(rules.length, 7); | ||||||
|  |         equal(rules[0].startHour, 0); | ||||||
|  |         const asStr = OH.ToString(rules); | ||||||
|  |         equal(asStr, "24/7"); | ||||||
|     }] |     }] | ||||||
| ]); | ]); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue