@angular-wave/angular.ts 0.0.1

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 (231) hide show
  1. package/.eslintignore +1 -0
  2. package/.eslintrc.cjs +29 -0
  3. package/.github/workflows/playwright.yml +27 -0
  4. package/CHANGELOG.md +17974 -0
  5. package/CODE_OF_CONDUCT.md +3 -0
  6. package/CONTRIBUTING.md +246 -0
  7. package/DEVELOPERS.md +488 -0
  8. package/LICENSE +22 -0
  9. package/Makefile +31 -0
  10. package/README.md +115 -0
  11. package/RELEASE.md +98 -0
  12. package/SECURITY.md +16 -0
  13. package/TRIAGING.md +135 -0
  14. package/css/angular.css +22 -0
  15. package/dist/angular-ts.cjs.js +36843 -0
  16. package/dist/angular-ts.esm.js +36841 -0
  17. package/dist/angular-ts.umd.js +36848 -0
  18. package/dist/build/angular-animate.js +4272 -0
  19. package/dist/build/angular-aria.js +426 -0
  20. package/dist/build/angular-message-format.js +1072 -0
  21. package/dist/build/angular-messages.js +829 -0
  22. package/dist/build/angular-mocks.js +3757 -0
  23. package/dist/build/angular-parse-ext.js +1275 -0
  24. package/dist/build/angular-resource.js +911 -0
  25. package/dist/build/angular-route.js +1266 -0
  26. package/dist/build/angular-sanitize.js +891 -0
  27. package/dist/build/angular-touch.js +368 -0
  28. package/dist/build/angular.js +36600 -0
  29. package/e2e/unit.spec.ts +15 -0
  30. package/images/android-chrome-192x192.png +0 -0
  31. package/images/android-chrome-512x512.png +0 -0
  32. package/images/apple-touch-icon.png +0 -0
  33. package/images/favicon-16x16.png +0 -0
  34. package/images/favicon-32x32.png +0 -0
  35. package/images/favicon.ico +0 -0
  36. package/images/site.webmanifest +1 -0
  37. package/index.html +104 -0
  38. package/package.json +47 -0
  39. package/playwright.config.ts +78 -0
  40. package/public/circle.html +1 -0
  41. package/public/my_child_directive.html +1 -0
  42. package/public/my_directive.html +1 -0
  43. package/public/my_other_directive.html +1 -0
  44. package/public/test.html +1 -0
  45. package/rollup.config.js +31 -0
  46. package/src/animations/animateCache.js +55 -0
  47. package/src/animations/animateChildrenDirective.js +105 -0
  48. package/src/animations/animateCss.js +1139 -0
  49. package/src/animations/animateCssDriver.js +291 -0
  50. package/src/animations/animateJs.js +367 -0
  51. package/src/animations/animateJsDriver.js +67 -0
  52. package/src/animations/animateQueue.js +851 -0
  53. package/src/animations/animation.js +506 -0
  54. package/src/animations/module.js +779 -0
  55. package/src/animations/ngAnimateSwap.js +119 -0
  56. package/src/animations/rafScheduler.js +50 -0
  57. package/src/animations/shared.js +378 -0
  58. package/src/constants.js +20 -0
  59. package/src/core/animate.js +845 -0
  60. package/src/core/animateCss.js +73 -0
  61. package/src/core/animateRunner.js +195 -0
  62. package/src/core/attributes.js +199 -0
  63. package/src/core/cache.js +45 -0
  64. package/src/core/compile.js +4727 -0
  65. package/src/core/controller.js +225 -0
  66. package/src/core/exceptionHandler.js +63 -0
  67. package/src/core/filter.js +146 -0
  68. package/src/core/interpolate.js +442 -0
  69. package/src/core/interval.js +188 -0
  70. package/src/core/intervalFactory.js +57 -0
  71. package/src/core/location.js +1086 -0
  72. package/src/core/parser/parse.js +2562 -0
  73. package/src/core/parser/parse.md +13 -0
  74. package/src/core/q.js +746 -0
  75. package/src/core/rootScope.js +1596 -0
  76. package/src/core/sanitizeUri.js +85 -0
  77. package/src/core/sce.js +1161 -0
  78. package/src/core/taskTrackerFactory.js +125 -0
  79. package/src/core/timeout.js +121 -0
  80. package/src/core/urlUtils.js +187 -0
  81. package/src/core/utils.js +1349 -0
  82. package/src/directive/a.js +37 -0
  83. package/src/directive/attrs.js +283 -0
  84. package/src/directive/bind.js +51 -0
  85. package/src/directive/bind.md +142 -0
  86. package/src/directive/change.js +12 -0
  87. package/src/directive/change.md +25 -0
  88. package/src/directive/cloak.js +12 -0
  89. package/src/directive/cloak.md +24 -0
  90. package/src/directive/events.js +75 -0
  91. package/src/directive/events.md +166 -0
  92. package/src/directive/form.js +725 -0
  93. package/src/directive/init.js +15 -0
  94. package/src/directive/init.md +41 -0
  95. package/src/directive/input.js +1783 -0
  96. package/src/directive/list.js +46 -0
  97. package/src/directive/list.md +22 -0
  98. package/src/directive/ngClass.js +249 -0
  99. package/src/directive/ngController.js +64 -0
  100. package/src/directive/ngCsp.js +82 -0
  101. package/src/directive/ngIf.js +134 -0
  102. package/src/directive/ngInclude.js +217 -0
  103. package/src/directive/ngModel.js +1356 -0
  104. package/src/directive/ngModelOptions.js +509 -0
  105. package/src/directive/ngOptions.js +670 -0
  106. package/src/directive/ngRef.js +90 -0
  107. package/src/directive/ngRepeat.js +650 -0
  108. package/src/directive/ngShowHide.js +255 -0
  109. package/src/directive/ngSwitch.js +178 -0
  110. package/src/directive/ngTransclude.js +98 -0
  111. package/src/directive/non-bindable.js +11 -0
  112. package/src/directive/non-bindable.md +17 -0
  113. package/src/directive/script.js +30 -0
  114. package/src/directive/select.js +624 -0
  115. package/src/directive/style.js +25 -0
  116. package/src/directive/style.md +23 -0
  117. package/src/directive/validators.js +329 -0
  118. package/src/exts/aria.js +544 -0
  119. package/src/exts/messages.js +852 -0
  120. package/src/filters/filter.js +207 -0
  121. package/src/filters/filter.md +69 -0
  122. package/src/filters/filters.js +239 -0
  123. package/src/filters/json.md +16 -0
  124. package/src/filters/limit-to.js +43 -0
  125. package/src/filters/limit-to.md +19 -0
  126. package/src/filters/order-by.js +183 -0
  127. package/src/filters/order-by.md +83 -0
  128. package/src/index.js +13 -0
  129. package/src/injector.js +1034 -0
  130. package/src/jqLite.js +1117 -0
  131. package/src/loader.js +1320 -0
  132. package/src/public.js +215 -0
  133. package/src/routeToRegExp.js +41 -0
  134. package/src/services/anchorScroll.js +135 -0
  135. package/src/services/browser.js +321 -0
  136. package/src/services/cacheFactory.js +398 -0
  137. package/src/services/cookieReader.js +72 -0
  138. package/src/services/document.js +64 -0
  139. package/src/services/http.js +1537 -0
  140. package/src/services/httpBackend.js +206 -0
  141. package/src/services/log.js +160 -0
  142. package/src/services/templateRequest.js +139 -0
  143. package/test/angular.spec.js +2153 -0
  144. package/test/aria/aria.spec.js +1245 -0
  145. package/test/binding.spec.js +504 -0
  146. package/test/build-test.html +14 -0
  147. package/test/injector.spec.js +2327 -0
  148. package/test/jasmine/jasmine-5.1.2/boot0.js +65 -0
  149. package/test/jasmine/jasmine-5.1.2/boot1.js +133 -0
  150. package/test/jasmine/jasmine-5.1.2/jasmine-html.js +963 -0
  151. package/test/jasmine/jasmine-5.1.2/jasmine.css +320 -0
  152. package/test/jasmine/jasmine-5.1.2/jasmine.js +10824 -0
  153. package/test/jasmine/jasmine-5.1.2/jasmine_favicon.png +0 -0
  154. package/test/jasmine/jasmine-browser.json +17 -0
  155. package/test/jasmine/jasmine.json +9 -0
  156. package/test/jqlite.spec.js +2133 -0
  157. package/test/loader.spec.js +219 -0
  158. package/test/messages/messages.spec.js +1146 -0
  159. package/test/min-err.spec.js +174 -0
  160. package/test/mock-test.html +13 -0
  161. package/test/module-test.html +15 -0
  162. package/test/ng/anomate.spec.js +606 -0
  163. package/test/ng/cache-factor.spec.js +334 -0
  164. package/test/ng/compile.spec.js +17956 -0
  165. package/test/ng/controller-provider.spec.js +227 -0
  166. package/test/ng/cookie-reader.spec.js +98 -0
  167. package/test/ng/directive/a.spec.js +192 -0
  168. package/test/ng/directive/bind.spec.js +334 -0
  169. package/test/ng/directive/boolean.spec.js +136 -0
  170. package/test/ng/directive/change.spec.js +71 -0
  171. package/test/ng/directive/class.spec.js +858 -0
  172. package/test/ng/directive/click.spec.js +38 -0
  173. package/test/ng/directive/cloak.spec.js +44 -0
  174. package/test/ng/directive/constoller.spec.js +194 -0
  175. package/test/ng/directive/element-style.spec.js +92 -0
  176. package/test/ng/directive/event.spec.js +282 -0
  177. package/test/ng/directive/form.spec.js +1518 -0
  178. package/test/ng/directive/href.spec.js +143 -0
  179. package/test/ng/directive/if.spec.js +402 -0
  180. package/test/ng/directive/include.spec.js +828 -0
  181. package/test/ng/directive/init.spec.js +68 -0
  182. package/test/ng/directive/input.spec.js +3810 -0
  183. package/test/ng/directive/list.spec.js +170 -0
  184. package/test/ng/directive/model-options.spec.js +1008 -0
  185. package/test/ng/directive/model.spec.js +1905 -0
  186. package/test/ng/directive/non-bindable.spec.js +55 -0
  187. package/test/ng/directive/options.spec.js +3583 -0
  188. package/test/ng/directive/ref.spec.js +575 -0
  189. package/test/ng/directive/repeat.spec.js +1675 -0
  190. package/test/ng/directive/script.spec.js +52 -0
  191. package/test/ng/directive/scrset.spec.js +67 -0
  192. package/test/ng/directive/select.spec.js +2541 -0
  193. package/test/ng/directive/show-hide.spec.js +253 -0
  194. package/test/ng/directive/src.spec.js +157 -0
  195. package/test/ng/directive/style.spec.js +178 -0
  196. package/test/ng/directive/switch.spec.js +647 -0
  197. package/test/ng/directive/validators.spec.js +717 -0
  198. package/test/ng/document.spec.js +52 -0
  199. package/test/ng/filter/filter.spec.js +714 -0
  200. package/test/ng/filter/filters.spec.js +35 -0
  201. package/test/ng/filter/limit-to.spec.js +251 -0
  202. package/test/ng/filter/order-by.spec.js +891 -0
  203. package/test/ng/filter.spec.js +149 -0
  204. package/test/ng/http-backend.spec.js +398 -0
  205. package/test/ng/http.spec.js +4071 -0
  206. package/test/ng/interpolate.spec.js +642 -0
  207. package/test/ng/interval.spec.js +343 -0
  208. package/test/ng/location.spec.js +3488 -0
  209. package/test/ng/on.spec.js +229 -0
  210. package/test/ng/parse.spec.js +4655 -0
  211. package/test/ng/prop.spec.js +805 -0
  212. package/test/ng/q.spec.js +2904 -0
  213. package/test/ng/root-element.spec.js +16 -0
  214. package/test/ng/sanitize-uri.spec.js +249 -0
  215. package/test/ng/sce.spec.js +660 -0
  216. package/test/ng/scope.spec.js +3442 -0
  217. package/test/ng/template-request.spec.js +236 -0
  218. package/test/ng/timeout.spec.js +351 -0
  219. package/test/ng/url-utils.spec.js +156 -0
  220. package/test/ng/utils.spec.js +144 -0
  221. package/test/original-test.html +21 -0
  222. package/test/public.spec.js +34 -0
  223. package/test/sanitize/bing-html.spec.js +36 -0
  224. package/test/server/express.js +158 -0
  225. package/test/test-utils.js +11 -0
  226. package/tsconfig.json +17 -0
  227. package/types/angular.d.ts +138 -0
  228. package/types/global.d.ts +9 -0
  229. package/types/index.d.ts +2357 -0
  230. package/types/jqlite.d.ts +558 -0
  231. package/vite.config.js +14 -0
