@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,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
  });