@kwiz/common 1.0.127 → 1.0.128

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 (101) 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/auth/common.js +84 -37
  7. package/lib/cjs/utils/auth/common.js.map +1 -1
  8. package/lib/cjs/utils/sharepoint.rest/user.js +11 -11
  9. package/lib/esm/types/libs/msal.types.js +26 -26
  10. package/lib/esm/utils/auth/common.js +84 -38
  11. package/lib/esm/utils/auth/common.js.map +1 -1
  12. package/lib/esm/utils/sharepoint.rest/user.js +11 -11
  13. package/lib/types/types/auth.d.ts +7 -0
  14. package/lib/types/utils/auth/common.d.ts +2 -0
  15. package/package.json +81 -81
  16. package/readme.md +17 -17
  17. package/src/_dependencies.ts +12 -12
  18. package/src/config.ts +17 -17
  19. package/src/helpers/Guid.ts +181 -181
  20. package/src/helpers/base64.ts +173 -173
  21. package/src/helpers/browser.test.js +13 -13
  22. package/src/helpers/browser.ts +1498 -1498
  23. package/src/helpers/browserinfo.ts +292 -292
  24. package/src/helpers/collections.base.test.js +25 -25
  25. package/src/helpers/collections.base.ts +437 -437
  26. package/src/helpers/collections.ts +107 -107
  27. package/src/helpers/color.ts +54 -54
  28. package/src/helpers/cookies.ts +59 -59
  29. package/src/helpers/date.test.js +119 -119
  30. package/src/helpers/date.ts +188 -188
  31. package/src/helpers/debug.ts +186 -186
  32. package/src/helpers/diagrams.ts +43 -43
  33. package/src/helpers/emails.ts +6 -6
  34. package/src/helpers/eval.ts +5 -5
  35. package/src/helpers/file.test.js +50 -50
  36. package/src/helpers/file.ts +63 -63
  37. package/src/helpers/flatted.ts +149 -149
  38. package/src/helpers/functions.ts +16 -16
  39. package/src/helpers/graph/calendar.types.ts +10 -10
  40. package/src/helpers/http.ts +69 -69
  41. package/src/helpers/images.ts +22 -22
  42. package/src/helpers/json.ts +44 -44
  43. package/src/helpers/md5.ts +189 -189
  44. package/src/helpers/objects.test.js +33 -33
  45. package/src/helpers/objects.ts +274 -274
  46. package/src/helpers/promises.test.js +37 -37
  47. package/src/helpers/promises.ts +165 -165
  48. package/src/helpers/random.ts +27 -27
  49. package/src/helpers/scheduler/scheduler.test.js +103 -103
  50. package/src/helpers/scheduler/scheduler.ts +131 -131
  51. package/src/helpers/sharepoint.ts +796 -796
  52. package/src/helpers/strings.test.js +122 -122
  53. package/src/helpers/strings.ts +337 -337
  54. package/src/helpers/typecheckers.test.js +34 -34
  55. package/src/helpers/typecheckers.ts +266 -266
  56. package/src/helpers/url.test.js +43 -43
  57. package/src/helpers/url.ts +207 -207
  58. package/src/helpers/urlhelper.ts +111 -111
  59. package/src/index.ts +6 -6
  60. package/src/types/auth.ts +62 -54
  61. package/src/types/common.types.ts +15 -15
  62. package/src/types/flatted.types.ts +59 -59
  63. package/src/types/globals.types.ts +6 -6
  64. package/src/types/graph/calendar.types.ts +80 -80
  65. package/src/types/knownscript.types.ts +18 -18
  66. package/src/types/libs/datajs.types.ts +28 -28
  67. package/src/types/libs/ics.types.ts +30 -30
  68. package/src/types/libs/msal.types.ts +57 -57
  69. package/src/types/locales.ts +125 -125
  70. package/src/types/localstoragecache.types.ts +8 -8
  71. package/src/types/location.types.ts +27 -27
  72. package/src/types/moment.ts +11 -11
  73. package/src/types/regex.types.ts +16 -16
  74. package/src/types/rest.types.ts +95 -95
  75. package/src/types/sharepoint.types.ts +1466 -1466
  76. package/src/types/sharepoint.utils.types.ts +306 -306
  77. package/src/utils/auth/common.ts +119 -74
  78. package/src/utils/auth/discovery.test.js +12 -12
  79. package/src/utils/auth/discovery.ts +132 -132
  80. package/src/utils/base64.ts +27 -27
  81. package/src/utils/consolelogger.ts +333 -333
  82. package/src/utils/date.ts +172 -172
  83. package/src/utils/emails.ts +24 -24
  84. package/src/utils/knownscript.ts +286 -286
  85. package/src/utils/localstoragecache.ts +446 -446
  86. package/src/utils/rest.ts +501 -501
  87. package/src/utils/script.ts +170 -170
  88. package/src/utils/sharepoint.rest/common.ts +159 -159
  89. package/src/utils/sharepoint.rest/date.ts +62 -62
  90. package/src/utils/sharepoint.rest/file.folder.ts +685 -685
  91. package/src/utils/sharepoint.rest/item.ts +547 -547
  92. package/src/utils/sharepoint.rest/list.ts +1572 -1572
  93. package/src/utils/sharepoint.rest/listutils/GetListItemsByCaml.ts +774 -774
  94. package/src/utils/sharepoint.rest/listutils/GetListItemsById.ts +275 -275
  95. package/src/utils/sharepoint.rest/listutils/common.ts +206 -206
  96. package/src/utils/sharepoint.rest/location.ts +141 -141
  97. package/src/utils/sharepoint.rest/navigation-links.ts +86 -86
  98. package/src/utils/sharepoint.rest/user-search.ts +252 -252
  99. package/src/utils/sharepoint.rest/user.ts +558 -558
  100. package/src/utils/sharepoint.rest/web.ts +1384 -1384
  101. package/src/utils/sod.ts +194 -194
