@ui5/webcomponents-localization 0.0.0-f24ff9019 → 0.0.0-f42e7c18c

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 (175) hide show
  1. package/.eslintignore +2 -1
  2. package/CHANGELOG.md +875 -0
  3. package/README.md +3 -6
  4. package/dist/.tsbuildinfo +1 -0
  5. package/dist/Assets-fetch.d.ts +1 -0
  6. package/dist/Assets-fetch.js +3 -0
  7. package/dist/Assets-fetch.js.map +1 -0
  8. package/dist/CalendarUtils.d.ts +3 -0
  9. package/dist/CalendarUtils.js +6 -0
  10. package/dist/CalendarUtils.js.map +1 -0
  11. package/dist/DateFormat.d.ts +0 -1
  12. package/dist/LocaleData.d.ts +0 -1
  13. package/dist/dates/CalendarDate.d.ts +0 -1
  14. package/dist/dates/CalendarDate.js.map +1 -1
  15. package/dist/dates/ExtremeDates.d.ts +1 -1
  16. package/dist/dates/ExtremeDates.js.map +1 -1
  17. package/dist/dates/UI5Date.d.ts +0 -1
  18. package/dist/dates/convertMonthNumbersToMonthNames.js.map +1 -1
  19. package/dist/dates/getRoundedTimestamp.js.map +1 -1
  20. package/dist/dates/modifyDateBy.js.map +1 -1
  21. package/dist/dates/transformDateToSecondaryType.js.map +1 -1
  22. package/dist/generated/assets/cldr/Unicode-Data-Files-LICENSE.txt +27 -0
  23. package/dist/generated/assets/cldr/ar.json +7085 -5531
  24. package/dist/generated/assets/cldr/ar_EG.json +7085 -5531
  25. package/dist/generated/assets/cldr/ar_SA.json +7084 -5530
  26. package/dist/generated/assets/cldr/bg.json +5979 -4452
  27. package/dist/generated/assets/cldr/ca.json +6081 -4440
  28. package/dist/generated/assets/cldr/cnr.json +6169 -0
  29. package/dist/generated/assets/cldr/cs.json +6707 -4960
  30. package/dist/generated/assets/cldr/cy.json +6930 -5211
  31. package/dist/generated/assets/cldr/da.json +5925 -4308
  32. package/dist/generated/assets/cldr/de.json +6046 -4313
  33. package/dist/generated/assets/cldr/de_AT.json +6047 -4314
  34. package/dist/generated/assets/cldr/de_CH.json +6045 -4312
  35. package/dist/generated/assets/cldr/el.json +5830 -4281
  36. package/dist/generated/assets/cldr/el_CY.json +5830 -4281
  37. package/dist/generated/assets/cldr/en.json +6042 -4316
  38. package/dist/generated/assets/cldr/en_AU.json +6082 -4319
  39. package/dist/generated/assets/cldr/en_GB.json +6073 -4329
  40. package/dist/generated/assets/cldr/en_HK.json +6082 -4337
  41. package/dist/generated/assets/cldr/en_IE.json +6073 -4328
  42. package/dist/generated/assets/cldr/en_IN.json +6078 -4333
  43. package/dist/generated/assets/cldr/en_NZ.json +6073 -4328
  44. package/dist/generated/assets/cldr/en_PG.json +6074 -4329
  45. package/dist/generated/assets/cldr/en_SG.json +6078 -4333
  46. package/dist/generated/assets/cldr/en_ZA.json +6074 -4329
  47. package/dist/generated/assets/cldr/es.json +6101 -4331
  48. package/dist/generated/assets/cldr/es_AR.json +6104 -4334
  49. package/dist/generated/assets/cldr/es_BO.json +6103 -4333
  50. package/dist/generated/assets/cldr/es_CL.json +5996 -4334
  51. package/dist/generated/assets/cldr/es_CO.json +5996 -4333
  52. package/dist/generated/assets/cldr/es_MX.json +6105 -4335
  53. package/dist/generated/assets/cldr/es_PE.json +5887 -4333
  54. package/dist/generated/assets/cldr/es_UY.json +5889 -4335
  55. package/dist/generated/assets/cldr/es_VE.json +5888 -4334
  56. package/dist/generated/assets/cldr/et.json +6025 -4340
  57. package/dist/generated/assets/cldr/fa.json +5948 -4367
  58. package/dist/generated/assets/cldr/fi.json +6193 -4463
  59. package/dist/generated/assets/cldr/fr.json +5995 -4357
  60. package/dist/generated/assets/cldr/fr_BE.json +5995 -4357
  61. package/dist/generated/assets/cldr/fr_CA.json +5989 -4351
  62. package/dist/generated/assets/cldr/fr_CH.json +6013 -4375
  63. package/dist/generated/assets/cldr/fr_LU.json +5995 -4357
  64. package/dist/generated/assets/cldr/he.json +6539 -4869
  65. package/dist/generated/assets/cldr/hi.json +5857 -4295
  66. package/dist/generated/assets/cldr/hr.json +6194 -4583
  67. package/dist/generated/assets/cldr/hu.json +5943 -4364
  68. package/dist/generated/assets/cldr/id.json +5728 -4060
  69. package/dist/generated/assets/cldr/it.json +5984 -4299
  70. package/dist/generated/assets/cldr/it_CH.json +5984 -4299
  71. package/dist/generated/assets/cldr/ja.json +5887 -4211
  72. package/dist/generated/assets/cldr/kk.json +5937 -4339
  73. package/dist/generated/assets/cldr/ko.json +5768 -4189
  74. package/dist/generated/assets/cldr/lt.json +6576 -4850
  75. package/dist/generated/assets/cldr/lv.json +6112 -4587
  76. package/dist/generated/assets/cldr/mk.json +6045 -0
  77. package/dist/generated/assets/cldr/ms.json +5562 -4021
  78. package/dist/generated/assets/cldr/nb.json +6033 -4335
  79. package/dist/generated/assets/cldr/nl.json +6200 -4294
  80. package/dist/generated/assets/cldr/nl_BE.json +6200 -4294
  81. package/dist/generated/assets/cldr/pl.json +6587 -4667
  82. package/dist/generated/assets/cldr/pt.json +6113 -4235
  83. package/dist/generated/assets/cldr/pt_PT.json +6178 -4372
  84. package/dist/generated/assets/cldr/ro.json +6198 -4563
  85. package/dist/generated/assets/cldr/ru.json +6501 -4909
  86. package/dist/generated/assets/cldr/ru_UA.json +6501 -4909
  87. package/dist/generated/assets/cldr/sk.json +6430 -4939
  88. package/dist/generated/assets/cldr/sl.json +6442 -4910
  89. package/dist/generated/assets/cldr/sr.json +6239 -4585
  90. package/dist/generated/assets/cldr/sr_Latn.json +6224 -4574
  91. package/dist/generated/assets/cldr/sv.json +6074 -4362
  92. package/dist/generated/assets/cldr/th.json +5873 -4214
  93. package/dist/generated/assets/cldr/tr.json +6092 -4400
  94. package/dist/generated/assets/cldr/uk.json +6452 -4858
  95. package/dist/generated/assets/cldr/vi.json +5667 -4070
  96. package/dist/generated/assets/cldr/zh_CN.json +5715 -4100
  97. package/dist/generated/assets/cldr/zh_HK.json +5724 -4108
  98. package/dist/generated/assets/cldr/zh_SG.json +5724 -4108
  99. package/dist/generated/assets/cldr/zh_TW.json +5791 -4131
  100. package/dist/generated/json-imports/LocaleData-fetch.d.ts +1 -0
  101. package/dist/generated/json-imports/LocaleData-fetch.js +93 -0
  102. package/dist/generated/json-imports/LocaleData-fetch.js.map +1 -0
  103. package/dist/generated/json-imports/LocaleData.d.ts +1 -0
  104. package/dist/generated/json-imports/LocaleData.js +89 -89
  105. package/dist/generated/json-imports/LocaleData.js.map +1 -0
  106. package/dist/getCachedLocaleDataInstance.js.map +1 -1
  107. package/dist/locale/getLocaleData.js.map +1 -1
  108. package/dist/sap/base/Event.js +59 -0
  109. package/dist/sap/base/Eventing.js +146 -0
  110. package/dist/sap/base/Log.js +2 -239
  111. package/dist/sap/base/assert.js +28 -1
  112. package/dist/sap/base/config/MemoryConfigurationProvider.js +20 -0
  113. package/dist/sap/base/config.js +17 -0
  114. package/dist/sap/base/i18n/Formatting.d.ts +8 -0
  115. package/dist/sap/base/i18n/Formatting.js +11 -0
  116. package/dist/sap/base/i18n/Formatting.js.map +1 -0
  117. package/dist/sap/base/i18n/LanguageTag.js +168 -30
  118. package/dist/sap/base/i18n/date/CalendarType.js +36 -1
  119. package/dist/sap/base/i18n/date/CalendarWeekNumbering.js +76 -1
  120. package/dist/sap/base/i18n/date/TimezoneUtils.js +242 -12
  121. package/dist/sap/base/strings/camelize.js +30 -0
  122. package/dist/sap/base/strings/formatMessage.js +88 -15
  123. package/dist/sap/base/util/LoaderExtensions.js.map +1 -1
  124. package/dist/sap/base/util/ObjectPath.d.ts +4 -0
  125. package/dist/sap/base/util/ObjectPath.js +4 -33
  126. package/dist/sap/base/util/ObjectPath.js.map +1 -0
  127. package/dist/sap/base/util/Version.js +157 -0
  128. package/dist/sap/base/util/_merge.js +83 -26
  129. package/dist/sap/base/util/array/uniqueSort.js +37 -15
  130. package/dist/sap/base/util/deepClone.js +102 -0
  131. package/dist/sap/base/util/deepEqual.js +75 -51
  132. package/dist/sap/base/util/extend.js +58 -7
  133. package/dist/sap/base/util/isEmptyObject.js +34 -0
  134. package/dist/sap/base/util/isPlainObject.js +35 -1
  135. package/dist/sap/base/util/now.js +24 -3
  136. package/dist/sap/base/util/resolveReference.js +3 -0
  137. package/dist/sap/base/util/uid.js +27 -0
  138. package/dist/sap/ui/base/DataType.js +657 -0
  139. package/dist/sap/ui/base/Interface.js +47 -1
  140. package/dist/sap/ui/base/Metadata.js +433 -180
  141. package/dist/sap/ui/base/Object.js +284 -48
  142. package/dist/sap/ui/core/CalendarType.js +23 -1
  143. package/dist/sap/ui/core/Configuration.d.ts +1 -2
  144. package/dist/sap/ui/core/Core.d.ts +2 -4
  145. package/dist/sap/ui/core/FormatSettings.d.ts +1 -2
  146. package/dist/sap/ui/core/FormatSettings.js +0 -2
  147. package/dist/sap/ui/core/FormatSettings.js.map +1 -1
  148. package/dist/sap/ui/core/Locale.js +189 -57
  149. package/dist/sap/ui/core/LocaleData.js +2670 -1380
  150. package/dist/sap/ui/core/Supportability.js +5 -0
  151. package/dist/sap/ui/core/Theming.js +539 -0
  152. package/dist/sap/ui/core/date/Buddhist.js +162 -87
  153. package/dist/sap/ui/core/date/CalendarUtils.js +61 -21
  154. package/dist/sap/ui/core/date/CalendarWeekNumbering.js +29 -1
  155. package/dist/sap/ui/core/date/Gregorian.js +25 -10
  156. package/dist/sap/ui/core/date/Islamic.js +298 -185
  157. package/dist/sap/ui/core/date/Japanese.js +210 -115
  158. package/dist/sap/ui/core/date/Persian.js +324 -195
  159. package/dist/sap/ui/core/date/UI5Date.js +923 -237
  160. package/dist/sap/ui/core/date/UniversalDate.js +1238 -245
  161. package/dist/sap/ui/core/date/_Calendars.js +10 -1
  162. package/dist/sap/ui/core/format/DateFormat.js +3163 -2145
  163. package/dist/sap/ui/core/format/TimezoneUtil.js +23 -1
  164. package/package-scripts.cjs +12 -21
  165. package/package.json +12 -6
  166. package/tsconfig.json +20 -10
  167. package/used-modules.txt +19 -1
  168. package/dist/Assets-static.d.ts +0 -1
  169. package/dist/Assets-static.js +0 -3
  170. package/dist/Assets-static.js.map +0 -1
  171. package/dist/dates/calculateWeekNumber.d.ts +0 -5
  172. package/dist/dates/calculateWeekNumber.js +0 -45
  173. package/dist/dates/calculateWeekNumber.js.map +0 -1
  174. package/dist/generated/json-imports/LocaleData-static.js +0 -90
  175. package/dist/sap/ui/Device.js +0 -5
