@ancon/wildcat-utils 1.43.0-timezone-refactor.2 → 1.43.0-timezone-refactor.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/currency/getFormattedCurrency.js +1 -1
- package/currency/getFormattedCurrency.mjs +1 -1
- package/currency/getFormattedCurrencyPostfix.d.ts +1 -1
- package/currency/getFormattedCurrencyPostfix.js +1 -1
- package/currency/getFormattedCurrencyPostfix.mjs +1 -1
- package/currency/index.d.ts +2 -1
- package/currency/index.js +1 -1
- package/currency/index.mjs +4 -3
- package/date/createLocalTimezoneDate.js +1 -1
- package/date/createLocalTimezoneDate.mjs +5 -5
- package/date/createLocalTimezoneMoment.d.ts +9 -0
- package/date/createLocalTimezoneMoment.js +1 -0
- package/date/createLocalTimezoneMoment.mjs +8 -0
- package/date/index.d.ts +2 -1
- package/date/index.js +1 -1
- package/date/index.mjs +3 -1
- package/index.d.ts +1 -0
- package/index.js +1 -1
- package/index.mjs +279 -269
- package/license/getLicenseUIState.d.ts +4 -1
- package/license/getLicenseUIState.js +1 -1
- package/license/getLicenseUIState.mjs +17 -5
- package/license/index.d.ts +2 -2
- package/license/index.js +1 -1
- package/license/index.mjs +5 -2
- package/license/types.d.ts +2 -1
- package/license/types.js +1 -1
- package/license/types.mjs +1 -1
- package/outlet/getExpressAvailableOrderFormats.js +1 -1
- package/outlet/getExpressAvailableOrderFormats.mjs +34 -40
- package/outlet/getExpressNextAvailabilityShiftTime.d.ts +2 -2
- package/outlet/getExpressNextAvailabilityShiftTime.js +1 -1
- package/outlet/getExpressNextAvailabilityShiftTime.mjs +15 -22
- package/outlet/getExpressServiceIntervalEnd.d.ts +2 -2
- package/outlet/getExpressServiceIntervalEnd.js +1 -1
- package/outlet/getExpressServiceIntervalEnd.mjs +5 -11
- package/outlet/getExpressServiceIntervalStart.d.ts +2 -2
- package/outlet/getExpressServiceIntervalStart.js +1 -1
- package/outlet/getExpressServiceIntervalStart.mjs +5 -11
- package/outlet/getListOutletOpeningHoursTable.js +1 -1
- package/outlet/getListOutletOpeningHoursTable.mjs +62 -61
- package/outlet/getOutletActiveOpeningInterval.js +1 -1
- package/outlet/getOutletActiveOpeningInterval.mjs +15 -12
- package/outlet/getOutletAvailabilityInfo.js +1 -1
- package/outlet/getOutletAvailabilityInfo.mjs +23 -25
- package/outlet/getOutletCurrentAvailabilityInfo.js +1 -1
- package/outlet/getOutletCurrentAvailabilityInfo.mjs +2 -2
- package/outlet/getOutletCurrentClosingTimeText.js +1 -1
- package/outlet/getOutletCurrentClosingTimeText.mjs +8 -7
- package/outlet/getOutletNextOpeningTagInformation.js +1 -1
- package/outlet/getOutletNextOpeningTagInformation.mjs +2 -2
- package/outlet/getOutletNextOpeningTimeText.js +1 -1
- package/outlet/getOutletNextOpeningTimeText.mjs +10 -10
- package/outlet/getOutletNextReadyToOrderTime.js +1 -1
- package/outlet/getOutletNextReadyToOrderTime.mjs +1 -1
- package/outlet/getOutletPickerTimesForDay.js +1 -1
- package/outlet/getOutletPickerTimesForDay.mjs +1 -1
- package/outlet/getOutletPickerTimesForWeek.js +1 -1
- package/outlet/getOutletPickerTimesForWeek.mjs +1 -1
- package/outlet/getOutletTagInformation.js +1 -1
- package/outlet/getOutletTagInformation.mjs +51 -53
- package/outlet/getOutletTodayOpeningTimes.js +1 -1
- package/outlet/getOutletTodayOpeningTimes.mjs +20 -19
- package/outlet/getPickerIntervalsForDay.js +1 -1
- package/outlet/getPickerIntervalsForDay.mjs +16 -18
- package/outlet/index.js +1 -1
- package/outlet/index.mjs +1 -1
- package/outlet/searchNextOpeningMoment.js +1 -1
- package/outlet/searchNextOpeningMoment.mjs +49 -52
- package/package.json +21 -1
- package/ticketItem/index.d.ts +3 -0
- package/ticketItem/index.js +1 -0
- package/ticketItem/index.mjs +7 -0
- package/ticketItem/isTicketItemClosed.d.ts +9 -0
- package/ticketItem/isTicketItemClosed.js +1 -0
- package/ticketItem/isTicketItemClosed.mjs +7 -0
- package/ticketItem/isTicketItemReady.d.ts +6 -0
- package/ticketItem/isTicketItemReady.js +1 -0
- package/ticketItem/isTicketItemReady.mjs +7 -0
|
@@ -1,9 +1,21 @@
|
|
|
1
1
|
import n from "moment";
|
|
2
|
-
import { LicenseStatus as
|
|
3
|
-
import { LicenseUIState as
|
|
4
|
-
function
|
|
5
|
-
return (
|
|
2
|
+
import { LicenseStatus as r } from "@ancon/wildcat-types";
|
|
3
|
+
import { LicenseUIState as i } from "./types.mjs";
|
|
4
|
+
function o(e) {
|
|
5
|
+
return (e & r.Terminated) === r.Terminated;
|
|
6
|
+
}
|
|
7
|
+
function u(e) {
|
|
8
|
+
return (e & r.Expired) === r.Expired;
|
|
9
|
+
}
|
|
10
|
+
function m(e) {
|
|
11
|
+
return (e & r.Extended) === r.Extended;
|
|
12
|
+
}
|
|
13
|
+
function E(e, t, d, f = 10) {
|
|
14
|
+
return o(e) ? i.Terminated : u(e) ? i.Expired : m(e) ? i.Extended : d ? i.Deleted : t && n(t).diff(n(), "day") <= f ? i.AboutToExpire : i.Valid;
|
|
6
15
|
}
|
|
7
16
|
export {
|
|
8
|
-
|
|
17
|
+
E as default,
|
|
18
|
+
u as isLicenseExpired,
|
|
19
|
+
m as isLicenseExtended,
|
|
20
|
+
o as isLicenseTerminated
|
|
9
21
|
};
|
package/license/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import getLicenseUIState from './getLicenseUIState';
|
|
2
|
-
export { getLicenseUIState };
|
|
1
|
+
import getLicenseUIState, { isLicenseExpired, isLicenseExtended, isLicenseTerminated } from './getLicenseUIState';
|
|
2
|
+
export { getLicenseUIState, isLicenseExpired, isLicenseExtended, isLicenseTerminated, };
|
package/license/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./getLicenseUIState.js");require("moment");require("@ancon/wildcat-types");require("./types.js");exports.getLicenseUIState=e;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./getLicenseUIState.js");require("moment");require("@ancon/wildcat-types");require("./types.js");exports.getLicenseUIState=e.default;exports.isLicenseExpired=e.isLicenseExpired;exports.isLicenseExtended=e.isLicenseExtended;exports.isLicenseTerminated=e.isLicenseTerminated;
|
package/license/index.mjs
CHANGED
|
@@ -1,7 +1,10 @@
|
|
|
1
|
-
import { default as m } from "./getLicenseUIState.mjs";
|
|
1
|
+
import { default as n, isLicenseExpired as d, isLicenseExtended as m, isLicenseTerminated as o } from "./getLicenseUIState.mjs";
|
|
2
2
|
import "moment";
|
|
3
3
|
import "@ancon/wildcat-types";
|
|
4
4
|
import "./types.mjs";
|
|
5
5
|
export {
|
|
6
|
-
|
|
6
|
+
n as getLicenseUIState,
|
|
7
|
+
d as isLicenseExpired,
|
|
8
|
+
m as isLicenseExtended,
|
|
9
|
+
o as isLicenseTerminated
|
|
7
10
|
};
|
package/license/types.d.ts
CHANGED
package/license/types.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var r=(d=>(d[d.Valid=0]="Valid",d[d.AboutToExpire=1]="AboutToExpire",d[d.Extended=2]="Extended",d[d.Expired=3]="Expired",d[d.Terminated=4]="Terminated",d[d.Deleted=5]="Deleted",d))(r||{});exports.LicenseUIState=r;
|
package/license/types.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var r = /* @__PURE__ */ ((d) => (d[d.Valid = 0] = "Valid", d[d.AboutToExpire = 1] = "AboutToExpire", d[d.Extended = 2] = "Extended", d[d.Expired = 3] = "Expired", d[d.Terminated = 4] = "Terminated", d))(r || {});
|
|
1
|
+
var r = /* @__PURE__ */ ((d) => (d[d.Valid = 0] = "Valid", d[d.AboutToExpire = 1] = "AboutToExpire", d[d.Extended = 2] = "Extended", d[d.Expired = 3] = "Expired", d[d.Terminated = 4] = "Terminated", d[d.Deleted = 5] = "Deleted", d))(r || {});
|
|
2
2
|
export {
|
|
3
3
|
r as LicenseUIState
|
|
4
4
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const r=require("@ancon/wildcat-types"),
|
|
1
|
+
"use strict";const r=require("@ancon/wildcat-types"),l=require("moment"),F=require("../shared/constants.js"),c=require("../date/createLocalTimezoneMoment.js"),d=require("./getExpressServiceIntervalStart.js"),u=require("./getExpressServiceIntervalEnd.js");require("../time/getTimeSpanParts.js");const k=[r.OrderFormat.TakeAway,r.OrderFormat.EatIn];function E(n){var i;if(!((i=n.openingHours)!=null&&i.length))return[];const o=l(),{openingHours:m,supportedOrderFormats:p}=n,y=[...m].reduce((t,e,g,f)=>{switch(e.type){case r.IntervalType.Exception:{const s=c(e.periodFrom),a=c(e.periodTo),O=d(s,e),T=u(a,e);if(o.isBetween(O,T,void 0,"[]"))return e.state===r.IntervalState.Closed?(f.splice(1),r.OrderFormat.None):e.orderFormat}break;case r.IntervalType.Normal:default:if(e.dayOfWeek===r.DayOfWeek.Everyday||e.dayOfWeek===F.DaysOfWeekMap[o.isoWeekday()]){const s=d(o,e),a=u(o,e);if(o.isBetween(s,a,void 0,"[]"))return t|e.orderFormat}break}return t},r.OrderFormat.None);return k.filter(t=>(y&t)===t&&(p&t)===t)}module.exports=E;
|
|
@@ -1,65 +1,59 @@
|
|
|
1
|
-
import { OrderFormat as
|
|
2
|
-
import
|
|
3
|
-
import { DaysOfWeekMap as
|
|
4
|
-
import
|
|
1
|
+
import { OrderFormat as o, DayOfWeek as E, IntervalType as i, IntervalState as g } from "@ancon/wildcat-types";
|
|
2
|
+
import l from "moment";
|
|
3
|
+
import { DaysOfWeekMap as F } from "../shared/constants.mjs";
|
|
4
|
+
import p from "../date/createLocalTimezoneMoment.mjs";
|
|
5
|
+
import d from "./getExpressServiceIntervalStart.mjs";
|
|
5
6
|
import c from "./getExpressServiceIntervalEnd.mjs";
|
|
6
7
|
import "../time/getTimeSpanParts.mjs";
|
|
7
|
-
const x = [
|
|
8
|
-
function
|
|
9
|
-
var
|
|
10
|
-
if (!((
|
|
8
|
+
const x = [o.TakeAway, o.EatIn];
|
|
9
|
+
function v(n) {
|
|
10
|
+
var m;
|
|
11
|
+
if (!((m = n.openingHours) != null && m.length))
|
|
11
12
|
return [];
|
|
12
|
-
const
|
|
13
|
-
(
|
|
13
|
+
const t = l(), { openingHours: f, supportedOrderFormats: u } = n, y = [...f].reduce(
|
|
14
|
+
(r, e, D, O) => {
|
|
14
15
|
switch (e.type) {
|
|
15
|
-
case
|
|
16
|
+
case i.Exception:
|
|
16
17
|
{
|
|
17
|
-
const
|
|
18
|
+
const s = p(e.periodFrom), a = p(e.periodTo), T = d(
|
|
19
|
+
s,
|
|
20
|
+
e
|
|
21
|
+
), k = c(
|
|
18
22
|
a,
|
|
19
|
-
e
|
|
20
|
-
o
|
|
21
|
-
), T = c(
|
|
22
|
-
n,
|
|
23
|
-
e,
|
|
24
|
-
o
|
|
23
|
+
e
|
|
25
24
|
);
|
|
26
|
-
if (
|
|
27
|
-
return e.state ===
|
|
25
|
+
if (t.isBetween(T, k, void 0, "[]"))
|
|
26
|
+
return e.state === g.Closed ? (O.splice(1), o.None) : e.orderFormat;
|
|
28
27
|
}
|
|
29
28
|
break;
|
|
30
|
-
case
|
|
29
|
+
case i.Normal:
|
|
31
30
|
default:
|
|
32
31
|
if (
|
|
33
32
|
// Every day in the week
|
|
34
|
-
e.dayOfWeek ===
|
|
35
|
-
e.dayOfWeek ===
|
|
33
|
+
e.dayOfWeek === E.Everyday || // Specific day in the week
|
|
34
|
+
e.dayOfWeek === F[t.isoWeekday()]
|
|
36
35
|
) {
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
e
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
r
|
|
43
|
-
e,
|
|
44
|
-
o
|
|
45
|
-
);
|
|
46
|
-
if (r.isBetween(a, n, void 0, "[]"))
|
|
47
|
-
return t | e.orderFormat;
|
|
36
|
+
const s = d(
|
|
37
|
+
t,
|
|
38
|
+
e
|
|
39
|
+
), a = c(t, e);
|
|
40
|
+
if (t.isBetween(s, a, void 0, "[]"))
|
|
41
|
+
return r | e.orderFormat;
|
|
48
42
|
}
|
|
49
43
|
break;
|
|
50
44
|
}
|
|
51
|
-
return
|
|
45
|
+
return r;
|
|
52
46
|
},
|
|
53
|
-
|
|
47
|
+
o.None
|
|
54
48
|
);
|
|
55
49
|
return x.filter(
|
|
56
|
-
(
|
|
50
|
+
(r) => (
|
|
57
51
|
// Check if the order format is available
|
|
58
|
-
(
|
|
59
|
-
(
|
|
52
|
+
(y & r) === r && // Check if the order format is supported by the outlet
|
|
53
|
+
(u & r) === r
|
|
60
54
|
)
|
|
61
55
|
);
|
|
62
56
|
}
|
|
63
57
|
export {
|
|
64
|
-
|
|
58
|
+
v as default
|
|
65
59
|
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { OpeningHoursInterval } from '@ancon/wildcat-types';
|
|
2
2
|
import { Moment } from 'moment';
|
|
3
|
-
export default function getExpressNextAvailabilityShiftTime(openingHours: Array<
|
|
3
|
+
export default function getExpressNextAvailabilityShiftTime(openingHours: Array<OpeningHoursInterval>): Moment;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const
|
|
1
|
+
"use strict";const r=require("@ancon/wildcat-types"),f=require("moment"),u=require("../shared/constants.js"),c=require("../date/createLocalTimezoneMoment.js"),m=require("./getExpressServiceIntervalStart.js"),T=require("./getExpressServiceIntervalEnd.js");require("../time/getTimeSpanParts.js");function l(d){const t=f();let o=t.clone().add(1,"day").startOf("day");function s(e){const i=e.type===r.IntervalType.Exception,p=i?c(e.periodFrom):t,y=i?c(e.periodTo):t,n=m(p,e),a=T(y,e);n.isBetween(t,o)?o=n:a.isBetween(t,o)&&(o=a)}return d.forEach(e=>{switch(e.type){case r.IntervalType.Exception:s(e);break;case r.IntervalType.Normal:default:(e.dayOfWeek===r.DayOfWeek.Everyday||e.dayOfWeek===u.DaysOfWeekMap[t.isoWeekday()])&&s(e);break}}),o}module.exports=l;
|
|
@@ -1,38 +1,31 @@
|
|
|
1
|
-
import { DayOfWeek as
|
|
2
|
-
import
|
|
1
|
+
import { DayOfWeek as d, IntervalType as r } from "@ancon/wildcat-types";
|
|
2
|
+
import y from "moment";
|
|
3
3
|
import { DaysOfWeekMap as x } from "../shared/constants.mjs";
|
|
4
|
+
import f from "../date/createLocalTimezoneMoment.mjs";
|
|
4
5
|
import E from "./getExpressServiceIntervalStart.mjs";
|
|
5
|
-
import
|
|
6
|
+
import T from "./getExpressServiceIntervalEnd.mjs";
|
|
6
7
|
import "../time/getTimeSpanParts.mjs";
|
|
7
|
-
function
|
|
8
|
-
const t =
|
|
8
|
+
function I(n) {
|
|
9
|
+
const t = y();
|
|
9
10
|
let o = t.clone().add(1, "day").startOf("day");
|
|
10
|
-
function
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
e,
|
|
14
|
-
a
|
|
15
|
-
), n = k(
|
|
16
|
-
d,
|
|
17
|
-
e,
|
|
18
|
-
a
|
|
19
|
-
);
|
|
20
|
-
m.isBetween(t, o) ? o = m : n.isBetween(t, o) && (o = n);
|
|
11
|
+
function i(e) {
|
|
12
|
+
const a = e.type === r.Exception, c = a ? f(e.periodFrom) : t, p = a ? f(e.periodTo) : t, m = E(c, e), s = T(p, e);
|
|
13
|
+
m.isBetween(t, o) ? o = m : s.isBetween(t, o) && (o = s);
|
|
21
14
|
}
|
|
22
|
-
return
|
|
15
|
+
return n.forEach((e) => {
|
|
23
16
|
switch (e.type) {
|
|
24
17
|
case r.Exception:
|
|
25
|
-
|
|
18
|
+
i(e);
|
|
26
19
|
break;
|
|
27
|
-
case r.
|
|
20
|
+
case r.Normal:
|
|
28
21
|
default:
|
|
29
22
|
// Every day in the week
|
|
30
|
-
(e.dayOfWeek ===
|
|
31
|
-
e.dayOfWeek === x[t.isoWeekday()]) &&
|
|
23
|
+
(e.dayOfWeek === d.Everyday || // Specific day in the week
|
|
24
|
+
e.dayOfWeek === x[t.isoWeekday()]) && i(e);
|
|
32
25
|
break;
|
|
33
26
|
}
|
|
34
27
|
}), o;
|
|
35
28
|
}
|
|
36
29
|
export {
|
|
37
|
-
|
|
30
|
+
I as default
|
|
38
31
|
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { OpeningHoursInterval } from '@ancon/wildcat-types';
|
|
2
2
|
import { Moment } from 'moment';
|
|
3
|
-
export default function getExpressServiceIntervalEnd(date: Moment, interval:
|
|
3
|
+
export default function getExpressServiceIntervalEnd(date: Moment, interval: OpeningHoursInterval): Moment;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const
|
|
1
|
+
"use strict";const r=require("../time/getTimeSpanParts.js");function i(s,t){const e=r(t.from),o=r(t.duration),n=s.clone().hour(e.hours).minute(e.minutes).second(0).millisecond(0);return n.add(o),n}module.exports=i;
|
|
@@ -1,14 +1,8 @@
|
|
|
1
|
-
import
|
|
2
|
-
function
|
|
3
|
-
const
|
|
4
|
-
|
|
5
|
-
if (o) {
|
|
6
|
-
const i = n(o);
|
|
7
|
-
r = i.hours * 60 + i.minutes;
|
|
8
|
-
}
|
|
9
|
-
const t = e.clone().hour(u.hours).minute(u.minutes).second(0).millisecond(0), d = t.add(r, "minute").date() - e.date();
|
|
10
|
-
return Math.abs(d) && t.subtract(d, "day"), t.add(a.hours, "hour").add(a.minutes, "minute"), t;
|
|
1
|
+
import o from "../time/getTimeSpanParts.mjs";
|
|
2
|
+
function d(r, t) {
|
|
3
|
+
const e = o(t.from), s = o(t.duration), n = r.clone().hour(e.hours).minute(e.minutes).second(0).millisecond(0);
|
|
4
|
+
return n.add(s), n;
|
|
11
5
|
}
|
|
12
6
|
export {
|
|
13
|
-
|
|
7
|
+
d as default
|
|
14
8
|
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { OpeningHoursInterval } from '@ancon/wildcat-types';
|
|
2
2
|
import { Moment } from 'moment';
|
|
3
|
-
export default function getExpressServiceIntervalStart(date: Moment, interval:
|
|
3
|
+
export default function getExpressServiceIntervalStart(date: Moment, interval: OpeningHoursInterval): Moment;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const
|
|
1
|
+
"use strict";const s=require("../time/getTimeSpanParts.js");function n(e,r){const t=s(r.from);return e.clone().hour(t.hours).minute(t.minutes).second(0).millisecond(0)}module.exports=n;
|
|
@@ -1,14 +1,8 @@
|
|
|
1
|
-
import
|
|
2
|
-
function
|
|
3
|
-
const
|
|
4
|
-
|
|
5
|
-
if (s) {
|
|
6
|
-
const o = u(s);
|
|
7
|
-
r = o.hours * 60 + o.minutes;
|
|
8
|
-
}
|
|
9
|
-
const e = t.clone().hour(a.hours).minute(a.minutes).second(0).millisecond(0), n = e.add(r, "minute").date() - t.date();
|
|
10
|
-
return Math.abs(n) && e.subtract(n, "day"), e;
|
|
1
|
+
import s from "../time/getTimeSpanParts.mjs";
|
|
2
|
+
function a(e, r) {
|
|
3
|
+
const t = s(r.from);
|
|
4
|
+
return e.clone().hour(t.hours).minute(t.minutes).second(0).millisecond(0);
|
|
11
5
|
}
|
|
12
6
|
export {
|
|
13
|
-
|
|
7
|
+
a as default
|
|
14
8
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const
|
|
1
|
+
"use strict";const T=require("moment"),t=require("@ancon/wildcat-types"),g=require("../shared/isWithinFlag.js"),O=require("../shared/generateId.js");require("react");const F=require("../time/getTimeSpanParts.js"),I=require("../date/createLocalTimezoneMoment.js"),l=[{id:t.OrderFormat.EatIn,name:"eatIn"},{id:t.OrderFormat.TakeAway,name:"takeaway"},{id:t.OrderFormat.TableOrder,name:"tableOrder"},{id:t.OrderFormat.Delivery,name:"delivery"},{id:t.OrderFormat.BoxPickup,name:"boxPickup"}];function W(r){const n=T(r).subtract(1,"day").startOf("day"),e=[];for(let d=0,o=n;d<7;d+=1)o=o.clone().add(1,"day").startOf("day"),e.push(o.clone());return e}function v(r){return[...r].sort((n,e)=>n.isoWeekday()-e.isoWeekday())}function D(r,n){const e=F(r.from),d=F(r.duration);if(r.type===t.IntervalType.Normal){let o=n.clone().add(e.hours,"hour").add(e.minutes,"minute");const m=o.date()-n.date();m!==0&&(o=o.subtract(m,"day"));const s=o.clone().add(d);return{id:r.id,start:o.format("YYYY-MM-DDTHH:mm:ss"),end:s.format("YYYY-MM-DDTHH:mm:ss")}}if(r.type===t.IntervalType.Exception){const o=I(r.periodFrom),m=I(r.periodTo);if(n.isBetween(o,m,void 0,"[]")){const s=n.clone().add(e.hours,"hour").add(e.minutes,"minute"),i=s.clone().add(d);return{id:r.id,start:s.format("YYYY-MM-DDTHH:mm:ss"),end:i.format("YYYY-MM-DDTHH:mm:ss"),reason:r.reason}}return null}throw new Error("Invalid interval type")}function M(r,n,e){const d={[t.DayOfWeek.Monday]:1,[t.DayOfWeek.Tuesday]:2,[t.DayOfWeek.Wednesday]:3,[t.DayOfWeek.Thursday]:4,[t.DayOfWeek.Friday]:5,[t.DayOfWeek.Saturday]:6,[t.DayOfWeek.Sunday]:7,[t.DayOfWeek.Everyday]:null};for(let o=0;o<n.length;o+=1){const m=n[o],s=m.isoWeekday(),i=r.dayOfWeek,u=(d[i]??null)===s||i===t.DayOfWeek.Everyday;if(e[s]||(e[s]={isoWeekday:s,key:"",open:[],adjusted:[],closed:[]}),u){const a=D(r,m);a&&(e[s].key+=a.id,r.type===t.IntervalType.Normal&&r.state===t.IntervalState.Opened?e[s].open.push(a):r.type===t.IntervalType.Normal&&r.state===t.IntervalState.Closed?e[s].closed.push(a):r.type===t.IntervalType.Exception&&r.state===t.IntervalState.Opened?e[s].adjusted.push(a):r.type===t.IntervalType.Exception&&r.state===t.IntervalState.Closed&&e[s].closed.push(a))}}}function h(r){switch(r.type){case t.IntervalType.Exception:return O("interval-exception");case t.IntervalType.Normal:return O("interval-normal");default:return O("interval-unknown")}}function H(r){const n=r.reduce((e,d)=>(l.forEach(o=>{g(o.id,d.orderFormats)&&(e[o.id]||(e[o.id]={orderFormat:o,intervals:[]}),e[o.id].intervals.push(...d.intervals.sort((m,s)=>m.dayOfWeek-s.dayOfWeek)))}),e),{});return Object.values(n)}function Y(r,n){const e=n.reduce((d,o)=>o<=r?d+1:d,0);return r-e}function x(r){const{mergedTables:n}=r.reduce((e,d,o)=>{const m=e.mergedTables.findIndex(s=>s!==d&&!s.orderFormats.some(i=>d.orderFormats.some(p=>p.id===i.id))&&s.openingHours.every(i=>d.openingHours.some(p=>p.key===i.key))&&d.openingHours.every(i=>s.openingHours.some(p=>p.key===i.key)));if(m>=0){if(e.skipOrderFormats.some(a=>d.orderFormats.every(y=>y.id===a.id)))return e;const i=e.mergedTables[m];e.mergedTables.splice(m,1,{...i,orderFormats:[...d.orderFormats,...i.orderFormats]});const p=i.orderFormats.filter(a=>!e.skipOrderFormats.some(y=>y.id===a.id));p.length>0&&e.skipOrderFormats.push(...p);const u=Y(o,[...e.removedIndexes]);return e.mergedTables.splice(u,1),e.removedIndexes.push(o),e}return e},{mergedTables:[...r],removedIndexes:[],skipOrderFormats:[]});return n}function S(r){return r.map(n=>({...n,intervals:n.intervals.map(e=>({...e,id:h(e)}))}))}function E(r,n){const e=H(S(r.serviceDateTimes)),d=W(n),o=v(d),m=e.reduce((u,a)=>(u[a.orderFormat.id]||(u[a.orderFormat.id]={}),a.intervals.reduce((y,f)=>(M(f,o,y),y),u[a.orderFormat.id]),u),{}),s={[t.OrderFormat.EatIn]:l[0],[t.OrderFormat.TakeAway]:l[1],[t.OrderFormat.TableOrder]:l[2],[t.OrderFormat.Delivery]:l[3],[t.OrderFormat.BoxPickup]:l[4]},i=Object.entries(m).map(([u,a])=>({orderFormats:[s[Number(u)]],openingHours:Object.entries(a).map(([y,f])=>({isoWeekday:Number(y),key:f.key,open:f.open.sort((c,k)=>c.start.localeCompare(k.start)),adjusted:f.adjusted.sort((c,k)=>c.start.localeCompare(k.start)),closed:f.closed.sort((c,k)=>c.start.localeCompare(k.start))}))}));return x(i).sort((u,a)=>u.orderFormats[0].id-a.orderFormats[0].id)}module.exports=E;
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import
|
|
1
|
+
import W from "moment";
|
|
2
2
|
import { OrderFormat as p, DayOfWeek as f, IntervalType as l, IntervalState as F } from "@ancon/wildcat-types";
|
|
3
|
-
import
|
|
3
|
+
import H from "../shared/isWithinFlag.mjs";
|
|
4
4
|
import I from "../shared/generateId.mjs";
|
|
5
5
|
import "react";
|
|
6
|
-
import
|
|
6
|
+
import T from "../time/getTimeSpanParts.mjs";
|
|
7
|
+
import M from "../date/createLocalTimezoneMoment.mjs";
|
|
7
8
|
const k = [
|
|
8
9
|
{ id: p.EatIn, name: "eatIn" },
|
|
9
10
|
{ id: p.TakeAway, name: "takeaway" },
|
|
@@ -11,35 +12,35 @@ const k = [
|
|
|
11
12
|
{ id: p.Delivery, name: "delivery" },
|
|
12
13
|
{ id: p.BoxPickup, name: "boxPickup" }
|
|
13
14
|
];
|
|
14
|
-
function
|
|
15
|
-
const
|
|
16
|
-
for (let
|
|
15
|
+
function h(r) {
|
|
16
|
+
const s = W(r).subtract(1, "day").startOf("day"), e = [];
|
|
17
|
+
for (let n = 0, t = s; n < 7; n += 1)
|
|
17
18
|
t = t.clone().add(1, "day").startOf("day"), e.push(t.clone());
|
|
18
19
|
return e;
|
|
19
20
|
}
|
|
20
|
-
function
|
|
21
|
-
return [...r].sort((
|
|
21
|
+
function Y(r) {
|
|
22
|
+
return [...r].sort((s, e) => s.isoWeekday() - e.isoWeekday());
|
|
22
23
|
}
|
|
23
|
-
function
|
|
24
|
-
const e =
|
|
24
|
+
function x(r, s) {
|
|
25
|
+
const e = T(r.from), n = T(r.duration);
|
|
25
26
|
if (r.type === l.Normal) {
|
|
26
|
-
let t =
|
|
27
|
-
const i = t.date() -
|
|
27
|
+
let t = s.clone().add(e.hours, "hour").add(e.minutes, "minute");
|
|
28
|
+
const i = t.date() - s.date();
|
|
28
29
|
i !== 0 && (t = t.subtract(i, "day"));
|
|
29
|
-
const
|
|
30
|
+
const o = t.clone().add(n);
|
|
30
31
|
return {
|
|
31
32
|
id: r.id,
|
|
32
33
|
start: t.format("YYYY-MM-DDTHH:mm:ss"),
|
|
33
|
-
end:
|
|
34
|
+
end: o.format("YYYY-MM-DDTHH:mm:ss")
|
|
34
35
|
};
|
|
35
36
|
}
|
|
36
37
|
if (r.type === l.Exception) {
|
|
37
|
-
const t =
|
|
38
|
-
if (
|
|
39
|
-
const
|
|
38
|
+
const t = M(r.periodFrom), i = M(r.periodTo);
|
|
39
|
+
if (s.isBetween(t, i, void 0, "[]")) {
|
|
40
|
+
const o = s.clone().add(e.hours, "hour").add(e.minutes, "minute"), a = o.clone().add(n);
|
|
40
41
|
return {
|
|
41
42
|
id: r.id,
|
|
42
|
-
start:
|
|
43
|
+
start: o.format("YYYY-MM-DDTHH:mm:ss"),
|
|
43
44
|
end: a.format("YYYY-MM-DDTHH:mm:ss"),
|
|
44
45
|
reason: r.reason
|
|
45
46
|
};
|
|
@@ -48,8 +49,8 @@ function Y(r, n) {
|
|
|
48
49
|
}
|
|
49
50
|
throw new Error("Invalid interval type");
|
|
50
51
|
}
|
|
51
|
-
function
|
|
52
|
-
const
|
|
52
|
+
function D(r, s, e) {
|
|
53
|
+
const n = {
|
|
53
54
|
[f.Monday]: 1,
|
|
54
55
|
[f.Tuesday]: 2,
|
|
55
56
|
[f.Wednesday]: 3,
|
|
@@ -59,21 +60,21 @@ function x(r, n, e) {
|
|
|
59
60
|
[f.Sunday]: 7,
|
|
60
61
|
[f.Everyday]: null
|
|
61
62
|
};
|
|
62
|
-
for (let t = 0; t <
|
|
63
|
-
const i =
|
|
64
|
-
if (e[
|
|
65
|
-
isoWeekday:
|
|
63
|
+
for (let t = 0; t < s.length; t += 1) {
|
|
64
|
+
const i = s[t], o = i.isoWeekday(), a = r.dayOfWeek, m = (n[a] ?? null) === o || a === f.Everyday;
|
|
65
|
+
if (e[o] || (e[o] = {
|
|
66
|
+
isoWeekday: o,
|
|
66
67
|
key: "",
|
|
67
68
|
open: [],
|
|
68
69
|
adjusted: [],
|
|
69
70
|
closed: []
|
|
70
71
|
}), m) {
|
|
71
|
-
const d =
|
|
72
|
-
d && (e[
|
|
72
|
+
const d = x(r, i);
|
|
73
|
+
d && (e[o].key += d.id, r.type === l.Normal && r.state === F.Opened ? e[o].open.push(d) : r.type === l.Normal && r.state === F.Closed ? e[o].closed.push(d) : r.type === l.Exception && r.state === F.Opened ? e[o].adjusted.push(d) : r.type === l.Exception && r.state === F.Closed && e[o].closed.push(d));
|
|
73
74
|
}
|
|
74
75
|
}
|
|
75
76
|
}
|
|
76
|
-
function
|
|
77
|
+
function v(r) {
|
|
77
78
|
switch (r.type) {
|
|
78
79
|
case l.Exception:
|
|
79
80
|
return I("interval-exception");
|
|
@@ -83,76 +84,76 @@ function D(r) {
|
|
|
83
84
|
return I("interval-unknown");
|
|
84
85
|
}
|
|
85
86
|
}
|
|
86
|
-
function
|
|
87
|
-
const
|
|
88
|
-
|
|
87
|
+
function E(r) {
|
|
88
|
+
const s = r.reduce((e, n) => (k.forEach((t) => {
|
|
89
|
+
H(t.id, n.orderFormats) && (e[t.id] || (e[t.id] = {
|
|
89
90
|
orderFormat: t,
|
|
90
91
|
intervals: []
|
|
91
92
|
}), e[t.id].intervals.push(
|
|
92
|
-
...
|
|
93
|
-
(i,
|
|
93
|
+
...n.intervals.sort(
|
|
94
|
+
(i, o) => i.dayOfWeek - o.dayOfWeek
|
|
94
95
|
)
|
|
95
96
|
));
|
|
96
97
|
}), e), {});
|
|
97
|
-
return Object.values(
|
|
98
|
+
return Object.values(s);
|
|
98
99
|
}
|
|
99
|
-
function
|
|
100
|
-
const e =
|
|
100
|
+
function S(r, s) {
|
|
101
|
+
const e = s.reduce((n, t) => t <= r ? n + 1 : n, 0);
|
|
101
102
|
return r - e;
|
|
102
103
|
}
|
|
103
|
-
function
|
|
104
|
-
const { mergedTables:
|
|
105
|
-
(e,
|
|
104
|
+
function j(r) {
|
|
105
|
+
const { mergedTables: s } = r.reduce(
|
|
106
|
+
(e, n, t) => {
|
|
106
107
|
const i = e.mergedTables.findIndex(
|
|
107
|
-
(
|
|
108
|
-
(a) =>
|
|
108
|
+
(o) => o !== n && !o.orderFormats.some(
|
|
109
|
+
(a) => n.orderFormats.some(
|
|
109
110
|
(u) => u.id === a.id
|
|
110
111
|
)
|
|
111
|
-
) && s.openingHours.every(
|
|
112
|
-
(a) => o.openingHours.some((u) => u.key === a.key)
|
|
113
112
|
) && o.openingHours.every(
|
|
114
|
-
(a) =>
|
|
113
|
+
(a) => n.openingHours.some((u) => u.key === a.key)
|
|
114
|
+
) && n.openingHours.every(
|
|
115
|
+
(a) => o.openingHours.some((u) => u.key === a.key)
|
|
115
116
|
)
|
|
116
117
|
);
|
|
117
118
|
if (i >= 0) {
|
|
118
119
|
if (e.skipOrderFormats.some(
|
|
119
|
-
(d) =>
|
|
120
|
+
(d) => n.orderFormats.every((y) => y.id === d.id)
|
|
120
121
|
))
|
|
121
122
|
return e;
|
|
122
123
|
const a = e.mergedTables[i];
|
|
123
124
|
e.mergedTables.splice(i, 1, {
|
|
124
125
|
...a,
|
|
125
|
-
orderFormats: [...
|
|
126
|
+
orderFormats: [...n.orderFormats, ...a.orderFormats]
|
|
126
127
|
});
|
|
127
128
|
const u = a.orderFormats.filter(
|
|
128
129
|
(d) => !e.skipOrderFormats.some((y) => y.id === d.id)
|
|
129
130
|
);
|
|
130
131
|
u.length > 0 && e.skipOrderFormats.push(...u);
|
|
131
|
-
const m =
|
|
132
|
+
const m = S(t, [...e.removedIndexes]);
|
|
132
133
|
return e.mergedTables.splice(m, 1), e.removedIndexes.push(t), e;
|
|
133
134
|
}
|
|
134
135
|
return e;
|
|
135
136
|
},
|
|
136
137
|
{ mergedTables: [...r], removedIndexes: [], skipOrderFormats: [] }
|
|
137
138
|
);
|
|
138
|
-
return
|
|
139
|
+
return s;
|
|
139
140
|
}
|
|
140
|
-
function
|
|
141
|
-
return r.map((
|
|
142
|
-
...
|
|
143
|
-
intervals:
|
|
141
|
+
function w(r) {
|
|
142
|
+
return r.map((s) => ({
|
|
143
|
+
...s,
|
|
144
|
+
intervals: s.intervals.map((e) => ({
|
|
144
145
|
...e,
|
|
145
|
-
id:
|
|
146
|
+
id: v(e)
|
|
146
147
|
}))
|
|
147
148
|
}));
|
|
148
149
|
}
|
|
149
|
-
function
|
|
150
|
-
const e =
|
|
151
|
-
|
|
152
|
-
),
|
|
153
|
-
(m, d) => (m[d.orderFormat.id] || (m[d.orderFormat.id] = {}), d.intervals.reduce((y, c) => (
|
|
150
|
+
function L(r, s) {
|
|
151
|
+
const e = E(
|
|
152
|
+
w(r.serviceDateTimes)
|
|
153
|
+
), n = h(s), t = Y(n), i = e.reduce(
|
|
154
|
+
(m, d) => (m[d.orderFormat.id] || (m[d.orderFormat.id] = {}), d.intervals.reduce((y, c) => (D(c, t, y), y), m[d.orderFormat.id]), m),
|
|
154
155
|
{}
|
|
155
|
-
),
|
|
156
|
+
), o = {
|
|
156
157
|
[p.EatIn]: k[0],
|
|
157
158
|
[p.TakeAway]: k[1],
|
|
158
159
|
[p.TableOrder]: k[2],
|
|
@@ -161,7 +162,7 @@ function R(r, n) {
|
|
|
161
162
|
}, a = Object.entries(
|
|
162
163
|
i
|
|
163
164
|
).map(([m, d]) => ({
|
|
164
|
-
orderFormats: [
|
|
165
|
+
orderFormats: [o[Number(m)]],
|
|
165
166
|
openingHours: Object.entries(d).map(
|
|
166
167
|
([y, c]) => ({
|
|
167
168
|
isoWeekday: Number(y),
|
|
@@ -178,10 +179,10 @@ function R(r, n) {
|
|
|
178
179
|
})
|
|
179
180
|
)
|
|
180
181
|
}));
|
|
181
|
-
return
|
|
182
|
+
return j(a).sort(
|
|
182
183
|
(m, d) => m.orderFormats[0].id - d.orderFormats[0].id
|
|
183
184
|
);
|
|
184
185
|
}
|
|
185
186
|
export {
|
|
186
|
-
|
|
187
|
+
L as default
|
|
187
188
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const n=require("@ancon/wildcat-types"),
|
|
1
|
+
"use strict";const n=require("@ancon/wildcat-types"),f=require("../shared/constants.js"),p=require("../date/createLocalTimezoneMoment.js");require("moment");function y(r,c,i){const a=c.reduce((t,e)=>{if((e.orderFormat&i)===i)switch(e.type){case n.IntervalType.Exception:{const s=p(e.periodFrom),l=p(e.periodTo);r.isBetween(s,l,"day","[]")&&(e.state===n.IntervalState.Closed?t.closedExceptions.push(e):t.openExceptions.push(e))}break;case n.IntervalType.Normal:default:(e.dayOfWeek===n.DayOfWeek.Everyday||e.dayOfWeek===f.DaysOfWeekMap[r.isoWeekday()])&&t.openIntervals.push(e);break}return t},{closedExceptions:[],openExceptions:[],openIntervals:[]}),{closedExceptions:d,openExceptions:o,openIntervals:u}=a;if(!d.length){if(o.length){if(o.length>1){const[t]=o.sort((e,s)=>e.position-s.position);return t}return o[0]}return u[0]}}module.exports=y;
|