@ui5/webcomponents-localization 0.0.0-f651a470c → 0.0.0-f6676abdd

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 (188) hide show
  1. package/.eslintignore +2 -1
  2. package/CHANGELOG.md +1256 -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 +2 -3
  14. package/dist/dates/CalendarDate.js.map +1 -1
  15. package/dist/dates/ExtremeDates.d.ts +3 -3
  16. package/dist/dates/ExtremeDates.js.map +1 -1
  17. package/dist/dates/UI5Date.d.ts +0 -1
  18. package/dist/dates/UniversalDate.d.ts +1 -1
  19. package/dist/dates/UniversalDate.js.map +1 -1
  20. package/dist/dates/convertMonthNumbersToMonthNames.d.ts +1 -1
  21. package/dist/dates/convertMonthNumbersToMonthNames.js.map +1 -1
  22. package/dist/dates/getRoundedTimestamp.js.map +1 -1
  23. package/dist/dates/getTodayUTCTimestamp.d.ts +1 -1
  24. package/dist/dates/getTodayUTCTimestamp.js.map +1 -1
  25. package/dist/dates/modifyDateBy.d.ts +2 -1
  26. package/dist/dates/modifyDateBy.js +34 -19
  27. package/dist/dates/modifyDateBy.js.map +1 -1
  28. package/dist/dates/transformDateToSecondaryType.d.ts +1 -1
  29. package/dist/dates/transformDateToSecondaryType.js.map +1 -1
  30. package/dist/generated/assets/cldr/Unicode-Data-Files-LICENSE.txt +27 -0
  31. package/dist/generated/assets/cldr/ar.json +7085 -2816
  32. package/dist/generated/assets/cldr/ar_EG.json +7085 -2816
  33. package/dist/generated/assets/cldr/ar_SA.json +7084 -2815
  34. package/dist/generated/assets/cldr/bg.json +5979 -2733
  35. package/dist/generated/assets/cldr/ca.json +6081 -2680
  36. package/dist/generated/assets/cldr/cnr.json +6169 -0
  37. package/dist/generated/assets/cldr/cs.json +6707 -2716
  38. package/dist/generated/assets/cldr/cy.json +6930 -2797
  39. package/dist/generated/assets/cldr/da.json +5925 -2597
  40. package/dist/generated/assets/cldr/de.json +6046 -2614
  41. package/dist/generated/assets/cldr/de_AT.json +6047 -2614
  42. package/dist/generated/assets/cldr/de_CH.json +6045 -2614
  43. package/dist/generated/assets/cldr/el.json +5830 -2595
  44. package/dist/generated/assets/cldr/el_CY.json +5830 -2595
  45. package/dist/generated/assets/cldr/en.json +6042 -2583
  46. package/dist/generated/assets/cldr/en_AU.json +6082 -2592
  47. package/dist/generated/assets/cldr/en_GB.json +6073 -2584
  48. package/dist/generated/assets/cldr/en_HK.json +6082 -2593
  49. package/dist/generated/assets/cldr/en_IE.json +6073 -2584
  50. package/dist/generated/assets/cldr/en_IN.json +6078 -2588
  51. package/dist/generated/assets/cldr/en_NZ.json +6073 -2584
  52. package/dist/generated/assets/cldr/en_PG.json +6074 -2584
  53. package/dist/generated/assets/cldr/en_SG.json +6078 -2588
  54. package/dist/generated/assets/cldr/en_ZA.json +6074 -2584
  55. package/dist/generated/assets/cldr/es.json +6101 -2640
  56. package/dist/generated/assets/cldr/es_AR.json +6104 -2645
  57. package/dist/generated/assets/cldr/es_BO.json +6103 -2645
  58. package/dist/generated/assets/cldr/es_CL.json +5996 -2645
  59. package/dist/generated/assets/cldr/es_CO.json +5996 -2644
  60. package/dist/generated/assets/cldr/es_MX.json +6105 -2645
  61. package/dist/generated/assets/cldr/es_PE.json +5887 -2645
  62. package/dist/generated/assets/cldr/es_UY.json +5889 -2645
  63. package/dist/generated/assets/cldr/es_VE.json +5888 -2645
  64. package/dist/generated/assets/cldr/et.json +6025 -2599
  65. package/dist/generated/assets/cldr/fa.json +5948 -2618
  66. package/dist/generated/assets/cldr/fi.json +6193 -2726
  67. package/dist/generated/assets/cldr/fr.json +5995 -2590
  68. package/dist/generated/assets/cldr/fr_BE.json +5995 -2590
  69. package/dist/generated/assets/cldr/fr_CA.json +5989 -2605
  70. package/dist/generated/assets/cldr/fr_CH.json +6013 -2607
  71. package/dist/generated/assets/cldr/fr_LU.json +5995 -2590
  72. package/dist/generated/assets/cldr/he.json +6539 -2711
  73. package/dist/generated/assets/cldr/hi.json +5857 -2602
  74. package/dist/generated/assets/cldr/hr.json +6194 -2652
  75. package/dist/generated/assets/cldr/hu.json +5943 -2598
  76. package/dist/generated/assets/cldr/id.json +5728 -2544
  77. package/dist/generated/assets/cldr/it.json +5984 -2590
  78. package/dist/generated/assets/cldr/it_CH.json +5984 -2590
  79. package/dist/generated/assets/cldr/ja.json +5887 -2663
  80. package/dist/generated/assets/cldr/kk.json +5937 -2589
  81. package/dist/generated/assets/cldr/ko.json +5768 -2641
  82. package/dist/generated/assets/cldr/lt.json +6576 -2720
  83. package/dist/generated/assets/cldr/lv.json +6112 -2644
  84. package/dist/generated/assets/cldr/mk.json +6045 -0
  85. package/dist/generated/assets/cldr/ms.json +5562 -2538
  86. package/dist/generated/assets/cldr/nb.json +6033 -2621
  87. package/dist/generated/assets/cldr/nl.json +6200 -2601
  88. package/dist/generated/assets/cldr/nl_BE.json +6200 -2601
  89. package/dist/generated/assets/cldr/pl.json +6587 -2723
  90. package/dist/generated/assets/cldr/pt.json +6113 -2607
  91. package/dist/generated/assets/cldr/pt_PT.json +6178 -2658
  92. package/dist/generated/assets/cldr/ro.json +6198 -2645
  93. package/dist/generated/assets/cldr/ru.json +6501 -2704
  94. package/dist/generated/assets/cldr/ru_UA.json +6501 -2704
  95. package/dist/generated/assets/cldr/sk.json +6430 -2726
  96. package/dist/generated/assets/cldr/sl.json +6442 -2688
  97. package/dist/generated/assets/cldr/sr.json +6239 -2663
  98. package/dist/generated/assets/cldr/sr_Latn.json +6224 -2666
  99. package/dist/generated/assets/cldr/sv.json +6074 -2631
  100. package/dist/generated/assets/cldr/th.json +5873 -2635
  101. package/dist/generated/assets/cldr/tr.json +6092 -2612
  102. package/dist/generated/assets/cldr/uk.json +6452 -2684
  103. package/dist/generated/assets/cldr/vi.json +5667 -2555
  104. package/dist/generated/assets/cldr/zh_CN.json +5715 -2555
  105. package/dist/generated/assets/cldr/zh_HK.json +5724 -2563
  106. package/dist/generated/assets/cldr/zh_SG.json +5724 -2562
  107. package/dist/generated/assets/cldr/zh_TW.json +5791 -2587
  108. package/dist/generated/json-imports/LocaleData-fetch.d.ts +1 -0
  109. package/dist/generated/json-imports/LocaleData-fetch.js +93 -0
  110. package/dist/generated/json-imports/LocaleData-fetch.js.map +1 -0
  111. package/dist/generated/json-imports/LocaleData.d.ts +1 -0
  112. package/dist/generated/json-imports/LocaleData.js +89 -89
  113. package/dist/generated/json-imports/LocaleData.js.map +1 -0
  114. package/dist/getCachedLocaleDataInstance.js.map +1 -1
  115. package/dist/locale/getLocaleData.js.map +1 -1
  116. package/dist/sap/base/Event.js +59 -0
  117. package/dist/sap/base/Eventing.js +146 -0
  118. package/dist/sap/base/Log.js +2 -239
  119. package/dist/sap/base/assert.js +28 -1
  120. package/dist/sap/base/config/MemoryConfigurationProvider.js +20 -0
  121. package/dist/sap/base/config.js +17 -0
  122. package/dist/sap/base/i18n/Formatting.d.ts +8 -0
  123. package/dist/sap/base/i18n/Formatting.js +11 -0
  124. package/dist/sap/base/i18n/Formatting.js.map +1 -0
  125. package/dist/sap/base/i18n/LanguageTag.js +173 -0
  126. package/dist/sap/base/i18n/Localization.d.ts +4 -0
  127. package/dist/sap/base/i18n/Localization.js +12 -0
  128. package/dist/sap/base/i18n/Localization.js.map +1 -0
  129. package/dist/sap/base/i18n/date/CalendarType.js +43 -0
  130. package/dist/sap/base/i18n/date/CalendarWeekNumbering.js +105 -0
  131. package/dist/sap/base/i18n/date/TimezoneUtils.js +319 -0
  132. package/dist/sap/base/strings/camelize.js +30 -0
  133. package/dist/sap/base/strings/formatMessage.js +88 -15
  134. package/dist/sap/base/util/LoaderExtensions.js.map +1 -1
  135. package/dist/sap/base/util/ObjectPath.d.ts +4 -0
  136. package/dist/sap/base/util/ObjectPath.js +4 -33
  137. package/dist/sap/base/util/ObjectPath.js.map +1 -0
  138. package/dist/sap/base/util/Version.js +157 -0
  139. package/dist/sap/base/util/_merge.js +83 -26
  140. package/dist/sap/base/util/array/uniqueSort.js +37 -15
  141. package/dist/sap/base/util/deepClone.js +102 -0
  142. package/dist/sap/base/util/deepEqual.js +75 -51
  143. package/dist/sap/base/util/extend.js +58 -7
  144. package/dist/sap/base/util/isEmptyObject.js +34 -0
  145. package/dist/sap/base/util/isPlainObject.js +35 -1
  146. package/dist/sap/base/util/now.js +24 -3
  147. package/dist/sap/base/util/resolveReference.js +3 -0
  148. package/dist/sap/base/util/uid.js +27 -0
  149. package/dist/sap/ui/base/DataType.js +657 -0
  150. package/dist/sap/ui/base/Interface.js +47 -1
  151. package/dist/sap/ui/base/Metadata.js +435 -171
  152. package/dist/sap/ui/base/Object.js +284 -48
  153. package/dist/sap/ui/core/CalendarType.js +24 -8
  154. package/dist/sap/ui/core/Configuration.d.ts +2 -2
  155. package/dist/sap/ui/core/Configuration.js +2 -0
  156. package/dist/sap/ui/core/Configuration.js.map +1 -1
  157. package/dist/sap/ui/core/Core.d.ts +3 -4
  158. package/dist/sap/ui/core/FormatSettings.d.ts +1 -2
  159. package/dist/sap/ui/core/FormatSettings.js +0 -2
  160. package/dist/sap/ui/core/FormatSettings.js.map +1 -1
  161. package/dist/sap/ui/core/Locale.js +190 -155
  162. package/dist/sap/ui/core/LocaleData.js +2659 -1351
  163. package/dist/sap/ui/core/Supportability.js +5 -0
  164. package/dist/sap/ui/core/Theming.js +539 -0
  165. package/dist/sap/ui/core/date/Buddhist.js +162 -87
  166. package/dist/sap/ui/core/date/CalendarUtils.js +61 -32
  167. package/dist/sap/ui/core/date/CalendarWeekNumbering.js +30 -7
  168. package/dist/sap/ui/core/date/Gregorian.js +25 -10
  169. package/dist/sap/ui/core/date/Islamic.js +298 -185
  170. package/dist/sap/ui/core/date/Japanese.js +210 -115
  171. package/dist/sap/ui/core/date/Persian.js +324 -195
  172. package/dist/sap/ui/core/date/UI5Date.js +923 -237
  173. package/dist/sap/ui/core/date/UniversalDate.js +1238 -256
  174. package/dist/sap/ui/core/date/_Calendars.js +10 -1
  175. package/dist/sap/ui/core/format/DateFormat.js +3171 -2111
  176. package/dist/sap/ui/core/format/TimezoneUtil.js +24 -89
  177. package/package-scripts.cjs +12 -21
  178. package/package.json +13 -7
  179. package/tsconfig.json +20 -10
  180. package/used-modules.txt +23 -1
  181. package/dist/Assets-static.d.ts +0 -1
  182. package/dist/Assets-static.js +0 -3
  183. package/dist/Assets-static.js.map +0 -1
  184. package/dist/dates/calculateWeekNumber.d.ts +0 -5
  185. package/dist/dates/calculateWeekNumber.js +0 -45
  186. package/dist/dates/calculateWeekNumber.js.map +0 -1
  187. package/dist/generated/json-imports/LocaleData-static.js +0 -90
  188. 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;