@kwiz/common 1.0.78 → 1.0.79
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/.github/workflows/npm-publish.yml +24 -0
- package/.madgerc +2 -2
- package/LICENSE +21 -21
- package/fix-folder-imports.js +26 -26
- package/lib/cjs/helpers/sharepoint.js +5 -1
- package/lib/cjs/helpers/sharepoint.js.map +1 -1
- package/lib/cjs/types/libs/msal.types.js +26 -26
- package/lib/cjs/utils/sharepoint.rest/list.js +1 -1
- package/lib/cjs/utils/sharepoint.rest/list.js.map +1 -1
- package/lib/cjs/utils/sharepoint.rest/user.js +11 -11
- package/lib/esm/helpers/sharepoint.js +3 -0
- package/lib/esm/helpers/sharepoint.js.map +1 -1
- package/lib/esm/types/libs/msal.types.js +26 -26
- package/lib/esm/utils/sharepoint.rest/list.js +2 -2
- package/lib/esm/utils/sharepoint.rest/list.js.map +1 -1
- package/lib/esm/utils/sharepoint.rest/user.js +11 -11
- package/lib/types/helpers/sharepoint.d.ts +1 -0
- package/package.json +77 -77
- package/readme.md +17 -17
- package/src/_dependencies.ts +12 -12
- package/src/config.ts +17 -17
- package/src/helpers/Guid.ts +181 -181
- package/src/helpers/base64.ts +173 -173
- package/src/helpers/browser.test.js +13 -13
- package/src/helpers/browser.ts +1348 -1348
- package/src/helpers/browserinfo.ts +292 -292
- package/src/helpers/collections.base.test.js +25 -25
- package/src/helpers/collections.base.ts +437 -437
- package/src/helpers/collections.ts +107 -107
- package/src/helpers/color.ts +54 -54
- package/src/helpers/cookies.ts +59 -59
- package/src/helpers/date.test.js +119 -119
- package/src/helpers/date.ts +188 -188
- package/src/helpers/debug.ts +186 -186
- package/src/helpers/emails.ts +6 -6
- package/src/helpers/eval.ts +5 -5
- package/src/helpers/file.test.js +50 -50
- package/src/helpers/file.ts +58 -58
- package/src/helpers/flatted.ts +149 -149
- package/src/helpers/functions.ts +16 -16
- package/src/helpers/graph/calendar.types.ts +10 -10
- package/src/helpers/http.ts +69 -69
- package/src/helpers/images.ts +22 -22
- package/src/helpers/json.ts +38 -38
- package/src/helpers/md5.ts +189 -189
- package/src/helpers/objects.test.js +33 -33
- package/src/helpers/objects.ts +270 -270
- package/src/helpers/promises.test.js +37 -37
- package/src/helpers/promises.ts +165 -165
- package/src/helpers/random.ts +27 -27
- package/src/helpers/scheduler/scheduler.test.js +103 -103
- package/src/helpers/scheduler/scheduler.ts +131 -131
- package/src/helpers/sharepoint.ts +776 -772
- package/src/helpers/strings.test.js +101 -101
- package/src/helpers/strings.ts +317 -317
- package/src/helpers/typecheckers.test.js +34 -34
- package/src/helpers/typecheckers.ts +262 -262
- package/src/helpers/url.test.js +43 -43
- package/src/helpers/url.ts +207 -207
- package/src/helpers/urlhelper.ts +111 -111
- package/src/index.ts +6 -6
- package/src/types/auth.ts +54 -54
- package/src/types/common.types.ts +15 -15
- package/src/types/flatted.types.ts +59 -59
- package/src/types/globals.types.ts +6 -6
- package/src/types/graph/calendar.types.ts +80 -80
- package/src/types/knownscript.types.ts +18 -18
- package/src/types/libs/datajs.types.ts +28 -28
- package/src/types/libs/ics.types.ts +30 -30
- package/src/types/libs/msal.types.ts +49 -49
- package/src/types/locales.ts +124 -124
- package/src/types/localstoragecache.types.ts +8 -8
- package/src/types/location.types.ts +27 -27
- package/src/types/moment.ts +11 -11
- package/src/types/regex.types.ts +16 -16
- package/src/types/rest.types.ts +95 -95
- package/src/types/sharepoint.types.ts +1465 -1465
- package/src/types/sharepoint.utils.types.ts +287 -287
- package/src/utils/auth/common.ts +74 -74
- package/src/utils/auth/discovery.test.js +12 -12
- package/src/utils/auth/discovery.ts +132 -132
- package/src/utils/base64.ts +27 -27
- package/src/utils/consolelogger.ts +320 -320
- package/src/utils/date.ts +35 -35
- package/src/utils/emails.ts +24 -24
- package/src/utils/knownscript.ts +286 -286
- package/src/utils/localstoragecache.ts +441 -441
- package/src/utils/rest.ts +501 -501
- package/src/utils/script.ts +170 -170
- package/src/utils/sharepoint.rest/common.ts +154 -154
- package/src/utils/sharepoint.rest/date.ts +62 -62
- package/src/utils/sharepoint.rest/file.folder.ts +598 -598
- package/src/utils/sharepoint.rest/item.ts +547 -547
- package/src/utils/sharepoint.rest/list.ts +1388 -1388
- package/src/utils/sharepoint.rest/listutils/GetListItemsByCaml.ts +774 -774
- package/src/utils/sharepoint.rest/listutils/GetListItemsById.ts +275 -275
- package/src/utils/sharepoint.rest/listutils/common.ts +206 -206
- package/src/utils/sharepoint.rest/location.ts +141 -141
- package/src/utils/sharepoint.rest/navigation-links.ts +86 -86
- package/src/utils/sharepoint.rest/user-search.ts +252 -252
- package/src/utils/sharepoint.rest/user.ts +491 -491
- package/src/utils/sharepoint.rest/web.ts +1384 -1384
- package/src/utils/sod.ts +194 -194
- package/lib/cjs/helpers/_dependencies.js +0 -21
- package/lib/cjs/helpers/_dependencies.js.map +0 -1
- package/lib/cjs/utils/_dependencies.js +0 -24
- package/lib/cjs/utils/_dependencies.js.map +0 -1
- package/lib/esm/helpers/_dependencies.js +0 -3
- package/lib/esm/helpers/_dependencies.js.map +0 -1
- package/lib/esm/utils/_dependencies.js +0 -4
- package/lib/esm/utils/_dependencies.js.map +0 -1
- package/lib/types/helpers/_dependencies.d.ts +0 -2
- package/lib/types/utils/_dependencies.d.ts +0 -3
|
@@ -1,132 +1,132 @@
|
|
|
1
|
-
import { firstOrNull, sortNumberArrayAsc } from "../collections.base";
|
|
2
|
-
import { cloneDate } from "../date";
|
|
3
|
-
import { padLeft } from "../strings";
|
|
4
|
-
import { isNotEmptyArray, isNullOrUndefined } from "../typecheckers";
|
|
5
|
-
|
|
6
|
-
export type hourlyInterval = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;
|
|
7
|
-
export type hours = 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23;
|
|
8
|
-
export type days = 0 | 1 | 2 | 3 | 4 | 5 | 6;
|
|
9
|
-
|
|
10
|
-
export enum ScheduleTypes {
|
|
11
|
-
hourly = "hourly",
|
|
12
|
-
daily = "daily",
|
|
13
|
-
weekly = "weekly"
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export const ScheduleTypesDefinitions: { [Name: string]: { title: string, value: ScheduleTypes }; } = {
|
|
17
|
-
weekly: {
|
|
18
|
-
value: ScheduleTypes.weekly,
|
|
19
|
-
title: "Run on specific days, at specific times"
|
|
20
|
-
},
|
|
21
|
-
daily: {
|
|
22
|
-
value: ScheduleTypes.daily,
|
|
23
|
-
title: "Run every day, at specific times"
|
|
24
|
-
},
|
|
25
|
-
hourly: {
|
|
26
|
-
value: ScheduleTypes.hourly,
|
|
27
|
-
title: "Run every few hours"
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
export interface IScheduleHourly {
|
|
32
|
-
ScheduleType: ScheduleTypes.hourly,
|
|
33
|
-
/** run every x number of hours */
|
|
34
|
-
interval: hourlyInterval;
|
|
35
|
-
}
|
|
36
|
-
export interface IScheduleDaily {
|
|
37
|
-
ScheduleType: ScheduleTypes.daily,
|
|
38
|
-
/** run every day, at these hours */
|
|
39
|
-
hours: hours[];
|
|
40
|
-
}
|
|
41
|
-
export interface IScheduleWeekly {
|
|
42
|
-
ScheduleType: ScheduleTypes.weekly,
|
|
43
|
-
/** run in the following days */
|
|
44
|
-
days: days[];
|
|
45
|
-
/** run at these hours */
|
|
46
|
-
hours: hours[];
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
export type TypeSchedule = IScheduleHourly | IScheduleDaily | IScheduleWeekly;
|
|
50
|
-
|
|
51
|
-
export const defaultWeeklySchedule: IScheduleWeekly = {
|
|
52
|
-
ScheduleType: ScheduleTypes.weekly,
|
|
53
|
-
days: [1, 2, 3, 4, 5],
|
|
54
|
-
hours: [0]
|
|
55
|
-
};
|
|
56
|
-
export const defaultDailySchedule: IScheduleDaily = {
|
|
57
|
-
ScheduleType: ScheduleTypes.daily,
|
|
58
|
-
hours: [0, 12]
|
|
59
|
-
};
|
|
60
|
-
export const defaultHourlySchedule: IScheduleHourly = {
|
|
61
|
-
ScheduleType: ScheduleTypes.hourly,
|
|
62
|
-
interval: 4
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
export function isValidSchedule(schedule: TypeSchedule) {
|
|
66
|
-
if (isNullOrUndefined(schedule)) return false;
|
|
67
|
-
if (schedule.ScheduleType === ScheduleTypes.hourly)
|
|
68
|
-
return schedule.interval > 0 && schedule.interval <= 12;
|
|
69
|
-
else if (schedule.ScheduleType === ScheduleTypes.daily) {
|
|
70
|
-
return isNotEmptyArray(schedule.hours) && schedule.hours.every(h => h >= 0 && h <= 23);
|
|
71
|
-
}
|
|
72
|
-
else if (schedule.ScheduleType === ScheduleTypes.weekly) {
|
|
73
|
-
return isNotEmptyArray(schedule.hours) && schedule.hours.every(h => h >= 0 && h <= 23)
|
|
74
|
-
&& isNotEmptyArray(schedule.days) && schedule.days.every(d => d >= 0 && d <= 6);
|
|
75
|
-
}
|
|
76
|
-
else return false;
|
|
77
|
-
}
|
|
78
|
-
/** returns a yyyyMMddHH for the next time this schedule needs to run after the currentDate */
|
|
79
|
-
export function getNextUTC(currentDate: Date, schedule: TypeSchedule): string {
|
|
80
|
-
if (!isValidSchedule(schedule)) return "9999999999";
|
|
81
|
-
|
|
82
|
-
currentDate = cloneDate(currentDate);
|
|
83
|
-
|
|
84
|
-
let date = currentDate.getUTCDate();
|
|
85
|
-
let hour = currentDate.getUTCHours();
|
|
86
|
-
let day = currentDate.getUTCDay() as days;
|
|
87
|
-
|
|
88
|
-
//adjust date based on selected schedule
|
|
89
|
-
if (schedule.ScheduleType === ScheduleTypes.hourly) {
|
|
90
|
-
hour += schedule.interval;
|
|
91
|
-
currentDate.setUTCHours(hour);
|
|
92
|
-
}
|
|
93
|
-
else if (schedule.ScheduleType === ScheduleTypes.daily) {
|
|
94
|
-
//get current hour, see if the next run is today or tomorrow
|
|
95
|
-
let sortedHours = schedule.hours.sort(sortNumberArrayAsc);
|
|
96
|
-
let nextHour = firstOrNull(sortedHours.filter(h => h > hour));
|
|
97
|
-
if (nextHour !== null) {
|
|
98
|
-
currentDate.setUTCHours(nextHour);
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
//tomorrow at the first scheduled hour
|
|
102
|
-
currentDate.setUTCHours(sortedHours[0]);
|
|
103
|
-
currentDate.setUTCDate(date + 1);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
else {
|
|
107
|
-
//implement weekly
|
|
108
|
-
let sortedDays = schedule.days.sort(sortNumberArrayAsc);
|
|
109
|
-
let sortedHours = schedule.hours.sort(sortNumberArrayAsc);
|
|
110
|
-
let nextHour = firstOrNull(sortedHours.filter(h => h > hour));
|
|
111
|
-
let nextDay = firstOrNull(sortedDays.filter(h => h > day));
|
|
112
|
-
|
|
113
|
-
if (sortedDays.includes(day) && nextHour !== null)//today is allowed
|
|
114
|
-
{
|
|
115
|
-
currentDate.setUTCHours(nextHour);
|
|
116
|
-
}
|
|
117
|
-
else//move to next allowed day, at first hour allowed
|
|
118
|
-
{
|
|
119
|
-
let daysToAdd = nextDay === null
|
|
120
|
-
? 7 - day + sortedDays[0]
|
|
121
|
-
: nextDay - day;
|
|
122
|
-
currentDate.setUTCHours(sortedHours[0]);
|
|
123
|
-
currentDate.setUTCDate(date + daysToAdd);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
return getUTCDateMarker(currentDate);
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
export function getUTCDateMarker(date: Date) {
|
|
131
|
-
return `${date.getUTCFullYear()}${padLeft(date.getUTCMonth() + 1, 2)}${padLeft(date.getUTCDate(), 2)}${padLeft(date.getUTCHours(), 2)}`;
|
|
1
|
+
import { firstOrNull, sortNumberArrayAsc } from "../collections.base";
|
|
2
|
+
import { cloneDate } from "../date";
|
|
3
|
+
import { padLeft } from "../strings";
|
|
4
|
+
import { isNotEmptyArray, isNullOrUndefined } from "../typecheckers";
|
|
5
|
+
|
|
6
|
+
export type hourlyInterval = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;
|
|
7
|
+
export type hours = 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23;
|
|
8
|
+
export type days = 0 | 1 | 2 | 3 | 4 | 5 | 6;
|
|
9
|
+
|
|
10
|
+
export enum ScheduleTypes {
|
|
11
|
+
hourly = "hourly",
|
|
12
|
+
daily = "daily",
|
|
13
|
+
weekly = "weekly"
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export const ScheduleTypesDefinitions: { [Name: string]: { title: string, value: ScheduleTypes }; } = {
|
|
17
|
+
weekly: {
|
|
18
|
+
value: ScheduleTypes.weekly,
|
|
19
|
+
title: "Run on specific days, at specific times"
|
|
20
|
+
},
|
|
21
|
+
daily: {
|
|
22
|
+
value: ScheduleTypes.daily,
|
|
23
|
+
title: "Run every day, at specific times"
|
|
24
|
+
},
|
|
25
|
+
hourly: {
|
|
26
|
+
value: ScheduleTypes.hourly,
|
|
27
|
+
title: "Run every few hours"
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
export interface IScheduleHourly {
|
|
32
|
+
ScheduleType: ScheduleTypes.hourly,
|
|
33
|
+
/** run every x number of hours */
|
|
34
|
+
interval: hourlyInterval;
|
|
35
|
+
}
|
|
36
|
+
export interface IScheduleDaily {
|
|
37
|
+
ScheduleType: ScheduleTypes.daily,
|
|
38
|
+
/** run every day, at these hours */
|
|
39
|
+
hours: hours[];
|
|
40
|
+
}
|
|
41
|
+
export interface IScheduleWeekly {
|
|
42
|
+
ScheduleType: ScheduleTypes.weekly,
|
|
43
|
+
/** run in the following days */
|
|
44
|
+
days: days[];
|
|
45
|
+
/** run at these hours */
|
|
46
|
+
hours: hours[];
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export type TypeSchedule = IScheduleHourly | IScheduleDaily | IScheduleWeekly;
|
|
50
|
+
|
|
51
|
+
export const defaultWeeklySchedule: IScheduleWeekly = {
|
|
52
|
+
ScheduleType: ScheduleTypes.weekly,
|
|
53
|
+
days: [1, 2, 3, 4, 5],
|
|
54
|
+
hours: [0]
|
|
55
|
+
};
|
|
56
|
+
export const defaultDailySchedule: IScheduleDaily = {
|
|
57
|
+
ScheduleType: ScheduleTypes.daily,
|
|
58
|
+
hours: [0, 12]
|
|
59
|
+
};
|
|
60
|
+
export const defaultHourlySchedule: IScheduleHourly = {
|
|
61
|
+
ScheduleType: ScheduleTypes.hourly,
|
|
62
|
+
interval: 4
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
export function isValidSchedule(schedule: TypeSchedule) {
|
|
66
|
+
if (isNullOrUndefined(schedule)) return false;
|
|
67
|
+
if (schedule.ScheduleType === ScheduleTypes.hourly)
|
|
68
|
+
return schedule.interval > 0 && schedule.interval <= 12;
|
|
69
|
+
else if (schedule.ScheduleType === ScheduleTypes.daily) {
|
|
70
|
+
return isNotEmptyArray(schedule.hours) && schedule.hours.every(h => h >= 0 && h <= 23);
|
|
71
|
+
}
|
|
72
|
+
else if (schedule.ScheduleType === ScheduleTypes.weekly) {
|
|
73
|
+
return isNotEmptyArray(schedule.hours) && schedule.hours.every(h => h >= 0 && h <= 23)
|
|
74
|
+
&& isNotEmptyArray(schedule.days) && schedule.days.every(d => d >= 0 && d <= 6);
|
|
75
|
+
}
|
|
76
|
+
else return false;
|
|
77
|
+
}
|
|
78
|
+
/** returns a yyyyMMddHH for the next time this schedule needs to run after the currentDate */
|
|
79
|
+
export function getNextUTC(currentDate: Date, schedule: TypeSchedule): string {
|
|
80
|
+
if (!isValidSchedule(schedule)) return "9999999999";
|
|
81
|
+
|
|
82
|
+
currentDate = cloneDate(currentDate);
|
|
83
|
+
|
|
84
|
+
let date = currentDate.getUTCDate();
|
|
85
|
+
let hour = currentDate.getUTCHours();
|
|
86
|
+
let day = currentDate.getUTCDay() as days;
|
|
87
|
+
|
|
88
|
+
//adjust date based on selected schedule
|
|
89
|
+
if (schedule.ScheduleType === ScheduleTypes.hourly) {
|
|
90
|
+
hour += schedule.interval;
|
|
91
|
+
currentDate.setUTCHours(hour);
|
|
92
|
+
}
|
|
93
|
+
else if (schedule.ScheduleType === ScheduleTypes.daily) {
|
|
94
|
+
//get current hour, see if the next run is today or tomorrow
|
|
95
|
+
let sortedHours = schedule.hours.sort(sortNumberArrayAsc);
|
|
96
|
+
let nextHour = firstOrNull(sortedHours.filter(h => h > hour));
|
|
97
|
+
if (nextHour !== null) {
|
|
98
|
+
currentDate.setUTCHours(nextHour);
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
//tomorrow at the first scheduled hour
|
|
102
|
+
currentDate.setUTCHours(sortedHours[0]);
|
|
103
|
+
currentDate.setUTCDate(date + 1);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
//implement weekly
|
|
108
|
+
let sortedDays = schedule.days.sort(sortNumberArrayAsc);
|
|
109
|
+
let sortedHours = schedule.hours.sort(sortNumberArrayAsc);
|
|
110
|
+
let nextHour = firstOrNull(sortedHours.filter(h => h > hour));
|
|
111
|
+
let nextDay = firstOrNull(sortedDays.filter(h => h > day));
|
|
112
|
+
|
|
113
|
+
if (sortedDays.includes(day) && nextHour !== null)//today is allowed
|
|
114
|
+
{
|
|
115
|
+
currentDate.setUTCHours(nextHour);
|
|
116
|
+
}
|
|
117
|
+
else//move to next allowed day, at first hour allowed
|
|
118
|
+
{
|
|
119
|
+
let daysToAdd = nextDay === null
|
|
120
|
+
? 7 - day + sortedDays[0]
|
|
121
|
+
: nextDay - day;
|
|
122
|
+
currentDate.setUTCHours(sortedHours[0]);
|
|
123
|
+
currentDate.setUTCDate(date + daysToAdd);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
return getUTCDateMarker(currentDate);
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
export function getUTCDateMarker(date: Date) {
|
|
131
|
+
return `${date.getUTCFullYear()}${padLeft(date.getUTCMonth() + 1, 2)}${padLeft(date.getUTCDate(), 2)}${padLeft(date.getUTCHours(), 2)}`;
|
|
132
132
|
}
|