2020-10-08 19:03:00 +02:00
|
|
|
/**
|
|
|
|
* The full opening hours element, including the table, opening hours picker.
|
|
|
|
* Keeps track of unparsed rules
|
2023-04-16 03:42:26 +02:00
|
|
|
* Exports everything conveniently as a string, for direct use
|
2020-10-08 19:03:00 +02:00
|
|
|
*/
|
2022-06-05 02:24:14 +02:00
|
|
|
import { Store, UIEventSource } from "../../Logic/UIEventSource"
|
|
|
|
import { OH, OpeningHour } from "./OpeningHours"
|
2021-01-02 16:04:16 +01:00
|
|
|
|
2024-09-05 17:14:47 +02:00
|
|
|
export default class OpeningHoursState {
|
|
|
|
public readonly normalOhs: UIEventSource<OpeningHour[]>
|
|
|
|
public readonly leftoverRules: Store<string[]>
|
|
|
|
public readonly phSelectorValue: UIEventSource<string>
|
2022-09-08 21:40:48 +02:00
|
|
|
|
2021-10-29 03:42:33 +02:00
|
|
|
constructor(
|
|
|
|
value: UIEventSource<string> = new UIEventSource<string>(""),
|
|
|
|
prefix = "",
|
2024-09-05 17:14:47 +02:00
|
|
|
postfix = "",
|
2021-10-29 03:42:33 +02:00
|
|
|
) {
|
|
|
|
let valueWithoutPrefix = value
|
|
|
|
if (prefix !== "" && postfix !== "") {
|
2022-06-05 02:24:14 +02:00
|
|
|
valueWithoutPrefix = value.sync(
|
|
|
|
(str) => {
|
2021-10-29 03:42:33 +02:00
|
|
|
if (str === undefined) {
|
|
|
|
return undefined
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2021-11-07 16:34:51 +01:00
|
|
|
if (str === "") {
|
2021-10-29 03:42:33 +02:00
|
|
|
return ""
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2021-10-29 03:42:33 +02:00
|
|
|
if (str.startsWith(prefix) && str.endsWith(postfix)) {
|
|
|
|
return str.substring(prefix.length, str.length - postfix.length)
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2021-10-29 03:42:33 +02:00
|
|
|
return str
|
2022-09-08 21:40:48 +02:00
|
|
|
},
|
|
|
|
[],
|
2021-11-07 16:34:51 +01:00
|
|
|
(noPrefix) => {
|
2021-10-29 03:42:33 +02:00
|
|
|
if (noPrefix === undefined) {
|
|
|
|
return undefined
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2021-11-07 16:34:51 +01:00
|
|
|
if (noPrefix === "") {
|
2021-10-29 03:42:33 +02:00
|
|
|
return ""
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2021-10-29 03:42:33 +02:00
|
|
|
if (noPrefix.startsWith(prefix) && noPrefix.endsWith(postfix)) {
|
|
|
|
return noPrefix
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
|
|
|
|
2021-10-29 03:42:33 +02:00
|
|
|
return prefix + noPrefix + postfix
|
2024-09-05 17:14:47 +02:00
|
|
|
},
|
2021-10-29 03:42:33 +02:00
|
|
|
)
|
|
|
|
}
|
2021-06-10 01:36:20 +02:00
|
|
|
|
2024-09-05 17:14:47 +02:00
|
|
|
this.leftoverRules = valueWithoutPrefix.map((str) => {
|
2020-10-08 19:03:00 +02:00
|
|
|
if (str === undefined) {
|
|
|
|
return []
|
|
|
|
}
|
|
|
|
const leftOvers: string[] = []
|
|
|
|
const rules = str.split(";")
|
|
|
|
for (const rule of rules) {
|
|
|
|
if (OH.ParseRule(rule) !== null) {
|
|
|
|
continue
|
|
|
|
}
|
2021-06-16 16:39:48 +02:00
|
|
|
if (OH.ParsePHRule(rule) !== null) {
|
2020-10-08 19:03:00 +02:00
|
|
|
continue
|
|
|
|
}
|
2023-06-14 20:39:36 +02:00
|
|
|
if (leftOvers.indexOf(rule) >= 0) {
|
2023-05-04 23:32:37 +02:00
|
|
|
continue
|
|
|
|
}
|
2020-10-08 19:03:00 +02:00
|
|
|
leftOvers.push(rule)
|
|
|
|
}
|
|
|
|
return leftOvers
|
|
|
|
})
|
2022-09-08 21:40:48 +02:00
|
|
|
|
2022-06-05 02:24:14 +02:00
|
|
|
let ph = ""
|
|
|
|
const rules = valueWithoutPrefix.data?.split(";") ?? []
|
|
|
|
for (const rule of rules) {
|
|
|
|
if (OH.ParsePHRule(rule) !== null) {
|
2023-10-18 02:08:49 +02:00
|
|
|
// We found the rule containing the public holiday information
|
2022-06-05 02:24:14 +02:00
|
|
|
ph = rule
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
2024-09-05 17:14:47 +02:00
|
|
|
this.phSelectorValue = new UIEventSource<string>(ph ?? "")
|
2024-09-05 13:17:49 +02:00
|
|
|
|
2022-09-08 21:40:48 +02:00
|
|
|
|
2021-06-16 16:39:48 +02:00
|
|
|
// Note: MUST be bound AFTER the leftover rules!
|
2024-09-05 17:14:47 +02:00
|
|
|
this.normalOhs = valueWithoutPrefix.sync(
|
2022-06-05 02:24:14 +02:00
|
|
|
(str) => {
|
|
|
|
return OH.Parse(str)
|
|
|
|
},
|
2024-09-05 17:14:47 +02:00
|
|
|
[this.leftoverRules, this.phSelectorValue],
|
2022-06-05 02:24:14 +02:00
|
|
|
(rules, oldString) => {
|
2022-06-29 17:27:23 +02:00
|
|
|
// We always add a ';', to easily add new rules. We remove the ';' again at the end of the function
|
2022-06-05 02:24:14 +02:00
|
|
|
// Important: spaces are _not_ allowed after a ';' as it'll destabilize the parsing!
|
|
|
|
let str = OH.ToString(rules) + ";"
|
2024-09-05 17:14:47 +02:00
|
|
|
const ph = this.phSelectorValue.data
|
2022-09-08 21:40:48 +02:00
|
|
|
if (ph) {
|
2024-10-10 20:16:13 +02:00
|
|
|
str += " " + ph + ";" // There must be a space after every ";"
|
2022-06-05 02:24:14 +02:00
|
|
|
}
|
2020-10-08 19:03:00 +02:00
|
|
|
|
2024-10-10 20:16:13 +02:00
|
|
|
str += this.leftoverRules.data.join("; ") + ";"
|
2020-10-08 19:03:00 +02:00
|
|
|
|
2021-06-10 01:36:20 +02:00
|
|
|
str = str.trim()
|
2023-05-02 19:00:38 +02:00
|
|
|
while (str.endsWith(";")) {
|
2021-06-10 01:36:20 +02:00
|
|
|
str = str.substring(0, str.length - 1)
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2021-06-10 01:36:20 +02:00
|
|
|
if (str.startsWith(";")) {
|
|
|
|
str = str.substring(1)
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2022-06-29 17:27:23 +02:00
|
|
|
str.trim()
|
2020-10-08 19:03:00 +02:00
|
|
|
|
|
|
|
if (str === oldString) {
|
|
|
|
return oldString // We pass a reference to the old string to stabilize the EventSource
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|
2020-10-08 19:03:00 +02:00
|
|
|
return str
|
2024-09-05 17:14:47 +02:00
|
|
|
},
|
2022-09-08 21:40:48 +02:00
|
|
|
)
|
2024-09-05 17:14:47 +02:00
|
|
|
/*
|
|
|
|
const leftoverWarning = new VariableUiElement(
|
|
|
|
leftoverRules.map((leftovers: string[]) => {
|
|
|
|
if (leftovers.length == 0) {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
return new Combine([
|
|
|
|
Translations.t.general.opening_hours.not_all_rules_parsed,
|
|
|
|
new FixedUiElement(leftovers.map((r) => `${r}<br/>`).join("")).SetClass(
|
|
|
|
"subtle"
|
|
|
|
),
|
|
|
|
])
|
|
|
|
})
|
|
|
|
)*/
|
2020-10-08 19:03:00 +02:00
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|