@rzl-zone/utils-js 3.12.1-beta.0 → 3.12.1-beta.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 (239) hide show
  1. package/README.md +7 -7
  2. package/dist/.references/index.d.cts +1 -1
  3. package/dist/.references/index.d.ts +1 -1
  4. package/dist/{assertIsArray-BChqwPiP.cjs → assertIsArray-DJXkjHZs.cjs} +3 -3
  5. package/dist/{assertIsArray-BChqwPiP.cjs.map → assertIsArray-DJXkjHZs.cjs.map} +1 -1
  6. package/dist/{assertIsArray-BfAbIUfa.js → assertIsArray-bTA3XLjq.js} +3 -3
  7. package/dist/{assertIsArray-BfAbIUfa.js.map → assertIsArray-bTA3XLjq.js.map} +1 -1
  8. package/dist/{assertIsBoolean-DozdtbNi.cjs → assertIsBoolean-C8WEXVr2.cjs} +8 -8
  9. package/dist/assertIsBoolean-C8WEXVr2.cjs.map +1 -0
  10. package/dist/{assertIsBoolean-BlBct0Fc.js → assertIsBoolean-DR1SaXPD.js} +8 -8
  11. package/dist/assertIsBoolean-DR1SaXPD.js.map +1 -0
  12. package/dist/{assertIsString-Bvk7bUL7.cjs → assertIsString-BiHQSrB2.cjs} +3 -3
  13. package/dist/{assertIsString-Bvk7bUL7.cjs.map → assertIsString-BiHQSrB2.cjs.map} +1 -1
  14. package/dist/{assertIsString-DqV9NwbI.js → assertIsString-CEB07_83.js} +3 -3
  15. package/dist/{assertIsString-DqV9NwbI.js.map → assertIsString-CEB07_83.js.map} +1 -1
  16. package/dist/assertions/index.cjs +5 -5
  17. package/dist/assertions/index.d.cts +2 -2
  18. package/dist/assertions/index.d.ts +2 -2
  19. package/dist/assertions/index.js +5 -5
  20. package/dist/conversions/index.cjs +6 -6
  21. package/dist/conversions/index.d.cts +2 -2
  22. package/dist/conversions/index.d.ts +2 -2
  23. package/dist/conversions/index.js +6 -6
  24. package/dist/{conversions-EMJa3g-D.js → conversions-BNIh_tCH.js} +16 -18
  25. package/dist/conversions-BNIh_tCH.js.map +1 -0
  26. package/dist/{conversions-CBs8-REq.cjs → conversions-D_Kh0a_C.cjs} +16 -18
  27. package/dist/conversions-D_Kh0a_C.cjs.map +1 -0
  28. package/dist/events/index.cjs +4 -4
  29. package/dist/events/index.cjs.map +1 -1
  30. package/dist/events/index.d.cts +153 -151
  31. package/dist/events/index.d.ts +153 -151
  32. package/dist/events/index.js +4 -4
  33. package/dist/events/index.js.map +1 -1
  34. package/dist/{formatEnvPort-hHNvOim-.cjs → formatEnvPort-B3OLxQk9.cjs} +9 -9
  35. package/dist/formatEnvPort-B3OLxQk9.cjs.map +1 -0
  36. package/dist/{formatEnvPort-DpIXzPAZ.js → formatEnvPort-ByFVLjSV.js} +9 -9
  37. package/dist/formatEnvPort-ByFVLjSV.js.map +1 -0
  38. package/dist/formatters/index.cjs +2 -2
  39. package/dist/formatters/index.d.cts +2 -2
  40. package/dist/formatters/index.d.ts +2 -2
  41. package/dist/formatters/index.js +2 -2
  42. package/dist/{formatters-QcZO_Cpx.js → formatters--1m_vpE8.js} +17 -15
  43. package/dist/formatters--1m_vpE8.js.map +1 -0
  44. package/dist/{formatters-lAYgA11L.cjs → formatters-Cbij0XLU.cjs} +17 -15
  45. package/dist/formatters-Cbij0XLU.cjs.map +1 -0
  46. package/dist/generators/index.cjs +12 -8
  47. package/dist/generators/index.cjs.map +1 -1
  48. package/dist/generators/index.d.cts +2 -2
  49. package/dist/generators/index.d.ts +2 -2
  50. package/dist/generators/index.js +12 -8
  51. package/dist/generators/index.js.map +1 -1
  52. package/dist/index-59zbLcPr.d.ts +340 -0
  53. package/dist/index-B6tawc8L.d.cts +1716 -0
  54. package/dist/index-C267akkJ.d.ts +2158 -0
  55. package/dist/index-CeBC2Vvl.d.cts +2361 -0
  56. package/dist/index-CgRDTI6f.d.ts +822 -0
  57. package/dist/index-CoiUBVmr.d.ts +720 -0
  58. package/dist/index-D4fcasfZ.d.cts +720 -0
  59. package/dist/index-DDrSQKIc.d.ts +1716 -0
  60. package/dist/index-DsGxO31H.d.cts +765 -0
  61. package/dist/index-Hg1qJkjl.d.ts +765 -0
  62. package/dist/index-Qm3iFwd0.d.cts +2158 -0
  63. package/dist/index-UPp94Agr.d.ts +2361 -0
  64. package/dist/index-gBA_8SuF.d.cts +340 -0
  65. package/dist/index-jyDqzicx.d.cts +822 -0
  66. package/dist/{isBigInt-B1cijjqm.cjs → isBigInt-C4krUeAw.cjs} +2 -2
  67. package/dist/{isBigInt-B1cijjqm.cjs.map → isBigInt-C4krUeAw.cjs.map} +1 -1
  68. package/dist/{isBigInt-C0bN0Rhu.js → isBigInt-DKe0M6hp.js} +2 -2
  69. package/dist/{isBigInt-C0bN0Rhu.js.map → isBigInt-DKe0M6hp.js.map} +1 -1
  70. package/dist/{isEmptyObject-DeLVIJpl.js → isEmptyObject-DCipFwxJ.js} +3 -3
  71. package/dist/{isEmptyObject-DeLVIJpl.js.map → isEmptyObject-DCipFwxJ.js.map} +1 -1
  72. package/dist/{isEmptyObject-DI42NEo0.cjs → isEmptyObject-ZkSwRC_D.cjs} +3 -3
  73. package/dist/{isEmptyObject-DI42NEo0.cjs.map → isEmptyObject-ZkSwRC_D.cjs.map} +1 -1
  74. package/dist/{isEmptyString-BTUWYTbw.js → isEmptyString-BXzKAC2j.js} +3 -3
  75. package/dist/{isEmptyString-BTUWYTbw.js.map → isEmptyString-BXzKAC2j.js.map} +1 -1
  76. package/dist/{isEmptyString-CCK3bP74.cjs → isEmptyString-UiiUsSQj.cjs} +3 -3
  77. package/dist/{isEmptyString-CCK3bP74.cjs.map → isEmptyString-UiiUsSQj.cjs.map} +1 -1
  78. package/dist/{isEmptyValue-DMSMFTU8.cjs → isEmptyValue-BQzcjVaL.cjs} +5 -5
  79. package/dist/{isEmptyValue-DMSMFTU8.cjs.map → isEmptyValue-BQzcjVaL.cjs.map} +1 -1
  80. package/dist/{isEmptyValue-fjnfQnt5.js → isEmptyValue-jqOr7OHD.js} +5 -5
  81. package/dist/{isEmptyValue-fjnfQnt5.js.map → isEmptyValue-jqOr7OHD.js.map} +1 -1
  82. package/dist/{isEqual-DhyP8fB_.js → isEqual-BX49cF9m.js} +4 -4
  83. package/dist/{isEqual-DhyP8fB_.js.map → isEqual-BX49cF9m.js.map} +1 -1
  84. package/dist/{isEqual-B1fRgEuU.cjs → isEqual-BvumA3RA.cjs} +4 -4
  85. package/dist/{isEqual-B1fRgEuU.cjs.map → isEqual-BvumA3RA.cjs.map} +1 -1
  86. package/dist/{isFinite-BYMOo0os.js → isFinite-BCnaDpod.js} +3 -3
  87. package/dist/{isFinite-BYMOo0os.js.map → isFinite-BCnaDpod.js.map} +1 -1
  88. package/dist/{isFinite-sFkps2TY.cjs → isFinite-D24ZaE6c.cjs} +3 -3
  89. package/dist/{isFinite-sFkps2TY.cjs.map → isFinite-D24ZaE6c.cjs.map} +1 -1
  90. package/dist/{isInteger-FTCthMre.cjs → isInteger-Caeuz0rB.cjs} +2 -2
  91. package/dist/{isInteger-FTCthMre.cjs.map → isInteger-Caeuz0rB.cjs.map} +1 -1
  92. package/dist/{isInteger-DS9V7l_f.js → isInteger-naMbJsxJ.js} +2 -2
  93. package/dist/{isInteger-DS9V7l_f.js.map → isInteger-naMbJsxJ.js.map} +1 -1
  94. package/dist/isPlainObject-BF-2-phb.d.cts +339 -0
  95. package/dist/isPlainObject-DxNDL8XU.d.ts +339 -0
  96. package/dist/{isServer-q-QLFCqE.cjs → isServer-BJHVnixd.cjs} +2 -2
  97. package/dist/{isServer-q-QLFCqE.cjs.map → isServer-BJHVnixd.cjs.map} +1 -1
  98. package/dist/{isServer-D1TXfOs3.js → isServer-Da3o3XSs.js} +2 -2
  99. package/dist/{isServer-D1TXfOs3.js.map → isServer-Da3o3XSs.js.map} +1 -1
  100. package/dist/{isTypedArray-47R0wdrc.js → isTypedArray-DuNA8tK6.js} +3 -3
  101. package/dist/{isTypedArray-47R0wdrc.js.map → isTypedArray-DuNA8tK6.js.map} +1 -1
  102. package/dist/{isTypedArray-DiCoqffZ.cjs → isTypedArray-TJptiw2b.cjs} +3 -3
  103. package/dist/{isTypedArray-DiCoqffZ.cjs.map → isTypedArray-TJptiw2b.cjs.map} +1 -1
  104. package/dist/{isURL-CQiowFq2.js → isURL-C-kSk6KJ.js} +2 -2
  105. package/dist/{isURL-CQiowFq2.js.map → isURL-C-kSk6KJ.js.map} +1 -1
  106. package/dist/{isURL-WZypXsax.cjs → isURL-DeUPO_oR.cjs} +2 -2
  107. package/dist/{isURL-WZypXsax.cjs.map → isURL-DeUPO_oR.cjs.map} +1 -1
  108. package/dist/{isValidDomain-BSXshgkC.cjs → isValidDomain-BB9IGhJs.cjs} +65 -8
  109. package/dist/isValidDomain-BB9IGhJs.cjs.map +1 -0
  110. package/dist/{isValidDomain-DwA2EN79.js → isValidDomain-DoE98yhJ.js} +54 -9
  111. package/dist/isValidDomain-DoE98yhJ.js.map +1 -0
  112. package/dist/next/index.cjs +7 -7
  113. package/dist/next/index.cjs.map +1 -1
  114. package/dist/next/index.d.cts +185 -191
  115. package/dist/next/index.d.ts +185 -191
  116. package/dist/next/index.js +7 -7
  117. package/dist/next/index.js.map +1 -1
  118. package/dist/next/server/index.cjs +2 -2
  119. package/dist/next/server/index.d.cts +26 -26
  120. package/dist/next/server/index.d.ts +26 -26
  121. package/dist/next/server/index.js +2 -2
  122. package/dist/{noop-B2mTBhW-.cjs → noop-B13_ii35.cjs} +2 -2
  123. package/dist/{noop-B2mTBhW-.cjs.map → noop-B13_ii35.cjs.map} +1 -1
  124. package/dist/{noop-BzktGBVz.js → noop-ubqAIbHD.js} +2 -2
  125. package/dist/{noop-BzktGBVz.js.map → noop-ubqAIbHD.js.map} +1 -1
  126. package/dist/{normalizeSpaces-WS_iERJk.js → normalizeSpaces-Bg2IZW7W.js} +3 -3
  127. package/dist/{normalizeSpaces-WS_iERJk.js.map → normalizeSpaces-Bg2IZW7W.js.map} +1 -1
  128. package/dist/{normalizeSpaces-DQHR3Tlr.cjs → normalizeSpaces-ZXnR4Qzp.cjs} +3 -3
  129. package/dist/{normalizeSpaces-DQHR3Tlr.cjs.map → normalizeSpaces-ZXnR4Qzp.cjs.map} +1 -1
  130. package/dist/{normalizeString-2WLth_Gj.js → normalizeString-BDdkaXui.js} +3 -3
  131. package/dist/{normalizeString-2WLth_Gj.js.map → normalizeString-BDdkaXui.js.map} +1 -1
  132. package/dist/{normalizeString-D8euBcRD.cjs → normalizeString-BE6ELqEb.cjs} +3 -3
  133. package/dist/{normalizeString-D8euBcRD.cjs.map → normalizeString-BE6ELqEb.cjs.map} +1 -1
  134. package/dist/operations/index.cjs +10 -10
  135. package/dist/operations/index.cjs.map +1 -1
  136. package/dist/operations/index.d.cts +120 -120
  137. package/dist/operations/index.d.ts +120 -120
  138. package/dist/operations/index.js +10 -10
  139. package/dist/operations/index.js.map +1 -1
  140. package/dist/parsers/index.cjs +2 -2
  141. package/dist/parsers/index.d.cts +222 -222
  142. package/dist/parsers/index.d.ts +222 -222
  143. package/dist/parsers/index.js +2 -2
  144. package/dist/{parsers-Dpuq-V4u.js → parsers-BSBPgvsq.js} +4 -4
  145. package/dist/{parsers-Dpuq-V4u.js.map → parsers-BSBPgvsq.js.map} +1 -1
  146. package/dist/{parsers-DXtpsDyj.cjs → parsers-OqDeffqc.cjs} +4 -4
  147. package/dist/{parsers-DXtpsDyj.cjs.map → parsers-OqDeffqc.cjs.map} +1 -1
  148. package/dist/{parsing-B43x1sxn.js → parsing-Cao8b358.js} +3 -3
  149. package/dist/{parsing-B43x1sxn.js.map → parsing-Cao8b358.js.map} +1 -1
  150. package/dist/{parsing-lRoxn1Nz.cjs → parsing-DOGSCH6N.cjs} +3 -3
  151. package/dist/{parsing-lRoxn1Nz.cjs.map → parsing-DOGSCH6N.cjs.map} +1 -1
  152. package/dist/predicates/index.cjs +15 -15
  153. package/dist/predicates/index.d.cts +3 -3
  154. package/dist/predicates/index.d.ts +3 -3
  155. package/dist/predicates/index.js +15 -15
  156. package/dist/{predicates-gNepszvo.js → predicates-Bj6meyXV.js} +13 -14
  157. package/dist/{predicates-gNepszvo.js.map → predicates-Bj6meyXV.js.map} +1 -1
  158. package/dist/{predicates-DiaYA7Ps.cjs → predicates-D0ubqgqy.cjs} +13 -14
  159. package/dist/{predicates-DiaYA7Ps.cjs.map → predicates-D0ubqgqy.cjs.map} +1 -1
  160. package/dist/promises/index.cjs +4 -4
  161. package/dist/promises/index.d.cts +101 -101
  162. package/dist/promises/index.d.ts +101 -101
  163. package/dist/promises/index.js +4 -4
  164. package/dist/{punyCode-hmiFzLWT.js → punyCode-8SrbMWfM.js} +6 -6
  165. package/dist/punyCode-8SrbMWfM.js.map +1 -0
  166. package/dist/{punyCode-CTWXVVFo.cjs → punyCode-D-Qu6nj6.cjs} +6 -6
  167. package/dist/punyCode-D-Qu6nj6.cjs.map +1 -0
  168. package/dist/{removeSpaces-BE8lfh-4.js → removeSpaces-Bmc5DX4F.js} +3 -3
  169. package/dist/removeSpaces-Bmc5DX4F.js.map +1 -0
  170. package/dist/{removeSpaces-DRRxNWlb.cjs → removeSpaces-CWIvhZHg.cjs} +3 -3
  171. package/dist/removeSpaces-CWIvhZHg.cjs.map +1 -0
  172. package/dist/rzl-utils.global.js +21 -0
  173. package/dist/{safeJsonParse-CXruaP0p.js → safeJsonParse-BP38mwlj.js} +9 -9
  174. package/dist/safeJsonParse-BP38mwlj.js.map +1 -0
  175. package/dist/{safeJsonParse-BBnQElk8.cjs → safeJsonParse-Sms2CJf4.cjs} +9 -9
  176. package/dist/safeJsonParse-Sms2CJf4.cjs.map +1 -0
  177. package/dist/{safeStableStringify-Cc62pfRp.cjs → safeStableStringify-CJtP89qn.cjs} +4 -4
  178. package/dist/{safeStableStringify-Cc62pfRp.cjs.map → safeStableStringify-CJtP89qn.cjs.map} +1 -1
  179. package/dist/{safeStableStringify-BNh3D0K0.js → safeStableStringify-CXOZ9Ub8.js} +4 -4
  180. package/dist/{safeStableStringify-BNh3D0K0.js.map → safeStableStringify-CXOZ9Ub8.js.map} +1 -1
  181. package/dist/strings/index.cjs +12 -9
  182. package/dist/strings/index.cjs.map +1 -1
  183. package/dist/strings/index.d.cts +2 -2
  184. package/dist/strings/index.d.ts +2 -2
  185. package/dist/strings/index.js +12 -9
  186. package/dist/strings/index.js.map +1 -1
  187. package/dist/tailwind/index.cjs +2 -2
  188. package/dist/tailwind/index.d.cts +2 -2
  189. package/dist/tailwind/index.d.ts +2 -2
  190. package/dist/tailwind/index.js +2 -2
  191. package/dist/{tailwind-IJvOdkZp.js → tailwind-B2ssevxq.js} +5 -5
  192. package/dist/tailwind-B2ssevxq.js.map +1 -0
  193. package/dist/{tailwind-DJ4cmLUw.cjs → tailwind-CHIx9uxu.cjs} +5 -5
  194. package/dist/tailwind-CHIx9uxu.cjs.map +1 -0
  195. package/dist/{toStringArrayUnRecursive-xUaU8Ot9.cjs → toStringArrayUnRecursive-C4zYCja7.cjs} +6 -6
  196. package/dist/{toStringArrayUnRecursive-xUaU8Ot9.cjs.map → toStringArrayUnRecursive-C4zYCja7.cjs.map} +1 -1
  197. package/dist/{toStringArrayUnRecursive-CFs0jTEg.js → toStringArrayUnRecursive-DJGtPsFb.js} +6 -6
  198. package/dist/{toStringArrayUnRecursive-CFs0jTEg.js.map → toStringArrayUnRecursive-DJGtPsFb.js.map} +1 -1
  199. package/dist/urls/index.cjs +15 -14
  200. package/dist/urls/index.cjs.map +1 -1
  201. package/dist/urls/index.d.cts +656 -659
  202. package/dist/urls/index.d.ts +656 -659
  203. package/dist/urls/index.js +15 -14
  204. package/dist/urls/index.js.map +1 -1
  205. package/package.json +2 -2
  206. package/dist/assertIsBoolean-BlBct0Fc.js.map +0 -1
  207. package/dist/assertIsBoolean-DozdtbNi.cjs.map +0 -1
  208. package/dist/conversions-CBs8-REq.cjs.map +0 -1
  209. package/dist/conversions-EMJa3g-D.js.map +0 -1
  210. package/dist/formatEnvPort-DpIXzPAZ.js.map +0 -1
  211. package/dist/formatEnvPort-hHNvOim-.cjs.map +0 -1
  212. package/dist/formatters-QcZO_Cpx.js.map +0 -1
  213. package/dist/formatters-lAYgA11L.cjs.map +0 -1
  214. package/dist/index-26W7ItWx.d.ts +0 -760
  215. package/dist/index-BPPQjAfs.d.cts +0 -2359
  216. package/dist/index-BXjlgBLz.d.cts +0 -2139
  217. package/dist/index-B_Wwo91H.d.ts +0 -2359
  218. package/dist/index-CpufydcI.d.cts +0 -704
  219. package/dist/index-Czc4O526.d.ts +0 -333
  220. package/dist/index-DPs1_p5G.d.cts +0 -760
  221. package/dist/index-DRpOyBSC.d.ts +0 -1703
  222. package/dist/index-DWWvtHUn.d.cts +0 -822
  223. package/dist/index-DnM0LD0n.d.cts +0 -333
  224. package/dist/index-GUZ9fK6T.d.ts +0 -2139
  225. package/dist/index-I4fAzwXV.d.ts +0 -704
  226. package/dist/index-JDrOl_19.d.ts +0 -822
  227. package/dist/index-b66P49Qe.d.cts +0 -1703
  228. package/dist/isPlainObject-DcFGh3_5.d.ts +0 -530
  229. package/dist/isPlainObject-doTI11Ib.d.cts +0 -530
  230. package/dist/isValidDomain-BSXshgkC.cjs.map +0 -1
  231. package/dist/isValidDomain-DwA2EN79.js.map +0 -1
  232. package/dist/punyCode-CTWXVVFo.cjs.map +0 -1
  233. package/dist/punyCode-hmiFzLWT.js.map +0 -1
  234. package/dist/removeSpaces-BE8lfh-4.js.map +0 -1
  235. package/dist/removeSpaces-DRRxNWlb.cjs.map +0 -1
  236. package/dist/safeJsonParse-BBnQElk8.cjs.map +0 -1
  237. package/dist/safeJsonParse-CXruaP0p.js.map +0 -1
  238. package/dist/tailwind-DJ4cmLUw.cjs.map +0 -1
  239. package/dist/tailwind-IJvOdkZp.js.map +0 -1
