@kwiz/common 1.0.129 → 1.0.132

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.
Files changed (100) hide show
  1. package/.github/workflows/npm-publish.yml +24 -24
  2. package/LICENSE +21 -21
  3. package/lib/cjs/config.js +2 -0
  4. package/lib/cjs/config.js.map +1 -1
  5. package/lib/cjs/types/libs/msal.types.js +26 -26
  6. package/lib/cjs/utils/sharepoint.rest/user.js +11 -11
  7. package/lib/esm/config.js +2 -0
  8. package/lib/esm/config.js.map +1 -1
  9. package/lib/esm/types/libs/msal.types.js +26 -26
  10. package/lib/esm/utils/sharepoint.rest/user.js +11 -11
  11. package/lib/types/config.d.ts +2 -0
  12. package/package.json +81 -81
  13. package/readme.md +17 -17
  14. package/src/_dependencies.ts +12 -12
  15. package/src/config.ts +19 -17
  16. package/src/helpers/Guid.ts +181 -181
  17. package/src/helpers/base64.ts +173 -173
  18. package/src/helpers/browser.test.js +13 -13
  19. package/src/helpers/browser.ts +1504 -1504
  20. package/src/helpers/browserinfo.ts +292 -292
  21. package/src/helpers/collections.base.test.js +25 -25
  22. package/src/helpers/collections.base.ts +437 -437
  23. package/src/helpers/collections.ts +107 -107
  24. package/src/helpers/color.ts +54 -54
  25. package/src/helpers/cookies.ts +59 -59
  26. package/src/helpers/date.test.js +119 -119
  27. package/src/helpers/date.ts +188 -188
  28. package/src/helpers/debug.ts +186 -186
  29. package/src/helpers/diagrams.ts +43 -43
  30. package/src/helpers/emails.ts +6 -6
  31. package/src/helpers/eval.ts +5 -5
  32. package/src/helpers/file.test.js +50 -50
  33. package/src/helpers/file.ts +63 -63
  34. package/src/helpers/flatted.ts +149 -149
  35. package/src/helpers/functions.ts +16 -16
  36. package/src/helpers/graph/calendar.types.ts +10 -10
  37. package/src/helpers/http.ts +69 -69
  38. package/src/helpers/images.ts +22 -22
  39. package/src/helpers/json.ts +44 -44
  40. package/src/helpers/md5.ts +189 -189
  41. package/src/helpers/objects.test.js +33 -33
  42. package/src/helpers/objects.ts +274 -274
  43. package/src/helpers/promises.test.js +37 -37
  44. package/src/helpers/promises.ts +165 -165
  45. package/src/helpers/random.ts +27 -27
  46. package/src/helpers/scheduler/scheduler.test.js +103 -103
  47. package/src/helpers/scheduler/scheduler.ts +131 -131
  48. package/src/helpers/sharepoint.ts +796 -796
  49. package/src/helpers/strings.test.js +122 -122
  50. package/src/helpers/strings.ts +337 -337
  51. package/src/helpers/typecheckers.test.js +34 -34
  52. package/src/helpers/typecheckers.ts +266 -266
  53. package/src/helpers/url.test.js +43 -43
  54. package/src/helpers/url.ts +207 -207
  55. package/src/helpers/urlhelper.ts +111 -111
  56. package/src/index.ts +6 -6
  57. package/src/types/auth.ts +62 -62
  58. package/src/types/common.types.ts +15 -15
  59. package/src/types/flatted.types.ts +59 -59
  60. package/src/types/globals.types.ts +6 -6
  61. package/src/types/graph/calendar.types.ts +80 -80
  62. package/src/types/knownscript.types.ts +18 -18
  63. package/src/types/libs/datajs.types.ts +28 -28
  64. package/src/types/libs/ics.types.ts +30 -30
  65. package/src/types/libs/msal.types.ts +57 -57
  66. package/src/types/locales.ts +125 -125
  67. package/src/types/localstoragecache.types.ts +8 -8
  68. package/src/types/location.types.ts +27 -27
  69. package/src/types/moment.ts +11 -11
  70. package/src/types/regex.types.ts +16 -16
  71. package/src/types/rest.types.ts +95 -95
  72. package/src/types/sharepoint.types.ts +1466 -1466
  73. package/src/types/sharepoint.utils.types.ts +306 -306
  74. package/src/utils/auth/common.ts +118 -118
  75. package/src/utils/auth/discovery.test.js +12 -12
  76. package/src/utils/auth/discovery.ts +132 -132
  77. package/src/utils/base64.ts +27 -27
  78. package/src/utils/consolelogger.ts +333 -333
  79. package/src/utils/date.ts +172 -172
  80. package/src/utils/emails.ts +24 -24
  81. package/src/utils/knownscript.ts +286 -286
  82. package/src/utils/localstoragecache.ts +446 -446
  83. package/src/utils/rest.ts +501 -501
  84. package/src/utils/script.ts +170 -170
  85. package/src/utils/sharepoint.rest/common.ts +159 -159
  86. package/src/utils/sharepoint.rest/date.ts +62 -62
  87. package/src/utils/sharepoint.rest/file.folder.ts +685 -685
  88. package/src/utils/sharepoint.rest/item.ts +547 -547
  89. package/src/utils/sharepoint.rest/list.ts +1572 -1572
  90. package/src/utils/sharepoint.rest/listutils/GetListItemsByCaml.ts +774 -774
  91. package/src/utils/sharepoint.rest/listutils/GetListItemsById.ts +275 -275
  92. package/src/utils/sharepoint.rest/listutils/common.ts +206 -206
  93. package/src/utils/sharepoint.rest/location.ts +141 -141
  94. package/src/utils/sharepoint.rest/navigation-links.ts +86 -86
  95. package/src/utils/sharepoint.rest/user-search.ts +252 -252
  96. package/src/utils/sharepoint.rest/user.ts +558 -558
  97. package/src/utils/sharepoint.rest/web.ts +1384 -1384
  98. package/src/utils/sod.ts +194 -194
  99. package/.madgerc +0 -3
  100. package/fix-folder-imports.js +0 -27
@@ -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
  }