@tim-code/my-util 0.4.6 → 0.4.8
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.
- package/package.json +1 -1
- package/src/math.js +9 -0
- package/src/math.test.js +34 -1
- package/src/time.js +11 -0
- package/src/time.test.js +29 -0
package/package.json
CHANGED
package/src/math.js
CHANGED
|
@@ -141,3 +141,12 @@ export function range(start, end, increment = 1) {
|
|
|
141
141
|
}
|
|
142
142
|
return results
|
|
143
143
|
}
|
|
144
|
+
|
|
145
|
+
/**
|
|
146
|
+
* Check if the argument is a number (typeof is "number" and not NaN).
|
|
147
|
+
* @param {any} number
|
|
148
|
+
* @returns {boolean}
|
|
149
|
+
*/
|
|
150
|
+
export function isNumber(number) {
|
|
151
|
+
return typeof number === "number" && !isNaN(number)
|
|
152
|
+
}
|
package/src/math.test.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { describe, expect, it } from "@jest/globals"
|
|
2
|
-
const { mod, formatPlus, line, sum, average, variance, range } = await import(
|
|
2
|
+
const { mod, formatPlus, line, sum, average, variance, range, isNumber } = await import(
|
|
3
|
+
"./math.js"
|
|
4
|
+
)
|
|
3
5
|
|
|
4
6
|
describe("mod", () => {
|
|
5
7
|
it("returns n when n is less than m and n is non-negative", () => {
|
|
@@ -299,3 +301,34 @@ describe("range", () => {
|
|
|
299
301
|
expect(range(0, 1, 0.25)).toEqual([0, 0.25, 0.5, 0.75])
|
|
300
302
|
})
|
|
301
303
|
})
|
|
304
|
+
|
|
305
|
+
describe("isNumber", () => {
|
|
306
|
+
it("returns true for finite numbers", () => {
|
|
307
|
+
expect(isNumber(0)).toBe(true)
|
|
308
|
+
expect(isNumber(42)).toBe(true)
|
|
309
|
+
expect(isNumber(-3.14)).toBe(true)
|
|
310
|
+
expect(isNumber(Number.MAX_SAFE_INTEGER)).toBe(true)
|
|
311
|
+
expect(isNumber(Number.MIN_SAFE_INTEGER)).toBe(true)
|
|
312
|
+
})
|
|
313
|
+
|
|
314
|
+
it("returns true for Infinity and -Infinity", () => {
|
|
315
|
+
expect(isNumber(Infinity)).toBe(true)
|
|
316
|
+
expect(isNumber(-Infinity)).toBe(true)
|
|
317
|
+
})
|
|
318
|
+
|
|
319
|
+
it("returns false for NaN", () => {
|
|
320
|
+
expect(isNumber(NaN)).toBe(false)
|
|
321
|
+
})
|
|
322
|
+
|
|
323
|
+
it("returns false for non-number types", () => {
|
|
324
|
+
expect(isNumber("123")).toBe(false)
|
|
325
|
+
expect(isNumber(undefined)).toBe(false)
|
|
326
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
327
|
+
expect(isNumber(null)).toBe(false)
|
|
328
|
+
expect(isNumber({})).toBe(false)
|
|
329
|
+
expect(isNumber([])).toBe(false)
|
|
330
|
+
expect(isNumber(true)).toBe(false)
|
|
331
|
+
expect(isNumber(Symbol("x"))).toBe(false)
|
|
332
|
+
expect(isNumber(() => 1)).toBe(false)
|
|
333
|
+
})
|
|
334
|
+
})
|
package/src/time.js
CHANGED
|
@@ -200,3 +200,14 @@ export function getDateRange(start, end, { limit = 1000 } = {}) {
|
|
|
200
200
|
}
|
|
201
201
|
return dates
|
|
202
202
|
}
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* Get the first date in the week containing the passed date string.
|
|
206
|
+
* @param {string} dateString YYYY-MM-DD
|
|
207
|
+
* @returns {string} YYYY-MM-DD
|
|
208
|
+
*/
|
|
209
|
+
export function getStartOfWeek(dateString) {
|
|
210
|
+
const index = getDayIndexInWeek(dateString)
|
|
211
|
+
const start = addDays(dateString, { days: -index })
|
|
212
|
+
return start
|
|
213
|
+
}
|
package/src/time.test.js
CHANGED
|
@@ -7,6 +7,7 @@ import {
|
|
|
7
7
|
// getDayOfWeek, // removed, replaced by getDayIndexInWeek
|
|
8
8
|
getEasternTime,
|
|
9
9
|
getMinute,
|
|
10
|
+
getStartOfWeek,
|
|
10
11
|
getTime,
|
|
11
12
|
getTimeRange,
|
|
12
13
|
isDate,
|
|
@@ -492,3 +493,31 @@ describe("getDateRange", () => {
|
|
|
492
493
|
expect(getDateRange("not-a-date", "2024-01-01")).toEqual([])
|
|
493
494
|
})
|
|
494
495
|
})
|
|
496
|
+
|
|
497
|
+
// Tests for getStartOfWeek (newly exported function)
|
|
498
|
+
describe("getStartOfWeek", () => {
|
|
499
|
+
test("returns same date if input is Sunday", () => {
|
|
500
|
+
expect(getStartOfWeek("2024-06-02")).toBe("2024-06-02") // Sunday
|
|
501
|
+
expect(getDayIndexInWeek("2024-06-02")).toBe(0)
|
|
502
|
+
})
|
|
503
|
+
|
|
504
|
+
test("returns previous Sunday for a weekday", () => {
|
|
505
|
+
expect(getStartOfWeek("2024-06-05")).toBe("2024-06-02") // Wednesday -> previous Sunday
|
|
506
|
+
expect(getStartOfWeek("2024-06-03")).toBe("2024-06-02") // Monday -> previous Sunday
|
|
507
|
+
expect(getStartOfWeek("2024-06-08")).toBe("2024-06-02") // Saturday -> previous Sunday
|
|
508
|
+
})
|
|
509
|
+
|
|
510
|
+
test("works for leap day", () => {
|
|
511
|
+
// 2024-02-29 is Thursday (4), so start of week should be 2024-02-25
|
|
512
|
+
expect(getStartOfWeek("2024-02-29")).toBe("2024-02-25")
|
|
513
|
+
})
|
|
514
|
+
|
|
515
|
+
test("works for year boundary", () => {
|
|
516
|
+
// 2023-01-01 is Sunday
|
|
517
|
+
expect(getStartOfWeek("2023-01-01")).toBe("2023-01-01")
|
|
518
|
+
// 2023-01-07 is Saturday, so start of week is 2023-01-01
|
|
519
|
+
expect(getStartOfWeek("2023-01-07")).toBe("2023-01-01")
|
|
520
|
+
// 2023-01-02 is Monday, so start of week is 2023-01-01
|
|
521
|
+
expect(getStartOfWeek("2023-01-02")).toBe("2023-01-01")
|
|
522
|
+
})
|
|
523
|
+
})
|