@ui5/webcomponents-localization 0.0.0-6298a142d → 0.0.0-6827fdc09

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 (182) hide show
  1. package/.eslintignore +2 -1
  2. package/CHANGELOG.md +1285 -0
  3. package/README.md +3 -5
  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.d.ts +2 -1
  21. package/dist/dates/modifyDateBy.js +34 -19
  22. package/dist/dates/modifyDateBy.js.map +1 -1
  23. package/dist/dates/transformDateToSecondaryType.js.map +1 -1
  24. package/dist/generated/assets/cldr/Unicode-Data-Files-LICENSE.txt +27 -0
  25. package/dist/generated/assets/cldr/ar.json +7085 -5531
  26. package/dist/generated/assets/cldr/ar_EG.json +7085 -5531
  27. package/dist/generated/assets/cldr/ar_SA.json +7084 -5530
  28. package/dist/generated/assets/cldr/bg.json +5979 -4452
  29. package/dist/generated/assets/cldr/ca.json +6081 -4440
  30. package/dist/generated/assets/cldr/cnr.json +6169 -0
  31. package/dist/generated/assets/cldr/cs.json +6707 -4960
  32. package/dist/generated/assets/cldr/cy.json +6930 -5211
  33. package/dist/generated/assets/cldr/da.json +5925 -4308
  34. package/dist/generated/assets/cldr/de.json +6046 -4313
  35. package/dist/generated/assets/cldr/de_AT.json +6047 -4314
  36. package/dist/generated/assets/cldr/de_CH.json +6045 -4312
  37. package/dist/generated/assets/cldr/el.json +5830 -4281
  38. package/dist/generated/assets/cldr/el_CY.json +5830 -4281
  39. package/dist/generated/assets/cldr/en.json +6042 -4316
  40. package/dist/generated/assets/cldr/en_AU.json +6082 -4319
  41. package/dist/generated/assets/cldr/en_GB.json +6073 -4329
  42. package/dist/generated/assets/cldr/en_HK.json +6082 -4337
  43. package/dist/generated/assets/cldr/en_IE.json +6073 -4328
  44. package/dist/generated/assets/cldr/en_IN.json +6078 -4333
  45. package/dist/generated/assets/cldr/en_NZ.json +6073 -4328
  46. package/dist/generated/assets/cldr/en_PG.json +6074 -4329
  47. package/dist/generated/assets/cldr/en_SG.json +6078 -4333
  48. package/dist/generated/assets/cldr/en_ZA.json +6074 -4329
  49. package/dist/generated/assets/cldr/es.json +6101 -4331
  50. package/dist/generated/assets/cldr/es_AR.json +6104 -4334
  51. package/dist/generated/assets/cldr/es_BO.json +6103 -4333
  52. package/dist/generated/assets/cldr/es_CL.json +5996 -4334
  53. package/dist/generated/assets/cldr/es_CO.json +5996 -4333
  54. package/dist/generated/assets/cldr/es_MX.json +6105 -4335
  55. package/dist/generated/assets/cldr/es_PE.json +5887 -4333
  56. package/dist/generated/assets/cldr/es_UY.json +5889 -4335
  57. package/dist/generated/assets/cldr/es_VE.json +5888 -4334
  58. package/dist/generated/assets/cldr/et.json +6025 -4340
  59. package/dist/generated/assets/cldr/fa.json +5948 -4367
  60. package/dist/generated/assets/cldr/fi.json +6193 -4463
  61. package/dist/generated/assets/cldr/fr.json +5995 -4357
  62. package/dist/generated/assets/cldr/fr_BE.json +5995 -4357
  63. package/dist/generated/assets/cldr/fr_CA.json +5989 -4351
  64. package/dist/generated/assets/cldr/fr_CH.json +6013 -4375
  65. package/dist/generated/assets/cldr/fr_LU.json +5995 -4357
  66. package/dist/generated/assets/cldr/he.json +6539 -4869
  67. package/dist/generated/assets/cldr/hi.json +5857 -4295
  68. package/dist/generated/assets/cldr/hr.json +6194 -4583
  69. package/dist/generated/assets/cldr/hu.json +5943 -4364
  70. package/dist/generated/assets/cldr/id.json +5728 -4060
  71. package/dist/generated/assets/cldr/it.json +5984 -4299
  72. package/dist/generated/assets/cldr/it_CH.json +5984 -4299
  73. package/dist/generated/assets/cldr/ja.json +5887 -4211
  74. package/dist/generated/assets/cldr/kk.json +5937 -4339
  75. package/dist/generated/assets/cldr/ko.json +5768 -4189
  76. package/dist/generated/assets/cldr/lt.json +6576 -4850
  77. package/dist/generated/assets/cldr/lv.json +6112 -4587
  78. package/dist/generated/assets/cldr/mk.json +6045 -0
  79. package/dist/generated/assets/cldr/ms.json +5562 -4021
  80. package/dist/generated/assets/cldr/nb.json +6033 -4335
  81. package/dist/generated/assets/cldr/nl.json +6200 -4294
  82. package/dist/generated/assets/cldr/nl_BE.json +6200 -4294
  83. package/dist/generated/assets/cldr/pl.json +6587 -4667
  84. package/dist/generated/assets/cldr/pt.json +6113 -4235
  85. package/dist/generated/assets/cldr/pt_PT.json +6178 -4372
  86. package/dist/generated/assets/cldr/ro.json +6198 -4563
  87. package/dist/generated/assets/cldr/ru.json +6501 -4909
  88. package/dist/generated/assets/cldr/ru_UA.json +6501 -4909
  89. package/dist/generated/assets/cldr/sk.json +6430 -4939
  90. package/dist/generated/assets/cldr/sl.json +6442 -4910
  91. package/dist/generated/assets/cldr/sr.json +6239 -4585
  92. package/dist/generated/assets/cldr/sr_Latn.json +6224 -4574
  93. package/dist/generated/assets/cldr/sv.json +6074 -4362
  94. package/dist/generated/assets/cldr/th.json +5873 -4214
  95. package/dist/generated/assets/cldr/tr.json +6092 -4400
  96. package/dist/generated/assets/cldr/uk.json +6452 -4858
  97. package/dist/generated/assets/cldr/vi.json +5667 -4070
  98. package/dist/generated/assets/cldr/zh_CN.json +5715 -4100
  99. package/dist/generated/assets/cldr/zh_HK.json +5724 -4108
  100. package/dist/generated/assets/cldr/zh_SG.json +5724 -4108
  101. package/dist/generated/assets/cldr/zh_TW.json +5791 -4131
  102. package/dist/generated/json-imports/LocaleData-fetch.d.ts +1 -0
  103. package/dist/generated/json-imports/LocaleData-fetch.js +93 -0
  104. package/dist/generated/json-imports/LocaleData-fetch.js.map +1 -0
  105. package/dist/generated/json-imports/LocaleData.d.ts +1 -0
  106. package/dist/generated/json-imports/LocaleData.js +89 -89
  107. package/dist/generated/json-imports/LocaleData.js.map +1 -0
  108. package/dist/getCachedLocaleDataInstance.js.map +1 -1
  109. package/dist/locale/getLocaleData.js.map +1 -1
  110. package/dist/sap/base/Event.js +59 -0
  111. package/dist/sap/base/Eventing.js +146 -0
  112. package/dist/sap/base/Log.js +2 -239
  113. package/dist/sap/base/assert.js +28 -1
  114. package/dist/sap/base/config/MemoryConfigurationProvider.js +20 -0
  115. package/dist/sap/base/config.js +17 -0
  116. package/dist/sap/base/i18n/Formatting.d.ts +8 -0
  117. package/dist/sap/base/i18n/Formatting.js +11 -0
  118. package/dist/sap/base/i18n/Formatting.js.map +1 -0
  119. package/dist/sap/base/i18n/LanguageTag.js +173 -0
  120. package/dist/sap/base/i18n/Localization.d.ts +4 -0
  121. package/dist/sap/base/i18n/Localization.js +12 -0
  122. package/dist/sap/base/i18n/Localization.js.map +1 -0
  123. package/dist/sap/base/i18n/date/CalendarType.js +43 -0
  124. package/dist/sap/base/i18n/date/CalendarWeekNumbering.js +105 -0
  125. package/dist/sap/base/i18n/date/TimezoneUtils.js +319 -0
  126. package/dist/sap/base/strings/camelize.js +30 -0
  127. package/dist/sap/base/strings/formatMessage.js +88 -15
  128. package/dist/sap/base/util/LoaderExtensions.js.map +1 -1
  129. package/dist/sap/base/util/ObjectPath.d.ts +4 -0
  130. package/dist/sap/base/util/ObjectPath.js +4 -33
  131. package/dist/sap/base/util/ObjectPath.js.map +1 -0
  132. package/dist/sap/base/util/Version.js +157 -0
  133. package/dist/sap/base/util/_merge.js +83 -26
  134. package/dist/sap/base/util/array/uniqueSort.js +37 -15
  135. package/dist/sap/base/util/deepClone.js +102 -0
  136. package/dist/sap/base/util/deepEqual.js +75 -51
  137. package/dist/sap/base/util/extend.js +58 -7
  138. package/dist/sap/base/util/isEmptyObject.js +34 -0
  139. package/dist/sap/base/util/isPlainObject.js +35 -1
  140. package/dist/sap/base/util/now.js +24 -3
  141. package/dist/sap/base/util/resolveReference.js +3 -0
  142. package/dist/sap/base/util/uid.js +27 -0
  143. package/dist/sap/ui/base/DataType.js +657 -0
  144. package/dist/sap/ui/base/Interface.js +47 -1
  145. package/dist/sap/ui/base/Metadata.js +435 -171
  146. package/dist/sap/ui/base/Object.js +284 -48
  147. package/dist/sap/ui/core/CalendarType.js +24 -8
  148. package/dist/sap/ui/core/Configuration.d.ts +2 -2
  149. package/dist/sap/ui/core/Configuration.js +2 -0
  150. package/dist/sap/ui/core/Configuration.js.map +1 -1
  151. package/dist/sap/ui/core/Core.d.ts +3 -4
  152. package/dist/sap/ui/core/FormatSettings.d.ts +1 -2
  153. package/dist/sap/ui/core/FormatSettings.js +0 -2
  154. package/dist/sap/ui/core/FormatSettings.js.map +1 -1
  155. package/dist/sap/ui/core/Locale.js +190 -155
  156. package/dist/sap/ui/core/LocaleData.js +2659 -1351
  157. package/dist/sap/ui/core/Supportability.js +5 -0
  158. package/dist/sap/ui/core/Theming.js +539 -0
  159. package/dist/sap/ui/core/date/Buddhist.js +162 -87
  160. package/dist/sap/ui/core/date/CalendarUtils.js +61 -32
  161. package/dist/sap/ui/core/date/CalendarWeekNumbering.js +30 -7
  162. package/dist/sap/ui/core/date/Gregorian.js +25 -10
  163. package/dist/sap/ui/core/date/Islamic.js +298 -185
  164. package/dist/sap/ui/core/date/Japanese.js +210 -115
  165. package/dist/sap/ui/core/date/Persian.js +324 -195
  166. package/dist/sap/ui/core/date/UI5Date.js +923 -237
  167. package/dist/sap/ui/core/date/UniversalDate.js +1238 -256
  168. package/dist/sap/ui/core/date/_Calendars.js +10 -1
  169. package/dist/sap/ui/core/format/DateFormat.js +3171 -2111
  170. package/dist/sap/ui/core/format/TimezoneUtil.js +24 -89
  171. package/package-scripts.cjs +12 -21
  172. package/package.json +12 -6
  173. package/tsconfig.json +20 -10
  174. package/used-modules.txt +23 -1
  175. package/dist/Assets-static.d.ts +0 -1
  176. package/dist/Assets-static.js +0 -3
  177. package/dist/Assets-static.js.map +0 -1
  178. package/dist/dates/calculateWeekNumber.d.ts +0 -5
  179. package/dist/dates/calculateWeekNumber.js +0 -45
  180. package/dist/dates/calculateWeekNumber.js.map +0 -1
  181. package/dist/generated/json-imports/LocaleData-static.js +0 -90
  182. package/dist/sap/ui/Device.js +0 -5
