@alwatr/parse-duration 9.3.0 → 9.4.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/dist/main.js CHANGED
@@ -1,5 +1,5 @@
1
- /* 📦 @alwatr/parse-duration v9.3.0 */
1
+ /* 📦 @alwatr/parse-duration v9.4.0 */
2
2
  import{toNumber as A}from"@alwatr/is-number";var z=Object.freeze({s:1000,m:60000,h:3600000,d:86400000,w:604800000,M:2592000000,y:31536000000}),D=(h,k)=>{let j;if(typeof h==="number")j=h;else{if(h.length<2)throw Error("invalid_format",{cause:{duration:h}});let q=h.slice(-1),x=z[q];if(x===void 0)throw Error("invalid_unit",{cause:{durationUnit:q}});let y=A(h.slice(0,-1));if(y===null)throw Error("not_a_number",{cause:{duration:h}});j=y*x}if(k===void 0)return j;let p=z[k];if(p===void 0)throw Error("invalid_unit",{cause:{toUnit:k}});return j/p};export{D as parseDuration};
3
3
 
4
- //# debugId=C4003AA01207715464756E2164756E21
4
+ //# debugId=BEC56B45C8659E2164756E2164756E21
5
5
  //# sourceMappingURL=main.js.map
package/dist/main.js.map CHANGED
@@ -5,6 +5,6 @@
5
5
  "import {toNumber} from '@alwatr/is-number';\n\n/**\n * Unit conversion table (milliseconds)\n */\nconst unitConversion = Object.freeze({\n s: 1_000,\n m: 60_000,\n h: 3_600_000,\n d: 86_400_000,\n w: 604_800_000,\n M: 2_592_000_000,\n y: 31_536_000_000,\n} as const);\n\n/**\n * Duration unit: `s` for seconds, `m` for minutes, `h` for hours, `d` for days, `w` for weeks, `M` for months, `y` for years.\n */\nexport type DurationUnit = keyof typeof unitConversion;\n\n/**\n * Duration string format: `number + unit`, for example `10m` means 10 minutes.\n */\nexport type Duration = `${number}${DurationUnit}` | number;\n\n/**\n * Error types that can be thrown by parseDuration\n */\nexport type DurationError = 'not_a_number' | 'invalid_unit' | 'invalid_format';\n\n/**\n * Parse duration string to milliseconds number.\n *\n * @param duration - Duration string or number, for example `10m` means 10 minutes.\n * @param toUnit - Convert to unit, default is `ms` for milliseconds.\n * @throws {Error} With message 'not_a_number' if duration string doesn't contain a valid number.\n * @throws {Error} With message 'invalid_unit' if the unit is not recognized.\n * @throws {Error} With message 'invalid_format' if the duration format is invalid.\n * @returns Duration in specified unit (or milliseconds by default).\n *\n * @example\n * ```ts\n * parseDuration('10m'); // 600000\n * parseDuration('10m', 's'); // 600\n * parseDuration(120_000, 'm'); // 2\n * ```\n */\nexport const parseDuration = (duration: Duration, toUnit?: DurationUnit): number => {\n let ms: number;\n\n // Convert input to milliseconds\n if (typeof duration === 'number') {\n ms = duration;\n }\n else {\n if (duration.length < 2) {\n throw new Error('invalid_format', {cause: {duration}});\n }\n\n const durationUnit = duration.slice(-1) as DurationUnit;\n const unitConversionFactor = unitConversion[durationUnit];\n\n if (unitConversionFactor === undefined) {\n throw new Error('invalid_unit', {cause: {durationUnit}});\n }\n\n const durationNumber = toNumber(duration.slice(0, -1));\n if (durationNumber === null) {\n throw new Error('not_a_number', {cause: {duration}});\n }\n\n ms = durationNumber * unitConversionFactor;\n }\n\n // Return as is if no conversion needed\n if (toUnit === undefined) {\n return ms;\n }\n\n // Convert to target unit\n const toFactor = unitConversion[toUnit];\n if (toFactor === undefined) {\n throw new Error('invalid_unit', {cause: {toUnit}});\n }\n\n return ms / toFactor;\n};\n"
6
6
  ],
7
7
  "mappings": ";AAAA,mBAAQ,0BAKR,IAAM,EAAiB,OAAO,OAAO,CACnC,EAAG,KACH,EAAG,MACH,EAAG,QACH,EAAG,SACH,EAAG,UACH,EAAG,WACH,EAAG,WACL,CAAU,EAkCG,EAAgB,CAAC,EAAoB,IAAkC,CAClF,IAAI,EAGJ,GAAI,OAAO,IAAa,SACtB,EAAK,EAEF,KACH,GAAI,EAAS,OAAS,EACpB,MAAU,MAAM,iBAAkB,CAAC,MAAO,CAAC,UAAQ,CAAC,CAAC,EAGvD,IAAM,EAAe,EAAS,MAAM,EAAE,EAChC,EAAuB,EAAe,GAE5C,GAAI,IAAyB,OAC3B,MAAU,MAAM,eAAgB,CAAC,MAAO,CAAC,cAAY,CAAC,CAAC,EAGzD,IAAM,EAAiB,EAAS,EAAS,MAAM,EAAG,EAAE,CAAC,EACrD,GAAI,IAAmB,KACrB,MAAU,MAAM,eAAgB,CAAC,MAAO,CAAC,UAAQ,CAAC,CAAC,EAGrD,EAAK,EAAiB,EAIxB,GAAI,IAAW,OACb,OAAO,EAIT,IAAM,EAAW,EAAe,GAChC,GAAI,IAAa,OACf,MAAU,MAAM,eAAgB,CAAC,MAAO,CAAC,QAAM,CAAC,CAAC,EAGnD,OAAO,EAAK",
8
- "debugId": "C4003AA01207715464756E2164756E21",
8
+ "debugId": "BEC56B45C8659E2164756E2164756E21",
9
9
  "names": []
10
10
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alwatr/parse-duration",
3
- "version": "9.3.0",
3
+ "version": "9.4.0",
4
4
  "description": "A simple utility to parse a duration string into milliseconds number.",
5
5
  "license": "MPL-2.0",
6
6
  "author": "S. Ali Mihandoost <ali.mihandoost@gmail.com> (https://ali.mihandoost.com)",
@@ -21,11 +21,11 @@
21
21
  },
22
22
  "sideEffects": false,
23
23
  "dependencies": {
24
- "@alwatr/is-number": "9.3.0"
24
+ "@alwatr/is-number": "9.4.0"
25
25
  },
26
26
  "devDependencies": {
27
27
  "@alwatr/nano-build": "9.3.0",
28
- "@alwatr/standard": "9.3.0",
28
+ "@alwatr/standard": "9.4.0",
29
29
  "@alwatr/type-helper": "9.1.1",
30
30
  "typescript": "^6.0.2"
31
31
  },
@@ -75,5 +75,5 @@
75
75
  "utility",
76
76
  "utils"
77
77
  ],
78
- "gitHead": "adf6d486667eefee42dfc87938e3af96f87c4738"
78
+ "gitHead": "662f1047fc2a1b53a00902028d6cebfd04b52dd5"
79
79
  }