mapcomplete/UI/OpeningHours/OpeningHoursPicker.ts

48 lines
1.6 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { UIEventSource } from "../../Logic/UIEventSource"
import OpeningHoursPickerTable from "./OpeningHoursPickerTable"
import { OH, OpeningHour } from "./OpeningHours"
import { InputElement } from "../Input/InputElement"
import BaseUIElement from "../BaseUIElement"
2020-10-04 01:04:46 +02:00
export default class OpeningHoursPicker extends InputElement<OpeningHour[]> {
2022-09-08 21:40:48 +02:00
public readonly IsSelected: UIEventSource<boolean> = new UIEventSource<boolean>(false)
private readonly _ohs: UIEventSource<OpeningHour[]>
private readonly _backgroundTable: OpeningHoursPickerTable
2020-09-30 22:22:58 +02:00
2020-10-04 12:55:44 +02:00
constructor(ohs: UIEventSource<OpeningHour[]> = new UIEventSource<OpeningHour[]>([])) {
2022-09-08 21:40:48 +02:00
super()
this._ohs = ohs
2020-09-30 22:22:58 +02:00
2022-09-08 21:40:48 +02:00
ohs.addCallback((oh) => {
ohs.setData(OH.MergeTimes(oh))
2021-06-16 14:23:53 +02:00
})
2020-09-30 22:22:58 +02:00
2022-09-08 21:40:48 +02:00
this._backgroundTable = new OpeningHoursPickerTable(this._ohs)
2021-06-16 14:23:53 +02:00
this._backgroundTable.ConstructElement()
2020-09-30 22:22:58 +02:00
}
2021-06-10 01:36:20 +02:00
InnerRender(): BaseUIElement {
2022-09-08 21:40:48 +02:00
return this._backgroundTable
2021-06-10 01:36:20 +02:00
}
2020-10-04 01:04:46 +02:00
GetValue(): UIEventSource<OpeningHour[]> {
return this._ohs
2020-09-30 22:22:58 +02:00
}
2020-10-04 01:04:46 +02:00
IsValid(t: OpeningHour[]): boolean {
2022-09-08 21:40:48 +02:00
return true
2020-09-30 22:22:58 +02:00
}
/**
2022-09-08 21:40:48 +02:00
*
* const rules = OH.ParseRule("Jul-Aug Sa closed; Mo,Tu,Th,Fr,PH 12:00-22:30, We 17:00-22:30, Sa 14:00-19:00, Su 10:00-21:00; Dec 24,25,31 off; Jan 1 off")
* const v = new UIEventSource(rules)
* const ohpicker = new OpeningHoursPicker(v)
* const html = ohpicker.InnerConstructElement()
* html !== undefined // => true
*/
2021-06-16 14:23:53 +02:00
protected InnerConstructElement(): HTMLElement {
2022-09-08 21:40:48 +02:00
return this._backgroundTable.ConstructElement()
2021-06-16 14:23:53 +02:00
}
2022-09-08 21:40:48 +02:00
}