@kwiz/common 1.0.96 → 1.0.98

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