@@ -2,238 +2,238 @@
2
2
  * ========================================================================
3
3
  * @rzl-zone/utils-js
4
4
  * ------------------------------------------------------------------------
5
- * Version: `3.12.1-beta.0`
5
+ * Version: `3.12.1-beta.1`
6
6
  * Author: `Rizalvin Dwiky <rizalvindwiky@gmail.com>`
7
7
  * Repository: `https://github.com/rzl-zone/rzl-zone/tree/main/packages/utils-js`
8
8
  * ========================================================================
9
9
  */
10
10
  type ExtractFileNameOptions = {
11
11
  /** ----------------------------------------------------------
12
- * * ***Indicates whether the input should be treated as a potential domain string.***
13
- * ----------------------------------------------------------
14
- *
15
- * - Behavior when `true`:
16
- * - The `domainName` option is required and must be a string and non-empty string.
17
- * If `domainName` is `undefined`, `null`, or an empty string, a `TypeError` will be thrown.
18
- * - The `domainName` is used to determine if the input is a domain-only string.
19
- * - Returns `null` if the input exactly matches `domainName` or any of its subdomains **and** has no additional path or filename.
20
- * - If the input does not match `domainName` or its subdomains, it will be processed as a regular file-like name.
21
- * - Supports **Unicode/IDN domains** (e.g., `tést-ドメイン.com`) and **ASCII filenames**, mixed safely.
22
- *
23
- * @default false
24
- */
12
+ * * ***Indicates whether the input should be treated as a potential domain string.***
13
+ * ----------------------------------------------------------
14
+ *
15
+ * - Behavior when `true`:
16
+ * - The `domainName` option is required and must be a string and non-empty string.
17
+ * If `domainName` is `undefined`, `null`, or an empty string, a `TypeError` will be thrown.
18
+ * - The `domainName` is used to determine if the input is a domain-only string.
19
+ * - Returns `null` if the input exactly matches `domainName` or any of its subdomains **and** has no additional path or filename.
20
+ * - If the input does not match `domainName` or its subdomains, it will be processed as a regular file-like name.
21
+ * - Supports **Unicode/IDN domains** (e.g., `tést-ドメイン.com`) and **ASCII filenames**, mixed safely.
22
+ *
23
+ * @default false
24
+ */
25
25
  domainAware?: boolean;
26
26
  /** ----------------------------------------------------------
27
- * * ***The base domain name used for comparison (e.g., `"example.com"`).***
28
- * ----------------------------------------------------------
29
- *
30
- * - Required when `domainAware` is `true`.
31
- * - Helps differentiate between a domain-only input (ignored) and a standalone file-like string (processed normally).
32
- * - Must be a string and non-empty string. Invalid values (`undefined`, `null`, or empty string) will trigger a `TypeError`.
33
- * - Works with both **ASCII domains** and **Unicode/IDN domains**.
34
- * - Example:
35
- * ```ts *
36
- * // ASCII domain + ASCII filename
37
- * extractFileName("resume.com", {
38
- * domainAware: true,
39
- * domainName: "example.com"
40
- * });
41
- * // ➔ "resume"
42
- * extractFileName("example.com", {
43
- * domainAware: true,
44
- * domainName: "example.com"
45
- * });
46
- * // ➔ null (because input is treated as domain-name)
47
- *
48
- * // Unicode domain + ASCII filename
49
- * extractFileName("tést-ドメイン.com/file.txt", {
50
- * domainAware: true,
51
- * domainName: "ドメイン.com"
52
- * });
53
- * // ➔ "file"
54
- *
55
- * // Unicode domain + Unicode filename
56
- * extractFileName("tést-ドメイン.com/ファイル名.pdf", {
57
- * domainAware: true,
58
- * domainName: "ドメイン.com"
59
- * });
60
- * // ➔ "ファイル名"
61
- *
62
- * // Invalid domainName, will throw TypeError
63
- * extractFileName("resume.com", {
64
- * domainAware: true,
65
- * domainName: ""
66
- * });
67
- * // ➔ TypeError
68
- * ```
69
- *
70
- * @default undefined
71
- */
27
+ * * ***The base domain name used for comparison (e.g., `"example.com"`).***
28
+ * ----------------------------------------------------------
29
+ *
30
+ * - Required when `domainAware` is `true`.
31
+ * - Helps differentiate between a domain-only input (ignored) and a standalone file-like string (processed normally).
32
+ * - Must be a string and non-empty string. Invalid values (`undefined`, `null`, or empty string) will trigger a `TypeError`.
33
+ * - Works with both **ASCII domains** and **Unicode/IDN domains**.
34
+ * - Example:
35
+ * ```ts *
36
+ * // ASCII domain + ASCII filename
37
+ * extractFileName("resume.com", {
38
+ * domainAware: true,
39
+ * domainName: "example.com"
40
+ * });
41
+ * // ➔ "resume"
42
+ * extractFileName("example.com", {
43
+ * domainAware: true,
44
+ * domainName: "example.com"
45
+ * });
46
+ * // ➔ null (because input is treated as domain-name)
47
+ *
48
+ * // Unicode domain + ASCII filename
49
+ * extractFileName("tést-ドメイン.com/file.txt", {
50
+ * domainAware: true,
51
+ * domainName: "ドメイン.com"
52
+ * });
53
+ * // ➔ "file"
54
+ *
55
+ * // Unicode domain + Unicode filename
56
+ * extractFileName("tést-ドメイン.com/ファイル名.pdf", {
57
+ * domainAware: true,
58
+ * domainName: "ドメイン.com"
59
+ * });
60
+ * // ➔ "ファイル名"
61
+ *
62
+ * // Invalid domainName, will throw TypeError
63
+ * extractFileName("resume.com", {
64
+ * domainAware: true,
65
+ * domainName: ""
66
+ * });
67
+ * // ➔ TypeError
68
+ * ```
69
+ *
70
+ * @default undefined
71
+ */
72
72
  domainName?: string;
73
73
  };
