@kwiz/common 1.0.102 → 1.0.103

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