@valkyriestudios/utils 7.0.0 → 7.1.0
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/CHANGELOG.md +10 -0
- package/README.md +55 -1
- package/date/addUTC.js +56 -0
- package/date/endOfUTC.js +48 -0
- package/date/startOfUTC.js +20 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -5,6 +5,16 @@ All notable changes to this project will be documented in this file.
|
|
|
5
5
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic
|
|
6
6
|
Versioning](https://semver.org/spec/v2.0.0.html).
|
|
7
7
|
|
|
8
|
+
## [7.1.0] - 2023-05-13
|
|
9
|
+
### Added
|
|
10
|
+
- date/addUTC (1.000.000 ops in ~750ms)
|
|
11
|
+
- date/endOfUTC (1.000.000 ops in ~600ms), supports year,quarter,month,week,week_sun,day,hour,minute,second
|
|
12
|
+
|
|
13
|
+
### Improved
|
|
14
|
+
- date/startOfUTC now supports 'quarter'
|
|
15
|
+
- date/startOfUTC now supports 'week' (monday as first day of the week)
|
|
16
|
+
- date/startOfUTC now supports 'week_sun' (sunday as first day of the week)
|
|
17
|
+
|
|
8
18
|
## [7.0.0] - 2023-05-07
|
|
9
19
|
### Added
|
|
10
20
|
- Dep: @babel/cli
|
package/README.md
CHANGED
|
@@ -288,18 +288,72 @@ Returns the current unix timestamp in seconds
|
|
|
288
288
|
Returns the current unix timestamp in milliseconds
|
|
289
289
|
|
|
290
290
|
- **startOfUTC(val:Date, key:String)**
|
|
291
|
-
Take the incoming date and return a date set to the start of passed key. Possible key options(year,month,day,hour,minute,second).
|
|
291
|
+
Take the incoming date and return a date set to the start of passed key. Possible key options(year,quarter,month,week,week_sun,day,hour,minute,second).
|
|
292
292
|
|
|
293
293
|
Note: Does not touch the date object passed
|
|
294
294
|
```js
|
|
295
295
|
startOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'year'); // new Date("2023-01-01T00:00:00.000Z")
|
|
296
|
+
startOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'quarter'); // new Date("2023-04-01T00:00:00.000Z")
|
|
296
297
|
startOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'month'); // new Date("2023-05-01T00:00:00.000Z")
|
|
298
|
+
startOfUTC(new Date("2023-05-14T12:04:27+02:00"), 'week'); // new Date("2023-05-08T00:00:00.000Z")
|
|
299
|
+
startOfUTC(new Date("2023-02-03T12:04:27+02:00"), 'week'); // new Date("2023-01-30T00:00:00.000Z")
|
|
300
|
+
startOfUTC(new Date("2023-01-01T12:04:27+02:00"), 'week'); // new Date("2022-12-26T00:00:00.000Z")
|
|
301
|
+
startOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'week_sun'); // new Date("2023-04-30T00:00:00.000Z")
|
|
302
|
+
startOfUTC(new Date("2023-02-03T12:04:27+02:00"), 'week_sun'); // new Date("2023-01-29T00:00:00.000Z")
|
|
303
|
+
startOfUTC(new Date("2022-01-01T12:04:27+02:00"), 'week_sun'); // new Date("2021-12-26T00:00:00.000Z")
|
|
297
304
|
startOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'day'); // new Date("2023-05-04T00:00:00.000Z")
|
|
298
305
|
startOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'hour'); // new Date("2023-05-04T10:00:00.000Z")
|
|
299
306
|
startOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'minute'); // new Date("2023-05-04T10:04:00.000Z")
|
|
300
307
|
startOfUTC(new Date("2023-05-04T12:04:27.043+02:00"), 'second'); // new Date("2023-05-04T10:04:27.000Z")
|
|
301
308
|
```
|
|
302
309
|
|
|
310
|
+
- **endOfUTC(val:Date, key:String)**
|
|
311
|
+
Take the incoming date and return a date set to the end of passed key. Possible key options(year,quarter,month,week,week_sun,day,hour,minute,second).
|
|
312
|
+
|
|
313
|
+
Note: Does not touch the date object passed
|
|
314
|
+
```js
|
|
315
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'year'); // new Date("2023-12-31T23:59:59.999Z")
|
|
316
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'quarter'); // new Date("2023-06-30T23:59:59.999Z")
|
|
317
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'month'); // new Date("2023-05-31T23:59:59.999Z")
|
|
318
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'week'); // new Date("2023-05-07T23:59:59.999Z")
|
|
319
|
+
endOfUTC(new Date("2023-05-13T12:04:27+02:00"), 'week'); // new Date("2023-05-14T23:59:59.999Z")
|
|
320
|
+
endOfUTC(new Date("2023-05-14T12:04:27+02:00"), 'week'); // new Date("2023-05-14T23:59:59.999Z")
|
|
321
|
+
endOfUTC(new Date("2023-02-27T12:04:27+02:00"), 'week'); // new Date("2023-03-05T23:59:59.999Z")
|
|
322
|
+
endOfUTC(new Date("2022-12-29T12:04:27+02:00"), 'week'); // new Date("2023-01-01T23:59:59.999Z")
|
|
323
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'week_sun'); // new Date("2023-05-06T23:59:59.999Z")
|
|
324
|
+
endOfUTC(new Date("2023-05-12T12:04:27+02:00"), 'week_sun'); // new Date("2023-05-13T23:59:59.999Z")
|
|
325
|
+
endOfUTC(new Date("2023-05-06T12:04:27+02:00"), 'week_sun'); // new Date("2023-05-06T23:59:59.999Z")
|
|
326
|
+
endOfUTC(new Date("2023-03-29T12:04:27+02:00"), 'week_sun'); // new Date("2023-04-01T23:59:59.999Z")
|
|
327
|
+
endOfUTC(new Date("2021-12-28T12:04:27+02:00"), 'week_sun'); // new Date("2022-01-01T23:59:59.999Z")
|
|
328
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'day'); // new Date("2023-05-04T23:59:59.999Z")
|
|
329
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'hour'); // new Date("2023-05-04T10:59:59.999Z")
|
|
330
|
+
endOfUTC(new Date("2023-05-04T12:04:27+02:00"), 'minute'); // new Date("2023-05-04T10:04:59.999Z")
|
|
331
|
+
endOfUTC(new Date("2023-05-04T12:04:27.043+02:00"), 'second'); // new Date("2023-05-04T10:04:27.999Z")
|
|
332
|
+
```
|
|
333
|
+
|
|
334
|
+
- **addUTC(val:Date, amount:integer, key:String)**
|
|
335
|
+
Take the incoming date and add a certain amount of the passed key. Possible key options(year,years,month,months,day,days,hour,hours,minute,minutes,second,seconds).
|
|
336
|
+
|
|
337
|
+
Note: Does not touch the date object passed
|
|
338
|
+
```js
|
|
339
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 10, 'year'); // new Date("2032-10-05T11:12:11.000Z")
|
|
340
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), -10, 'year'); // new Date("2012-10-05T11:12:11.000Z")
|
|
341
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 10, 'month'); // new Date("2023-08-05T11:12:11.000Z")
|
|
342
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), -8970, 'month'); // new Date("1275-04-05T11:12:11.000Z")
|
|
343
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 200, 'day'); // new Date("2023-04-23T11:12:11.000Z")
|
|
344
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), -400, 'day'); // new Date("2021-08-31T11:12:11.000Z")
|
|
345
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 2200, 'hour'); // new Date("2023-01-05T03:12:11.000Z")
|
|
346
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), -10, 'hour'); // new Date("2022-10-05T01:12:11.000Z")
|
|
347
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 59, 'minute'); // new Date("2022-10-05T12:11:11.000Z")
|
|
348
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 336000, 'minute'); // new Date("2023-05-26T19:12:11.000Z")
|
|
349
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), -34, 'minute'); // new Date("2022-10-05T10:38:11.000Z")
|
|
350
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), -769, 'minute'); // new Date("2022-10-04T22:23:11.000Z")
|
|
351
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 59, 'second'); // new Date("2022-10-05T11:13:10.000Z")
|
|
352
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 2873 * 60, 'second'); // new Date("2022-10-07T11:05:11.000Z")
|
|
353
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), 336000 * 60, 'second'); // new Date("2023-05-26T19:12:11.000Z")
|
|
354
|
+
addUTC(new Date("2022-10-05T13:12:11+02:00"), -10, 'second'); // new Date("2022-10-05T11:12:01.000Z")
|
|
355
|
+
```
|
|
356
|
+
|
|
303
357
|
### deep
|
|
304
358
|
- **deepFreeze(val:Object)**
|
|
305
359
|
Recursively freezes all properties of an object
|
package/date/addUTC.js
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = addUTC;
|
|
7
|
+
var _is = _interopRequireDefault(require("./is"));
|
|
8
|
+
var _isInteger = _interopRequireDefault(require("../number/isInteger"));
|
|
9
|
+
var _isNotEmpty = _interopRequireDefault(require("../string/isNotEmpty"));
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
+
function addUTC(val, amount, key) {
|
|
12
|
+
if (!(0, _is["default"])(val)) throw new Error('Date To UTC requires a date object');
|
|
13
|
+
if (!(0, _isInteger["default"])(amount)) throw new Error('Amount needs to be an integer');
|
|
14
|
+
if (!(0, _isNotEmpty["default"])(key)) throw new Error('Key needs to be a string with content');
|
|
15
|
+
var copy = new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), val.getUTCHours(), val.getUTCMinutes(), val.getUTCSeconds(), val.getUTCMilliseconds()));
|
|
16
|
+
switch (key) {
|
|
17
|
+
case 'years':
|
|
18
|
+
case 'year':
|
|
19
|
+
{
|
|
20
|
+
copy.setUTCFullYear(copy.getUTCFullYear() + amount);
|
|
21
|
+
return copy;
|
|
22
|
+
}
|
|
23
|
+
case 'months':
|
|
24
|
+
case 'month':
|
|
25
|
+
{
|
|
26
|
+
copy.setUTCMonth(copy.getUTCMonth() + amount);
|
|
27
|
+
return copy;
|
|
28
|
+
}
|
|
29
|
+
case 'days':
|
|
30
|
+
case 'day':
|
|
31
|
+
{
|
|
32
|
+
copy.setUTCDate(copy.getUTCDate() + amount);
|
|
33
|
+
return copy;
|
|
34
|
+
}
|
|
35
|
+
case 'hours':
|
|
36
|
+
case 'hour':
|
|
37
|
+
{
|
|
38
|
+
copy.setUTCHours(copy.getUTCHours() + amount);
|
|
39
|
+
return copy;
|
|
40
|
+
}
|
|
41
|
+
case 'minutes':
|
|
42
|
+
case 'minute':
|
|
43
|
+
{
|
|
44
|
+
copy.setUTCMinutes(copy.getUTCMinutes() + amount);
|
|
45
|
+
return copy;
|
|
46
|
+
}
|
|
47
|
+
case 'seconds':
|
|
48
|
+
case 'second':
|
|
49
|
+
{
|
|
50
|
+
copy.setUTCSeconds(copy.getUTCSeconds() + amount);
|
|
51
|
+
return copy;
|
|
52
|
+
}
|
|
53
|
+
default:
|
|
54
|
+
return copy;
|
|
55
|
+
}
|
|
56
|
+
}
|
package/date/endOfUTC.js
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = endOfUTC;
|
|
7
|
+
var _is = _interopRequireDefault(require("./is"));
|
|
8
|
+
var _isNotEmpty = _interopRequireDefault(require("../string/isNotEmpty"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
10
|
+
function endOfUTC(val, key) {
|
|
11
|
+
if (!(0, _is["default"])(val)) throw new Error('Date To UTC requires a date object');
|
|
12
|
+
if (!(0, _isNotEmpty["default"])(key)) throw new Error('Key needs to be a string with content');
|
|
13
|
+
switch (key) {
|
|
14
|
+
case 'year':
|
|
15
|
+
return new Date(Date.UTC(val.getUTCFullYear(), 11, 31, 23, 59, 59, 999));
|
|
16
|
+
case 'quarter':
|
|
17
|
+
{
|
|
18
|
+
var new_quarter = val.getUTCMonth() - val.getUTCMonth() % 3;
|
|
19
|
+
return new Date(Date.UTC(val.getUTCFullYear(), new_quarter >= 0 ? new_quarter + 3 : 3, 0, 23, 59, 59, 999));
|
|
20
|
+
}
|
|
21
|
+
case 'month':
|
|
22
|
+
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth() + 1, 0, 23, 59, 59, 999));
|
|
23
|
+
case 'week':
|
|
24
|
+
{
|
|
25
|
+
var date = new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), 23, 59, 59, 999));
|
|
26
|
+
var day = date.getUTCDay();
|
|
27
|
+
if (day !== 0) date.setUTCDate(date.getUTCDate() + (7 - day));
|
|
28
|
+
return date;
|
|
29
|
+
}
|
|
30
|
+
case 'week_sun':
|
|
31
|
+
{
|
|
32
|
+
var _date = new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), 23, 59, 59, 999));
|
|
33
|
+
var _day = _date.getUTCDay();
|
|
34
|
+
if (_day !== 6) _date.setUTCDate(_date.getUTCDate() + (6 - _day));
|
|
35
|
+
return _date;
|
|
36
|
+
}
|
|
37
|
+
case 'day':
|
|
38
|
+
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), 23, 59, 59, 999));
|
|
39
|
+
case 'hour':
|
|
40
|
+
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), val.getUTCHours(), 59, 59, 999));
|
|
41
|
+
case 'minute':
|
|
42
|
+
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), val.getUTCHours(), val.getUTCMinutes(), 59, 999));
|
|
43
|
+
case 'second':
|
|
44
|
+
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), val.getUTCHours(), val.getUTCMinutes(), val.getUTCSeconds(), 999));
|
|
45
|
+
default:
|
|
46
|
+
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), val.getUTCHours(), val.getUTCMinutes(), val.getUTCSeconds(), val.getUTCMilliseconds()));
|
|
47
|
+
}
|
|
48
|
+
}
|
package/date/startOfUTC.js
CHANGED
|
@@ -13,8 +13,27 @@ function startOfUTC(val, key) {
|
|
|
13
13
|
switch (key) {
|
|
14
14
|
case 'year':
|
|
15
15
|
return new Date(Date.UTC(val.getUTCFullYear(), 0, 1, 0, 0, 0, 0));
|
|
16
|
+
case 'quarter':
|
|
17
|
+
{
|
|
18
|
+
var new_quarter = val.getUTCMonth() - val.getUTCMonth() % 3;
|
|
19
|
+
return new Date(Date.UTC(val.getUTCFullYear(), new_quarter >= 0 ? new_quarter : 0, 1, 0, 0, 0, 0));
|
|
20
|
+
}
|
|
16
21
|
case 'month':
|
|
17
22
|
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), 1, 0, 0, 0, 0));
|
|
23
|
+
case 'week':
|
|
24
|
+
{
|
|
25
|
+
var date = new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), 0, 0, 0, 0));
|
|
26
|
+
var subtract = date.getUTCDay() || 7;
|
|
27
|
+
if (subtract !== 1) date.setUTCDate(date.getUTCDate() - subtract + 1);
|
|
28
|
+
return date;
|
|
29
|
+
}
|
|
30
|
+
case 'week_sun':
|
|
31
|
+
{
|
|
32
|
+
var _date = new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), 0, 0, 0, 0));
|
|
33
|
+
var _subtract = _date.getUTCDay();
|
|
34
|
+
if (_subtract !== 0) _date.setUTCDate(_date.getUTCDate() - _subtract);
|
|
35
|
+
return _date;
|
|
36
|
+
}
|
|
18
37
|
case 'day':
|
|
19
38
|
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), 0, 0, 0, 0));
|
|
20
39
|
case 'hour':
|
|
@@ -24,6 +43,6 @@ function startOfUTC(val, key) {
|
|
|
24
43
|
case 'second':
|
|
25
44
|
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), val.getUTCHours(), val.getUTCMinutes(), val.getUTCSeconds(), 0));
|
|
26
45
|
default:
|
|
27
|
-
return val;
|
|
46
|
+
return new Date(Date.UTC(val.getUTCFullYear(), val.getUTCMonth(), val.getUTCDate(), val.getUTCHours(), val.getUTCMinutes(), val.getUTCSeconds(), val.getUTCMilliseconds()));
|
|
28
47
|
}
|
|
29
48
|
}
|