@@ -1,20 +1,93 @@
1
- import assert from '../assert.js';
1
+ /*!
2
+ * OpenUI5
3
+ * (c) Copyright 2009-2024 SAP SE or an SAP affiliate company.
4
+ * Licensed under the Apache License, Version 2.0 - see LICENSE.txt.
5
+ */
6
+ import assert from "../assert.js";
7
+ /**
8
+ * Pattern to analyze MessageFormat strings.
9
+ *
10
+ * Group 1: captures doubled single quotes within the string
11
+ * Group 2: captures quoted fragments within the string.
12
+ * Note that java.util.MessageFormat silently forgives a missing single quote at
13
+ * the end of a pattern. This special case is handled by the RegEx as well.
14
+ * Group 3: captures placeholders
15
+ * Checks only for numerical argument index, any remainder is ignored up to the next
16
+ * closing curly brace. Nested placeholders are not accepted!
17
+ * Group 4: captures any remaining curly braces and indicates syntax errors
18
+ *
19
+ * [-1] [----- quoted string -----] [------ placeholder ------] [--]
20
+ * @private
21
+ */
2
22
  var rMessageFormat = /('')|'([^']+(?:''[^']*)*)(?:'|$)|\{([0-9]+(?:\s*,[^{}]*)?)\}|[{}]/g;
23
+
24
+ /**
25
+ * Creates a string from a pattern by replacing placeholders with concrete values.
26
+ *
27
+ * The syntax of the pattern is inspired by (but not fully equivalent to) the
28
+ * java.util.MessageFormat.
29
+ *
30
+ * Placeholders have the form <code>{ integer }</code>, where any occurrence of
31
+ * <code>{0}</code> is replaced by the value with index 0 in <code>aValues</code>,
32
+ * <code>{1}</code> by the value with index 1 in <code>aValues</code> etc.
33
+ *
34
+ * To avoid interpretation of curly braces as placeholders, any non-placeholder fragment
35
+ * of the pattern can be enclosed in single quotes. The surrounding single quotes will be
36
+ * omitted from the result. Single quotes that are not meant to escape a fragment and
37
+ * that should appear in the result, need to be doubled. In the result, only a single
38
+ * single quote will occur.
39
+ *
40
+ * Example: Pattern Strings
41
+ * <pre>
42
+ * formatMessage("Say {0}", ["Hello"]) -> "Say Hello" // normal use case
43
+ * formatMessage("Say '{0}'", ["Hello"]) -> "Say {0}" // escaped placeholder
44
+ * formatMessage("Say ''{0}''", ["Hello"]) -> "Say 'Hello'" // doubled single quote
45
+ * formatMessage("Say '{0}'''", ["Hello"]) -> "Say {0}'" // doubled single quote in quoted fragment
46
+ * </pre>
47
+ * In contrast to java.util.MessageFormat, format types or format styles are not supported.
48
+ * Everything after the argument index and up to the first closing curly brace is ignored.
49
+ * Nested placeholders (as supported by java.lang.MessageFormat for the format type choice)
50
+ * are not ignored but reported as a parse error.
51
+ *
52
+ * This method throws an Error when the pattern syntax is not fulfilled (e.g. unbalanced curly
53
+ * braces, nested placeholders or a non-numerical argument index).
54
+ *
55
+ * This method can also be used as a formatter within a binding. The first part of a composite binding
56
+ * will be used as pattern, the following parts as aValues. If there is only one value and this
57
+ * value is an array it will be handled like the default described above.
58
+ *
59
+ * @function
60
+ * @since 1.58
61
+ * @alias module:sap/base/strings/formatMessage
62
+ * @param {string} sPattern A pattern string in the described syntax
63
+ * @param {any[]} [aValues=[]] The values to be used instead of the placeholders.
64
+ * @returns {string} The formatted result string
65
+ * @SecPassthrough {*|return}
66
+ * @public
67
+ */
3
68
  var fnFormatMessage = function (sPattern, aValues) {
4
- assert(typeof sPattern === 'string' || sPattern instanceof String, 'pattern must be string');
5
- if (arguments.length > 2 || aValues != null && !Array.isArray(aValues)) {
6
- aValues = Array.prototype.slice.call(arguments, 1);
69
+ assert(typeof sPattern === "string" || sPattern instanceof String, "pattern must be string");
70
+ if (arguments.length > 2 || aValues != null && !Array.isArray(aValues)) {
71
+ aValues = Array.prototype.slice.call(arguments, 1);
72
+ }
73
+ aValues = aValues || [];
74
+ return sPattern.replace(rMessageFormat, function ($0, $1, $2, $3, offset) {
75
+ if ($1) {
76
+ // a doubled single quote in a normal string fragment
77
+ // --> emit a single quote
78
+ return "'";
79
+ } else if ($2) {
80
+ // a quoted sequence of chars, potentially containing doubled single quotes again
81
+ // --> emit with doubled single quotes replaced by a single quote
82
+ return $2.replace(/''/g, "'");
83
+ } else if ($3) {
84
+ // a welformed curly brace
85
+ // --> emit the argument but ignore other parameters
86
+ return String(aValues[parseInt($3)]);
7
87
  }
8
- aValues = aValues || [];
9
- return sPattern.replace(rMessageFormat, function ($0, $1, $2, $3, offset) {
10
- if ($1) {
11
- return '\'';
12
- } else if ($2) {
13
- return $2.replace(/''/g, '\'');
14
- } else if ($3) {
15
- return String(aValues[parseInt($3)]);
16
- }
17
- throw new Error('formatMessage: pattern syntax error at pos. ' + offset);
18
- });
88
+ // e.g. malformed curly braces
89
+ // --> throw Error
90
+ throw new Error("formatMessage: pattern syntax error at pos. " + offset);
91
+ });
19
92
  };
20
93
  export default fnFormatMessage;
@@ -1 +1 @@
1
- {"version":3,"file":"LoaderExtensions.js","sourceRoot":"","sources":["../../../../src/sap/base/util/LoaderExtensions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,6DAA6D,CAAC;AAE5F,MAAM,YAAY,GAAG,CAAC,UAAkB,EAAE,EAAE;IAC3C,MAAM,YAAY,GAAG,UAAU,CAAC,KAAK,CAAC,kCAAkC,CAAC,CAAC;IAC1E,IAAI,CAAC,YAAY,EAAE;QAClB,MAAM,IAAI,KAAK,CAAC,mBAAmB,UAAU,GAAG,CAAC,CAAC;KAClD;IAED,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;IACjC,OAAO,aAAa,CAAC,QAAQ,CAAC,CAAC;AAChC,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG;IACxB,YAAY;CACZ,CAAC;AAEF,eAAe,gBAAgB,CAAC","sourcesContent":["import { getLocaleData } from \"@ui5/webcomponents-base/dist/asset-registries/LocaleData.js\";\n\nconst loadResource = (moduleName: string) => {\n\tconst moduleFormat = moduleName.match(/sap\\/ui\\/core\\/cldr\\/(\\w+)\\.json/);\n\tif (!moduleFormat) {\n\t\tthrow new Error(`Unknown module \"${moduleName}\"`);\n\t}\n\n\tconst localeId = moduleFormat[1];\n\treturn getLocaleData(localeId);\n};\n\nconst LoaderExtensions = {\n\tloadResource,\n};\n\nexport default LoaderExtensions;\n"]}
1
+ {"version":3,"file":"LoaderExtensions.js","sourceRoot":"","sources":["../../../../src/sap/base/util/LoaderExtensions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,6DAA6D,CAAC;AAE5F,MAAM,YAAY,GAAG,CAAC,UAAkB,EAAE,EAAE;IAC3C,MAAM,YAAY,GAAG,UAAU,CAAC,KAAK,CAAC,kCAAkC,CAAC,CAAC;IAC1E,IAAI,CAAC,YAAY,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,mBAAmB,UAAU,GAAG,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;IACjC,OAAO,aAAa,CAAC,QAAQ,CAAC,CAAC;AAChC,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG;IACxB,YAAY;CACZ,CAAC;AAEF,eAAe,gBAAgB,CAAC","sourcesContent":["import { getLocaleData } from \"@ui5/webcomponents-base/dist/asset-registries/LocaleData.js\";\n\nconst loadResource = (moduleName: string) => {\n\tconst moduleFormat = moduleName.match(/sap\\/ui\\/core\\/cldr\\/(\\w+)\\.json/);\n\tif (!moduleFormat) {\n\t\tthrow new Error(`Unknown module \"${moduleName}\"`);\n\t}\n\n\tconst localeId = moduleFormat[1];\n\treturn getLocaleData(localeId);\n};\n\nconst LoaderExtensions = {\n\tloadResource,\n};\n\nexport default LoaderExtensions;\n"]}
@@ -0,0 +1,4 @@
1
+ declare const ObjectPath: {
2
+ set(): void;
3
+ };
4
+ export default ObjectPath;
@@ -1,35 +1,6 @@
1
- var ObjectPath = {};
2
- var defaultRootContext = window;
3
- function getObjectPathArray(vObjectPath) {
4
- return Array.isArray(vObjectPath) ? vObjectPath.slice() : vObjectPath.split(".");
5
- }
6
- ObjectPath.create = function (vObjectPath, oRootContext) {
7
- var oObject = oRootContext || defaultRootContext;
8
- var aNames = getObjectPathArray(vObjectPath);
9
- for (var i = 0; i < aNames.length; i++) {
10
- var sName = aNames[i];
11
- if (oObject[sName] === null || oObject[sName] !== undefined && (typeof oObject[sName] !== "object" && typeof oObject[sName] !== "function")) {
12
- throw new Error("Could not set object-path for '" + aNames.join(".") + "', path segment '" + sName + "' already exists.");
13
- }
14
- oObject[sName] = oObject[sName] || ({});
15
- oObject = oObject[sName];
16
- }
17
- return oObject;
18
- };
19
- ObjectPath.get = function (vObjectPath, oRootContext) {
20
- var oObject = oRootContext || defaultRootContext;
21
- var aNames = getObjectPathArray(vObjectPath);
22
- var sPropertyName = aNames.pop();
23
- for (var i = 0; i < aNames.length && oObject; i++) {
24
- oObject = oObject[aNames[i]];
25
- }
26
- return oObject ? oObject[sPropertyName] : undefined;
27
- };
28
- ObjectPath.set = function (vObjectPath, vValue, oRootContext) {
29
- oRootContext = oRootContext || defaultRootContext;
30
- var aNames = getObjectPathArray(vObjectPath);
31
- var sPropertyName = aNames.pop();
32
- var oObject = ObjectPath.create(aNames, oRootContext);
33
- oObject[sPropertyName] = vValue;
1
+ // ObjectPath is accessing window which breaks SSR, hence the overlay
2
+ const ObjectPath = {
3
+ set() { },
34
4
  };
35
5
  export default ObjectPath;
6
+ //# sourceMappingURL=ObjectPath.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ObjectPath.js","sourceRoot":"","sources":["../../../../src/sap/base/util/ObjectPath.ts"],"names":[],"mappings":"AAAA,qEAAqE;AAErE,MAAM,UAAU,GAAG;IAClB,GAAG,KAAI,CAAC;CACR,CAAC;AAEF,eAAe,UAAU,CAAC","sourcesContent":["// ObjectPath is accessing window which breaks SSR, hence the overlay\n\nconst ObjectPath = {\n\tset() {},\n};\n\nexport default ObjectPath;\n"]}
@@ -0,0 +1,157 @@
1
+ // @evo-todo make it a simple object with immutable properties (Object.defineProperties)
2
+
3
+ // -------------------------- VERSION -------------------------------------
4
+ /*!
5
+ * OpenUI5
6
+ * (c) Copyright 2009-2024 SAP SE or an SAP affiliate company.
7
+ * Licensed under the Apache License, Version 2.0 - see LICENSE.txt.
8
+ */
9
+
10
+ var rVersion = /^[0-9]+(?:\.([0-9]+)(?:\.([0-9]+))?)?(.*)$/;
11
+
12
+ /**
13
+ * Returns a Version instance created from the given parameters.
14
+ *
15
+ * This function can either be called as a constructor (using <code>new</code>) or as a normal function.
16
+ * It always returns an immutable Version instance.
17
+ *
18
+ * The parts of the version number (major, minor, patch, suffix) can be provided in several ways:
19
+ * <ul>
20
+ * <li>Version("1.2.3-SNAPSHOT") - as a dot-separated string. Any non-numerical char or a dot followed
21
+ * by a non-numerical char starts the suffix portion. Any missing major,
22
+ * minor or patch versions will be set to 0.</li>
23
+ * <li>Version(1,2,3,"-SNAPSHOT") - as individual parameters. Major, minor and patch must be integer numbers
24
+ * or empty, suffix must be a string not starting with digits.</li>
25
+ * <li>Version([1,2,3,"-SNAPSHOT"]) - as an array with the individual parts. The same type restrictions apply
26
+ * as before.</li>
27
+ * <li>Version(otherVersion) - as a Version instance (cast operation). Returns the given instance instead
28
+ * of creating a new one.</li>
29
+ * </ul>
30
+ *
31
+ * To keep the code size small, this implementation mainly validates the single string variant.
32
+ * All other variants are only validated to some degree. It is the responsibility of the caller to
33
+ * provide proper parts.
34
+ *
35
+ * @param {int|string|any[]|module:sap/base/util/Version} vMajor the major part of the version (int) or any of the single
36
+ * parameter variants explained above.
37
+ * @param {int} iMinor the minor part of the version number
38
+ * @param {int} iPatch the patch part of the version number
39
+ * @param {string} sSuffix the suffix part of the version number
40
+ * @class Represents a version consisting of major, minor, patch version, and suffix, for example '1.2.7-SNAPSHOT'.
41
+ * @since 1.58
42
+ * @alias module:sap/base/util/Version
43
+ * @public
44
+ */
45
+ function Version(vMajor, iMinor, iPatch, sSuffix) {
46
+ if (vMajor instanceof Version) {
47
+ // note: even a constructor may return a value different from 'this'
48
+ return vMajor;
49
+ }
50
+ if (!(this instanceof Version)) {
51
+ // act as a cast operator when called as function (not as a constructor)
52
+ return new Version(vMajor, iMinor, iPatch, sSuffix);
53
+ }
54
+ var m;
55
+ if (typeof vMajor === "string") {
56
+ m = rVersion.exec(vMajor);
57
+ } else if (Array.isArray(vMajor)) {
58
+ m = vMajor;
59
+ } else {
60
+ m = arguments;
61
+ }
62
+ m = m || [];
63
+ function norm(v) {
64
+ v = parseInt(v);
65
+ return isNaN(v) ? 0 : v;
66
+ }
67
+ vMajor = norm(m[0]);
68
+ iMinor = norm(m[1]);
69
+ iPatch = norm(m[2]);
70
+ sSuffix = String(m[3] || "");
71
+
72
+ /**
73
+ * Returns a string representation of this version.
74
+ *
75
+ * @return {string} a string representation of this version.
76
+ * @public
77
+ */
78
+ this.toString = function () {
79
+ return vMajor + "." + iMinor + "." + iPatch + sSuffix;
80
+ };
81
+
82
+ /**
83
+ * Returns the major version part of this version.
84
+ *
85
+ * @return {int} the major version part of this version
86
+ * @public
87
+ */
88
+ this.getMajor = function () {
89
+ return vMajor;
90
+ };
91
+
92
+ /**
93
+ * Returns the minor version part of this version.
94
+ *
95
+ * @return {int} the minor version part of this version
96
+ * @public
97
+ */
98
+ this.getMinor = function () {
99
+ return iMinor;
100
+ };
101
+
102
+ /**
103
+ * Returns the patch (or micro) version part of this version.
104
+ *
105
+ * @return {int} the patch version part of this version
106
+ * @public
107
+ */
108
+ this.getPatch = function () {
109
+ return iPatch;
110
+ };
111
+
112
+ /**
113
+ * Returns the version suffix of this version.
114
+ *
115
+ * @return {string} the version suffix of this version
116
+ * @public
117
+ */
118
+ this.getSuffix = function () {
119
+ return sSuffix;
120
+ };
121
+
122
+ /**
123
+ * Compares this version with a given one.
124
+ *
125
+ * The version with which this version should be compared can be given as a <code>sap/base/util/Version</code> instance,
126
+ * as a string (e.g. <code>v.compareto("1.4.5")</code>). Or major, minor, patch and suffix values can be given as
127
+ * separate parameters (e.g. <code>v.compareTo(1, 4, 5)</code>) or in an array (e.g. <code>v.compareTo([1, 4, 5])</code>).
128
+ *
129
+ * @return {int} 0, if the given version is equal to this version, a negative value if the given other version is greater
130
+ * and a positive value otherwise
131
+ * @public
132
+ */
133
+ this.compareTo = function () {
134
+ var vOther = Version.apply(window, arguments);
135
+ /*eslint-disable no-nested-ternary */
136
+ return vMajor - vOther.getMajor() || iMinor - vOther.getMinor() || iPatch - vOther.getPatch() || (sSuffix < vOther.getSuffix() ? -1 : sSuffix === vOther.getSuffix() ? 0 : 1);
137
+ /*eslint-enable no-nested-ternary */
138
+ };
139
+ }
140
+
141
+ /**
142
+ * Checks whether this version is in the range of the given interval (start inclusive, end exclusive).
143
+ *
144
+ * The boundaries against which this version should be checked can be given as <code>sap/base/util/Version</code>
145
+ * instances (e.g. <code>v.inRange(v1, v2)</code>), as strings (e.g. <code>v.inRange("1.4", "2.7")</code>)
146
+ * or as arrays (e.g. <code>v.inRange([1,4], [2,7])</code>).
147
+ *
148
+ * @param {string|any[]|module:sap/base/util/Version} vMin the start of the range (inclusive)
149
+ * @param {string|any[]|module:sap/base/util/Version} vMax the end of the range (exclusive)
150
+ * @return {boolean} <code>true</code> if this version is greater or equal to <code>vMin</code> and smaller
151
+ * than <code>vMax</code>, <code>false</code> otherwise.
152
+ * @public
153
+ */
154
+ Version.prototype.inRange = function (vMin, vMax) {
155
+ return this.compareTo(vMin) >= 0 && this.compareTo(vMax) < 0;
156
+ };
157
+ export default Version;
@@ -1,32 +1,89 @@
1
- import isPlainObject from './isPlainObject.js';
1
+ /*!
2
+ * OpenUI5
3
+ * (c) Copyright 2009-2024 SAP SE or an SAP affiliate company.
4
+ * Licensed under the Apache License, Version 2.0 - see LICENSE.txt.
5
+ */
6
+ import isPlainObject from "./isPlainObject.js";
2
7
  var oToken = Object.create(null);
8
+
9
+ /**
10
+ * Performs object extension by merging source objects into a target object.
11
+ *
12
+ * @example
13
+ * var oMerged = _merge(true, false, {}, {prop1:1}, {prop2:2});
14
+ *
15
+ * @function
16
+ * @since 1.71
17
+ * @private
18
+ * @alias module:sap/base/util/_merge
19
+ * @param {boolean} deep Shallow copy or deep merge
20
+ * @param {boolean} skipUndefined Whether <code>undefined</code> values will be skipped, otherwise <code>undefined</code> values will overwrite existing values
21
+ * @param {object} target The object that will receive new properties
22
+ * @param {...object} [source] One or more objects which get merged into the target object
23
+ * @return {object} the target object which is the result of the merge
24
+ */
3
25
  var fnMerge = function () {
4
- var src, copyIsArray, copy, name, options, clone, target = arguments[2] || {}, i = 3, length = arguments.length, deep = arguments[0] || false, skipToken = arguments[1] ? undefined : oToken;
5
- if (typeof target !== 'object' && typeof target !== 'function') {
6
- target = {};
7
- }
8
- for (; i < length; i++) {
9
- if ((options = arguments[i]) != null) {
10
- for (name in options) {
11
- src = target[name];
12
- copy = options[name];
13
- if (name === '__proto__' || target === copy) {
14
- continue;
15
- }
16
- if (deep && copy && (isPlainObject(copy) || (copyIsArray = Array.isArray(copy)))) {
17
- if (copyIsArray) {
18
- copyIsArray = false;
19
- clone = src && Array.isArray(src) ? src : [];
20
- } else {
21
- clone = src && isPlainObject(src) ? src : {};
22
- }
23
- target[name] = fnMerge(deep, arguments[1], clone, copy);
24
- } else if (copy !== skipToken) {
25
- target[name] = copy;
26
- }
27
- }
26
+ /*
27
+ * The code in this function is taken from jQuery 3.6.0 "jQuery.extend" and got modified.
28
+ *
29
+ * jQuery JavaScript Library v3.6.0
30
+ * https://jquery.com/
31
+ *
32
+ * Copyright OpenJS Foundation and other contributors
33
+ * Released under the MIT license
34
+ * https://jquery.org/license
35
+ */
36
+ var src,
37
+ copyIsArray,
38
+ copy,
39
+ name,
40
+ options,
41
+ clone,
42
+ target = arguments[2] || {},
43
+ i = 3,
44
+ length = arguments.length,
45
+ deep = arguments[0] || false,
46
+ skipToken = arguments[1] ? undefined : oToken;
47
+
48
+ // Handle case when target is a string or something (possible in deep copy)
49
+ if (typeof target !== "object" && typeof target !== "function") {
50
+ target = {};
51
+ }
52
+ for (; i < length; i++) {
53
+ if ((options = arguments[i]) != null) {
54
+ // Extend the base object
55
+ for (name in options) {
56
+ src = target[name];
57
+ copy = options[name];
58
+
59
+ // Prevent never-ending loop
60
+ // Prevent Object.prototype pollution for $.extend( true, ... )
61
+ // For further information, please visit https://github.com/jquery/jquery/pull/4333
62
+ if (name === "__proto__" || target === copy) {
63
+ continue;
64
+ }
65
+
66
+ // Recurse if we're merging plain objects or arrays
67
+ if (deep && copy && (isPlainObject(copy) || (copyIsArray = Array.isArray(copy)))) {
68
+ if (copyIsArray) {
69
+ copyIsArray = false;
70
+ clone = src && Array.isArray(src) ? src : [];
71
+ } else {
72
+ clone = src && isPlainObject(src) ? src : {};
73
+ }
74
+
75
+ // Never move original objects, clone them
76
+ target[name] = fnMerge(deep, arguments[1], clone, copy);
77
+
78
+ // Don't bring in undefined values
79
+ } else if (copy !== skipToken) {
80
+ target[name] = copy;
28
81
  }
82
+ }
29
83
  }
30
- return target;
84
+ }
85
+
86
+ // Return the modified object
87
+ return target;
31
88
  };
32
89
  export default fnMerge;
@@ -1,19 +1,41 @@
1
- import assert from '../../assert.js';
1
+ /*!
2
+ * OpenUI5
3
+ * (c) Copyright 2009-2024 SAP SE or an SAP affiliate company.
4
+ * Licensed under the Apache License, Version 2.0 - see LICENSE.txt.
5
+ */
6
+ import assert from "../../assert.js";
7
+ /**
8
+ * Sorts the given array in-place and removes any duplicates (identified by "===").
9
+ *
10
+ * Uses Array#sort()
11
+ * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort
12
+ *
13
+ * Use <code>jQuery.uniqueSort()</code> for arrays of DOMElements.
14
+ *
15
+ * @function
16
+ * @since 1.58
17
+ * @param {any[]} aArray An Array of any type
18
+ * @alias module:sap/base/util/array/uniqueSort
19
+ * @return {any[]} Same array as given (for chaining)
20
+ * @public
21
+ */
2
22
  var fnUniqueSort = function (aArray) {
3
- assert(Array.isArray(aArray), 'uniqueSort: input parameter must be an Array');
4
- var iLength = aArray.length;
5
- if (iLength > 1) {
6
- aArray.sort();
7
- var j = 0;
8
- for (var i = 1; i < iLength; i++) {
9
- if (aArray.indexOf(aArray[i]) === i) {
10
- aArray[++j] = aArray[i];
11
- }
12
- }
13
- if (++j < iLength) {
14
- aArray.splice(j, iLength - j);
15
- }
23
+ assert(Array.isArray(aArray), "uniqueSort: input parameter must be an Array");
24
+ var iLength = aArray.length;
25
+ if (iLength > 1) {
26
+ aArray.sort();
27
+ var j = 0;
28
+ for (var i = 1; i < iLength; i++) {
29
+ // invariant: i is the entry to check, j is the last unique entry known so far
30
+ if (aArray.indexOf(aArray[i]) === i) {
31
+ aArray[++j] = aArray[i];
32
+ }
16
33
  }
17
- return aArray;
34
+ // cut off the rest - if any
35
+ if (++j < iLength) {
36
+ aArray.splice(j, iLength - j);
37
+ }
38
+ }
39
+ return aArray;
18
40
  };
19
41
  export default fnUniqueSort;
@@ -0,0 +1,102 @@
1
+ /*!
2
+ * OpenUI5
3
+ * (c) Copyright 2009-2024 SAP SE or an SAP affiliate company.
4
+ * Licensed under the Apache License, Version 2.0 - see LICENSE.txt.
5
+ */
6
+ import isPlainObject from "./isPlainObject.js";
7
+ /**
8
+ * Creates a deep clone of the source value.
9
+ *
10
+ * Only arrays, JavaScript Date objects and objects that pass the {@link module:sap/base/util/isPlainObject isPlainObject}
11
+ * check will be cloned. For other object types, a <code>TypeError</code> will be thrown as there's no standard way
12
+ * to clone them. Primitive values (boolean, number, string) as well as <code>null</code> and <code>undefined</code>
13
+ * will be copied, they have value semantics anyhow.
14
+ *
15
+ * <code>deepClone</code> is designed to match the semantics of {@link module:sap/base/util/deepEqual deepEqual}.
16
+ * Any deeply cloned object should be deep-equal to the source. However, not every object that can be handled
17
+ * by <code>deepEqual</code> can also be deeply cloned (e.g. <code>deepClone</code> fails on non-plain objects).
18
+ *
19
+ * To limit the time needed for a deep clone and to avoid endless recursion in case of cyclic structures, the
20
+ * recursion depth is limited by the parameter <code>maxDepth</code>, which defaults to 10. When the recursion
21
+ * depth exceeds the given limit, a <code>TypeError</code> is thrown.
22
+ *
23
+ * Note that object identities are not honored by the clone operation. If the original source contained multiple
24
+ * references to the same plain object instance, the clone will contain a different clone for each reference.
25
+ *
26
+ * @example <caption>Simple operation</caption>
27
+ * var oSource = { a: 1, b: { x: "test", y : 5.0 }, c: new Date(), d: null };
28
+ * var oClone = deepClone(oValue);
29
+ *
30
+ * deepEqual(oClone, oSource); // true
31
+ * oClone !== oSource; // true
32
+ * oClone.b !== oSource.b; // true
33
+ * oClone.c !== oSource.c; // true
34
+ *
35
+ * @example <caption>Object Identities</caption>
36
+ * var oCommon = { me: "unique" };
37
+ * var oValue = { a: oCommon, b: oCommon };
38
+ * var oClone = deepClone(oValue);
39
+ *
40
+ * deepEqual(oClone, oSource); // true
41
+ * oSource.a === oSource.b; // true
42
+ * oClone.a === oClone.b; // false
43
+ * deepEqual(oClone.a, oClone.b); // true
44
+ *
45
+ * @since 1.63
46
+ * @public
47
+ * @alias module:sap/base/util/deepClone
48
+ * @param {any} src Source value that shall be cloned
49
+ * @param {int} [maxDepth=10] Maximum recursion depth for the clone operation, deeper structures will throw an error
50
+ * @returns {any} A clone of the source value
51
+ * @throws {TypeError} When a non-plain object is encountered or when the max structure depth is exceeded
52
+ */
53
+ var fnDeepClone = function (src, maxDepth) {
54
+ if (!maxDepth) {
55
+ maxDepth = 10;
56
+ }
57
+ return clone(src, 0, maxDepth);
58
+ };
59
+ function clone(src, depth, maxDepth) {
60
+ // avoid endless recursion due to cyclic structures
61
+ if (depth > maxDepth) {
62
+ throw new TypeError("The structure depth of the source exceeds the maximum depth (" + maxDepth + ")");
63
+ }
64
+ if (src == null) {
65
+ return src;
66
+ } else if (src instanceof Date) {
67
+ if (src.clone) {
68
+ // sap.ui.core.date.UI5Date
69
+ return src.clone();
70
+ }
71
+
72
+ // clone date object using #getTime(). Officially the date constructor does not support parameter Date.
73
+ return new Date(src.getTime());
74
+ } else if (Array.isArray(src)) {
75
+ return cloneArray(src, depth, maxDepth);
76
+ } else if (typeof src === "object") {
77
+ return cloneObject(src, depth, maxDepth);
78
+ } else {
79
+ return src;
80
+ }
81
+ }
82
+ function cloneArray(src, depth, maxDepth) {
83
+ var aClone = [];
84
+ for (var i = 0; i < src.length; i++) {
85
+ aClone.push(clone(src[i], depth + 1, maxDepth));
86
+ }
87
+ return aClone;
88
+ }
89
+ function cloneObject(src, depth, maxDepth) {
90
+ if (!isPlainObject(src)) {
91
+ throw new TypeError("Cloning is only supported for plain objects");
92
+ }
93
+ var oClone = {};
94
+ for (var key in src) {
95
+ if (key === "__proto__") {
96
+ continue;
97
+ }
98
+ oClone[key] = clone(src[key], depth + 1, maxDepth);
99
+ }
100
+ return oClone;
101
+ }
102
+ export default fnDeepClone;