@design-edito/tools 0.1.44 → 0.1.46

Sign up to get free protection for your applications and to get access to all the features.
Files changed (106) hide show
  1. package/agnostic/arrays/random-pick/index.js +4 -4
  2. package/agnostic/css/index.js +15 -15
  3. package/agnostic/errors/index.js +2 -2
  4. package/agnostic/html/hyper-json/cast/index.js +6 -5
  5. package/agnostic/html/hyper-json/index.js +7 -6
  6. package/agnostic/html/hyper-json/smart-tags/coalesced/add/index.js +6 -5
  7. package/agnostic/html/hyper-json/smart-tags/coalesced/addclass/index.js +6 -5
  8. package/agnostic/html/hyper-json/smart-tags/coalesced/and/index.js +6 -5
  9. package/agnostic/html/hyper-json/smart-tags/coalesced/append/index.js +6 -5
  10. package/agnostic/html/hyper-json/smart-tags/coalesced/at/index.js +6 -5
  11. package/agnostic/html/hyper-json/smart-tags/coalesced/call/index.js +6 -5
  12. package/agnostic/html/hyper-json/smart-tags/coalesced/clone/index.js +6 -5
  13. package/agnostic/html/hyper-json/smart-tags/coalesced/deleteproperties/index.js +6 -5
  14. package/agnostic/html/hyper-json/smart-tags/coalesced/equals/index.js +6 -5
  15. package/agnostic/html/hyper-json/smart-tags/coalesced/getattribute/index.js +6 -5
  16. package/agnostic/html/hyper-json/smart-tags/coalesced/getproperties/index.js +6 -5
  17. package/agnostic/html/hyper-json/smart-tags/coalesced/getproperty/index.js +6 -5
  18. package/agnostic/html/hyper-json/smart-tags/coalesced/if/index.js +6 -5
  19. package/agnostic/html/hyper-json/smart-tags/coalesced/initialize/index.js +6 -5
  20. package/agnostic/html/hyper-json/smart-tags/coalesced/join/index.js +6 -5
  21. package/agnostic/html/hyper-json/smart-tags/coalesced/length/index.js +6 -5
  22. package/agnostic/html/hyper-json/smart-tags/coalesced/map/index.js +6 -5
  23. package/agnostic/html/hyper-json/smart-tags/coalesced/negate/index.js +6 -5
  24. package/agnostic/html/hyper-json/smart-tags/coalesced/notrailing/index.js +6 -5
  25. package/agnostic/html/hyper-json/smart-tags/coalesced/or/index.js +6 -5
  26. package/agnostic/html/hyper-json/smart-tags/coalesced/pickrandom/index.js +6 -5
  27. package/agnostic/html/hyper-json/smart-tags/coalesced/populate/index.js +6 -5
  28. package/agnostic/html/hyper-json/smart-tags/coalesced/print/index.js +6 -5
  29. package/agnostic/html/hyper-json/smart-tags/coalesced/push/index.js +6 -5
  30. package/agnostic/html/hyper-json/smart-tags/coalesced/pusheach/index.js +6 -5
  31. package/agnostic/html/hyper-json/smart-tags/coalesced/recordtoarray/index.js +6 -5
  32. package/agnostic/html/hyper-json/smart-tags/coalesced/removeattribute/index.js +6 -5
  33. package/agnostic/html/hyper-json/smart-tags/coalesced/removeclass/index.js +6 -5
  34. package/agnostic/html/hyper-json/smart-tags/coalesced/renameproperty/index.js +6 -5
  35. package/agnostic/html/hyper-json/smart-tags/coalesced/replace/index.js +6 -5
  36. package/agnostic/html/hyper-json/smart-tags/coalesced/select/index.js +6 -5
  37. package/agnostic/html/hyper-json/smart-tags/coalesced/set/index.js +6 -5
  38. package/agnostic/html/hyper-json/smart-tags/coalesced/setattribute/index.js +6 -5
  39. package/agnostic/html/hyper-json/smart-tags/coalesced/setproperty/index.js +6 -5
  40. package/agnostic/html/hyper-json/smart-tags/coalesced/sorton/index.js +6 -5
  41. package/agnostic/html/hyper-json/smart-tags/coalesced/split/index.js +6 -5
  42. package/agnostic/html/hyper-json/smart-tags/coalesced/spread/index.js +6 -5
  43. package/agnostic/html/hyper-json/smart-tags/coalesced/toarray/index.js +6 -5
  44. package/agnostic/html/hyper-json/smart-tags/coalesced/toboolean/index.js +6 -5
  45. package/agnostic/html/hyper-json/smart-tags/coalesced/toelement/index.js +6 -5
  46. package/agnostic/html/hyper-json/smart-tags/coalesced/toggleclass/index.js +6 -5
  47. package/agnostic/html/hyper-json/smart-tags/coalesced/tonodelist/index.js +6 -5
  48. package/agnostic/html/hyper-json/smart-tags/coalesced/tonull/index.js +6 -5
  49. package/agnostic/html/hyper-json/smart-tags/coalesced/tonumber/index.js +6 -5
  50. package/agnostic/html/hyper-json/smart-tags/coalesced/torecord/index.js +6 -5
  51. package/agnostic/html/hyper-json/smart-tags/coalesced/toref/index.js +6 -5
  52. package/agnostic/html/hyper-json/smart-tags/coalesced/tostring/index.js +6 -5
  53. package/agnostic/html/hyper-json/smart-tags/coalesced/totext/index.js +6 -5
  54. package/agnostic/html/hyper-json/smart-tags/coalesced/transformselected/index.js +6 -5
  55. package/agnostic/html/hyper-json/smart-tags/coalesced/trim/index.js +6 -5
  56. package/agnostic/html/hyper-json/smart-tags/isolated/array/index.js +1 -1
  57. package/agnostic/html/hyper-json/smart-tags/isolated/boolean/index.js +6 -5
  58. package/agnostic/html/hyper-json/smart-tags/isolated/element/index.js +6 -5
  59. package/agnostic/html/hyper-json/smart-tags/isolated/get/index.js +6 -5
  60. package/agnostic/html/hyper-json/smart-tags/isolated/global/index.js +6 -5
  61. package/agnostic/html/hyper-json/smart-tags/isolated/guess/index.js +6 -5
  62. package/agnostic/html/hyper-json/smart-tags/isolated/nodelist/index.js +6 -5
  63. package/agnostic/html/hyper-json/smart-tags/isolated/number/index.js +6 -5
  64. package/agnostic/html/hyper-json/smart-tags/isolated/record/index.js +6 -5
  65. package/agnostic/html/hyper-json/smart-tags/isolated/ref/index.js +6 -5
  66. package/agnostic/html/hyper-json/smart-tags/isolated/string/index.js +6 -5
  67. package/agnostic/html/hyper-json/smart-tags/isolated/text/index.js +6 -5
  68. package/agnostic/html/hyper-json/tree/index.d.ts +0 -21
  69. package/agnostic/html/hyper-json/tree/index.js +6 -5
  70. package/agnostic/html/hyper-json/utils/index.js +6 -5
  71. package/agnostic/html/index.js +19 -18
  72. package/agnostic/html/sanitize/index.js +4 -4
  73. package/agnostic/html/selector-to-element/index.js +4 -4
  74. package/agnostic/html/string-to-nodes/index.js +5 -5
  75. package/agnostic/misc/assert/index.js +3 -3
  76. package/agnostic/misc/index.js +25 -25
  77. package/agnostic/misc/lorem-ipsum/index.js +11 -11
  78. package/agnostic/numbers/index.js +3 -3
  79. package/agnostic/objects/index.js +13 -13
  80. package/agnostic/random/index.js +2 -2
  81. package/agnostic/strings/index.js +9 -9
  82. package/agnostic/time/index.js +3 -3
  83. package/chunks/chunk-4HPUOADZ.js +37 -0
  84. package/chunks/chunk-7DNQ6RM2.js +211 -0
  85. package/chunks/chunk-7NO34XJI.js +26 -0
  86. package/chunks/chunk-AQBJ6HNB.js +29 -0
  87. package/chunks/chunk-CK73EBO5.js +35 -0
  88. package/chunks/chunk-CRZMH2K5.js +2369 -0
  89. package/chunks/chunk-FDPPGRBY.js +211 -0
  90. package/chunks/chunk-FHEUGVMU.js +37 -0
  91. package/chunks/chunk-FQD3VK47.js +37 -0
  92. package/chunks/chunk-MQPY7A3O.js +211 -0
  93. package/chunks/chunk-PJDZMLNG.js +127 -0
  94. package/chunks/chunk-QAQZEKIF.js +20 -0
  95. package/chunks/chunk-RX3BKRJU.js +2407 -0
  96. package/chunks/chunk-SBAY4ZKE.js +211 -0
  97. package/chunks/chunk-SKBOSWM2.js +35 -0
  98. package/chunks/chunk-TAVCC26N.js +37 -0
  99. package/chunks/chunk-TIER4TF4.js +26 -0
  100. package/chunks/chunk-WFED6NDN.js +28 -0
  101. package/chunks/chunk-WJMBLQRX.js +29 -0
  102. package/chunks/chunk-WKW34B3A.js +2369 -0
  103. package/chunks/chunk-XB3EGDBI.js +127 -0
  104. package/chunks/chunk-YCZQAM7E.js +2407 -0
  105. package/chunks/chunk-ZBBU2P4D.js +28 -0
  106. package/package.json +1 -1
