forked from MapComplete/MapComplete
102 lines
No EOL
3.2 KiB
TypeScript
102 lines
No EOL
3.2 KiB
TypeScript
import {UIElement} from "../../UIElement";
|
|
import {UIEventSource} from "../../../Logic/UIEventSource";
|
|
import {OH, OpeningHour} from "../../../Logic/OpeningHours";
|
|
import Combine from "../../Base/Combine";
|
|
import {Utils} from "../../../Utils";
|
|
import {FixedUiElement} from "../../Base/FixedUiElement";
|
|
import {VariableUiElement} from "../../Base/VariableUIElement";
|
|
|
|
/**
|
|
* A single opening hours range, shown on top of the OH-picker table
|
|
*/
|
|
export default class OpeningHoursRange extends UIElement {
|
|
private _oh: UIEventSource<OpeningHour>;
|
|
|
|
private readonly _startTime: UIElement;
|
|
private readonly _endTime: UIElement;
|
|
private readonly _deleteRange: UIElement;
|
|
private readonly _tableId: string;
|
|
|
|
constructor(oh: UIEventSource<OpeningHour>, tableId: string) {
|
|
super(oh);
|
|
this._tableId = tableId;
|
|
const self = this;
|
|
this._oh = oh;
|
|
this.SetClass("oh-timerange");
|
|
oh.addCallbackAndRun(() => {
|
|
const el = document.getElementById(this.id) as HTMLElement;
|
|
self.InnerUpdate(el);
|
|
})
|
|
|
|
this._deleteRange = new FixedUiElement("<img src='./assets/delete.svg'>")
|
|
.SetClass("oh-delete-range")
|
|
.onClick(() => {
|
|
oh.data.weekday = undefined;
|
|
oh.ping();
|
|
});
|
|
|
|
|
|
this._startTime = new VariableUiElement(oh.map(oh => {
|
|
return Utils.TwoDigits(oh.startHour) + ":" + Utils.TwoDigits(oh.startMinutes);
|
|
})).SetClass("oh-timerange-label")
|
|
|
|
this._endTime = new VariableUiElement(oh.map(oh => {
|
|
return Utils.TwoDigits(oh.endHour) + ":" + Utils.TwoDigits(oh.endMinutes);
|
|
})).SetClass("oh-timerange-label")
|
|
|
|
|
|
}
|
|
|
|
InnerRender(): string {
|
|
const oh = this._oh.data;
|
|
if (oh === undefined) {
|
|
return "";
|
|
}
|
|
const height = this.getHeight();
|
|
|
|
let content = [this._deleteRange]
|
|
if (height > 2) {
|
|
content = [this._startTime, this._deleteRange, this._endTime];
|
|
}
|
|
|
|
return new Combine(content)
|
|
.SetClass("oh-timerange-inner")
|
|
.Render();
|
|
}
|
|
|
|
private getHeight(): number {
|
|
const oh = this._oh.data;
|
|
|
|
let endhour = oh.endHour;
|
|
if (oh.endHour == 0 && oh.endMinutes == 0) {
|
|
endhour = 24;
|
|
}
|
|
const height = (endhour - oh.startHour + ((oh.endMinutes - oh.startMinutes) / 60));
|
|
return height;
|
|
}
|
|
|
|
protected InnerUpdate(el: HTMLElement) {
|
|
if (el == null) {
|
|
return;
|
|
}
|
|
const oh = this._oh.data;
|
|
if (oh === undefined) {
|
|
return;
|
|
}
|
|
|
|
// The header cell containing monday, tuesday, ...
|
|
const table = document.getElementById(this._tableId) as HTMLTableElement;
|
|
|
|
const bodyRect = document.body.getBoundingClientRect();
|
|
const rangeStart = table.rows[1].cells[1].getBoundingClientRect().top - bodyRect.top;
|
|
const rangeEnd = table.rows[table.rows.length - 1].cells[1].getBoundingClientRect().bottom - bodyRect.top;
|
|
|
|
const pixelsPerHour = (rangeEnd - rangeStart) / 24;
|
|
|
|
el.style.top = (pixelsPerHour * OH.startTime(oh)) + "px";
|
|
el.style.height = (pixelsPerHour * (OH.endTime(oh) - OH.startTime(oh))) + "px";
|
|
|
|
}
|
|
|
|
|
|
} |