@@ -1,123 +1,123 @@
1
- import assert from 'assert/strict';
2
- import test from 'node:test';
3
- import { ReplaceTokensInDictionary, capitalizeFirstLetter, escapeXml, maskString, replaceAll, replaceRegex, splitString } from './strings';
4
-
5
- test('replaceAll', t => {
6
- assert.strictEqual(replaceAll("hello old#@! world old#@! !", "old#@!", "new!@$"), "hello new!@$ world new!@$ !");
7
-
8
- //this failed since the input find included protected regex characters.
9
- //escapeRegExp needs to fix that
10
- let string = "string with special regex[:(s:) chars";
11
- let find = "regex[:(s:)";
12
- let replace = "regex[~~(s~~)";
13
- let result = "string with special regex[~~(s~~) chars";
14
- assert.strictEqual(replaceAll(string, find, replace), result);
15
-
16
- string = `To activate the KWIZ Forms feature in your list you should click the "KWIZ Forms Display Mode" button:
17
-
18
- ![](https://kwizcom.sharepoint.com/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg)
19
-
20
- Now select one "Side Panel" or "Full Page" for the display mode:`;
21
- find = "https://kwizcom.sharepoint.com/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg";
22
- replace = "/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg";
23
- result = `To activate the KWIZ Forms feature in your list you should click the "KWIZ Forms Display Mode" button:
24
-
25
- ![](/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg)
26
-
27
- Now select one "Side Panel" or "Full Page" for the display mode:`;
28
- assert.strictEqual(replaceAll(string, find, replace, true), result);
29
-
30
- });
31
-
32
- test('capitalizeFirstLetter', async t => {
33
- assert.strictEqual(capitalizeFirstLetter(), "");
34
- assert.strictEqual(capitalizeFirstLetter("a"), "A");
35
- assert.strictEqual(capitalizeFirstLetter("hello"), "Hello");
36
- assert.strictEqual(capitalizeFirstLetter("hello world!"), "Hello world!");
37
- assert.strictEqual(capitalizeFirstLetter("helloworld"), "Helloworld");
38
- assert.strictEqual(capitalizeFirstLetter(""), "");
39
- });
40
-
41
- test('escapeXml', async t => {
42
- assert.strictEqual(escapeXml(), "");
43
- assert.strictEqual(escapeXml(""), "");
44
- assert.strictEqual(escapeXml(" "), " ");
45
- assert.strictEqual(escapeXml("<test />"), "&lt;test /&gt;");
46
- assert.strictEqual(escapeXml(`full scope: <>&'"`), `full scope: &lt;&gt;&amp;'"`);
47
- assert.strictEqual(escapeXml(undefined, true), "");
48
- assert.strictEqual(escapeXml("", true), "");
49
- assert.strictEqual(escapeXml(" ", true), " ");
50
- assert.strictEqual(escapeXml("<test />", true), "&lt;test /&gt;");
51
- assert.strictEqual(escapeXml(`full scope: <>&'"`, true), `full scope: &lt;&gt;&amp;&apos;&quot;`);
52
- });
53
-
54
- test('replaceRegex', t => {
55
- /** Match anything between {zone:*} */
56
- var match = /{zone:\w+}/gi;
57
-
58
- var source = `text {zone:one} {zone:two}
59
- more text
60
- {zone:three}`;
61
- var result = `text ONE TWO
62
- more text
63
- THREE`;
64
-
65
- assert.strictEqual(replaceRegex(source, match, m => m.slice(1, m.length - 1).split(':')[1].toLocaleUpperCase()), result);
66
-
67
- /** match: "](______)" */
68
- match = /]\(.+\)/gi;
69
- source = '[name:root](https://kwizcom.sharepoint.com/:fl:/g/contentstorage)';
70
- result = '[name:root](https~~~~//kwizcom.sharepoint.com/~~~~fl~~~~/g/contentstorage)';
71
- assert.strictEqual(replaceRegex(source, match, m => m.replace(/:/gi, "~~~~")), result);
72
- });
73
-
74
- test('maskString', async t => {
75
- assert.strictEqual(maskString("abcdefg"), "ab*****fg");
76
- assert.strictEqual(maskString("ab"), "ab*****ab");
77
- assert.strictEqual(maskString(""), "*****");
78
- assert.strictEqual(maskString("abcdefg", { mask: "..." }), "ab...fg");
79
- assert.strictEqual(maskString("abcdefg", { mask: "...", start: 0, end: 0 }), "...");
80
- assert.strictEqual(maskString("abcdefg", { mask: "...", start: 1, end: 1 }), "a...g");
81
- });
82
-
83
- test('ReplaceTokensInDictionary', async t => {
84
- const tokens = { "t1": "token1", "t2": "token 2" };
85
- let dic = {};
86
- let expected = {};
87
-
88
- dic = { a: "hello" };
89
- expected = { a: "hello" };
90
- ReplaceTokensInDictionary(dic, tokens);
91
- assert.strictEqual(JSON.stringify(dic), JSON.stringify(expected));
92
-
93
- dic = { a: "hello", b: "hello [t1]" };
94
- expected = { a: "hello", b: "hello token1" };
95
- ReplaceTokensInDictionary(dic, tokens);
96
- assert.strictEqual(JSON.stringify(dic), JSON.stringify(expected));
97
-
98
- dic = { a: "hello", b: "hello [t1] [t2]", c: "[t2]" };
99
- expected = { a: "hello", b: "hello token1 token 2", c: "token 2" };
100
- ReplaceTokensInDictionary(dic, tokens);
101
- assert.strictEqual(JSON.stringify(dic), JSON.stringify(expected));
102
- });
103
-
104
- test('splitString', async t => {
105
- const str = "abcd|1234|efgh|5678";
106
- let expected = [
107
- 'abc', 'd|1',
108
- '234', '|ef',
109
- 'gh|', '567',
110
- '8'
111
- ];
112
- assert.strictEqual(JSON.stringify(splitString(str, { maxLength: 3 })), JSON.stringify(expected));
113
- expected = [
114
- 'abcd', '1234',
115
- 'efgh', '5678'
116
- ];
117
- assert.strictEqual(JSON.stringify(splitString(str, { marker: "|" })), JSON.stringify(expected));
118
- expected = [
119
- 'ab', 'cd', '12', '34',
120
- 'ef', 'gh', '56', '78'
121
- ];
122
- assert.strictEqual(JSON.stringify(splitString(str, { marker: "|", maxLength: 2 })), JSON.stringify(expected));
1
+ import assert from 'assert/strict';
2
+ import test from 'node:test';
3
+ import { ReplaceTokensInDictionary, capitalizeFirstLetter, escapeXml, maskString, replaceAll, replaceRegex, splitString } from './strings';
4
+
5
+ test('replaceAll', t => {
6
+ assert.strictEqual(replaceAll("hello old#@! world old#@! !", "old#@!", "new!@$"), "hello new!@$ world new!@$ !");
7
+
8
+ //this failed since the input find included protected regex characters.
9
+ //escapeRegExp needs to fix that
10
+ let string = "string with special regex[:(s:) chars";
11
+ let find = "regex[:(s:)";
12
+ let replace = "regex[~~(s~~)";
13
+ let result = "string with special regex[~~(s~~) chars";
14
+ assert.strictEqual(replaceAll(string, find, replace), result);
15
+
16
+ string = `To activate the KWIZ Forms feature in your list you should click the "KWIZ Forms Display Mode" button:
17
+
18
+ ![](https://kwizcom.sharepoint.com/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg)
19
+
20
+ Now select one "Side Panel" or "Full Page" for the display mode:`;
21
+ find = "https://kwizcom.sharepoint.com/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg";
22
+ replace = "/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg";
23
+ result = `To activate the KWIZ Forms feature in your list you should click the "KWIZ Forms Display Mode" button:
24
+
25
+ ![](/sites/Docs/CMSResources/CMS365/Screenshot 2024-06-18 123120.jpg)
26
+
27
+ Now select one "Side Panel" or "Full Page" for the display mode:`;
28
+ assert.strictEqual(replaceAll(string, find, replace, true), result);
29
+
30
+ });
31
+
32
+ test('capitalizeFirstLetter', async t => {
33
+ assert.strictEqual(capitalizeFirstLetter(), "");
34
+ assert.strictEqual(capitalizeFirstLetter("a"), "A");
35
+ assert.strictEqual(capitalizeFirstLetter("hello"), "Hello");
36
+ assert.strictEqual(capitalizeFirstLetter("hello world!"), "Hello world!");
37
+ assert.strictEqual(capitalizeFirstLetter("helloworld"), "Helloworld");
38
+ assert.strictEqual(capitalizeFirstLetter(""), "");
39
+ });
40
+
41
+ test('escapeXml', async t => {
42
+ assert.strictEqual(escapeXml(), "");
43
+ assert.strictEqual(escapeXml(""), "");
44
+ assert.strictEqual(escapeXml(" "), " ");
45
+ assert.strictEqual(escapeXml("<test />"), "&lt;test /&gt;");
46
+ assert.strictEqual(escapeXml(`full scope: <>&'"`), `full scope: &lt;&gt;&amp;'"`);
47
+ assert.strictEqual(escapeXml(undefined, true), "");
48
+ assert.strictEqual(escapeXml("", true), "");
49
+ assert.strictEqual(escapeXml(" ", true), " ");
50
+ assert.strictEqual(escapeXml("<test />", true), "&lt;test /&gt;");
51
+ assert.strictEqual(escapeXml(`full scope: <>&'"`, true), `full scope: &lt;&gt;&amp;&apos;&quot;`);
52
+ });
53
+
54
+ test('replaceRegex', t => {
55
+ /** Match anything between {zone:*} */
56
+ var match = /{zone:\w+}/gi;
57
+
58
+ var source = `text {zone:one} {zone:two}
59
+ more text
60
+ {zone:three}`;
61
+ var result = `text ONE TWO
62
+ more text
63
+ THREE`;
64
+
65
+ assert.strictEqual(replaceRegex(source, match, m => m.slice(1, m.length - 1).split(':')[1].toLocaleUpperCase()), result);
66
+
67
+ /** match: "](______)" */
68
+ match = /]\(.+\)/gi;
69
+ source = '[name:root](https://kwizcom.sharepoint.com/:fl:/g/contentstorage)';
70
+ result = '[name:root](https~~~~//kwizcom.sharepoint.com/~~~~fl~~~~/g/contentstorage)';
71
+ assert.strictEqual(replaceRegex(source, match, m => m.replace(/:/gi, "~~~~")), result);
72
+ });
73
+
74
+ test('maskString', async t => {
75
+ assert.strictEqual(maskString("abcdefg"), "ab*****fg");
76
+ assert.strictEqual(maskString("ab"), "ab*****ab");
77
+ assert.strictEqual(maskString(""), "*****");
78
+ assert.strictEqual(maskString("abcdefg", { mask: "..." }), "ab...fg");
79
+ assert.strictEqual(maskString("abcdefg", { mask: "...", start: 0, end: 0 }), "...");
80
+ assert.strictEqual(maskString("abcdefg", { mask: "...", start: 1, end: 1 }), "a...g");
81
+ });
82
+
83
+ test('ReplaceTokensInDictionary', async t => {
84
+ const tokens = { "t1": "token1", "t2": "token 2" };
85
+ let dic = {};
86
+ let expected = {};
87
+
88
+ dic = { a: "hello" };
89
+ expected = { a: "hello" };
90
+ ReplaceTokensInDictionary(dic, tokens);
91
+ assert.strictEqual(JSON.stringify(dic), JSON.stringify(expected));
92
+
93
+ dic = { a: "hello", b: "hello [t1]" };
94
+ expected = { a: "hello", b: "hello token1" };
95
+ ReplaceTokensInDictionary(dic, tokens);
96
+ assert.strictEqual(JSON.stringify(dic), JSON.stringify(expected));
97
+
98
+ dic = { a: "hello", b: "hello [t1] [t2]", c: "[t2]" };
99
+ expected = { a: "hello", b: "hello token1 token 2", c: "token 2" };
100
+ ReplaceTokensInDictionary(dic, tokens);
101
+ assert.strictEqual(JSON.stringify(dic), JSON.stringify(expected));
102
+ });
103
+
104
+ test('splitString', async t => {
105
+ const str = "abcd|1234|efgh|5678";
106
+ let expected = [
107
+ 'abc', 'd|1',
108
+ '234', '|ef',
109
+ 'gh|', '567',
110
+ '8'
111
+ ];
112
+ assert.strictEqual(JSON.stringify(splitString(str, { maxLength: 3 })), JSON.stringify(expected));
113
+ expected = [
114
+ 'abcd', '1234',
115
+ 'efgh', '5678'
116
+ ];
117
+ assert.strictEqual(JSON.stringify(splitString(str, { marker: "|" })), JSON.stringify(expected));
118
+ expected = [
119
+ 'ab', 'cd', '12', '34',
120
+ 'ef', 'gh', '56', '78'
121
+ ];
122
+ assert.strictEqual(JSON.stringify(splitString(str, { marker: "|", maxLength: 2 })), JSON.stringify(expected));
123
123
  });