@kwiz/common 1.0.107 → 1.0.109

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 (116) 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/helpers/browser.js +9 -5
  6. package/lib/cjs/helpers/browser.js.map +1 -1
  7. package/lib/cjs/types/libs/msal.types.js +26 -26
  8. package/lib/cjs/types/libs/msal.types.js.map +1 -1
  9. package/lib/cjs/types/sharepoint.utils.types.js +9 -1
  10. package/lib/cjs/types/sharepoint.utils.types.js.map +1 -1
  11. package/lib/cjs/utils/sharepoint.rest/file.folder.js +4 -4
  12. package/lib/cjs/utils/sharepoint.rest/file.folder.js.map +1 -1
  13. package/lib/cjs/utils/sharepoint.rest/list.js +60 -1
  14. package/lib/cjs/utils/sharepoint.rest/list.js.map +1 -1
  15. package/lib/cjs/utils/sharepoint.rest/user.js +11 -11
  16. package/lib/esm/helpers/browser.js +9 -5
  17. package/lib/esm/helpers/browser.js.map +1 -1
  18. package/lib/esm/types/libs/msal.types.js +26 -26
  19. package/lib/esm/types/libs/msal.types.js.map +1 -1
  20. package/lib/esm/types/sharepoint.utils.types.js +8 -0
  21. package/lib/esm/types/sharepoint.utils.types.js.map +1 -1
  22. package/lib/esm/utils/sharepoint.rest/file.folder.js +4 -4
  23. package/lib/esm/utils/sharepoint.rest/file.folder.js.map +1 -1
  24. package/lib/esm/utils/sharepoint.rest/list.js +57 -0
  25. package/lib/esm/utils/sharepoint.rest/list.js.map +1 -1
  26. package/lib/esm/utils/sharepoint.rest/user.js +11 -11
  27. package/lib/types/types/libs/msal.types.d.ts +8 -3
  28. package/lib/types/types/sharepoint.utils.types.d.ts +17 -0
  29. package/lib/types/utils/sharepoint.rest/list.d.ts +7 -1
  30. package/package.json +81 -81
  31. package/readme.md +17 -17
  32. package/src/_dependencies.ts +12 -12
  33. package/src/config.ts +17 -17
  34. package/src/helpers/Guid.ts +181 -181
  35. package/src/helpers/base64.ts +173 -173
  36. package/src/helpers/browser.test.js +13 -13
  37. package/src/helpers/browser.ts +1448 -1448
  38. package/src/helpers/browserinfo.ts +292 -292
  39. package/src/helpers/collections.base.test.js +25 -25
  40. package/src/helpers/collections.base.ts +437 -437
  41. package/src/helpers/collections.ts +107 -107
  42. package/src/helpers/color.ts +54 -54
  43. package/src/helpers/cookies.ts +59 -59
  44. package/src/helpers/date.test.js +119 -119
  45. package/src/helpers/date.ts +188 -188
  46. package/src/helpers/debug.ts +186 -186
  47. package/src/helpers/diagrams.ts +43 -43
  48. package/src/helpers/emails.ts +6 -6
  49. package/src/helpers/eval.ts +5 -5
  50. package/src/helpers/file.test.js +50 -50
  51. package/src/helpers/file.ts +63 -63
  52. package/src/helpers/flatted.ts +149 -149
  53. package/src/helpers/functions.ts +16 -16
  54. package/src/helpers/graph/calendar.types.ts +10 -10
  55. package/src/helpers/http.ts +69 -69
  56. package/src/helpers/images.ts +22 -22
  57. package/src/helpers/json.ts +44 -44
  58. package/src/helpers/md5.ts +189 -189
  59. package/src/helpers/objects.test.js +33 -33
  60. package/src/helpers/objects.ts +274 -274
  61. package/src/helpers/promises.test.js +37 -37
  62. package/src/helpers/promises.ts +165 -165
  63. package/src/helpers/random.ts +27 -27
  64. package/src/helpers/scheduler/scheduler.test.js +103 -103
  65. package/src/helpers/scheduler/scheduler.ts +131 -131
  66. package/src/helpers/sharepoint.ts +785 -785
  67. package/src/helpers/strings.test.js +122 -122
  68. package/src/helpers/strings.ts +337 -337
  69. package/src/helpers/typecheckers.test.js +34 -34
  70. package/src/helpers/typecheckers.ts +266 -266
  71. package/src/helpers/url.test.js +43 -43
  72. package/src/helpers/url.ts +207 -207
  73. package/src/helpers/urlhelper.ts +111 -111
  74. package/src/index.ts +6 -6
  75. package/src/types/auth.ts +54 -54
  76. package/src/types/common.types.ts +15 -15
  77. package/src/types/flatted.types.ts +59 -59
  78. package/src/types/globals.types.ts +6 -6
  79. package/src/types/graph/calendar.types.ts +80 -80
  80. package/src/types/knownscript.types.ts +18 -18
  81. package/src/types/libs/datajs.types.ts +28 -28
  82. package/src/types/libs/ics.types.ts +30 -30
  83. package/src/types/libs/msal.types.ts +57 -49
  84. package/src/types/locales.ts +125 -125
  85. package/src/types/localstoragecache.types.ts +8 -8
  86. package/src/types/location.types.ts +27 -27
  87. package/src/types/moment.ts +11 -11
  88. package/src/types/regex.types.ts +16 -16
  89. package/src/types/rest.types.ts +95 -95
  90. package/src/types/sharepoint.types.ts +1466 -1466
  91. package/src/types/sharepoint.utils.types.ts +306 -287
  92. package/src/utils/auth/common.ts +74 -74
  93. package/src/utils/auth/discovery.test.js +12 -12
  94. package/src/utils/auth/discovery.ts +132 -132
  95. package/src/utils/base64.ts +27 -27
  96. package/src/utils/consolelogger.ts +320 -320
  97. package/src/utils/date.ts +172 -172
  98. package/src/utils/emails.ts +24 -24
  99. package/src/utils/knownscript.ts +286 -286
  100. package/src/utils/localstoragecache.ts +446 -446
  101. package/src/utils/rest.ts +501 -501
  102. package/src/utils/script.ts +170 -170
  103. package/src/utils/sharepoint.rest/common.ts +154 -154
  104. package/src/utils/sharepoint.rest/date.ts +62 -62
  105. package/src/utils/sharepoint.rest/file.folder.ts +598 -598
  106. package/src/utils/sharepoint.rest/item.ts +547 -547
  107. package/src/utils/sharepoint.rest/list.ts +1548 -1482
  108. package/src/utils/sharepoint.rest/listutils/GetListItemsByCaml.ts +774 -774
  109. package/src/utils/sharepoint.rest/listutils/GetListItemsById.ts +275 -275
  110. package/src/utils/sharepoint.rest/listutils/common.ts +206 -206
  111. package/src/utils/sharepoint.rest/location.ts +141 -141
  112. package/src/utils/sharepoint.rest/navigation-links.ts +86 -86
  113. package/src/utils/sharepoint.rest/user-search.ts +252 -252
  114. package/src/utils/sharepoint.rest/user.ts +491 -491
  115. package/src/utils/sharepoint.rest/web.ts +1384 -1384
  116. package/src/utils/sod.ts +194 -194