@@ -0,0 +1,35 @@
1
+ import { publishExternalAPI } from "../../../src/public";
2
+ import { createInjector } from "../../../src/injector";
3
+ import { toJson } from "../../../src/core/utils";
4
+
5
+ describe("filters", () => {
6
+ let filter;
7
+
8
+ beforeEach(() => {
9
+ publishExternalAPI();
10
+ var injector = createInjector(["ng"]);
11
+ filter = injector.get("$filter");
12
+ });
13
+
14
+ it("should call the filter when evaluating expression", () => {
15
+ const filter = jasmine.createSpy("myFilter");
16
+ createInjector([
17
+ "ng",
18
+ function ($filterProvider) {
19
+ $filterProvider.register("myFilter", () => filter);
20
+ },
21
+ ]).invoke(($rootScope) => {
22
+ $rootScope.$eval("10|myFilter");
23
+ });
24
+ expect(filter).toHaveBeenCalledWith(10);
25
+ });
26
+
27
+ describe("json", () => {
28
+ it("should do basic filter", () => {
29
+ expect(filter("json")({ a: "b" })).toEqual(toJson({ a: "b" }, true));
30
+ });
31
+ it("should allow custom indentation", () => {
32
+ expect(filter("json")({ a: "b" }, 4)).toEqual(toJson({ a: "b" }, 4));
33
+ });
34
+ });
35
+ });
@@ -0,0 +1,251 @@
1
+ import { publishExternalAPI } from "../../../src/public";
2
+ import { createInjector } from "../../../src/injector";
3
+ import { jqLite } from "../../../src/jqLite";
4
+
5
+ describe("Filter: limitTo", () => {
6
+ let items;
7
+ let str;
8
+ let number;
9
+ let arrayLike;
10
+ let limitTo;
11
+
12
+ beforeEach(() => {
13
+ publishExternalAPI();
14
+ var injector = createInjector(["ng"]);
15
+ var $filter = injector.get("$filter");
16
+
17
+ items = ["a", "b", "c", "d", "e", "f", "g", "h"];
18
+ str = "tuvwxyz";
19
+ number = 100.045;
20
+ arrayLike = {
21
+ 0: "a",
22
+ 1: "b",
23
+ 2: "c",
24
+ 3: "d",
25
+ 4: "e",
26
+ 5: "f",
27
+ 6: "g",
28
+ 7: "h",
29
+ get length() {
30
+ return Object.keys(this).length - 1;
31
+ },
32
+ };
33
+ limitTo = $filter("limitTo");
34
+ });
35
+
36
+ it("should return the first X items when X is positive", () => {
37
+ expect(limitTo(items, 3)).toEqual(["a", "b", "c"]);
38
+ expect(limitTo(items, "3")).toEqual(["a", "b", "c"]);
39
+ expect(limitTo(str, 3)).toEqual("tuv");
40
+ expect(limitTo(str, "3")).toEqual("tuv");
41
+ expect(limitTo(number, 3)).toEqual("100");
42
+ expect(limitTo(number, "3")).toEqual("100");
43
+ expect(limitTo(arrayLike, 3)).toEqual(["a", "b", "c"]);
44
+ expect(limitTo(arrayLike, "3")).toEqual(["a", "b", "c"]);
45
+ });
46
+
47
+ it("should return the first X items beginning from index Y when X and Y are positive", () => {
48
+ expect(limitTo(items, 3, "3")).toEqual(["d", "e", "f"]);
49
+ expect(limitTo(items, "3", 3)).toEqual(["d", "e", "f"]);
50
+ expect(limitTo(str, 3, 3)).toEqual("wxy");
51
+ expect(limitTo(str, "3", "3")).toEqual("wxy");
52
+ expect(limitTo(arrayLike, 3, 3)).toEqual(["d", "e", "f"]);
53
+ expect(limitTo(arrayLike, "3", "3")).toEqual(["d", "e", "f"]);
54
+ });
55
+
56
+ it("should return the first X items beginning from index Y when X is positive and Y is negative", () => {
57
+ expect(limitTo(items, 3, "-3")).toEqual(["f", "g", "h"]);
58
+ expect(limitTo(items, "3", -3)).toEqual(["f", "g", "h"]);
59
+ expect(limitTo(str, 3, -3)).toEqual("xyz");
60
+ expect(limitTo(str, "3", "-3")).toEqual("xyz");
61
+ expect(limitTo(arrayLike, 3, "-3")).toEqual(["f", "g", "h"]);
62
+ expect(limitTo(arrayLike, "3", -3)).toEqual(["f", "g", "h"]);
63
+ });
64
+
65
+ it("should return the last X items when X is negative", () => {
66
+ expect(limitTo(items, -3)).toEqual(["f", "g", "h"]);
67
+ expect(limitTo(items, "-3")).toEqual(["f", "g", "h"]);
68
+ expect(limitTo(str, -3)).toEqual("xyz");
69
+ expect(limitTo(str, "-3")).toEqual("xyz");
70
+ expect(limitTo(number, -3)).toEqual("045");
71
+ expect(limitTo(number, "-3")).toEqual("045");
72
+ expect(limitTo(arrayLike, -3)).toEqual(["f", "g", "h"]);
73
+ expect(limitTo(arrayLike, "-3")).toEqual(["f", "g", "h"]);
74
+ });
75
+
76
+ it("should return the last X items until index Y when X and Y are negative", () => {
77
+ expect(limitTo(items, -3, "-3")).toEqual(["c", "d", "e"]);
78
+ expect(limitTo(items, "-3", -3)).toEqual(["c", "d", "e"]);
79
+ expect(limitTo(str, -3, -3)).toEqual("uvw");
80
+ expect(limitTo(str, "-3", "-3")).toEqual("uvw");
81
+ expect(limitTo(arrayLike, -3, "-3")).toEqual(["c", "d", "e"]);
82
+ expect(limitTo(arrayLike, "-3", -3)).toEqual(["c", "d", "e"]);
83
+ });
84
+
85
+ it("should return the last X items until index Y when X is negative and Y is positive", () => {
86
+ expect(limitTo(items, -3, "4")).toEqual(["b", "c", "d"]);
87
+ expect(limitTo(items, "-3", 4)).toEqual(["b", "c", "d"]);
88
+ expect(limitTo(str, -3, 4)).toEqual("uvw");
89
+ expect(limitTo(str, "-3", "4")).toEqual("uvw");
90
+ expect(limitTo(arrayLike, -3, "4")).toEqual(["b", "c", "d"]);
91
+ expect(limitTo(arrayLike, "-3", 4)).toEqual(["b", "c", "d"]);
92
+ });
93
+
94
+ it("should return an empty array when X = 0", () => {
95
+ expect(limitTo(items, 0)).toEqual([]);
96
+ expect(limitTo(items, "0")).toEqual([]);
97
+ expect(limitTo(arrayLike, 0)).toEqual([]);
98
+ expect(limitTo(arrayLike, "0")).toEqual([]);
99
+ });
100
+
101
+ it("should return entire array when X cannot be parsed", () => {
102
+ expect(limitTo(items, "bogus")).toBe(items);
103
+ expect(limitTo(items, "null")).toBe(items);
104
+ expect(limitTo(items, "undefined")).toBe(items);
105
+ expect(limitTo(items, null)).toBe(items);
106
+ expect(limitTo(items, undefined)).toBe(items);
107
+ expect(limitTo(arrayLike, "bogus")).toBe(arrayLike);
108
+ expect(limitTo(arrayLike, "null")).toBe(arrayLike);
109
+ expect(limitTo(arrayLike, "undefined")).toBe(arrayLike);
110
+ expect(limitTo(arrayLike, null)).toBe(arrayLike);
111
+ expect(limitTo(arrayLike, undefined)).toBe(arrayLike);
112
+ });
113
+
114
+ it("should return an empty string when X = 0", () => {
115
+ expect(limitTo(str, 0)).toEqual("");
116
+ expect(limitTo(str, "0")).toEqual("");
117
+ });
118
+
119
+ it("should return entire string when X cannot be parsed", () => {
120
+ expect(limitTo(str, "bogus")).toEqual(str);
121
+ expect(limitTo(str, "null")).toEqual(str);
122
+ expect(limitTo(str, "undefined")).toEqual(str);
123
+ expect(limitTo(str, null)).toEqual(str);
124
+ expect(limitTo(str, undefined)).toEqual(str);
125
+ });
126
+
127
+ it("should take 0 as beginning index value when Y cannot be parsed", () => {
128
+ expect(limitTo(items, 3, "bogus")).toEqual(limitTo(items, 3, 0));
129
+ expect(limitTo(items, -3, "null")).toEqual(limitTo(items, -3));
130
+ expect(limitTo(items, "3", "undefined")).toEqual(limitTo(items, "3", 0));
131
+ expect(limitTo(items, "-3", null)).toEqual(limitTo(items, "-3"));
132
+ expect(limitTo(items, 3, undefined)).toEqual(limitTo(items, 3, 0));
133
+ expect(limitTo(str, 3, "bogus")).toEqual(limitTo(str, 3));
134
+ expect(limitTo(str, -3, "null")).toEqual(limitTo(str, -3, 0));
135
+ expect(limitTo(str, "3", "undefined")).toEqual(limitTo(str, "3"));
136
+ expect(limitTo(str, "-3", null)).toEqual(limitTo(str, "-3", 0));
137
+ expect(limitTo(str, 3, undefined)).toEqual(limitTo(str, 3));
138
+ expect(limitTo(arrayLike, 3, "bogus")).toEqual(limitTo(arrayLike, 3, 0));
139
+ expect(limitTo(arrayLike, -3, "null")).toEqual(limitTo(arrayLike, -3));
140
+ expect(limitTo(arrayLike, "3", "undefined")).toEqual(
141
+ limitTo(arrayLike, "3", 0),
142
+ );
143
+ expect(limitTo(arrayLike, "-3", null)).toEqual(limitTo(arrayLike, "-3"));
144
+ expect(limitTo(arrayLike, 3, undefined)).toEqual(limitTo(arrayLike, 3, 0));
145
+ });
146
+
147
+ it("should return input if not array-like or Number", () => {
148
+ expect(limitTo(null, 1)).toEqual(null);
149
+ expect(limitTo(undefined, 1)).toEqual(undefined);
150
+ expect(limitTo({}, 1)).toEqual({});
151
+ });
152
+
153
+ it("should return a copy of input array if X is exceeds array length", () => {
154
+ expect(limitTo(items, 9)).toEqual(items);
155
+ expect(limitTo(items, "9")).toEqual(items);
156
+ expect(limitTo(items, -9)).toEqual(items);
157
+ expect(limitTo(items, "-9")).toEqual(items);
158
+ expect(limitTo(arrayLike, 9)).toEqual(items);
159
+ expect(limitTo(arrayLike, "9")).toEqual(items);
160
+ expect(limitTo(arrayLike, -9)).toEqual(items);
161
+ expect(limitTo(arrayLike, "-9")).toEqual(items);
162
+
163
+ expect(limitTo(items, 9)).not.toBe(items);
164
+ expect(limitTo(arrayLike, 9)).not.toBe(arrayLike);
165
+ });
166
+
167
+ it("should return the entire string if X exceeds input length", () => {
168
+ expect(limitTo(str, 9)).toEqual(str);
169
+ expect(limitTo(str, "9")).toEqual(str);
170
+ expect(limitTo(str, -9)).toEqual(str);
171
+ expect(limitTo(str, "-9")).toEqual(str);
172
+ expect(limitTo(number, 9)).toEqual(number.toString());
173
+ expect(limitTo(number, "-9")).toEqual(number.toString());
174
+ });
175
+
176
+ it("should return entire input array when limited by Infinity", () => {
177
+ expect(limitTo(items, Infinity)).toEqual(items);
178
+ expect(limitTo(items, "Infinity")).toEqual(items);
179
+ expect(limitTo(items, -Infinity)).toEqual(items);
180
+ expect(limitTo(items, "-Infinity")).toEqual(items);
181
+ expect(limitTo(arrayLike, Infinity)).toEqual(items);
182
+ expect(limitTo(arrayLike, "Infinity")).toEqual(items);
183
+ expect(limitTo(arrayLike, -Infinity)).toEqual(items);
184
+ expect(limitTo(arrayLike, "-Infinity")).toEqual(items);
185
+ });
186
+
187
+ it("should return the entire string when limited by Infinity", () => {
188
+ expect(limitTo(str, Infinity)).toEqual(str);
189
+ expect(limitTo(str, "Infinity")).toEqual(str);
190
+ expect(limitTo(str, -Infinity)).toEqual(str);
191
+ expect(limitTo(str, "-Infinity")).toEqual(str);
192
+ });
193
+
194
+ it("should return an empty array if Y exceeds input length", () => {
195
+ expect(limitTo(items, "3", 12)).toEqual([]);
196
+ expect(limitTo(items, -3, "12")).toEqual([]);
197
+ expect(limitTo(arrayLike, "3", 12)).toEqual([]);
198
+ expect(limitTo(arrayLike, -3, "12")).toEqual([]);
199
+ });
200
+
201
+ it("should return an empty string if Y exceeds input length", () => {
202
+ expect(limitTo(str, "3", 12)).toEqual("");
203
+ expect(limitTo(str, -3, "12")).toEqual("");
204
+ });
205
+
206
+ it("should start at 0 if Y is negative and exceeds input length", () => {
207
+ expect(limitTo(items, 4, "-12")).toEqual(["a", "b", "c", "d"]);
208
+ expect(limitTo(items, "-4", -12)).toEqual(["e", "f", "g", "h"]);
209
+ expect(limitTo(str, 4, "-12")).toEqual("tuvw");
210
+ expect(limitTo(str, "-4", -12)).toEqual("wxyz");
211
+ expect(limitTo(arrayLike, 4, "-12")).toEqual(["a", "b", "c", "d"]);
212
+ expect(limitTo(arrayLike, "-4", -12)).toEqual(["e", "f", "g", "h"]);
213
+ });
214
+
215
+ it("should return the entire string beginning from Y if X is positive and X+Y exceeds input length", () => {
216
+ expect(limitTo(items, 7, 3)).toEqual(["d", "e", "f", "g", "h"]);
217
+ expect(limitTo(items, 7, -3)).toEqual(["f", "g", "h"]);
218
+ expect(limitTo(str, 6, 3)).toEqual("wxyz");
219
+ expect(limitTo(str, 6, -3)).toEqual("xyz");
220
+ expect(limitTo(arrayLike, 7, 3)).toEqual(["d", "e", "f", "g", "h"]);
221
+ expect(limitTo(arrayLike, 7, -3)).toEqual(["f", "g", "h"]);
222
+ });
223
+
224
+ it("should return the entire string until index Y if X is negative and X+Y exceeds input length", () => {
225
+ expect(limitTo(items, -7, 3)).toEqual(["a", "b", "c"]);
226
+ expect(limitTo(items, -7, -3)).toEqual(["a", "b", "c", "d", "e"]);
227
+ expect(limitTo(str, -6, 3)).toEqual("tuv");
228
+ expect(limitTo(str, -6, -3)).toEqual("tuvw");
229
+ expect(limitTo(arrayLike, -7, 3)).toEqual(["a", "b", "c"]);
230
+ expect(limitTo(arrayLike, -7, -3)).toEqual(["a", "b", "c", "d", "e"]);
231
+ });
232
+
233
+ it("should not throw an error if used with an array like object", () => {
234
+ function getArguments() {
235
+ return arguments;
236
+ }
237
+ const argsObj = getArguments(
238
+ { name: "Misko" },
239
+ { name: "Igor" },
240
+ { name: "Brad" },
241
+ );
242
+
243
+ const nodeList = jqLite(
244
+ "<p><span>Misko</span><span>Igor</span><span>Brad</span></p>",
245
+ )[0].childNodes;
246
+
247
+ expect(limitTo(argsObj, 2).length).toBe(2);
248
+ expect(limitTo("abc", 1).length).toBe(1);
249
+ expect(limitTo(nodeList, 2).length).toBe(2);
250
+ });
251
+ });