74
74
  /** ----------------------------------------------------------
75
- * * ***Utility: `extractFileName`.***
76
- * ----------------------------------------------------------
77
- *
78
- * **Extracts the **clean base filename** from nearly any input string, including URLs, local file paths,
79
- * UNC paths, and plain filenames.**
80
- *
81
- * - It automatically safely handles extracts the **base file name** (without extension) from:
82
- * - File system paths (Windows, Unix, UNC)
83
- * - Protocols like http, https, ftp, file, mailto, or custom schemes
84
- * - Percent-encoded, Unicode, and emoji characters
85
- * - Dotfiles, reserved OS names, multi-part extensions
86
- * - Data URIs
87
- * - Optional domain-aware mode to ignore domain-only inputs
88
- * - Plain filenames
89
- *
90
- * - Full support for:
91
- * - Unicode, emoji, percent-encoding
92
- * - Dotfiles (e.g., `.env`, `.gitignore`)
93
- * - Reserved/OS-protected filenames:
94
- * `CON`, `PRN`, `AUX`, `NUL`, `COM1`–`COM9`, `LPT1`–`LPT9`
95
- * - Known multi-part extensions:
96
- * `.tar.gz`, `.tar.bz2`, `.tar.xz`, `.tar.lz`, `.tar.zst`, `.min.js`, `.js.map`, `.log.gz`, `.sql.gz`,
97
- * `.backup.tar`, etc.
98
- * - Data URIs (`data:[mime];base64,...` ➔ payload string)
99
- * - Domain-aware mode (optional)
100
- *
101
- * ----------------------------------------------------------
102
- * - **Behavior / Features**
103
- * - Strips **known extensions**, including multi-part and common double/triple extensions.
104
- * - Leaves unknown/custom extensions intact.
105
- * - Preserves **dotfiles** as-is (leading dot preserved).
106
- * - Returns `null` if:
107
- * - input is `null`, `undefined`, or not a string
108
- * - input is empty, whitespace-only, or only slashes
109
- * - input represents a folder path (trailing slash/backslash, drive/folder only)
110
- * - input is a **domain-only string** in domain-aware mode
111
- * - Normalizes Windows-style backslashes (`\`) internally as `/`.
112
- * - Supports UNC paths, mixed slashes, and Windows drive letters safely.
113
- * - Handles URLs:
114
- * - Ignores query strings (`?v=1.2.3`) and hash fragments (`#section`)
115
- * - Decodes percent-encoded filenames (`my%20file.txt` ➔ `my file.txt`)
116
- * - Supports protocol-relative URLs (`//cdn.example.com/file.jpg`)
117
- * - Supports uncommon/custom protocols (`ftp://`, `file://`, `mailto:`, etc.)
118
- * - Handles **multiple dots**, **trailing dots**, **triple or more extensions**
119
- * - Supports filenames on mixed Unicode/ASCII domains:
120
- * - Domain names can include Unicode characters (IDN / punycode)
121
- * - Filenames may contain ASCII, Unicode, and emoji characters
122
- * - Works correctly when domain is Unicode and filename is ASCII, or vice versa
123
- * - Supports extremely long filenames safely (up to OS limits)
124
- * - Domain-aware mode (`domainAware: true` + `domainName`):
125
- * - Parameter `domainName` must be a string and non-empty string; otherwise a TypeError is thrown.
126
- * - Returns `null` if input equals `domainName` or any subdomain with no file path
127
- * - Extracts filename normally if path/file exists on domain or other domain
128
- * - Safe in Node.js and browsers
129
- *
130
- * ----------------------------------------------------------
131
- * @param {string | null | undefined} input
132
- * URL, file path, or plain filename to extract from.
133
- *
134
- * @param {ExtractFileNameOptions} [options]
135
- * Optional configuration:
136
- * - `domainAware?: boolean` – treat input as a domain string. Requires `domainName` to be a string and non-empty string; otherwise, a TypeError is thrown.
137
- * - `domainName?: string` – base domain for comparison eg (`example.com`), required when `domainAware` is true.
138
- *
139
- * @returns {string | null}
140
- * - Base filename without known extensions
141
- * - Original filename if extension unknown
142
- * - `null` for invalid inputs, folder paths, or domain-only strings
143
- *
144
- * ----------------------------------------------------------
145
- * @example
146
- * ```ts
147
- * // Basic files
148
- * extractFileName("document.pdf"); // ➔ "document"
149
- * extractFileName("/files/archive.tar.gz"); // ➔ "archive"
150
- * extractFileName("C:\\path\\file.txt"); // ➔ "file"
151
- * extractFileName(".env"); // ➔ ".env"
152
- * extractFileName("folder/"); // ➔ null
153
- *
154
- * // Not a file
155
- * extractFileName("not-file"); // ➔ null
156
- * extractFileName("not-file/"); // ➔ null
157
- * extractFileName("/not-file/"); // ➔ null
158
- * extractFileName("/not-file"); // ➔ null
159
- *
160
- * // URLs with queries, hashes, protocols
161
- * extractFileName("https://example.com/file.txt?ver=1"); // ➔ "file"
162
- * extractFileName("https://example.com/archive.tar.gz#part"); // ➔ "archive"
163
- * extractFileName("//cdn.example.com/image.png"); // ➔ "image"
164
- *
165
- *
166
- * // Special protocol handling
167
- * extractFileName("tel:+6212345678"); // ➔ "+6212345678"
168
- * extractFileName("sms:+6212345678"); // ➔ "+6212345678"
169
- * extractFileName("mailto:user@domain.com"); // ➔ "user@domain"
170
- * extractFileName("data:text/plain;base64,SGVsbG8="); // ➔ "SGVsbG8="
171
- * extractFileName("mailto:resume.com"); // ➔ "resume"
172
- * extractFileName("ftp://example.com/image.jpeg"); // ➔ "image"
173
- * extractFileName("ftp://files.example.com/app.min.js"); // ➔ "app.min"
174
- * extractFileName("file:///C:/path/to/document.pdf"); // ➔ "document"
175
- * extractFileName("custom-scheme://example.com/video.mp4"); // ➔ "video"
176
- *
177
- * // Unicode & emoji
178
- * extractFileName("emoji-😊.png"); // ➔ "emoji-😊"
179
- * extractFileName("🔥project.tar.gz"); // ➔ "🔥project"
180
- *
181
- * // Dotfiles
182
- * extractFileName(".gitignore"); // ➔ ".gitignore"
183
- * extractFileName("/path/.bashrc"); // ➔ ".bashrc"
184
- *
185
- * // Mixed Unicode domain and ASCII filename
186
- * extractFileName("https://tést-ドメイン.com/file.txt"); // ➔ "file"
187
- * extractFileName("https://example.com/ファイル名.pdf"); // ➔ "ファイル名"
188
- * extractFileName("https://ドメイン例.com/emoji-🔥.png"); // ➔ "emoji-🔥"
189
- *
190
- * // Reserved filenames
191
- * extractFileName("CON"); // ➔ "CON"
192
- * extractFileName("NUL.txt"); // ➔ "NUL"
193
- *
194
- * // Domain-aware mode
195
- * extractFileName("example.com", {
196
- * domainAware: true,
197
- * domainName: "example.com"
198
- * });
199
- * // ➔ null
200
- * extractFileName("cdn.example.com", {
201
- * domainAware: true,
202
- * domainName: "example.com"
203
- * });
204
- * // ➔ null
205
- * extractFileName("resume.com", {
206
- * domainAware: true,
207
- * domainName: "example.com"
208
- * });
209
- * // ➔ "resume"
210
- * extractFileName("https://example.com/file.txt", {
211
- * domainAware: true,
212
- * domainName: "example.com"
213
- * });
214
- * // ➔ "file"
215
- *
216
- * // Windows & UNC paths
217
- * extractFileName("C:\\Users\\rzl\\Documents\\file.txt"); // ➔ "file"
218
- * extractFileName("\\\\SERVER\\share\\logs\\output.log"); // ➔ "output"
219
- * extractFileName("C:/Users\\rzl/mix\\test.pdf"); // ➔ "test"
220
- *
221
- * // Edge / extreme cases
222
- * extractFileName("https://example.com/my%20file%20name.txt"); // ➔ "my file name"
223
- * extractFileName("app.min.js.map"); // ➔ "app.min"
224
- * extractFileName("backup.tar.bak"); // ➔ "backup.tar.bak" (unknown double extension)
225
- * extractFileName("filename."); // ➔ "filename."
226
- * extractFileName("a".repeat(255) + ".txt"); // ➔ "a".repeat(255)
227
- * ```
228
- *
229
- * ----------------------------------------------------------
230
- * @note
231
- * - Robust: never throws, handles unusual inputs safely.
232
- * - Suitable for display, logging, or safe storage.
233
- * - Normalizes slashes consistently.
234
- * - Covers nearly all real-world filename, URL, path, data URI, and domain scenarios.
235
- * - Handles Windows UNC paths, mixed slashes, percent-encoded, Unicode/emoji filenames.
236
- * - Known multi-part extensions list can be extended without breaking functionality.
237
- */
75
+ * * ***Utility: `extractFileName`.***
76
+ * ----------------------------------------------------------
77
+ *
78
+ * **Extracts the **clean base filename** from nearly any input string, including URLs, local file paths,
79
+ * UNC paths, and plain filenames.**
80
+ *
81
+ * - It automatically safely handles extracts the **base file name** (without extension) from:
82
+ * - File system paths (Windows, Unix, UNC)
83
+ * - Protocols like http, https, ftp, file, mailto, or custom schemes
84
+ * - Percent-encoded, Unicode, and emoji characters
85
+ * - Dotfiles, reserved OS names, multi-part extensions
86
+ * - Data URIs
87
+ * - Optional domain-aware mode to ignore domain-only inputs
88
+ * - Plain filenames
89
+ *
90
+ * - Full support for:
91
+ * - Unicode, emoji, percent-encoding
92
+ * - Dotfiles (e.g., `.env`, `.gitignore`)
93
+ * - Reserved/OS-protected filenames:
94
+ * `CON`, `PRN`, `AUX`, `NUL`, `COM1`–`COM9`, `LPT1`–`LPT9`
95
+ * - Known multi-part extensions:
96
+ * `.tar.gz`, `.tar.bz2`, `.tar.xz`, `.tar.lz`, `.tar.zst`, `.min.js`, `.js.map`, `.log.gz`, `.sql.gz`,
97
+ * `.backup.tar`, etc.
98
+ * - Data URIs (`data:[mime];base64,...` ➔ payload string)
99
+ * - Domain-aware mode (optional)
100
+ *
101
+ * ----------------------------------------------------------
102
+ * - **Behavior / Features**
103
+ * - Strips **known extensions**, including multi-part and common double/triple extensions.
104
+ * - Leaves unknown/custom extensions intact.
105
+ * - Preserves **dotfiles** as-is (leading dot preserved).
106
+ * - Returns `null` if:
107
+ * - input is `null`, `undefined`, or not a string
108
+ * - input is empty, whitespace-only, or only slashes
109
+ * - input represents a folder path (trailing slash/backslash, drive/folder only)
110
+ * - input is a **domain-only string** in domain-aware mode
111
+ * - Normalizes Windows-style backslashes (`\`) internally as `/`.
112
+ * - Supports UNC paths, mixed slashes, and Windows drive letters safely.
113
+ * - Handles URLs:
114
+ * - Ignores query strings (`?v=1.2.3`) and hash fragments (`#section`)
115
+ * - Decodes percent-encoded filenames (`my%20file.txt` ➔ `my file.txt`)
116
+ * - Supports protocol-relative URLs (`//cdn.example.com/file.jpg`)
117
+ * - Supports uncommon/custom protocols (`ftp://`, `file://`, `mailto:`, etc.)
118
+ * - Handles **multiple dots**, **trailing dots**, **triple or more extensions**
119
+ * - Supports filenames on mixed Unicode/ASCII domains:
120
+ * - Domain names can include Unicode characters (IDN / punycode)
121
+ * - Filenames may contain ASCII, Unicode, and emoji characters
122
+ * - Works correctly when domain is Unicode and filename is ASCII, or vice versa
123
+ * - Supports extremely long filenames safely (up to OS limits)
124
+ * - Domain-aware mode (`domainAware: true` + `domainName`):
125
+ * - Parameter `domainName` must be a string and non-empty string; otherwise a TypeError is thrown.
126
+ * - Returns `null` if input equals `domainName` or any subdomain with no file path
127
+ * - Extracts filename normally if path/file exists on domain or other domain
128
+ * - Safe in Node.js and browsers
129
+ *
130
+ * ----------------------------------------------------------
131
+ * @param {string | null | undefined} input
132
+ * URL, file path, or plain filename to extract from.
133
+ *
134
+ * @param {ExtractFileNameOptions} [options]
135
+ * Optional configuration:
136
+ * - `domainAware?: boolean` – treat input as a domain string. Requires `domainName` to be a string and non-empty string; otherwise, a TypeError is thrown.
137
+ * - `domainName?: string` – base domain for comparison eg (`example.com`), required when `domainAware` is true.
138
+ *
139
+ * @returns {string | null}
140
+ * - Base filename without known extensions
141
+ * - Original filename if extension unknown
142
+ * - `null` for invalid inputs, folder paths, or domain-only strings
143
+ *
144
+ * ----------------------------------------------------------
145
+ * @example
146
+ * ```ts
147
+ * // Basic files
148
+ * extractFileName("document.pdf"); // ➔ "document"
149
+ * extractFileName("/files/archive.tar.gz"); // ➔ "archive"
150
+ * extractFileName("C:\\path\\file.txt"); // ➔ "file"
151
+ * extractFileName(".env"); // ➔ ".env"
152
+ * extractFileName("folder/"); // ➔ null
153
+ *
154
+ * // Not a file
155
+ * extractFileName("not-file"); // ➔ null
156
+ * extractFileName("not-file/"); // ➔ null
157
+ * extractFileName("/not-file/"); // ➔ null
158
+ * extractFileName("/not-file"); // ➔ null
159
+ *
160
+ * // URLs with queries, hashes, protocols
161
+ * extractFileName("https://example.com/file.txt?ver=1"); // ➔ "file"
162
+ * extractFileName("https://example.com/archive.tar.gz#part"); // ➔ "archive"
163
+ * extractFileName("//cdn.example.com/image.png"); // ➔ "image"
164
+ *
165
+ *
166
+ * // Special protocol handling
167
+ * extractFileName("tel:+6212345678"); // ➔ "+6212345678"
168
+ * extractFileName("sms:+6212345678"); // ➔ "+6212345678"
169
+ * extractFileName("mailto:user@domain.com"); // ➔ "user@domain"
170
+ * extractFileName("data:text/plain;base64,SGVsbG8="); // ➔ "SGVsbG8="
171
+ * extractFileName("mailto:resume.com"); // ➔ "resume"
172
+ * extractFileName("ftp://example.com/image.jpeg"); // ➔ "image"
173
+ * extractFileName("ftp://files.example.com/app.min.js"); // ➔ "app.min"
174
+ * extractFileName("file:///C:/path/to/document.pdf"); // ➔ "document"
175
+ * extractFileName("custom-scheme://example.com/video.mp4"); // ➔ "video"
176
+ *
177
+ * // Unicode & emoji
178
+ * extractFileName("emoji-😊.png"); // ➔ "emoji-😊"
179
+ * extractFileName("🔥project.tar.gz"); // ➔ "🔥project"
180
+ *
181
+ * // Dotfiles
182
+ * extractFileName(".gitignore"); // ➔ ".gitignore"
183
+ * extractFileName("/path/.bashrc"); // ➔ ".bashrc"
184
+ *
185
+ * // Mixed Unicode domain and ASCII filename
186
+ * extractFileName("https://tést-ドメイン.com/file.txt"); // ➔ "file"
187
+ * extractFileName("https://example.com/ファイル名.pdf"); // ➔ "ファイル名"
188
+ * extractFileName("https://ドメイン例.com/emoji-🔥.png"); // ➔ "emoji-🔥"
189
+ *
190
+ * // Reserved filenames
191
+ * extractFileName("CON"); // ➔ "CON"
192
+ * extractFileName("NUL.txt"); // ➔ "NUL"
193
+ *
194
+ * // Domain-aware mode
195
+ * extractFileName("example.com", {
196
+ * domainAware: true,
197
+ * domainName: "example.com"
198
+ * });
199
+ * // ➔ null
200
+ * extractFileName("cdn.example.com", {
201
+ * domainAware: true,
202
+ * domainName: "example.com"
203
+ * });
204
+ * // ➔ null
205
+ * extractFileName("resume.com", {
206
+ * domainAware: true,
207
+ * domainName: "example.com"
208
+ * });
209
+ * // ➔ "resume"
210
+ * extractFileName("https://example.com/file.txt", {
211
+ * domainAware: true,
212
+ * domainName: "example.com"
213
+ * });
214
+ * // ➔ "file"
215
+ *
216
+ * // Windows & UNC paths
217
+ * extractFileName("C:\\Users\\rzl\\Documents\\file.txt"); // ➔ "file"
218
+ * extractFileName("\\\\SERVER\\share\\logs\\output.log"); // ➔ "output"
219
+ * extractFileName("C:/Users\\rzl/mix\\test.pdf"); // ➔ "test"
220
+ *
221
+ * // Edge / extreme cases
222
+ * extractFileName("https://example.com/my%20file%20name.txt"); // ➔ "my file name"
223
+ * extractFileName("app.min.js.map"); // ➔ "app.min"
224
+ * extractFileName("backup.tar.bak"); // ➔ "backup.tar.bak" (unknown double extension)
225
+ * extractFileName("filename."); // ➔ "filename."
226
+ * extractFileName("a".repeat(255) + ".txt"); // ➔ "a".repeat(255)
227
+ * ```
228
+ *
229
+ * ----------------------------------------------------------
230
+ * @note
231
+ * - Robust: never throws, handles unusual inputs safely.
232
+ * - Suitable for display, logging, or safe storage.
233
+ * - Normalizes slashes consistently.
234
+ * - Covers nearly all real-world filename, URL, path, data URI, and domain scenarios.
235
+ * - Handles Windows UNC paths, mixed slashes, percent-encoded, Unicode/emoji filenames.
236
+ * - Known multi-part extensions list can be extended without breaking functionality.
237
+ */
238
238
  declare const extractFileName: (input?: string | null, options?: ExtractFileNameOptions) => string | null;
239
239
  export { ExtractFileNameOptions, extractFileName };
@@ -2,10 +2,10 @@
2
2
  * ========================================================================
3
3
  * @rzl-zone/utils-js
4
4
  * ------------------------------------------------------------------------
5
- * Version: `3.12.1-beta.0`
5
+ * Version: `3.12.1-beta.1`
6
6
  * Author: `Rizalvin Dwiky <rizalvindwiky@gmail.com>`
7
7
  * Repository: `https://github.com/rzl-zone/rzl-zone/tree/main/packages/utils-js`
8
8
  * ========================================================================
9
9
  */
10
- import { t as extractFileName } from "../parsers-Dpuq-V4u.js";
10
+ import { t as extractFileName } from "../parsers-BSBPgvsq.js";
11
11
  export { extractFileName };
@@ -2,13 +2,13 @@
2
2
  * ========================================================================
3
3
  * @rzl-zone/utils-js
4
4
  * ------------------------------------------------------------------------
5
- * Version: `3.12.1-beta.0`
5
+ * Version: `3.12.1-beta.1`
6
6
  * Author: `Rizalvin Dwiky <rizalvindwiky@gmail.com>`
7
7
  * Repository: `https://github.com/rzl-zone/rzl-zone/tree/main/packages/utils-js`
8
8
  * ========================================================================
9
9
  */
10
- import { T as assertIsPlainObject, t as assertIsBoolean, y as isNonEmptyString } from "./assertIsBoolean-BlBct0Fc.js";
11
- import { t as punycodeUtilsJS } from "./punyCode-hmiFzLWT.js";
10
+ import { T as assertIsPlainObject, t as assertIsBoolean, y as isNonEmptyString } from "./assertIsBoolean-DR1SaXPD.js";
11
+ import { t as punycodeUtilsJS } from "./punyCode-8SrbMWfM.js";
12
12
  const EXTENSIONS_FILE = new Set([
13
13
  "txt",
14
14
  "md",
@@ -640,4 +640,4 @@ const extractFileName = (input, options = {}) => {
640
640
  return filename || null;
641
641
  };
642
642
  export { extractFileName as t };
643
- //# sourceMappingURL=parsers-Dpuq-V4u.js.map
643
+ //# sourceMappingURL=parsers-BSBPgvsq.js.map