@@ -1,187 +1,187 @@
1
- import { IsLocalDev } from "../_dependencies";
2
- import { deleteCookie, getCookie, setCookie } from "./cookies";
3
- import { $w, getKWizComGlobal } from "./objects";
4
- import { sleepAsync } from "./promises";
5
- import { isFunction, isNotEmptyArray, isNullOrEmptyString, isNullOrUndefined } from "./typecheckers";
6
-
7
- interface IKWizComGlobalDebug {
8
- _debug: boolean;
9
- _consoleLoggerFilter: string[];
10
- On: (Permanent?: boolean) => void;
11
- Off: () => void;
12
- ToggleLogs: (categoryName: string, silent?: boolean) => void;
13
- /** purge all cache storage (SPFx may keep scripts cached) */
14
- PurgeCache: (options?: {
15
- skipCookies?: boolean;
16
- skipStorage?: boolean;
17
- onlyKWizComCaches?: boolean;
18
- }) => Promise<{ success: boolean; error?: any; message?: string; }>;
19
- }
20
-
21
- /** Get the global debug object. it will only be on the top window so don't put it in the IKWizComGlobals */
22
- export function GetGlobalDebug() {
23
- return getKWizComGlobal(true) as { Debug?: IKWizComGlobalDebug; } & IKWizComGlobals;
24
- }
25
- function SetGlobalDebugFunction() {
26
- var kGlobal = GetGlobalDebug();
27
-
28
- if (isNullOrUndefined(kGlobal.Debug)) {
29
- kGlobal.Debug = {
30
- _debug: null,
31
- _consoleLoggerFilter: null,
32
- On: (Permanent?: boolean) => {
33
- kGlobal.Debug._debug = true;
34
- setCookie("KWizComDebug", "true", Permanent === true ? 365 : 1);
35
- console.log("KWIZ Debug Mode: On");
36
- },
37
- Off: () => {
38
- kGlobal.Debug._debug = false;
39
- deleteCookie("KWizComDebug");
40
- console.log("KWIZ Debug Mode: Off");
41
- },
42
- ToggleLogs: (categoryName: string, silent?: boolean) => {
43
- if (silent === true) {
44
- if (kGlobal.Debug._consoleLoggerFilter === null)
45
- kGlobal.Debug._consoleLoggerFilter = [categoryName];
46
- else if (!kGlobal.Debug._consoleLoggerFilter.includes(categoryName))
47
- kGlobal.Debug._consoleLoggerFilter.push(categoryName);
48
- }
49
- else {
50
- if (kGlobal.Debug._consoleLoggerFilter === null)
51
- kGlobal.Debug._consoleLoggerFilter = [];
52
- else if (kGlobal.Debug._consoleLoggerFilter.includes(categoryName))
53
- kGlobal.Debug._consoleLoggerFilter = kGlobal.Debug._consoleLoggerFilter.filter(c => c !== categoryName);
54
- }
55
-
56
- setCookie("KWizComDebugFilter", kGlobal.Debug._consoleLoggerFilter.join('~'), 365);
57
- console.log(`logs for ${categoryName} will ${silent === true ? 'not show up' : 'show up'}`);
58
- },
59
- PurgeCache: async (options?: {
60
- skipCookies?: boolean;
61
- skipStorage?: boolean;
62
- onlyKWizComCaches?: boolean;
63
- }) => {
64
- options = options || {};
65
-
66
- let result: { success: boolean; error?: any; message?: string; } = { success: true };
67
- let failedKeys: string[] = [];
68
- if (options.skipStorage !== true) {
69
- console.log(`purging local storage`);
70
- localStorage.clear();
71
- console.log(`purging session storage`);
72
- sessionStorage.clear();
73
- }
74
-
75
- if (options.skipCookies !== true) {
76
- console.log(`purging all cookies`);
77
- var cookies = document.cookie.split(";");
78
- cookies.forEach(cookie => { document.cookie = cookie.split("=")[0] + "=;expires=Thu, 01 Jan 1970 00:00:00 GMT"; });
79
- }
80
-
81
- console.log(`purging caches`);
82
- try {
83
- let keys = await caches.keys();
84
- for (let i1 = 0; i1 < keys.length; i1++) {
85
- let key = keys[i1];
86
- try {
87
- let cache = await caches.open(key);
88
- if (cache) {
89
- let subKeys = await cache.keys();
90
- if (subKeys && subKeys.length) {
91
- let keysToRemove = options.onlyKWizComCaches !== true ? subKeys : subKeys.filter(k => k.url.toLowerCase().indexOf('apps.kwizcom.com/') >= 0);
92
- for (let i2 = 0; i2 < keysToRemove.length; i2++) {
93
- let success = await cache.delete(keysToRemove[i2]);
94
- if (!success)//failed
95
- failedKeys.push(keysToRemove[i2].url);
96
- }
97
- }
98
- }
99
- } catch (b) {
100
- failedKeys.push(key);
101
- }
102
- }
103
- } catch (e) {
104
- result.success = false;
105
- result.error = e;
106
- result.message = (e.message || "Something went wrong.");
107
- }
108
-
109
- if (isNotEmptyArray(failedKeys)) {
110
- result.success = false;
111
- result.message = (isNullOrEmptyString(result.message) ? '' : ' ') + `Failed keys: ${failedKeys.join()}`;
112
- }
113
-
114
- console.group('PurgeCache complete');
115
- console.dir(result);
116
- console.groupEnd();
117
-
118
- return result;
119
- }
120
- };
121
- //no need to do this anymore, once we added max-age cache to our response headers, the SP Service worker now clears
122
- //the cache of our SPFx controls on its own.
123
- // //by default - DO NOT clear cookies/storage and non-KWIZ caches!
124
- // window.setTimeout(() => kGlobal.Debug.PurgeCache({
125
- // skipCookies: true,
126
- // skipStorage: true,
127
- // onlyKWizComCaches: true
128
- // }), 3000);
129
- }
130
- }
131
-
132
- SetGlobalDebugFunction();
133
-
134
- export function isDebug() {
135
- var kGlobal = GetGlobalDebug();
136
-
137
- if (isNullOrUndefined(kGlobal.Debug._debug)) {
138
- kGlobal.Debug._debug = IsLocalDev ||
139
- $w.location.href.indexOf('kwdebug=true') > 0 ||
140
- $w.location.href.indexOf('/workbench.aspx') > 0 ||
141
- getCookie("KWizComDebug") === "true";
142
- }
143
- return kGlobal.Debug._debug === true;
144
- }
145
- /** returns true if this is a kwizcom production/test tenant */
146
- export function isKWizComTenant() {
147
- return $w.location.host === "kwizcom.sharepoint.com" || window.location.host === "kwizcomqa.sharepoint.com";
148
- }
149
- export function isDebugOnKWizComTenant() {
150
- return isKWizComTenant() && isDebug();
151
- }
152
-
153
- export function consoleLoggerFilter() {
154
- var kGlobal = GetGlobalDebug();
155
-
156
- if (isNullOrUndefined(kGlobal.Debug._consoleLoggerFilter)) {
157
- let KWizComDebugFilter = getCookie("KWizComDebugFilter");
158
- if (!isNullOrEmptyString(KWizComDebugFilter))
159
- kGlobal.Debug._consoleLoggerFilter = KWizComDebugFilter.split('~');
160
- else kGlobal.Debug._consoleLoggerFilter = [];
161
- }
162
- return kGlobal.Debug._consoleLoggerFilter;
163
- }
164
-
165
- export async function waitIfDebug(seconds?: number): Promise<void> {
166
- if (isDebug())
167
- await sleepAsync(seconds);
168
- }
169
-
170
- export function trackChangesToObject<T>(parent: unknown, objectName: string, tracker: {
171
- onBeforeGet?: (v: T) => void;
172
- onBeforeSet?: (v: T) => void;
173
- onAfterSet?: (v: T) => void;
174
- }) {
175
- let originalValue: T = parent[objectName];
176
- Object.defineProperty(parent, objectName, {
177
- set: (newValue: T) => {
178
- if (isFunction(tracker.onBeforeSet)) tracker.onBeforeSet(newValue);
179
- originalValue = newValue;
180
- if (isFunction(tracker.onAfterSet)) tracker.onAfterSet(newValue);
181
- },
182
- get: () => {
183
- if (isFunction(tracker.onBeforeGet)) tracker.onBeforeGet(originalValue);
184
- return originalValue;
185
- }
186
- });
1
+ import { IsLocalDev } from "../_dependencies";
2
+ import { deleteCookie, getCookie, setCookie } from "./cookies";
3
+ import { $w, getKWizComGlobal } from "./objects";
4
+ import { sleepAsync } from "./promises";
5
+ import { isFunction, isNotEmptyArray, isNullOrEmptyString, isNullOrUndefined } from "./typecheckers";
6
+
7
+ interface IKWizComGlobalDebug {
8
+ _debug: boolean;
9
+ _consoleLoggerFilter: string[];
10
+ On: (Permanent?: boolean) => void;
11
+ Off: () => void;
12
+ ToggleLogs: (categoryName: string, silent?: boolean) => void;
13
+ /** purge all cache storage (SPFx may keep scripts cached) */
14
+ PurgeCache: (options?: {
15
+ skipCookies?: boolean;
16
+ skipStorage?: boolean;
17
+ onlyKWizComCaches?: boolean;
18
+ }) => Promise<{ success: boolean; error?: any; message?: string; }>;
19
+ }
20
+
21
+ /** Get the global debug object. it will only be on the top window so don't put it in the IKWizComGlobals */
22
+ export function GetGlobalDebug() {
23
+ return getKWizComGlobal(true) as { Debug?: IKWizComGlobalDebug; } & IKWizComGlobals;
24
+ }
25
+ function SetGlobalDebugFunction() {
26
+ var kGlobal = GetGlobalDebug();
27
+
28
+ if (isNullOrUndefined(kGlobal.Debug)) {
29
+ kGlobal.Debug = {
30
+ _debug: null,
31
+ _consoleLoggerFilter: null,
32
+ On: (Permanent?: boolean) => {
33
+ kGlobal.Debug._debug = true;
34
+ setCookie("KWizComDebug", "true", Permanent === true ? 365 : 1);
35
+ console.log("KWIZ Debug Mode: On");
36
+ },
37
+ Off: () => {
38
+ kGlobal.Debug._debug = false;
39
+ deleteCookie("KWizComDebug");
40
+ console.log("KWIZ Debug Mode: Off");
41
+ },
42
+ ToggleLogs: (categoryName: string, silent?: boolean) => {
43
+ if (silent === true) {
44
+ if (kGlobal.Debug._consoleLoggerFilter === null)
45
+ kGlobal.Debug._consoleLoggerFilter = [categoryName];
46
+ else if (!kGlobal.Debug._consoleLoggerFilter.includes(categoryName))
47
+ kGlobal.Debug._consoleLoggerFilter.push(categoryName);
48
+ }
49
+ else {
50
+ if (kGlobal.Debug._consoleLoggerFilter === null)
51
+ kGlobal.Debug._consoleLoggerFilter = [];
52
+ else if (kGlobal.Debug._consoleLoggerFilter.includes(categoryName))
53
+ kGlobal.Debug._consoleLoggerFilter = kGlobal.Debug._consoleLoggerFilter.filter(c => c !== categoryName);
54
+ }
55
+
56
+ setCookie("KWizComDebugFilter", kGlobal.Debug._consoleLoggerFilter.join('~'), 365);
57
+ console.log(`logs for ${categoryName} will ${silent === true ? 'not show up' : 'show up'}`);
58
+ },
59
+ PurgeCache: async (options?: {
60
+ skipCookies?: boolean;
61
+ skipStorage?: boolean;
62
+ onlyKWizComCaches?: boolean;
63
+ }) => {
64
+ options = options || {};
65
+
66
+ let result: { success: boolean; error?: any; message?: string; } = { success: true };
67
+ let failedKeys: string[] = [];
68
+ if (options.skipStorage !== true) {
69
+ console.log(`purging local storage`);
70
+ localStorage.clear();
71
+ console.log(`purging session storage`);
72
+ sessionStorage.clear();
73
+ }
74
+
75
+ if (options.skipCookies !== true) {
76
+ console.log(`purging all cookies`);
77
+ var cookies = document.cookie.split(";");
78
+ cookies.forEach(cookie => { document.cookie = cookie.split("=")[0] + "=;expires=Thu, 01 Jan 1970 00:00:00 GMT"; });
79
+ }
80
+
81
+ console.log(`purging caches`);
82
+ try {
83
+ let keys = await caches.keys();
84
+ for (let i1 = 0; i1 < keys.length; i1++) {
85
+ let key = keys[i1];
86
+ try {
87
+ let cache = await caches.open(key);
88
+ if (cache) {
89
+ let subKeys = await cache.keys();
90
+ if (subKeys && subKeys.length) {
91
+ let keysToRemove = options.onlyKWizComCaches !== true ? subKeys : subKeys.filter(k => k.url.toLowerCase().indexOf('apps.kwizcom.com/') >= 0);
92
+ for (let i2 = 0; i2 < keysToRemove.length; i2++) {
93
+ let success = await cache.delete(keysToRemove[i2]);
94
+ if (!success)//failed
95
+ failedKeys.push(keysToRemove[i2].url);
96
+ }
97
+ }
98
+ }
99
+ } catch (b) {
100
+ failedKeys.push(key);
101
+ }
102
+ }
103
+ } catch (e) {
104
+ result.success = false;
105
+ result.error = e;
106
+ result.message = (e.message || "Something went wrong.");
107
+ }
108
+
109
+ if (isNotEmptyArray(failedKeys)) {
110
+ result.success = false;
111
+ result.message = (isNullOrEmptyString(result.message) ? '' : ' ') + `Failed keys: ${failedKeys.join()}`;
112
+ }
113
+
114
+ console.group('PurgeCache complete');
115
+ console.dir(result);
116
+ console.groupEnd();
117
+
118
+ return result;
119
+ }
120
+ };
121
+ //no need to do this anymore, once we added max-age cache to our response headers, the SP Service worker now clears
122
+ //the cache of our SPFx controls on its own.
123
+ // //by default - DO NOT clear cookies/storage and non-KWIZ caches!
124
+ // window.setTimeout(() => kGlobal.Debug.PurgeCache({
125
+ // skipCookies: true,
126
+ // skipStorage: true,
127
+ // onlyKWizComCaches: true
128
+ // }), 3000);
129
+ }
130
+ }
131
+
132
+ SetGlobalDebugFunction();
133
+
134
+ export function isDebug() {
135
+ var kGlobal = GetGlobalDebug();
136
+
137
+ if (isNullOrUndefined(kGlobal.Debug._debug)) {
138
+ kGlobal.Debug._debug = IsLocalDev ||
139
+ $w.location.href.indexOf('kwdebug=true') > 0 ||
140
+ $w.location.href.indexOf('/workbench.aspx') > 0 ||
141
+ getCookie("KWizComDebug") === "true";
142
+ }
143
+ return kGlobal.Debug._debug === true;
144
+ }
145
+ /** returns true if this is a kwizcom production/test tenant */
146
+ export function isKWizComTenant() {
147
+ return $w.location.host === "kwizcom.sharepoint.com" || window.location.host === "kwizcomqa.sharepoint.com";
148
+ }
149
+ export function isDebugOnKWizComTenant() {
150
+ return isKWizComTenant() && isDebug();
151
+ }
152
+
153
+ export function consoleLoggerFilter() {
154
+ var kGlobal = GetGlobalDebug();
155
+
156
+ if (isNullOrUndefined(kGlobal.Debug._consoleLoggerFilter)) {
157
+ let KWizComDebugFilter = getCookie("KWizComDebugFilter");
158
+ if (!isNullOrEmptyString(KWizComDebugFilter))
159
+ kGlobal.Debug._consoleLoggerFilter = KWizComDebugFilter.split('~');
160
+ else kGlobal.Debug._consoleLoggerFilter = [];
161
+ }
162
+ return kGlobal.Debug._consoleLoggerFilter;
163
+ }
164
+
165
+ export async function waitIfDebug(seconds?: number): Promise<void> {
166
+ if (isDebug())
167
+ await sleepAsync(seconds);
168
+ }
169
+
170
+ export function trackChangesToObject<T>(parent: unknown, objectName: string, tracker: {
171
+ onBeforeGet?: (v: T) => void;
172
+ onBeforeSet?: (v: T) => void;
173
+ onAfterSet?: (v: T) => void;
174
+ }) {
175
+ let originalValue: T = parent[objectName];
176
+ Object.defineProperty(parent, objectName, {
177
+ set: (newValue: T) => {
178
+ if (isFunction(tracker.onBeforeSet)) tracker.onBeforeSet(newValue);
179
+ originalValue = newValue;
180
+ if (isFunction(tracker.onAfterSet)) tracker.onAfterSet(newValue);
181
+ },
182
+ get: () => {
183
+ if (isFunction(tracker.onBeforeGet)) tracker.onBeforeGet(originalValue);
184
+ return originalValue;
185
+ }
186
+ });
187
187
  }
@@ -1,44 +1,44 @@
1
- import { sortArray } from "./collections.base";
2
- import { isNullOrEmptyString } from "./typecheckers";
3
-
4
- export const stockUrl = "https://apps.kwizcom.com/products/apsig/images/diagrams";
5
- type DiagramInfo = {
6
- name: string;
7
- folderPrefix: string;
8
- filePrefix: string;
9
- };
10
- const diagrams: DiagramInfo[] = sortArray([
11
- { name: "Body, male, all", folderPrefix: "body-all", filePrefix: "body-all-" },
12
- { name: "Body, female, all", folderPrefix: "body-all", filePrefix: "body-all-fem-" },
13
- { name: "Body, male, front", folderPrefix: "body-frontal", filePrefix: "body-frontal-" },
14
- { name: "Body, female, front", folderPrefix: "body-frontal", filePrefix: "body-frontal-fem-" },
15
- { name: "Car", folderPrefix: "car", filePrefix: "car-" },
16
- { name: "Cat & Dog", folderPrefix: "cat-dog", filePrefix: "cat-dog-" },
17
- { name: "Cat", folderPrefix: "cat-dog", filePrefix: "cat-" },
18
- { name: "Dog", folderPrefix: "cat-dog", filePrefix: "dog-" },
19
- { name: "Face", folderPrefix: "face", filePrefix: "face-" },
20
- { name: "Pickup truck", folderPrefix: "pickup", filePrefix: "pickup-" },
21
- { name: "Shoulder & head", folderPrefix: "shoulder-head", filePrefix: "shoulder-head-" },
22
- { name: "Shoulder & head, female", folderPrefix: "shoulder-head", filePrefix: "shoulder-head-fem-" },
23
- { name: "Shoulder & head, all", folderPrefix: "shoulder-head-all", filePrefix: "shoulder-head-all-" },
24
- { name: "Shoulder & head, female, all", folderPrefix: "shoulder-head-all", filePrefix: "shoulder-head-all-fem-" },
25
- { name: "Signature line", folderPrefix: "signature", filePrefix: "signature-" }
26
- ], d => d.name);
27
- type DiagramOption = {
28
- url: string;
29
- name: string;
30
- };
31
- const diagramTypes = [{ suffix: "diagram-transparent", label: "transparent" }, { suffix: "diagram-whitebg-transparent", label: "partially transparent" }, { suffix: "diagram-whitebg", label: "" }];
32
- var diagramOptionsHiRes: DiagramOption[] = [];
33
- var diagramOptions: DiagramOption[] = [];
34
- function addDiagramOptions(info: DiagramInfo, options: DiagramOption[]) {
35
- diagramTypes.forEach(type => options.push({
36
- name: `${info.name}${isNullOrEmptyString(type.label) ? '' : `, ${type.label}`}`,
37
- url: `${info.folderPrefix}/${info.filePrefix}${type.suffix}.png`
38
- }));
39
- }
40
- diagrams.forEach(d => {
41
- addDiagramOptions(d, diagramOptionsHiRes);
42
- addDiagramOptions({ folderPrefix: `${d.folderPrefix}/small`, filePrefix: d.filePrefix, name: `${d.name}, small` }, diagramOptions);
43
- });
1
+ import { sortArray } from "./collections.base";
2
+ import { isNullOrEmptyString } from "./typecheckers";
3
+
4
+ export const stockUrl = "https://apps.kwizcom.com/products/apsig/images/diagrams";
5
+ type DiagramInfo = {
6
+ name: string;
7
+ folderPrefix: string;
8
+ filePrefix: string;
9
+ };
10
+ const diagrams: DiagramInfo[] = sortArray([
11
+ { name: "Body, male, all", folderPrefix: "body-all", filePrefix: "body-all-" },
12
+ { name: "Body, female, all", folderPrefix: "body-all", filePrefix: "body-all-fem-" },
13
+ { name: "Body, male, front", folderPrefix: "body-frontal", filePrefix: "body-frontal-" },
14
+ { name: "Body, female, front", folderPrefix: "body-frontal", filePrefix: "body-frontal-fem-" },
15
+ { name: "Car", folderPrefix: "car", filePrefix: "car-" },
16
+ { name: "Cat & Dog", folderPrefix: "cat-dog", filePrefix: "cat-dog-" },
17
+ { name: "Cat", folderPrefix: "cat-dog", filePrefix: "cat-" },
18
+ { name: "Dog", folderPrefix: "cat-dog", filePrefix: "dog-" },
19
+ { name: "Face", folderPrefix: "face", filePrefix: "face-" },
20
+ { name: "Pickup truck", folderPrefix: "pickup", filePrefix: "pickup-" },
21
+ { name: "Shoulder & head", folderPrefix: "shoulder-head", filePrefix: "shoulder-head-" },
22
+ { name: "Shoulder & head, female", folderPrefix: "shoulder-head", filePrefix: "shoulder-head-fem-" },
23
+ { name: "Shoulder & head, all", folderPrefix: "shoulder-head-all", filePrefix: "shoulder-head-all-" },
24
+ { name: "Shoulder & head, female, all", folderPrefix: "shoulder-head-all", filePrefix: "shoulder-head-all-fem-" },
25
+ { name: "Signature line", folderPrefix: "signature", filePrefix: "signature-" }
26
+ ], d => d.name);
27
+ type DiagramOption = {
28
+ url: string;
29
+ name: string;
30
+ };
31
+ const diagramTypes = [{ suffix: "diagram-transparent", label: "transparent" }, { suffix: "diagram-whitebg-transparent", label: "partially transparent" }, { suffix: "diagram-whitebg", label: "" }];
32
+ var diagramOptionsHiRes: DiagramOption[] = [];
33
+ var diagramOptions: DiagramOption[] = [];
34
+ function addDiagramOptions(info: DiagramInfo, options: DiagramOption[]) {
35
+ diagramTypes.forEach(type => options.push({
36
+ name: `${info.name}${isNullOrEmptyString(type.label) ? '' : `, ${type.label}`}`,
37
+ url: `${info.folderPrefix}/${info.filePrefix}${type.suffix}.png`
38
+ }));
39
+ }
40
+ diagrams.forEach(d => {
41
+ addDiagramOptions(d, diagramOptionsHiRes);
42
+ addDiagramOptions({ folderPrefix: `${d.folderPrefix}/small`, filePrefix: d.filePrefix, name: `${d.name}, small` }, diagramOptions);
43
+ });
44
44
  export const DiagramOptions = { options: diagramOptions, hiRes: diagramOptionsHiRes };
@@ -1,7 +1,7 @@
1
- import { isNullOrEmptyString } from "./typecheckers";
2
-
3
- export function isValidEmail(email: string) {
4
- return !isNullOrEmptyString(email) && /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email);
5
- }
6
-
1
+ import { isNullOrEmptyString } from "./typecheckers";
2
+
3
+ export function isValidEmail(email: string) {
4
+ return !isNullOrEmptyString(email) && /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email);
5
+ }
6
+
7
7
  export const freeEmailNotAllowedMessage = "Please use a work email, free emails are not allowed";