@@ -0,0 +1,127 @@
1
+ import {
2
+ register
3
+ } from "./chunk-TIER4TF4.js";
4
+
5
+ // src/agnostic/html/sanitize/index.ts
6
+ var Sanitize;
7
+ ((Sanitize2) => {
8
+ Sanitize2.defaultOptions = { depth: 20 };
9
+ function sanitize(inputStr, options = Sanitize2.defaultOptions) {
10
+ const actualDocument = options.documentObj ?? window.document;
11
+ if (actualDocument === null) throw register.getError("no-window-document-on-runtime-please-provide" /* NO_DOCUMENT_PLEASE_PROVIDE */, "See documentObj in the options object");
12
+ const wrapperDiv = actualDocument.createElement("div");
13
+ const { inputFreeTransform } = options;
14
+ wrapperDiv.innerHTML = inputFreeTransform !== void 0 ? inputFreeTransform(inputStr) : inputStr;
15
+ const sanitizedWrapper = sanitizeElement(wrapperDiv, options);
16
+ const returned = sanitizedWrapper?.innerHTML;
17
+ return returned ?? "";
18
+ }
19
+ Sanitize2.sanitize = sanitize;
20
+ function sanitizeElement(element, options = Sanitize2.defaultOptions) {
21
+ const actualDocument = options.documentObj ?? window.document;
22
+ if (actualDocument === null) throw register.getError("no-window-document-on-runtime-please-provide" /* NO_DOCUMENT_PLEASE_PROVIDE */, "See documentObj in the options object");
23
+ const { tagName, attributes, childNodes } = element;
24
+ const {
25
+ allowedTags = [],
26
+ allowedAttributes = {},
27
+ forbiddenTags = [],
28
+ forbiddenAttributes = {},
29
+ depth = 20,
30
+ verbose = false
31
+ } = options;
32
+ if (depth <= 0) {
33
+ console.warn("Max depth reached");
34
+ return null;
35
+ }
36
+ const normalizedTagName = tagName.toLowerCase().trim();
37
+ const tagIsInForbidden = forbiddenTags.includes("*") || forbiddenTags.includes(normalizedTagName);
38
+ if (tagIsInForbidden) {
39
+ if (verbose === true) console.warn(tagName, "tag is forbidden");
40
+ return null;
41
+ }
42
+ const tagIsInAllowed = allowedTags.includes("*") || allowedTags.includes(normalizedTagName);
43
+ if (!tagIsInAllowed) {
44
+ if (verbose === true) console.warn(tagName, "tag is not allowed");
45
+ return null;
46
+ }
47
+ const returnedElement = actualDocument.createElement(tagName);
48
+ const returnedAttributes = Array.from(attributes).filter(({ name: attributeName, value: attributeValue }) => {
49
+ const allTagsForbiddenAttributes = forbiddenAttributes["*"] ?? [];
50
+ const thisTagForbiddenAttributes = forbiddenAttributes[normalizedTagName] ?? [];
51
+ const mergedForbiddenAttributes = [...allTagsForbiddenAttributes, ...thisTagForbiddenAttributes];
52
+ const isInForbidden = mergedForbiddenAttributes.some(({
53
+ attributeName: nameTester,
54
+ attributeValues: valTesters
55
+ }) => {
56
+ if (typeof nameTester === "string" && nameTester !== "*" && attributeName !== nameTester) return false;
57
+ if (typeof nameTester !== "string" && !nameTester.test(attributeName)) return false;
58
+ if (valTesters === void 0) {
59
+ if (verbose === true) console.warn(attributeName, "attribute on", tagName, "tag is forbidden");
60
+ return true;
61
+ }
62
+ if (valTesters.includes("*")) {
63
+ if (verbose === true) console.warn(attributeName, "attribute on", tagName, "tag is forbidden");
64
+ return true;
65
+ }
66
+ return valTesters.some((valTester) => {
67
+ if (typeof valTester === "string" && attributeValue === valTester) {
68
+ if (verbose === true) console.warn(attributeValue, "value for", attributeName, "attribute on", tagName, "tag is forbidden. Rule:", valTester);
69
+ return true;
70
+ }
71
+ if (typeof valTester !== "string" && valTester.test(attributeValue)) {
72
+ if (verbose === true) console.warn(attributeValue, "value for", attributeName, "attribute on", tagName, "tag is forbidden. Rule:", valTester);
73
+ return true;
74
+ }
75
+ return false;
76
+ });
77
+ });
78
+ if (isInForbidden) return false;
79
+ const allTagsAllowedAttributes = allowedAttributes["*"] ?? [];
80
+ const thisTagAllowedAttributes = allowedAttributes[normalizedTagName] ?? [];
81
+ const mergedAllowedAttributes = [...allTagsAllowedAttributes, ...thisTagAllowedAttributes];
82
+ let latestNotAllowedReason = [tagName, "has no allowed attributes"];
83
+ const isInAllowed = mergedAllowedAttributes.some(({
84
+ attributeName: nameTester,
85
+ attributeValues: valTesters
86
+ }) => {
87
+ if (typeof nameTester === "string" && nameTester !== "*" && attributeName !== nameTester) {
88
+ latestNotAllowedReason = [attributeName, "attribute on", tagName, "tag is not allowed"];
89
+ return false;
90
+ }
91
+ if (typeof nameTester !== "string" && !nameTester.test(attributeName)) {
92
+ latestNotAllowedReason = [attributeName, "attribute on", tagName, "tag is not allowed"];
93
+ return false;
94
+ }
95
+ if (valTesters === void 0) return true;
96
+ if (valTesters.includes("*")) return true;
97
+ return valTesters.some((valTester) => {
98
+ if (typeof valTester === "string" && attributeValue === valTester) return true;
99
+ if (typeof valTester !== "string" && valTester.test(attributeValue)) return true;
100
+ latestNotAllowedReason = [attributeValue, "value for", attributeName, "attribute on", tagName, "tag is not allowed"];
101
+ return false;
102
+ });
103
+ });
104
+ if (!isInAllowed) {
105
+ if (verbose === true) console.warn(...latestNotAllowedReason);
106
+ return false;
107
+ }
108
+ return true;
109
+ });
110
+ returnedAttributes.forEach(({ name, value }) => {
111
+ returnedElement.setAttribute(name, value);
112
+ });
113
+ const sanitizedChildNodes = Array.from(childNodes).map((node) => {
114
+ if (node.nodeType === Node.ELEMENT_NODE) return sanitizeElement(node, { ...options, depth: depth - 1 });
115
+ else if (node.nodeType === Node.TEXT_NODE) return node;
116
+ else if (options.keepComments === true && node.nodeType === Node.COMMENT_NODE) return node;
117
+ return null;
118
+ }).filter((elt) => elt !== null);
119
+ returnedElement.replaceChildren(...sanitizedChildNodes);
120
+ return returnedElement;
121
+ }
122
+ Sanitize2.sanitizeElement = sanitizeElement;
123
+ })(Sanitize || (Sanitize = {}));
124
+
125
+ export {
126
+ Sanitize
127
+ };