@@ -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;
@@ -1,59 +1,83 @@
1
- import Log from '../Log.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
+ /*global Node */
7
+ //@evo-todo check isEqualNode dependency: not yet available...
8
+ //@evo-todo dependency to global name 'Node' contradicts sap/base package
9
+ import Log from "../Log.js";
10
+ /**
11
+ * Compares the two given values for equality, especially by comparing the content.
12
+ *
13
+ * <b>Note:</b> Function does not work with comparing XML objects.
14
+ *
15
+ * @function
16
+ * @since 1.58
17
+ * @param {any} a A value of any type
18
+ * @param {any} b A value of any type
19
+ * @param {int} [maxDepth=10] Maximum recursion depth
20
+ * @param {boolean} [contains] Whether all existing properties in a are equal as in b
21
+ * @alias module:sap/base/util/deepEqual
22
+ * @return {boolean} Whether a and b are equal
23
+ * @public
24
+ */
2
25
  var fnEqual = function (a, b, maxDepth, contains, depth) {
3
- if (typeof maxDepth == 'boolean') {
4
- contains = maxDepth;
5
- maxDepth = undefined;
6
- }
7
- if (!depth) {
8
- depth = 0;
26
+ // Optional parameter normalization
27
+ if (typeof maxDepth == "boolean") {
28
+ contains = maxDepth;
29
+ maxDepth = undefined;
30
+ }
31
+ if (!depth) {
32
+ depth = 0;
33
+ }
34
+ if (!maxDepth) {
35
+ maxDepth = 10;
36
+ }
37
+ if (depth > maxDepth) {
38
+ Log.warning("deepEqual comparison exceeded maximum recursion depth of " + maxDepth + ". Treating values as unequal");
39
+ return false;
40
+ }
41
+ if (a === b || Number.isNaN(a) && Number.isNaN(b)) {
42
+ return true;
43
+ }
44
+ if (Array.isArray(a) && Array.isArray(b)) {
45
+ if (!contains && a.length !== b.length) {
46
+ return false;
9
47
  }
10
- if (!maxDepth) {
11
- maxDepth = 10;
48
+ if (a.length > b.length) {
49
+ return false;
12
50
  }
13
- if (depth > maxDepth) {
14
- Log.warning('deepEqual comparison exceeded maximum recursion depth of ' + maxDepth + '. Treating values as unequal');
51
+ for (var i = 0; i < a.length; i++) {
52
+ if (!fnEqual(a[i], b[i], maxDepth, contains, depth + 1)) {
15
53
  return false;
54
+ }
16
55
  }
17
- if (a === b || Number.isNaN(a) && Number.isNaN(b)) {
18
- return true;
19
- }
20
- if (Array.isArray(a) && Array.isArray(b)) {
21
- if (!contains && a.length !== b.length) {
22
- return false;
23
- }
24
- if (a.length > b.length) {
25
- return false;
26
- }
27
- for (var i = 0; i < a.length; i++) {
28
- if (!fnEqual(a[i], b[i], maxDepth, contains, depth + 1)) {
29
- return false;
30
- }
31
- }
32
- return true;
33
- }
34
- if (typeof a == 'object' && typeof b == 'object') {
35
- if (!a || !b) {
36
- return false;
37
- }
38
- if (a.constructor !== b.constructor) {
39
- return false;
40
- }
41
- if (!contains && Object.keys(a).length !== Object.keys(b).length) {
42
- return false;
43
- }
44
- if (a instanceof Node) {
45
- return a.isEqualNode(b);
46
- }
47
- if (a instanceof Date) {
48
- return a.valueOf() === b.valueOf();
49
- }
50
- for (var i in a) {
51
- if (!fnEqual(a[i], b[i], maxDepth, contains, depth + 1)) {
52
- return false;
53
- }
54
- }
55
- return true;
56
+ return true;
57
+ }
58
+ if (typeof a == "object" && typeof b == "object") {
59
+ if (!a || !b) {
60
+ return false;
56
61
  }
57
- return false;
62
+ if (a.constructor !== b.constructor) {
63
+ return false;
64
+ }
65
+ if (!contains && Object.keys(a).length !== Object.keys(b).length) {
66
+ return false;
67
+ }
68
+ if (a instanceof Node) {
69
+ return a.isEqualNode(b);
70
+ }
71
+ if (a instanceof Date) {
72
+ return a.valueOf() === b.valueOf();
73
+ }
74
+ for (var i in a) {
75
+ if (!fnEqual(a[i], b[i], maxDepth, contains, depth + 1)) {
76
+ return false;
77
+ }
78
+ }
79
+ return true;
80
+ }
81
+ return false;
58
82
  };
59
83
  export default fnEqual;
@@ -1,10 +1,61 @@
1
- import _merge from './_merge.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 _merge from "./_merge.js";
7
+ /**
8
+ * Performs object extension by merging source objects into a target object. Generates a shallow copy.
9
+ *
10
+ * If during merging a key in the target object exists it is overwritten with the source object's value.
11
+ * Usage is the same as <code>jQuery.extend(...)</code>.
12
+ * Values that are <code>undefined</code> are ignored.
13
+ *
14
+ * As alternative you may also use <code>Object.assign</code>, but note that <code>Object.assign</code>
15
+ * only copies enumerable and own properties and doesn't copy properties on the prototype and non-enumerable
16
+ * properties. Also, values that are <code>undefined</code> are NOT ignored.
17
+ *
18
+ * For deep copies, you may use {@link module:sap/base/util/deepExtend sap/base/util/deepExtend}.
19
+ *
20
+ * @example
21
+ * var oResult = extend({}, {
22
+ * prop1: {
23
+ * prop1a: "1a"
24
+ * }
25
+ * }, {
26
+ * prop2: {
27
+ * prop2a: "2a"
28
+ * }
29
+ * }, {
30
+ * prop1: {
31
+ * prop1b: "1b"
32
+ * }
33
+ * }, {
34
+ * prop2: undefined
35
+ * });
36
+ *
37
+ *
38
+ * console.log(oResult);
39
+ * {
40
+ * "prop1": {
41
+ * "prop1b": "1b"
42
+ * },
43
+ * "prop2": {
44
+ * "prop2a": "2a"
45
+ * }
46
+ * }
47
+ *
48
+ * @function
49
+ * @alias module:sap/base/util/extend
50
+ * @param {object} target The object that will receive new properties
51
+ * @param {...object} [source] One or more objects which get merged into the target object
52
+ * @return {object} the target object which is the result of the merge
53
+ * @public
54
+ * @since 1.71
55
+ */
2
56
  var fnExtend = function () {
3
- var args = [
4
- false,
5
- true
6
- ];
7
- args.push.apply(args, arguments);
8
- return _merge.apply(null, args);
57
+ var args = [false, true];
58
+ args.push.apply(args, arguments);
59
+ return _merge.apply(null, args);
9
60
  };
10
61
  export default fnExtend;
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Validates if the given object is empty, that is that it has no enumerable properties.
3
+ *
4
+ * Note that <code>null</code> and <code>undefined</code> comply with this definition of 'empty'.
5
+ * The behavior for non-object values is undefined and might change in future.
6
+ *
7
+ * @example
8
+ * sap.ui.require(["sap/base/util/isEmptyObject"], function(isEmptyObject){
9
+ * isEmptyObject({}); // true
10
+ * isEmptyObject({test: '123'}); // false
11
+ * isEmptyObject(null); // true
12
+ * isEmptyObject(undefined); // true
13
+ * });
14
+ *
15
+ * @function
16
+ * @since 1.65
17
+ * @public
18
+ * @name module:sap/base/util/isEmptyObject
19
+ * @param {Object} obj the object which is checked
20
+ * @returns {boolean} whether or not the given object is empty
21
+ */ /*!
22
+ * OpenUI5
23
+ * (c) Copyright 2009-2024 SAP SE or an SAP affiliate company.
24
+ * Licensed under the Apache License, Version 2.0 - see LICENSE.txt.
25
+ */
26
+
27
+ var fnIsEmptyObject = function isEmptyObject(obj) {
28
+ // eslint-disable-next-line no-unreachable-loop
29
+ for (var sName in obj) {
30
+ return false;
31
+ }
32
+ return true;
33
+ };
34
+ export default fnIsEmptyObject;