@@ -1,5 +1,5 @@
1
- //eval breaks treeshaking for the entire module it is in, so keep it in separate
2
- export function eval2(str: string) {
3
- // eslint-disable-next-line no-eval
4
- return eval(str);
5
- }
1
+ //eval breaks treeshaking for the entire module it is in, so keep it in separate
2
+ export function eval2(str: string) {
3
+ // eslint-disable-next-line no-eval
4
+ return eval(str);
5
+ }
@@ -1,51 +1,51 @@
1
- import assert from 'assert/strict';
2
- import test from 'node:test';
3
- import { validateFilename, validateFoldername } from './file'
4
-
5
- test('validateFilename', t => {
6
- '"*:<>?/\\|'.split("").forEach((char) => {
7
- let result = validateFilename(`random${char}filename.txt`);
8
- assert.strictEqual(result.valid, false);
9
- assert.strictEqual(result.hasIllegalCharacter, true);
10
- });
11
-
12
- ".lock|CON|PRN|AUX|NUL|COM3|COM9|COM0|LPT8|LPT2|LPT6|random_VTI_filename|~$randomfilename".split("|").forEach((name) => {
13
- let result = validateFilename(`${name}.txt`);
14
- assert.strictEqual(result.valid, false);
15
- assert.strictEqual(result.hasIllegalName, true);
16
- });
17
-
18
- let result = validateFilename(`desktop.ini`);
19
- assert.strictEqual(result.valid, false);
20
- assert.strictEqual(result.hasIllegalName, true);
21
-
22
- ["filename.txt", "test.jpg", "image.png", "worddocument.doc"].forEach((name) => {
23
- result = validateFilename(name);
24
- assert.strictEqual(result.valid, true);
25
- assert.strictEqual(result.hasIllegalName, false);
26
- });
27
- });
28
-
29
- test('validateFoldername', t => {
30
- '"*:<>?/\\|'.split("").forEach((char) => {
31
- let result = validateFoldername(`random${char}folder`);
32
- assert.strictEqual(result.valid, false);
33
- assert.strictEqual(result.hasIllegalCharacter, true);
34
- });
35
-
36
- ".lock|CON|PRN|AUX|NUL|COM3|COM9|COM0|LPT8|LPT2|LPT6|random_VTI_folder|~$randomfolder".split("|").forEach((name) => {
37
- let result = validateFoldername(`${name}`);
38
- assert.strictEqual(result.valid, false);
39
- assert.strictEqual(result.hasIllegalName, true);
40
- });
41
-
42
- let result = validateFoldername(`desktop.ini`);
43
- assert.strictEqual(result.valid, false);
44
- assert.strictEqual(result.hasIllegalName, true);
45
-
46
- ["folder1", "imagesfolder", "assets", "kwizcom"].forEach((name) => {
47
- result = validateFoldername(name);
48
- assert.strictEqual(result.valid, true);
49
- assert.strictEqual(result.hasIllegalName, false);
50
- });
1
+ import assert from 'assert/strict';
2
+ import test from 'node:test';
3
+ import { validateFilename, validateFoldername } from './file'
4
+
5
+ test('validateFilename', t => {
6
+ '"*:<>?/\\|'.split("").forEach((char) => {
7
+ let result = validateFilename(`random${char}filename.txt`);
8
+ assert.strictEqual(result.valid, false);
9
+ assert.strictEqual(result.hasIllegalCharacter, true);
10
+ });
11
+
12
+ ".lock|CON|PRN|AUX|NUL|COM3|COM9|COM0|LPT8|LPT2|LPT6|random_VTI_filename|~$randomfilename".split("|").forEach((name) => {
13
+ let result = validateFilename(`${name}.txt`);
14
+ assert.strictEqual(result.valid, false);
15
+ assert.strictEqual(result.hasIllegalName, true);
16
+ });
17
+
18
+ let result = validateFilename(`desktop.ini`);
19
+ assert.strictEqual(result.valid, false);
20
+ assert.strictEqual(result.hasIllegalName, true);
21
+
22
+ ["filename.txt", "test.jpg", "image.png", "worddocument.doc"].forEach((name) => {
23
+ result = validateFilename(name);
24
+ assert.strictEqual(result.valid, true);
25
+ assert.strictEqual(result.hasIllegalName, false);
26
+ });
27
+ });
28
+
29
+ test('validateFoldername', t => {
30
+ '"*:<>?/\\|'.split("").forEach((char) => {
31
+ let result = validateFoldername(`random${char}folder`);
32
+ assert.strictEqual(result.valid, false);
33
+ assert.strictEqual(result.hasIllegalCharacter, true);
34
+ });
35
+
36
+ ".lock|CON|PRN|AUX|NUL|COM3|COM9|COM0|LPT8|LPT2|LPT6|random_VTI_folder|~$randomfolder".split("|").forEach((name) => {
37
+ let result = validateFoldername(`${name}`);
38
+ assert.strictEqual(result.valid, false);
39
+ assert.strictEqual(result.hasIllegalName, true);
40
+ });
41
+
42
+ let result = validateFoldername(`desktop.ini`);
43
+ assert.strictEqual(result.valid, false);
44
+ assert.strictEqual(result.hasIllegalName, true);
45
+
46
+ ["folder1", "imagesfolder", "assets", "kwizcom"].forEach((name) => {
47
+ result = validateFoldername(name);
48
+ assert.strictEqual(result.valid, true);
49
+ assert.strictEqual(result.hasIllegalName, false);
50
+ });
51
51
  });